blob: f75019af2d29dc7555e949e510a06db489c18045 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
import type { FC, ReactElement } from "react";
import { Tabs as NextraTabs, Tab } from "nextra-theme-docs";
import useSWR from "swr";
export { Tab };
export const Tabs: FC<{
storageKey?: string;
items: string[];
children: ReactElement;
}> = function ({ storageKey = "tab-index", items, children = null, ...props }) {
// Use SWR so all tabs with the same key can sync their states.
const { data, mutate } = useSWR(storageKey, (key) => {
try {
return JSON.parse(localStorage.getItem(key));
} catch (e) {
return null;
}
});
const selectedIndex = items.indexOf(data);
return (
<NextraTabs
onChange={(index) => {
localStorage.setItem(storageKey, JSON.stringify(items[index]));
mutate(items[index], false);
}}
selectedIndex={selectedIndex === -1 ? undefined : selectedIndex}
items={items}
{...props}
>
{children}
</NextraTabs>
);
};
|