@tokis/react 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +50 -0
- package/dist/cjs/components/accordion/index.js +36 -0
- package/dist/cjs/components/alert/index.js +14 -0
- package/dist/cjs/components/app-bar/index.js +9 -0
- package/dist/cjs/components/avatar/index.js +64 -0
- package/dist/cjs/components/badge/index.js +6 -0
- package/dist/cjs/components/bottom-nav/index.js +12 -0
- package/dist/cjs/components/breadcrumbs/index.js +19 -0
- package/dist/cjs/components/button/ButtonIcon.js +9 -0
- package/dist/cjs/components/button/ButtonLabel.js +9 -0
- package/dist/cjs/components/button/ButtonRoot.js +23 -0
- package/dist/cjs/components/button/index.js +11 -0
- package/dist/cjs/components/button/useButton.js +14 -0
- package/dist/cjs/components/card/index.js +25 -0
- package/dist/cjs/components/charts/index.js +214 -0
- package/dist/cjs/components/checkbox/index.js +18 -0
- package/dist/cjs/components/chip/index.js +6 -0
- package/dist/cjs/components/circular-progress/index.js +28 -0
- package/dist/cjs/components/codeblock/CodeBlock.js +35 -0
- package/dist/cjs/components/codeblock/index.js +5 -0
- package/dist/cjs/components/command-palette/index.js +84 -0
- package/dist/cjs/components/confirm-dialog/index.js +10 -0
- package/dist/cjs/components/context-menu/index.js +82 -0
- package/dist/cjs/components/dialog/index.js +43 -0
- package/dist/cjs/components/divider/index.js +6 -0
- package/dist/cjs/components/drawer/index.js +37 -0
- package/dist/cjs/components/dropdown/index.js +104 -0
- package/dist/cjs/components/emptystate/index.js +9 -0
- package/dist/cjs/components/extended/index.js +329 -0
- package/dist/cjs/components/hover-card/index.js +107 -0
- package/dist/cjs/components/infinite-scroll/index.js +21 -0
- package/dist/cjs/components/input/index.js +27 -0
- package/dist/cjs/components/layout/index.js +34 -0
- package/dist/cjs/components/link/index.js +7 -0
- package/dist/cjs/components/list/index.js +14 -0
- package/dist/cjs/components/menu/index.js +120 -0
- package/dist/cjs/components/nav-rail/index.js +12 -0
- package/dist/cjs/components/pagination/index.js +46 -0
- package/dist/cjs/components/popover/index.js +114 -0
- package/dist/cjs/components/portal/index.js +10 -0
- package/dist/cjs/components/progress/index.js +21 -0
- package/dist/cjs/components/radio/index.js +60 -0
- package/dist/cjs/components/result/index.js +25 -0
- package/dist/cjs/components/search-field/index.js +30 -0
- package/dist/cjs/components/select/index.js +88 -0
- package/dist/cjs/components/skeleton/index.js +6 -0
- package/dist/cjs/components/slider/index.js +73 -0
- package/dist/cjs/components/snackbar/index.js +41 -0
- package/dist/cjs/components/spinner/index.js +6 -0
- package/dist/cjs/components/statistic/index.js +17 -0
- package/dist/cjs/components/stepper/index.js +24 -0
- package/dist/cjs/components/switch/index.js +19 -0
- package/dist/cjs/components/table/index.js +26 -0
- package/dist/cjs/components/tabs/index.js +44 -0
- package/dist/cjs/components/tag/index.js +6 -0
- package/dist/cjs/components/timeline/index.js +12 -0
- package/dist/cjs/components/toggle/index.js +32 -0
- package/dist/cjs/components/tooltip/index.js +116 -0
- package/dist/cjs/components/treeview/index.js +89 -0
- package/dist/cjs/components/typography/index.js +20 -0
- package/dist/cjs/components/virtual-list/index.js +25 -0
- package/dist/cjs/context/ConfigProvider.js +22 -0
- package/dist/cjs/context/ThemeContext.js +25 -0
- package/dist/cjs/hooks/useControllableState.js +31 -0
- package/dist/cjs/hooks/useDialog.js +35 -0
- package/dist/cjs/hooks/useId.js +13 -0
- package/dist/cjs/hooks/useMenu.js +64 -0
- package/dist/cjs/hooks/usePopover.js +32 -0
- package/dist/cjs/hooks/useTabs.js +51 -0
- package/dist/cjs/index.js +102 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/utils/cn.js +10 -0
- package/dist/components/accordion/index.d.ts +19 -0
- package/dist/components/accordion/index.d.ts.map +1 -0
- package/dist/components/accordion/index.js +34 -0
- package/dist/components/accordion/index.js.map +1 -0
- package/dist/components/alert/index.d.ts +11 -0
- package/dist/components/alert/index.d.ts.map +1 -0
- package/dist/components/alert/index.js +12 -0
- package/dist/components/alert/index.js.map +1 -0
- package/dist/components/app-bar/index.d.ts +17 -0
- package/dist/components/app-bar/index.d.ts.map +1 -0
- package/dist/components/app-bar/index.js +7 -0
- package/dist/components/app-bar/index.js.map +1 -0
- package/dist/components/avatar/index.d.ts +33 -0
- package/dist/components/avatar/index.d.ts.map +1 -0
- package/dist/components/avatar/index.js +28 -0
- package/dist/components/avatar/index.js.map +1 -0
- package/dist/components/badge/index.d.ts +3 -0
- package/dist/components/badge/index.d.ts.map +1 -0
- package/dist/components/badge/index.js +3 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/bottom-nav/index.d.ts +18 -0
- package/dist/components/bottom-nav/index.d.ts.map +1 -0
- package/dist/components/bottom-nav/index.js +10 -0
- package/dist/components/bottom-nav/index.js.map +1 -0
- package/dist/components/breadcrumbs/index.d.ts +19 -0
- package/dist/components/breadcrumbs/index.d.ts.map +1 -0
- package/dist/components/breadcrumbs/index.js +17 -0
- package/dist/components/breadcrumbs/index.js.map +1 -0
- package/dist/components/button/ButtonIcon.d.ts +8 -0
- package/dist/components/button/ButtonIcon.d.ts.map +1 -0
- package/dist/components/button/ButtonIcon.js +6 -0
- package/dist/components/button/ButtonIcon.js.map +1 -0
- package/dist/components/button/ButtonLabel.d.ts +6 -0
- package/dist/components/button/ButtonLabel.d.ts.map +1 -0
- package/dist/components/button/ButtonLabel.js +6 -0
- package/dist/components/button/ButtonLabel.js.map +1 -0
- package/dist/components/button/ButtonRoot.d.ts +15 -0
- package/dist/components/button/ButtonRoot.d.ts.map +1 -0
- package/dist/components/button/ButtonRoot.js +21 -0
- package/dist/components/button/ButtonRoot.js.map +1 -0
- package/dist/components/button/index.d.ts +9 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/index.js +5 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/button/useButton.d.ts +16 -0
- package/dist/components/button/useButton.d.ts.map +1 -0
- package/dist/components/button/useButton.js +12 -0
- package/dist/components/button/useButton.js.map +1 -0
- package/dist/components/card/index.d.ts +17 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/card/index.js +23 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/charts/index.d.ts +60 -0
- package/dist/components/charts/index.d.ts.map +1 -0
- package/dist/components/charts/index.js +209 -0
- package/dist/components/charts/index.js.map +1 -0
- package/dist/components/checkbox/index.d.ts +17 -0
- package/dist/components/checkbox/index.d.ts.map +1 -0
- package/dist/components/checkbox/index.js +16 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/chip/index.d.ts +3 -0
- package/dist/components/chip/index.d.ts.map +1 -0
- package/dist/components/chip/index.js +3 -0
- package/dist/components/chip/index.js.map +1 -0
- package/dist/components/circular-progress/index.d.ts +15 -0
- package/dist/components/circular-progress/index.d.ts.map +1 -0
- package/dist/components/circular-progress/index.js +26 -0
- package/dist/components/circular-progress/index.js.map +1 -0
- package/dist/components/codeblock/CodeBlock.d.ts +13 -0
- package/dist/components/codeblock/CodeBlock.d.ts.map +1 -0
- package/dist/components/codeblock/CodeBlock.js +32 -0
- package/dist/components/codeblock/CodeBlock.js.map +1 -0
- package/dist/components/codeblock/index.d.ts +3 -0
- package/dist/components/codeblock/index.d.ts.map +1 -0
- package/dist/components/codeblock/index.js +2 -0
- package/dist/components/codeblock/index.js.map +1 -0
- package/dist/components/command-palette/index.d.ts +22 -0
- package/dist/components/command-palette/index.d.ts.map +1 -0
- package/dist/components/command-palette/index.js +82 -0
- package/dist/components/command-palette/index.js.map +1 -0
- package/dist/components/confirm-dialog/index.d.ts +17 -0
- package/dist/components/confirm-dialog/index.d.ts.map +1 -0
- package/dist/components/confirm-dialog/index.js +8 -0
- package/dist/components/confirm-dialog/index.js.map +1 -0
- package/dist/components/context-menu/index.d.ts +19 -0
- package/dist/components/context-menu/index.d.ts.map +1 -0
- package/dist/components/context-menu/index.js +47 -0
- package/dist/components/context-menu/index.js.map +1 -0
- package/dist/components/dialog/index.d.ts +16 -0
- package/dist/components/dialog/index.d.ts.map +1 -0
- package/dist/components/dialog/index.js +41 -0
- package/dist/components/dialog/index.js.map +1 -0
- package/dist/components/divider/index.d.ts +3 -0
- package/dist/components/divider/index.d.ts.map +1 -0
- package/dist/components/divider/index.js +3 -0
- package/dist/components/divider/index.js.map +1 -0
- package/dist/components/drawer/index.d.ts +16 -0
- package/dist/components/drawer/index.d.ts.map +1 -0
- package/dist/components/drawer/index.js +35 -0
- package/dist/components/drawer/index.js.map +1 -0
- package/dist/components/dropdown/index.d.ts +16 -0
- package/dist/components/dropdown/index.d.ts.map +1 -0
- package/dist/components/dropdown/index.js +69 -0
- package/dist/components/dropdown/index.js.map +1 -0
- package/dist/components/emptystate/index.d.ts +13 -0
- package/dist/components/emptystate/index.d.ts.map +1 -0
- package/dist/components/emptystate/index.js +7 -0
- package/dist/components/emptystate/index.js.map +1 -0
- package/dist/components/extended/index.d.ts +163 -0
- package/dist/components/extended/index.d.ts.map +1 -0
- package/dist/components/extended/index.js +267 -0
- package/dist/components/extended/index.js.map +1 -0
- package/dist/components/hover-card/index.d.ts +14 -0
- package/dist/components/hover-card/index.d.ts.map +1 -0
- package/dist/components/hover-card/index.js +72 -0
- package/dist/components/hover-card/index.js.map +1 -0
- package/dist/components/infinite-scroll/index.d.ts +16 -0
- package/dist/components/infinite-scroll/index.d.ts.map +1 -0
- package/dist/components/infinite-scroll/index.js +19 -0
- package/dist/components/infinite-scroll/index.js.map +1 -0
- package/dist/components/input/index.d.ts +19 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/index.js +25 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/layout/index.d.ts +39 -0
- package/dist/components/layout/index.d.ts.map +1 -0
- package/dist/components/layout/index.js +32 -0
- package/dist/components/layout/index.js.map +1 -0
- package/dist/components/link/index.d.ts +3 -0
- package/dist/components/link/index.d.ts.map +1 -0
- package/dist/components/link/index.js +3 -0
- package/dist/components/link/index.js.map +1 -0
- package/dist/components/list/index.d.ts +13 -0
- package/dist/components/list/index.d.ts.map +1 -0
- package/dist/components/list/index.js +12 -0
- package/dist/components/list/index.js.map +1 -0
- package/dist/components/menu/index.d.ts +19 -0
- package/dist/components/menu/index.d.ts.map +1 -0
- package/dist/components/menu/index.js +85 -0
- package/dist/components/menu/index.js.map +1 -0
- package/dist/components/nav-rail/index.d.ts +20 -0
- package/dist/components/nav-rail/index.d.ts.map +1 -0
- package/dist/components/nav-rail/index.js +10 -0
- package/dist/components/nav-rail/index.js.map +1 -0
- package/dist/components/pagination/index.d.ts +9 -0
- package/dist/components/pagination/index.d.ts.map +1 -0
- package/dist/components/pagination/index.js +44 -0
- package/dist/components/pagination/index.js.map +1 -0
- package/dist/components/popover/index.d.ts +16 -0
- package/dist/components/popover/index.d.ts.map +1 -0
- package/dist/components/popover/index.js +79 -0
- package/dist/components/popover/index.js.map +1 -0
- package/dist/components/portal/index.d.ts +7 -0
- package/dist/components/portal/index.d.ts.map +1 -0
- package/dist/components/portal/index.js +8 -0
- package/dist/components/portal/index.js.map +1 -0
- package/dist/components/progress/index.d.ts +25 -0
- package/dist/components/progress/index.d.ts.map +1 -0
- package/dist/components/progress/index.js +19 -0
- package/dist/components/progress/index.js.map +1 -0
- package/dist/components/radio/index.d.ts +25 -0
- package/dist/components/radio/index.d.ts.map +1 -0
- package/dist/components/radio/index.js +24 -0
- package/dist/components/radio/index.js.map +1 -0
- package/dist/components/result/index.d.ts +14 -0
- package/dist/components/result/index.d.ts.map +1 -0
- package/dist/components/result/index.js +23 -0
- package/dist/components/result/index.js.map +1 -0
- package/dist/components/search-field/index.d.ts +15 -0
- package/dist/components/search-field/index.d.ts.map +1 -0
- package/dist/components/search-field/index.js +28 -0
- package/dist/components/search-field/index.js.map +1 -0
- package/dist/components/select/index.d.ts +23 -0
- package/dist/components/select/index.d.ts.map +1 -0
- package/dist/components/select/index.js +86 -0
- package/dist/components/select/index.js.map +1 -0
- package/dist/components/skeleton/index.d.ts +3 -0
- package/dist/components/skeleton/index.d.ts.map +1 -0
- package/dist/components/skeleton/index.js +3 -0
- package/dist/components/skeleton/index.js.map +1 -0
- package/dist/components/slider/index.d.ts +18 -0
- package/dist/components/slider/index.d.ts.map +1 -0
- package/dist/components/slider/index.js +71 -0
- package/dist/components/slider/index.js.map +1 -0
- package/dist/components/snackbar/index.d.ts +27 -0
- package/dist/components/snackbar/index.d.ts.map +1 -0
- package/dist/components/snackbar/index.js +38 -0
- package/dist/components/snackbar/index.js.map +1 -0
- package/dist/components/spinner/index.d.ts +3 -0
- package/dist/components/spinner/index.d.ts.map +1 -0
- package/dist/components/spinner/index.js +3 -0
- package/dist/components/spinner/index.js.map +1 -0
- package/dist/components/statistic/index.d.ts +13 -0
- package/dist/components/statistic/index.d.ts.map +1 -0
- package/dist/components/statistic/index.js +15 -0
- package/dist/components/statistic/index.js.map +1 -0
- package/dist/components/stepper/index.d.ts +17 -0
- package/dist/components/stepper/index.d.ts.map +1 -0
- package/dist/components/stepper/index.js +22 -0
- package/dist/components/stepper/index.js.map +1 -0
- package/dist/components/switch/index.d.ts +16 -0
- package/dist/components/switch/index.d.ts.map +1 -0
- package/dist/components/switch/index.js +17 -0
- package/dist/components/switch/index.js.map +1 -0
- package/dist/components/table/index.d.ts +17 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/index.js +24 -0
- package/dist/components/table/index.js.map +1 -0
- package/dist/components/tabs/index.d.ts +19 -0
- package/dist/components/tabs/index.d.ts.map +1 -0
- package/dist/components/tabs/index.js +42 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/tag/index.d.ts +3 -0
- package/dist/components/tag/index.d.ts.map +1 -0
- package/dist/components/tag/index.js +3 -0
- package/dist/components/tag/index.js.map +1 -0
- package/dist/components/timeline/index.d.ts +16 -0
- package/dist/components/timeline/index.d.ts.map +1 -0
- package/dist/components/timeline/index.js +10 -0
- package/dist/components/timeline/index.js.map +1 -0
- package/dist/components/toggle/index.d.ts +32 -0
- package/dist/components/toggle/index.d.ts.map +1 -0
- package/dist/components/toggle/index.js +29 -0
- package/dist/components/toggle/index.js.map +1 -0
- package/dist/components/tooltip/index.d.ts +11 -0
- package/dist/components/tooltip/index.d.ts.map +1 -0
- package/dist/components/tooltip/index.js +81 -0
- package/dist/components/tooltip/index.js.map +1 -0
- package/dist/components/treeview/index.d.ts +19 -0
- package/dist/components/treeview/index.d.ts.map +1 -0
- package/dist/components/treeview/index.js +87 -0
- package/dist/components/treeview/index.js.map +1 -0
- package/dist/components/typography/index.d.ts +11 -0
- package/dist/components/typography/index.d.ts.map +1 -0
- package/dist/components/typography/index.js +18 -0
- package/dist/components/typography/index.js.map +1 -0
- package/dist/components/virtual-list/index.d.ts +15 -0
- package/dist/components/virtual-list/index.d.ts.map +1 -0
- package/dist/components/virtual-list/index.js +23 -0
- package/dist/components/virtual-list/index.js.map +1 -0
- package/dist/context/ConfigProvider.d.ts +12 -0
- package/dist/context/ConfigProvider.d.ts.map +1 -0
- package/dist/context/ConfigProvider.js +18 -0
- package/dist/context/ConfigProvider.js.map +1 -0
- package/dist/context/ThemeContext.d.ts +15 -0
- package/dist/context/ThemeContext.d.ts.map +1 -0
- package/dist/context/ThemeContext.js +21 -0
- package/dist/context/ThemeContext.js.map +1 -0
- package/dist/hooks/useControllableState.d.ts +10 -0
- package/dist/hooks/useControllableState.d.ts.map +1 -0
- package/dist/hooks/useControllableState.js +29 -0
- package/dist/hooks/useControllableState.js.map +1 -0
- package/dist/hooks/useDialog.d.ts +24 -0
- package/dist/hooks/useDialog.d.ts.map +1 -0
- package/dist/hooks/useDialog.js +33 -0
- package/dist/hooks/useDialog.js.map +1 -0
- package/dist/hooks/useId.d.ts +7 -0
- package/dist/hooks/useId.d.ts.map +1 -0
- package/dist/hooks/useId.js +11 -0
- package/dist/hooks/useId.js.map +1 -0
- package/dist/hooks/useMenu.d.ts +21 -0
- package/dist/hooks/useMenu.d.ts.map +1 -0
- package/dist/hooks/useMenu.js +62 -0
- package/dist/hooks/useMenu.js.map +1 -0
- package/dist/hooks/usePopover.d.ts +22 -0
- package/dist/hooks/usePopover.d.ts.map +1 -0
- package/dist/hooks/usePopover.js +30 -0
- package/dist/hooks/usePopover.js.map +1 -0
- package/dist/hooks/useTabs.d.ts +22 -0
- package/dist/hooks/useTabs.d.ts.map +1 -0
- package/dist/hooks/useTabs.js +49 -0
- package/dist/hooks/useTabs.js.map +1 -0
- package/dist/index.d.ts +65 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +85 -0
- package/dist/index.js.map +1 -0
- package/dist/utils/cn.d.ts +6 -0
- package/dist/utils/cn.d.ts.map +1 -0
- package/dist/utils/cn.js +8 -0
- package/dist/utils/cn.js.map +1 -0
- package/package.json +79 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SnackbarContainer = SnackbarContainer;
|
|
4
|
+
exports.useSnackbar = useSnackbar;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
const cn_js_1 = require("../../utils/cn");
|
|
8
|
+
const index_js_1 = require("../portal/index");
|
|
9
|
+
function SnackbarContainer({ position = 'bottom-right', items, onDismiss }) {
|
|
10
|
+
const posClassMap = {
|
|
11
|
+
'bottom-right': '', 'bottom-left': 'tokis-snackbar-container--bottom-left',
|
|
12
|
+
'bottom-center': 'tokis-snackbar-container--bottom-center',
|
|
13
|
+
'top-right': 'tokis-snackbar-container--top-right',
|
|
14
|
+
'top-center': 'tokis-snackbar-container--top-center',
|
|
15
|
+
};
|
|
16
|
+
return ((0, jsx_runtime_1.jsx)(index_js_1.Portal, { children: (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-snackbar-container', posClassMap[position]), "aria-live": "polite", "aria-atomic": "false", children: items.map((item) => ((0, jsx_runtime_1.jsx)(SnackbarToast, { item: item, onDismiss: onDismiss }, item.id))) }) }));
|
|
17
|
+
}
|
|
18
|
+
function SnackbarToast({ item, onDismiss }) {
|
|
19
|
+
(0, react_1.useEffect)(() => {
|
|
20
|
+
const duration = item.duration ?? 4000;
|
|
21
|
+
if (duration === Infinity)
|
|
22
|
+
return;
|
|
23
|
+
const t = setTimeout(() => onDismiss(item.id), duration);
|
|
24
|
+
return () => clearTimeout(t);
|
|
25
|
+
}, [item.id, item.duration, onDismiss]);
|
|
26
|
+
return ((0, jsx_runtime_1.jsxs)("div", { role: "status", className: (0, cn_js_1.cn)('tokis-snackbar', item.variant && item.variant !== 'default' && `tokis-snackbar--${item.variant}`), children: [(0, jsx_runtime_1.jsxs)("div", { className: "tokis-snackbar__body", children: [item.title && (0, jsx_runtime_1.jsx)("div", { className: "tokis-snackbar__title", children: item.title }), (0, jsx_runtime_1.jsx)("div", { children: item.message }), item.action && ((0, jsx_runtime_1.jsx)("button", { className: "tokis-snackbar__action", onClick: () => { item.action.onClick(); onDismiss(item.id); }, children: item.action.label }))] }), (0, jsx_runtime_1.jsx)("button", { className: "tokis-snackbar__close", onClick: () => onDismiss(item.id), "aria-label": "Dismiss", children: (0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M2 2l10 10M12 2L2 12", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" }) }) })] }));
|
|
27
|
+
}
|
|
28
|
+
// ─── useSnackbar hook ─────────────────────────────────────
|
|
29
|
+
function useSnackbar() {
|
|
30
|
+
const [items, setItems] = (0, react_1.useState)([]);
|
|
31
|
+
const add = (0, react_1.useCallback)((item) => {
|
|
32
|
+
const id = `snackbar-${Date.now()}-${Math.random().toString(36).slice(2, 6)}`;
|
|
33
|
+
setItems((prev) => [...prev, { ...item, id }]);
|
|
34
|
+
return id;
|
|
35
|
+
}, []);
|
|
36
|
+
const dismiss = (0, react_1.useCallback)((id) => {
|
|
37
|
+
setItems((prev) => prev.filter((i) => i.id !== id));
|
|
38
|
+
}, []);
|
|
39
|
+
const dismissAll = (0, react_1.useCallback)(() => setItems([]), []);
|
|
40
|
+
return { items, add, dismiss, dismissAll };
|
|
41
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Spinner = void 0;
|
|
4
|
+
// Re-export Spinner from progress
|
|
5
|
+
var index_js_1 = require("../progress/index");
|
|
6
|
+
Object.defineProperty(exports, "Spinner", { enumerable: true, get: function () { return index_js_1.Spinner; } });
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Statistic = Statistic;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const cn_js_1 = require("../../utils/cn");
|
|
6
|
+
function TrendIcon({ trend }) {
|
|
7
|
+
if (trend === 'up') {
|
|
8
|
+
return ((0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M7 11V3M3 7l4-4 4 4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
9
|
+
}
|
|
10
|
+
if (trend === 'down') {
|
|
11
|
+
return ((0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M7 3v8M3 7l4 4 4-4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
12
|
+
}
|
|
13
|
+
return ((0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M3 7h8", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" }) }));
|
|
14
|
+
}
|
|
15
|
+
function Statistic({ value, label, prefix, suffix, trend, trendValue, description, className, }) {
|
|
16
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-statistic', className), children: [(0, jsx_runtime_1.jsx)("div", { className: "tokis-statistic__label", children: label }), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-statistic__value-row", children: [prefix && (0, jsx_runtime_1.jsx)("span", { className: "tokis-statistic__prefix", children: prefix }), (0, jsx_runtime_1.jsx)("span", { className: "tokis-statistic__value", children: value }), suffix && (0, jsx_runtime_1.jsx)("span", { className: "tokis-statistic__suffix", children: suffix }), trend && trendValue && ((0, jsx_runtime_1.jsxs)("span", { className: (0, cn_js_1.cn)('tokis-statistic__trend', `tokis-statistic__trend--${trend}`), "aria-label": `Trend: ${trend === 'up' ? 'up' : trend === 'down' ? 'down' : 'neutral'} ${trendValue}`, children: [(0, jsx_runtime_1.jsx)(TrendIcon, { trend: trend }), trendValue] }))] }), description && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-statistic__desc", children: description }))] }));
|
|
17
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Stepper = Stepper;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const cn_js_1 = require("../../utils/cn");
|
|
6
|
+
const CheckIcon = () => ((0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M2 7l3.5 3.5L12 4", stroke: "currentColor", strokeWidth: "1.8", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
7
|
+
const ErrorIcon = () => ((0, jsx_runtime_1.jsx)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("path", { d: "M3 3l8 8M11 3L3 11", stroke: "currentColor", strokeWidth: "1.8", strokeLinecap: "round" }) }));
|
|
8
|
+
function getStepStatus(step, index, current) {
|
|
9
|
+
if (step.status)
|
|
10
|
+
return step.status;
|
|
11
|
+
if (index < current)
|
|
12
|
+
return 'completed';
|
|
13
|
+
if (index === current)
|
|
14
|
+
return 'active';
|
|
15
|
+
return 'pending';
|
|
16
|
+
}
|
|
17
|
+
function Stepper({ steps, current, orientation = 'horizontal', className }) {
|
|
18
|
+
return ((0, jsx_runtime_1.jsx)("ol", { className: (0, cn_js_1.cn)('tokis-stepper', `tokis-stepper--${orientation}`, className), "aria-label": "Progress steps", children: steps.map((step, index) => {
|
|
19
|
+
const status = getStepStatus(step, index, current);
|
|
20
|
+
const isLast = index === steps.length - 1;
|
|
21
|
+
return ((0, jsx_runtime_1.jsxs)("li", { className: (0, cn_js_1.cn)('tokis-stepper__step', `tokis-stepper__step--${status}`), "aria-current": status === 'active' ? 'step' : undefined, children: [(0, jsx_runtime_1.jsxs)("div", { className: "tokis-stepper__step-inner", children: [(0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-stepper__circle', `tokis-stepper__circle--${status}`), children: status === 'completed' ? (0, jsx_runtime_1.jsx)(CheckIcon, {}) : status === 'error' ? (0, jsx_runtime_1.jsx)(ErrorIcon, {}) : (0, jsx_runtime_1.jsx)("span", { children: index + 1 }) }), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-stepper__text", children: [(0, jsx_runtime_1.jsx)("div", { className: "tokis-stepper__label", children: step.label }), step.description && (0, jsx_runtime_1.jsx)("div", { className: "tokis-stepper__desc", children: step.description })] })] }), !isLast && (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-stepper__connector', status === 'completed' && 'tokis-stepper__connector--completed'), "aria-hidden": "true" })] }, index));
|
|
22
|
+
}) }));
|
|
23
|
+
}
|
|
24
|
+
Stepper.displayName = 'Stepper';
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Switch = Switch;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
function Switch({ checked, defaultChecked, onChange, label, description, disabled = false, size = 'md', id, name, className, 'aria-label': ariaLabel }) {
|
|
8
|
+
const autoId = (0, react_1.useId)();
|
|
9
|
+
const switchId = id ?? `switch-${autoId}`;
|
|
10
|
+
const descId = description ? `${switchId}-desc` : undefined;
|
|
11
|
+
const toggle = (0, react_1.useCallback)(() => {
|
|
12
|
+
if (!disabled)
|
|
13
|
+
onChange?.(!checked);
|
|
14
|
+
}, [checked, disabled, onChange]);
|
|
15
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-switch-root', size === 'sm' && 'tokis-switch-root--sm', className), "data-disabled": disabled || undefined, children: [(0, jsx_runtime_1.jsx)("div", { role: "switch", tabIndex: disabled ? -1 : 0, "aria-checked": checked ?? false, "aria-label": ariaLabel, "aria-labelledby": label ? switchId : undefined, "aria-describedby": descId, "aria-disabled": disabled, className: "tokis-switch-track", "data-checked": checked ? 'true' : undefined, onClick: toggle, onKeyDown: (e) => { if (e.key === ' ' || e.key === 'Enter') {
|
|
16
|
+
e.preventDefault();
|
|
17
|
+
toggle();
|
|
18
|
+
} }, children: (0, jsx_runtime_1.jsx)("span", { className: "tokis-switch-thumb" }) }), (label || description) && ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-switch-content", onClick: toggle, style: { cursor: disabled ? 'not-allowed' : 'pointer' }, children: [label && (0, jsx_runtime_1.jsx)("label", { id: switchId, className: "tokis-switch-label", children: label }), description && (0, jsx_runtime_1.jsx)("p", { id: descId, className: "tokis-switch-description", children: description })] })), (0, jsx_runtime_1.jsx)("input", { type: "checkbox", role: "none", name: name, checked: checked, defaultChecked: defaultChecked, disabled: disabled, onChange: (e) => onChange?.(e.target.checked), style: { position: 'absolute', opacity: 0, width: 0, height: 0 }, "aria-hidden": "true", tabIndex: -1 })] }));
|
|
19
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TableCell = exports.TableHeaderCell = exports.TableRow = exports.TableBody = exports.TableHead = exports.Table = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
exports.Table = (0, react_1.forwardRef)(({ striped = false, container = true, className, children, ...props }, ref) => {
|
|
8
|
+
const table = ((0, jsx_runtime_1.jsx)("table", { ref: ref, className: (0, cn_js_1.cn)('tokis-table', striped && 'tokis-table--striped', !container && className), ...props, children: children }));
|
|
9
|
+
if (!container)
|
|
10
|
+
return table;
|
|
11
|
+
return (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-table-container', className), children: table });
|
|
12
|
+
});
|
|
13
|
+
exports.Table.displayName = 'Table';
|
|
14
|
+
exports.TableHead = (0, react_1.forwardRef)((props, ref) => (0, jsx_runtime_1.jsx)("thead", { ref: ref, ...props }));
|
|
15
|
+
exports.TableHead.displayName = 'TableHead';
|
|
16
|
+
exports.TableBody = (0, react_1.forwardRef)((props, ref) => (0, jsx_runtime_1.jsx)("tbody", { ref: ref, ...props }));
|
|
17
|
+
exports.TableBody.displayName = 'TableBody';
|
|
18
|
+
exports.TableRow = (0, react_1.forwardRef)((props, ref) => (0, jsx_runtime_1.jsx)("tr", { ref: ref, ...props }));
|
|
19
|
+
exports.TableRow.displayName = 'TableRow';
|
|
20
|
+
exports.TableHeaderCell = (0, react_1.forwardRef)(({ sortable, sorted, onSort, className, children, ...props }, ref) => ((0, jsx_runtime_1.jsx)("th", { ref: ref, scope: "col", "aria-sort": sorted ? sorted === 'asc' ? 'ascending' : 'descending' : sortable ? 'none' : undefined, className: (0, cn_js_1.cn)(sortable && 'tokis-table th--sortable', className), onClick: sortable ? onSort : undefined, onKeyDown: sortable ? (e) => { if (e.key === 'Enter' || e.key === ' ') {
|
|
21
|
+
e.preventDefault();
|
|
22
|
+
onSort?.();
|
|
23
|
+
} } : undefined, tabIndex: sortable ? 0 : undefined, ...props, children: (0, jsx_runtime_1.jsxs)("span", { style: { display: 'inline-flex', alignItems: 'center', gap: '4px' }, children: [children, sortable && ((0, jsx_runtime_1.jsxs)("svg", { width: "12", height: "12", viewBox: "0 0 12 12", fill: "none", "aria-hidden": "true", style: { opacity: sorted ? 1 : 0.4 }, children: [sorted !== 'asc' && (0, jsx_runtime_1.jsx)("path", { d: "M4 7l2 2 2-2", stroke: "currentColor", strokeWidth: "1.2", strokeLinecap: "round", strokeLinejoin: "round" }), sorted !== 'desc' && (0, jsx_runtime_1.jsx)("path", { d: "M4 5l2-2 2 2", stroke: "currentColor", strokeWidth: "1.2", strokeLinecap: "round", strokeLinejoin: "round" })] }))] }) })));
|
|
24
|
+
exports.TableHeaderCell.displayName = 'TableHeaderCell';
|
|
25
|
+
exports.TableCell = (0, react_1.forwardRef)((props, ref) => (0, jsx_runtime_1.jsx)("td", { ref: ref, ...props }));
|
|
26
|
+
exports.TableCell.displayName = 'TableCell';
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Tabs = Tabs;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
function Tabs({ tabs, defaultValue, value, onChange, variant = 'line', orientation = 'horizontal', className }) {
|
|
8
|
+
const [internalValue, setInternalValue] = (0, react_1.useState)(defaultValue ?? tabs[0]?.value ?? '');
|
|
9
|
+
const activeValue = value ?? internalValue;
|
|
10
|
+
const tablistRef = (0, react_1.useRef)(null);
|
|
11
|
+
const groupId = (0, react_1.useId)();
|
|
12
|
+
const handleChange = (val) => {
|
|
13
|
+
if (value === undefined)
|
|
14
|
+
setInternalValue(val);
|
|
15
|
+
onChange?.(val);
|
|
16
|
+
};
|
|
17
|
+
const handleKeyDown = (e, currentIndex) => {
|
|
18
|
+
const enabledTabs = tabs.filter((t) => !t.disabled);
|
|
19
|
+
const idx = enabledTabs.findIndex((t) => t.value === tabs[currentIndex].value);
|
|
20
|
+
let nextIdx = idx;
|
|
21
|
+
const isVertical = orientation === 'vertical';
|
|
22
|
+
if ((e.key === 'ArrowRight' && !isVertical) || (e.key === 'ArrowDown' && isVertical)) {
|
|
23
|
+
nextIdx = (idx + 1) % enabledTabs.length;
|
|
24
|
+
}
|
|
25
|
+
else if ((e.key === 'ArrowLeft' && !isVertical) || (e.key === 'ArrowUp' && isVertical)) {
|
|
26
|
+
nextIdx = (idx - 1 + enabledTabs.length) % enabledTabs.length;
|
|
27
|
+
}
|
|
28
|
+
else if (e.key === 'Home') {
|
|
29
|
+
nextIdx = 0;
|
|
30
|
+
}
|
|
31
|
+
else if (e.key === 'End') {
|
|
32
|
+
nextIdx = enabledTabs.length - 1;
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
e.preventDefault();
|
|
38
|
+
handleChange(enabledTabs[nextIdx].value);
|
|
39
|
+
const buttons = tablistRef.current?.querySelectorAll('[role="tab"]:not([disabled])');
|
|
40
|
+
buttons?.[nextIdx]?.focus();
|
|
41
|
+
};
|
|
42
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-tabs-root', orientation === 'vertical' && 'tokis-tabs-root--vertical', className), children: [(0, jsx_runtime_1.jsx)("div", { ref: tablistRef, role: "tablist", "aria-orientation": orientation, className: (0, cn_js_1.cn)('tokis-tabs-list', variant === 'pills' && 'tokis-tabs-list--pills'), children: tabs.map((tab, i) => ((0, jsx_runtime_1.jsxs)("button", { role: "tab", id: `${groupId}-tab-${tab.value}`, "aria-controls": `${groupId}-panel-${tab.value}`, "aria-selected": tab.value === activeValue, "aria-disabled": tab.disabled, disabled: tab.disabled, tabIndex: tab.value === activeValue ? 0 : -1, "data-active": tab.value === activeValue ? 'true' : undefined, className: "tokis-tabs-trigger", onClick: () => { if (!tab.disabled)
|
|
43
|
+
handleChange(tab.value); }, onKeyDown: (e) => handleKeyDown(e, i), children: [tab.icon && (0, jsx_runtime_1.jsx)("span", { className: "tokis-btn__icon", "aria-hidden": "true", children: tab.icon }), tab.label] }, tab.value))) }), tabs.map((tab) => ((0, jsx_runtime_1.jsx)("div", { role: "tabpanel", id: `${groupId}-panel-${tab.value}`, "aria-labelledby": `${groupId}-tab-${tab.value}`, tabIndex: 0, className: "tokis-tabs-panel", hidden: tab.value !== activeValue, children: tab.value === activeValue ? tab.content : null }, tab.value)))] }));
|
|
44
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Tag = void 0;
|
|
4
|
+
// Re-export Chip as Tag (same component, different semantic)
|
|
5
|
+
var index_js_1 = require("../avatar/index");
|
|
6
|
+
Object.defineProperty(exports, "Tag", { enumerable: true, get: function () { return index_js_1.Chip; } });
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Timeline = Timeline;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const cn_js_1 = require("../../utils/cn");
|
|
6
|
+
function Timeline({ items, className }) {
|
|
7
|
+
return ((0, jsx_runtime_1.jsx)("ol", { className: (0, cn_js_1.cn)('tokis-timeline', className), "aria-label": "Timeline", children: items.map((item, index) => {
|
|
8
|
+
const variant = item.variant ?? 'default';
|
|
9
|
+
const isLast = index === items.length - 1;
|
|
10
|
+
return ((0, jsx_runtime_1.jsxs)("li", { className: "tokis-timeline__item", children: [(0, jsx_runtime_1.jsxs)("div", { className: "tokis-timeline__track", "aria-hidden": "true", children: [(0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-timeline__dot', `tokis-timeline__dot--${variant}`), children: item.icon ?? null }), !isLast && (0, jsx_runtime_1.jsx)("div", { className: "tokis-timeline__connector" })] }), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-timeline__content", children: [(0, jsx_runtime_1.jsxs)("div", { className: "tokis-timeline__header", children: [(0, jsx_runtime_1.jsx)("span", { className: "tokis-timeline__title", children: item.title }), item.date && ((0, jsx_runtime_1.jsx)("time", { className: "tokis-timeline__date", dateTime: item.date, children: item.date }))] }), item.description && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-timeline__desc", children: item.description }))] })] }, item.id));
|
|
11
|
+
}) }));
|
|
12
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ToggleButton = ToggleButton;
|
|
4
|
+
exports.ToggleGroup = ToggleGroup;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
function ToggleButton({ pressed, onChange, children, disabled = false, size = 'md', className, 'aria-label': ariaLabel, }) {
|
|
8
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: "button", className: (0, cn_js_1.cn)('tokis-toggle', `tokis-toggle--${size}`, pressed && 'tokis-toggle--pressed', className), "aria-pressed": pressed, "aria-label": ariaLabel, disabled: disabled, onClick: () => onChange(!pressed), children: children }));
|
|
9
|
+
}
|
|
10
|
+
ToggleButton.displayName = 'ToggleButton';
|
|
11
|
+
function ToggleGroup({ options, value, onChange, multiple = false, size = 'md', className, }) {
|
|
12
|
+
const isSelected = (v) => multiple ? value.includes(v) : value === v;
|
|
13
|
+
const handleClick = (v) => {
|
|
14
|
+
if (multiple) {
|
|
15
|
+
const arr = value;
|
|
16
|
+
if (arr.includes(v)) {
|
|
17
|
+
onChange(arr.filter((x) => x !== v));
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
onChange([...arr, v]);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
onChange(v);
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-toggle-group', className), role: multiple ? 'group' : 'radiogroup', "aria-label": "Toggle group", children: options.map((opt) => {
|
|
28
|
+
const selected = isSelected(opt.value);
|
|
29
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: "button", className: (0, cn_js_1.cn)('tokis-toggle-group__item', `tokis-toggle-group__item--${size}`, selected && 'tokis-toggle-group__item--active'), role: multiple ? 'checkbox' : 'radio', "aria-checked": selected, disabled: opt.disabled, onClick: () => handleClick(opt.value), children: opt.label }, opt.value));
|
|
30
|
+
}) }));
|
|
31
|
+
}
|
|
32
|
+
ToggleGroup.displayName = 'ToggleGroup';
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.Tooltip = Tooltip;
|
|
37
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
38
|
+
const react_1 = __importStar(require("react"));
|
|
39
|
+
const cn_js_1 = require("../../utils/cn");
|
|
40
|
+
const index_js_1 = require("../portal/index");
|
|
41
|
+
function Tooltip({ content, children, placement = 'top', delay = 300, disabled = false }) {
|
|
42
|
+
const [state, setState] = (0, react_1.useState)({ visible: false, top: 0, left: 0, placement });
|
|
43
|
+
const triggerRef = (0, react_1.useRef)(null);
|
|
44
|
+
const timerRef = (0, react_1.useRef)();
|
|
45
|
+
const tooltipId = (0, react_1.useId)();
|
|
46
|
+
// When placement prop changes and tooltip is visible, recompute
|
|
47
|
+
(0, react_1.useEffect)(() => {
|
|
48
|
+
if (state.visible && triggerRef.current) {
|
|
49
|
+
const rect = triggerRef.current.getBoundingClientRect();
|
|
50
|
+
const { top, left } = computePosition(rect, placement);
|
|
51
|
+
setState((prev) => ({ ...prev, top, left, placement }));
|
|
52
|
+
}
|
|
53
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
54
|
+
}, [placement]);
|
|
55
|
+
const show = (0, react_1.useCallback)(() => {
|
|
56
|
+
timerRef.current = setTimeout(() => {
|
|
57
|
+
if (!triggerRef.current)
|
|
58
|
+
return;
|
|
59
|
+
const rect = triggerRef.current.getBoundingClientRect();
|
|
60
|
+
const { top, left } = computePosition(rect, placement);
|
|
61
|
+
// Single atomic state update — position + visible at once
|
|
62
|
+
setState({ visible: true, top, left, placement });
|
|
63
|
+
}, delay);
|
|
64
|
+
}, [delay, placement]);
|
|
65
|
+
const hide = (0, react_1.useCallback)(() => {
|
|
66
|
+
clearTimeout(timerRef.current);
|
|
67
|
+
setState((prev) => ({ ...prev, visible: false }));
|
|
68
|
+
}, []);
|
|
69
|
+
(0, react_1.useEffect)(() => () => clearTimeout(timerRef.current), []);
|
|
70
|
+
const transformMap = {
|
|
71
|
+
top: 'translateX(-50%) translateY(-100%)',
|
|
72
|
+
bottom: 'translateX(-50%)',
|
|
73
|
+
left: 'translateX(-100%) translateY(-50%)',
|
|
74
|
+
right: 'translateY(-50%)',
|
|
75
|
+
};
|
|
76
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [react_1.default.cloneElement(children, {
|
|
77
|
+
ref: triggerRef,
|
|
78
|
+
'aria-describedby': state.visible ? tooltipId : undefined,
|
|
79
|
+
onMouseEnter: (...args) => {
|
|
80
|
+
if (!disabled)
|
|
81
|
+
show();
|
|
82
|
+
children.props.onMouseEnter?.(...args);
|
|
83
|
+
},
|
|
84
|
+
onMouseLeave: (...args) => {
|
|
85
|
+
hide();
|
|
86
|
+
children.props.onMouseLeave?.(...args);
|
|
87
|
+
},
|
|
88
|
+
onFocus: (...args) => {
|
|
89
|
+
if (!disabled)
|
|
90
|
+
show();
|
|
91
|
+
children.props.onFocus?.(...args);
|
|
92
|
+
},
|
|
93
|
+
onBlur: (...args) => {
|
|
94
|
+
hide();
|
|
95
|
+
children.props.onBlur?.(...args);
|
|
96
|
+
},
|
|
97
|
+
}), state.visible && !disabled && ((0, jsx_runtime_1.jsx)(index_js_1.Portal, { children: (0, jsx_runtime_1.jsx)("div", { id: tooltipId, role: "tooltip", className: (0, cn_js_1.cn)('tokis-tooltip-content', `tokis-tooltip-content--${state.placement}`), style: {
|
|
98
|
+
position: 'fixed',
|
|
99
|
+
top: state.top,
|
|
100
|
+
left: state.left,
|
|
101
|
+
transform: transformMap[state.placement],
|
|
102
|
+
}, children: content }) }))] }));
|
|
103
|
+
}
|
|
104
|
+
function computePosition(rect, placement) {
|
|
105
|
+
const gap = 8;
|
|
106
|
+
switch (placement) {
|
|
107
|
+
case 'top':
|
|
108
|
+
return { top: rect.top - gap, left: rect.left + rect.width / 2 };
|
|
109
|
+
case 'bottom':
|
|
110
|
+
return { top: rect.bottom + gap, left: rect.left + rect.width / 2 };
|
|
111
|
+
case 'left':
|
|
112
|
+
return { top: rect.top + rect.height / 2, left: rect.left - gap };
|
|
113
|
+
case 'right':
|
|
114
|
+
return { top: rect.top + rect.height / 2, left: rect.right + gap };
|
|
115
|
+
}
|
|
116
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TreeView = TreeView;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
function flattenVisible(nodes, expanded) {
|
|
8
|
+
const result = [];
|
|
9
|
+
function walk(items) {
|
|
10
|
+
for (const node of items) {
|
|
11
|
+
result.push(node);
|
|
12
|
+
if (node.children && expanded.includes(node.id)) {
|
|
13
|
+
walk(node.children);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
walk(nodes);
|
|
18
|
+
return result;
|
|
19
|
+
}
|
|
20
|
+
function TreeItem({ node, level, selected, expanded, onSelect, onExpand, multiSelect, allNodes, onKeyNav, }) {
|
|
21
|
+
const hasChildren = Boolean(node.children && node.children.length > 0);
|
|
22
|
+
const isExpanded = expanded.includes(node.id);
|
|
23
|
+
const isSelected = selected.includes(node.id);
|
|
24
|
+
const handleKeyDown = (e) => {
|
|
25
|
+
switch (e.key) {
|
|
26
|
+
case 'ArrowRight':
|
|
27
|
+
e.preventDefault();
|
|
28
|
+
if (hasChildren && !isExpanded)
|
|
29
|
+
onExpand(node.id);
|
|
30
|
+
else if (hasChildren && isExpanded)
|
|
31
|
+
onKeyNav(node.id, 'down');
|
|
32
|
+
break;
|
|
33
|
+
case 'ArrowLeft':
|
|
34
|
+
e.preventDefault();
|
|
35
|
+
if (hasChildren && isExpanded)
|
|
36
|
+
onExpand(node.id);
|
|
37
|
+
else
|
|
38
|
+
onKeyNav(node.id, 'up');
|
|
39
|
+
break;
|
|
40
|
+
case 'ArrowDown':
|
|
41
|
+
e.preventDefault();
|
|
42
|
+
onKeyNav(node.id, 'down');
|
|
43
|
+
break;
|
|
44
|
+
case 'ArrowUp':
|
|
45
|
+
e.preventDefault();
|
|
46
|
+
onKeyNav(node.id, 'up');
|
|
47
|
+
break;
|
|
48
|
+
case 'Enter':
|
|
49
|
+
case ' ':
|
|
50
|
+
e.preventDefault();
|
|
51
|
+
if (!node.disabled)
|
|
52
|
+
onSelect(node.id);
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
return ((0, jsx_runtime_1.jsxs)("li", { role: "none", children: [(0, jsx_runtime_1.jsxs)("div", { role: "treeitem", "aria-expanded": hasChildren ? isExpanded : undefined, "aria-selected": isSelected, "aria-disabled": node.disabled, "aria-level": level, tabIndex: node.disabled ? -1 : 0, className: (0, cn_js_1.cn)('tokis-treeview__item', isSelected && 'tokis-treeview__item--selected', node.disabled && 'tokis-treeview__item--disabled'), style: { paddingLeft: `calc(${(level - 1) * 20}px + var(--tokis-spacing-2))` }, onClick: () => {
|
|
57
|
+
if (node.disabled)
|
|
58
|
+
return;
|
|
59
|
+
if (hasChildren)
|
|
60
|
+
onExpand(node.id);
|
|
61
|
+
onSelect(node.id);
|
|
62
|
+
}, onKeyDown: handleKeyDown, "data-id": node.id, children: [hasChildren ? ((0, jsx_runtime_1.jsx)("span", { className: (0, cn_js_1.cn)('tokis-treeview__chevron', isExpanded && 'tokis-treeview__chevron--open'), "aria-hidden": "true", children: (0, jsx_runtime_1.jsx)("svg", { width: "12", height: "12", viewBox: "0 0 12 12", fill: "none", children: (0, jsx_runtime_1.jsx)("path", { d: "M4 3l4 3-4 3", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }) })) : ((0, jsx_runtime_1.jsx)("span", { className: "tokis-treeview__leaf-spacer", "aria-hidden": "true" })), node.icon && ((0, jsx_runtime_1.jsx)("span", { className: "tokis-treeview__icon", "aria-hidden": "true", children: node.icon })), (0, jsx_runtime_1.jsx)("span", { className: "tokis-treeview__label", children: node.label })] }), hasChildren && isExpanded && ((0, jsx_runtime_1.jsx)("ul", { role: "group", className: "tokis-treeview__group", "aria-label": node.label, children: node.children.map((child) => ((0, jsx_runtime_1.jsx)(TreeItem, { node: child, level: level + 1, selected: selected, expanded: expanded, onSelect: onSelect, onExpand: onExpand, multiSelect: multiSelect, allNodes: allNodes, onKeyNav: onKeyNav }, child.id))) }))] }));
|
|
63
|
+
}
|
|
64
|
+
function TreeView({ data, selected = [], onSelect, expanded = [], onExpand, multiSelect = false, className, }) {
|
|
65
|
+
const treeRef = (0, react_1.useRef)(null);
|
|
66
|
+
const handleSelect = (0, react_1.useCallback)((id) => {
|
|
67
|
+
onSelect?.(id);
|
|
68
|
+
}, [onSelect]);
|
|
69
|
+
const handleExpand = (0, react_1.useCallback)((id) => {
|
|
70
|
+
onExpand?.(id);
|
|
71
|
+
}, [onExpand]);
|
|
72
|
+
const handleKeyNav = (0, react_1.useCallback)((currentId, direction) => {
|
|
73
|
+
const visible = flattenVisible(data, expanded);
|
|
74
|
+
const currentIndex = visible.findIndex((n) => n.id === currentId);
|
|
75
|
+
if (currentIndex === -1)
|
|
76
|
+
return;
|
|
77
|
+
let targetIndex;
|
|
78
|
+
if (direction === 'down')
|
|
79
|
+
targetIndex = Math.min(currentIndex + 1, visible.length - 1);
|
|
80
|
+
if (direction === 'up')
|
|
81
|
+
targetIndex = Math.max(currentIndex - 1, 0);
|
|
82
|
+
if (targetIndex !== undefined && targetIndex !== currentIndex) {
|
|
83
|
+
const targetId = visible[targetIndex].id;
|
|
84
|
+
const el = treeRef.current?.querySelector(`[data-id="${targetId}"]`);
|
|
85
|
+
el?.focus();
|
|
86
|
+
}
|
|
87
|
+
}, [data, expanded]);
|
|
88
|
+
return ((0, jsx_runtime_1.jsx)("ul", { ref: treeRef, role: "tree", "aria-multiselectable": multiSelect, className: (0, cn_js_1.cn)('tokis-treeview', className), children: data.map((node) => ((0, jsx_runtime_1.jsx)(TreeItem, { node: node, level: 1, selected: selected, expanded: expanded, onSelect: handleSelect, onExpand: handleExpand, multiSelect: multiSelect, allNodes: data, onKeyNav: handleKeyNav }, node.id))) }));
|
|
89
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Typography = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
const variantElementMap = {
|
|
8
|
+
h1: 'h1', h2: 'h2', h3: 'h3', h4: 'h4', h5: 'h5', h6: 'h6',
|
|
9
|
+
body1: 'p', body2: 'p', caption: 'span', label: 'label', code: 'code', overline: 'span',
|
|
10
|
+
};
|
|
11
|
+
const variantClassMap = {
|
|
12
|
+
h1: 'tokis-h1', h2: 'tokis-h2', h3: 'tokis-h3', h4: 'tokis-h4', h5: 'tokis-h5', h6: 'tokis-h6',
|
|
13
|
+
body1: 'tokis-text', body2: 'tokis-text', caption: 'tokis-text', label: 'tokis-text',
|
|
14
|
+
code: 'tokis-code', overline: 'tokis-text',
|
|
15
|
+
};
|
|
16
|
+
exports.Typography = (0, react_1.forwardRef)(({ as, variant = 'body1', color, truncate, weight, align, className, children, ...props }, ref) => {
|
|
17
|
+
const Component = as ?? variantElementMap[variant] ?? 'p';
|
|
18
|
+
return ((0, jsx_runtime_1.jsx)(Component, { ref: ref, className: (0, cn_js_1.cn)(variantClassMap[variant], color && color !== 'inherit' && `tokis-text--${color}`, truncate && 'tokis-text--truncate', weight && `tokis-text--weight-${weight}`, align && `tokis-text--align-${align}`, className), ...props, children: children }));
|
|
19
|
+
});
|
|
20
|
+
exports.Typography.displayName = 'Typography';
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.VirtualizedList = VirtualizedList;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const cn_js_1 = require("../../utils/cn");
|
|
7
|
+
function VirtualizedList({ items, itemHeight, height, renderItem, overscan = 3, className, getItemKey, }) {
|
|
8
|
+
const [scrollTop, setScrollTop] = (0, react_1.useState)(0);
|
|
9
|
+
const containerRef = (0, react_1.useRef)(null);
|
|
10
|
+
const totalHeight = items.length * itemHeight;
|
|
11
|
+
const visibleCount = Math.ceil(height / itemHeight);
|
|
12
|
+
const startIndex = Math.max(0, Math.floor(scrollTop / itemHeight) - overscan);
|
|
13
|
+
const endIndex = Math.min(items.length - 1, startIndex + visibleCount + overscan * 2);
|
|
14
|
+
const paddingTop = startIndex * itemHeight;
|
|
15
|
+
const handleScroll = (0, react_1.useCallback)(() => {
|
|
16
|
+
if (containerRef.current)
|
|
17
|
+
setScrollTop(containerRef.current.scrollTop);
|
|
18
|
+
}, []);
|
|
19
|
+
return ((0, jsx_runtime_1.jsx)("div", { ref: containerRef, className: (0, cn_js_1.cn)('tokis-virtual-list', className), style: { height, overflow: 'auto' }, onScroll: handleScroll, children: (0, jsx_runtime_1.jsx)("div", { style: { height: totalHeight, position: 'relative' }, children: (0, jsx_runtime_1.jsx)("div", { style: { position: 'absolute', top: paddingTop, left: 0, right: 0 }, children: items.slice(startIndex, endIndex + 1).map((item, offset) => {
|
|
20
|
+
const index = startIndex + offset;
|
|
21
|
+
const key = getItemKey ? getItemKey(item, index) : index;
|
|
22
|
+
return ((0, jsx_runtime_1.jsx)("div", { style: { height: itemHeight }, children: renderItem(item, index) }, key));
|
|
23
|
+
}) }) }) }));
|
|
24
|
+
}
|
|
25
|
+
VirtualizedList.displayName = 'VirtualizedList';
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConfigProvider = void 0;
|
|
4
|
+
exports.useConfig = useConfig;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
const tokens_1 = require("@tokis/tokens");
|
|
8
|
+
const defaultConfig = {
|
|
9
|
+
tokens: tokens_1.lightTheme,
|
|
10
|
+
};
|
|
11
|
+
const ConfigContext = (0, react_1.createContext)(defaultConfig);
|
|
12
|
+
const ConfigProvider = ({ children, config }) => {
|
|
13
|
+
const resolved = {
|
|
14
|
+
...defaultConfig,
|
|
15
|
+
...config,
|
|
16
|
+
};
|
|
17
|
+
return (0, jsx_runtime_1.jsx)(ConfigContext.Provider, { value: resolved, children: children });
|
|
18
|
+
};
|
|
19
|
+
exports.ConfigProvider = ConfigProvider;
|
|
20
|
+
function useConfig() {
|
|
21
|
+
return (0, react_1.useContext)(ConfigContext);
|
|
22
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ThemeProvider = void 0;
|
|
4
|
+
exports.useTheme = useTheme;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
const ThemeContext = (0, react_1.createContext)(undefined);
|
|
8
|
+
const ThemeProvider = ({ children, initialMode = 'light' }) => {
|
|
9
|
+
const [mode, setMode] = (0, react_1.useState)(initialMode);
|
|
10
|
+
(0, react_1.useEffect)(() => {
|
|
11
|
+
document.documentElement.setAttribute('data-theme', mode);
|
|
12
|
+
return () => {
|
|
13
|
+
document.documentElement.removeAttribute('data-theme');
|
|
14
|
+
};
|
|
15
|
+
}, [mode]);
|
|
16
|
+
const toggle = () => setMode((prev) => (prev === 'light' ? 'dark' : 'light'));
|
|
17
|
+
return ((0, jsx_runtime_1.jsx)(ThemeContext.Provider, { value: { mode, toggle, setMode }, children: children }));
|
|
18
|
+
};
|
|
19
|
+
exports.ThemeProvider = ThemeProvider;
|
|
20
|
+
function useTheme() {
|
|
21
|
+
const ctx = (0, react_1.useContext)(ThemeContext);
|
|
22
|
+
if (!ctx)
|
|
23
|
+
throw new Error('useTheme must be used within ThemeProvider');
|
|
24
|
+
return ctx;
|
|
25
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useControllableState = useControllableState;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
const core_1 = require("@tokis/core");
|
|
6
|
+
/**
|
|
7
|
+
* A React hook for managing controllable state — supporting both
|
|
8
|
+
* controlled (externally managed) and uncontrolled (internally managed) modes.
|
|
9
|
+
*
|
|
10
|
+
* @param controlled - The externally controlled value (undefined = uncontrolled)
|
|
11
|
+
* @param defaultValue - The initial value for uncontrolled mode
|
|
12
|
+
* @param onChange - Optional callback invoked when internal state changes
|
|
13
|
+
*/
|
|
14
|
+
function useControllableState(controlled, defaultValue, onChange) {
|
|
15
|
+
const [internalState, setInternalState] = (0, react_1.useState)(defaultValue);
|
|
16
|
+
const controlled_ = (0, core_1.isControlled)(controlled);
|
|
17
|
+
const value = controlled_ ? controlled : internalState;
|
|
18
|
+
// Keep a stable ref to onChange to avoid stale closures
|
|
19
|
+
const onChangeRef = (0, react_1.useRef)(onChange);
|
|
20
|
+
onChangeRef.current = onChange;
|
|
21
|
+
const setValue = (0, react_1.useCallback)((next) => {
|
|
22
|
+
const nextValue = typeof next === 'function'
|
|
23
|
+
? next(value)
|
|
24
|
+
: next;
|
|
25
|
+
if (!controlled_) {
|
|
26
|
+
setInternalState(nextValue);
|
|
27
|
+
}
|
|
28
|
+
onChangeRef.current?.(nextValue);
|
|
29
|
+
}, [controlled_, value]);
|
|
30
|
+
return [value, setValue];
|
|
31
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useDialog = useDialog;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
function useDialog(defaultOpen = false) {
|
|
6
|
+
const [isOpen, setIsOpen] = (0, react_1.useState)(defaultOpen);
|
|
7
|
+
const dialogId = (0, react_1.useId)();
|
|
8
|
+
const titleId = `${dialogId}-title`;
|
|
9
|
+
const descriptionId = `${dialogId}-desc`;
|
|
10
|
+
const open = (0, react_1.useCallback)(() => setIsOpen(true), []);
|
|
11
|
+
const close = (0, react_1.useCallback)(() => setIsOpen(false), []);
|
|
12
|
+
const toggle = (0, react_1.useCallback)(() => setIsOpen((v) => !v), []);
|
|
13
|
+
return {
|
|
14
|
+
isOpen,
|
|
15
|
+
open,
|
|
16
|
+
close,
|
|
17
|
+
toggle,
|
|
18
|
+
dialogProps: {
|
|
19
|
+
open: isOpen,
|
|
20
|
+
onClose: close,
|
|
21
|
+
'aria-modal': true,
|
|
22
|
+
role: 'dialog',
|
|
23
|
+
'aria-labelledby': titleId,
|
|
24
|
+
'aria-describedby': descriptionId,
|
|
25
|
+
},
|
|
26
|
+
triggerProps: {
|
|
27
|
+
onClick: open,
|
|
28
|
+
'aria-haspopup': 'dialog',
|
|
29
|
+
'aria-expanded': isOpen,
|
|
30
|
+
'aria-controls': dialogId,
|
|
31
|
+
},
|
|
32
|
+
titleId,
|
|
33
|
+
descriptionId,
|
|
34
|
+
};
|
|
35
|
+
}
|