@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,329 @@
|
|
|
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.Autocomplete = Autocomplete;
|
|
37
|
+
exports.ButtonGroup = ButtonGroup;
|
|
38
|
+
exports.FloatingActionButton = FloatingActionButton;
|
|
39
|
+
exports.NumberField = NumberField;
|
|
40
|
+
exports.Rating = Rating;
|
|
41
|
+
exports.StarRating = Rating;
|
|
42
|
+
exports.TransferList = TransferList;
|
|
43
|
+
exports.Icon = Icon;
|
|
44
|
+
exports.MaterialIcon = MaterialIcon;
|
|
45
|
+
exports.Backdrop = Backdrop;
|
|
46
|
+
exports.Paper = Paper;
|
|
47
|
+
exports.SpeedDial = SpeedDial;
|
|
48
|
+
exports.ImageList = ImageList;
|
|
49
|
+
exports.ImageListItem = ImageListItem;
|
|
50
|
+
exports.ClickAwayListener = ClickAwayListener;
|
|
51
|
+
exports.OtpInput = OtpInput;
|
|
52
|
+
exports.FileDropZone = FileDropZone;
|
|
53
|
+
exports.CssBaseline = CssBaseline;
|
|
54
|
+
exports.InitColorSchemeScript = InitColorSchemeScript;
|
|
55
|
+
exports.Modal = Modal;
|
|
56
|
+
exports.NoSsr = NoSsr;
|
|
57
|
+
exports.Popper = Popper;
|
|
58
|
+
exports.TextareaAutosize = TextareaAutosize;
|
|
59
|
+
exports.Fade = Fade;
|
|
60
|
+
exports.useMediaQuery = useMediaQuery;
|
|
61
|
+
exports.DataGrid = DataGrid;
|
|
62
|
+
exports.DatePicker = DatePicker;
|
|
63
|
+
exports.TimePicker = TimePicker;
|
|
64
|
+
exports.DateTimePicker = DateTimePicker;
|
|
65
|
+
exports.Charts = Charts;
|
|
66
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
67
|
+
const react_1 = __importStar(require("react"));
|
|
68
|
+
const cn_js_1 = require("../../utils/cn");
|
|
69
|
+
const index_js_1 = require("../input/index");
|
|
70
|
+
const index_js_2 = require("../button/index");
|
|
71
|
+
const index_js_3 = require("../portal/index");
|
|
72
|
+
const index_js_4 = require("../card/index");
|
|
73
|
+
const index_js_5 = require("../table/index");
|
|
74
|
+
function Autocomplete({ options, value, onChange, label, placeholder = 'Search...', ...props }) {
|
|
75
|
+
const [query, setQuery] = (0, react_1.useState)(value ?? '');
|
|
76
|
+
const [open, setOpen] = (0, react_1.useState)(false);
|
|
77
|
+
const filtered = (0, react_1.useMemo)(() => options.filter((o) => o.label.toLowerCase().includes(query.toLowerCase())), [options, query]);
|
|
78
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-autocomplete", children: [(0, jsx_runtime_1.jsx)(index_js_1.TextField, { label: label, value: query, placeholder: placeholder, onFocus: () => setOpen(true), onChange: (e) => {
|
|
79
|
+
setQuery(e.target.value);
|
|
80
|
+
onChange?.(e.target.value);
|
|
81
|
+
setOpen(true);
|
|
82
|
+
}, ...props }), open && filtered.length > 0 && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-autocomplete-list", role: "listbox", children: filtered.map((option) => ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "tokis-autocomplete-item", onClick: () => {
|
|
83
|
+
setQuery(option.label);
|
|
84
|
+
onChange?.(option.value);
|
|
85
|
+
setOpen(false);
|
|
86
|
+
}, children: option.label }, option.value))) }))] }));
|
|
87
|
+
}
|
|
88
|
+
function ButtonGroup({ orientation = 'horizontal', className, ...props }) {
|
|
89
|
+
return (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-button-group', orientation === 'vertical' && 'tokis-button-group--vertical', className), ...props });
|
|
90
|
+
}
|
|
91
|
+
function FloatingActionButton({ children, label = 'Action', className, ...props }) {
|
|
92
|
+
return ((0, jsx_runtime_1.jsx)(index_js_2.ButtonRoot, { className: (0, cn_js_1.cn)('tokis-fab', className), iconOnly: true, "aria-label": label, ...props, children: children }));
|
|
93
|
+
}
|
|
94
|
+
function NumberField({ label, value = 0, onChange, step = 1, min, max, ...props }) {
|
|
95
|
+
const parsedStep = Number(step) || 1;
|
|
96
|
+
const minNum = typeof min === 'number' ? min : undefined;
|
|
97
|
+
const maxNum = typeof max === 'number' ? max : undefined;
|
|
98
|
+
const update = (next) => {
|
|
99
|
+
const boundedMin = minNum !== undefined ? Math.max(minNum, next) : next;
|
|
100
|
+
const bounded = maxNum !== undefined ? Math.min(maxNum, boundedMin) : boundedMin;
|
|
101
|
+
onChange?.(bounded);
|
|
102
|
+
};
|
|
103
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-number-field", children: [(0, jsx_runtime_1.jsx)(index_js_1.TextField, { ...props, type: "number", label: label, value: value, onChange: (e) => onChange?.(Number(e.target.value)) }), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-number-field-actions", children: [(0, jsx_runtime_1.jsx)(index_js_2.ButtonRoot, { size: "sm", variant: "outline", onClick: () => update(value - parsedStep), children: "-" }), (0, jsx_runtime_1.jsx)(index_js_2.ButtonRoot, { size: "sm", variant: "outline", onClick: () => update(value + parsedStep), children: "+" })] })] }));
|
|
104
|
+
}
|
|
105
|
+
function Rating({ value = 0, max = 5, readOnly = false, onChange, size = 'md', label = 'Rating' }) {
|
|
106
|
+
const [hovered, setHovered] = (0, react_1.useState)(null);
|
|
107
|
+
const display = hovered ?? value;
|
|
108
|
+
const sizeMap = { sm: '18px', md: '24px', lg: '32px' };
|
|
109
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-rating', readOnly && 'tokis-rating--readonly'), role: "radiogroup", "aria-label": label, "data-readonly": readOnly || undefined, children: Array.from({ length: max }).map((_, index) => {
|
|
110
|
+
const current = index + 1;
|
|
111
|
+
const filled = current <= display;
|
|
112
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: "button", role: "radio", "aria-checked": current <= value, "aria-label": `${current} star${current !== 1 ? 's' : ''}`, disabled: readOnly, className: (0, cn_js_1.cn)('tokis-rating-star', filled && 'tokis-rating-star--active', hovered !== null && filled && 'tokis-rating-star--hover'), style: { fontSize: sizeMap[size] }, onClick: () => onChange?.(current), onMouseEnter: () => !readOnly && setHovered(current), onMouseLeave: () => !readOnly && setHovered(null), children: (0, jsx_runtime_1.jsx)("svg", { viewBox: "0 0 24 24", width: sizeMap[size], height: sizeMap[size], "aria-hidden": "true", fill: filled ? 'currentColor' : 'none', stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round", children: (0, jsx_runtime_1.jsx)("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }) }) }, current));
|
|
113
|
+
}) }));
|
|
114
|
+
}
|
|
115
|
+
function TransferList({ left, right, onChange, leftTitle = 'Available', rightTitle = 'Selected' }) {
|
|
116
|
+
const [leftChecked, setLeftChecked] = (0, react_1.useState)([]);
|
|
117
|
+
const [rightChecked, setRightChecked] = (0, react_1.useState)([]);
|
|
118
|
+
const moveToRight = () => {
|
|
119
|
+
const moved = left.filter((item) => leftChecked.includes(item.id));
|
|
120
|
+
onChange(left.filter((item) => !leftChecked.includes(item.id)), [...right, ...moved]);
|
|
121
|
+
setLeftChecked([]);
|
|
122
|
+
};
|
|
123
|
+
const moveToLeft = () => {
|
|
124
|
+
const moved = right.filter((item) => rightChecked.includes(item.id));
|
|
125
|
+
onChange([...left, ...moved], right.filter((item) => !rightChecked.includes(item.id)));
|
|
126
|
+
setRightChecked([]);
|
|
127
|
+
};
|
|
128
|
+
const renderPane = (title, items, checked, setChecked) => ((0, jsx_runtime_1.jsxs)(index_js_4.Card, { className: "tokis-transfer-pane", children: [(0, jsx_runtime_1.jsx)(index_js_4.CardHeader, { children: title }), (0, jsx_runtime_1.jsx)(index_js_4.CardBody, { children: items.map((item) => ((0, jsx_runtime_1.jsxs)("label", { className: "tokis-transfer-item", children: [(0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: checked.includes(item.id), onChange: (e) => setChecked(e.target.checked ? [...checked, item.id] : checked.filter((id) => id !== item.id)) }), item.label] }, item.id))) })] }));
|
|
129
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-transfer-list", children: [renderPane(leftTitle, left, leftChecked, setLeftChecked), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-transfer-actions", children: [(0, jsx_runtime_1.jsx)(index_js_2.ButtonRoot, { size: "sm", onClick: moveToRight, children: '>' }), (0, jsx_runtime_1.jsx)(index_js_2.ButtonRoot, { size: "sm", onClick: moveToLeft, children: '<' })] }), renderPane(rightTitle, right, rightChecked, setRightChecked)] }));
|
|
130
|
+
}
|
|
131
|
+
const iconMap = {
|
|
132
|
+
search: '⌕',
|
|
133
|
+
close: '×',
|
|
134
|
+
menu: '☰',
|
|
135
|
+
check: '✓',
|
|
136
|
+
star: '★',
|
|
137
|
+
'arrow-right': '→',
|
|
138
|
+
};
|
|
139
|
+
function Icon({ name, className, ...props }) {
|
|
140
|
+
return (0, jsx_runtime_1.jsx)("span", { className: (0, cn_js_1.cn)('tokis-icon', className), "aria-hidden": "true", ...props, children: iconMap[name] });
|
|
141
|
+
}
|
|
142
|
+
function MaterialIcon({ icon, className, ...props }) {
|
|
143
|
+
return (0, jsx_runtime_1.jsx)("span", { className: (0, cn_js_1.cn)('tokis-material-icon', className), ...props, children: icon });
|
|
144
|
+
}
|
|
145
|
+
function Backdrop({ open, onClick, className, children, ...props }) {
|
|
146
|
+
if (!open)
|
|
147
|
+
return null;
|
|
148
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-backdrop', className), onClick: onClick, ...props, children: children }));
|
|
149
|
+
}
|
|
150
|
+
function Paper({ elevation = 1, className, ...props }) {
|
|
151
|
+
return (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-paper', `tokis-paper--${elevation}`, className), ...props });
|
|
152
|
+
}
|
|
153
|
+
function SpeedDial({ label = 'Open actions', actions }) {
|
|
154
|
+
const [open, setOpen] = (0, react_1.useState)(false);
|
|
155
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-speed-dial", children: [open && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-speed-dial-actions", children: actions.map((action) => ((0, jsx_runtime_1.jsxs)("button", { type: "button", className: "tokis-speed-dial-action", onClick: () => {
|
|
156
|
+
action.onClick?.();
|
|
157
|
+
setOpen(false);
|
|
158
|
+
}, children: [action.icon, (0, jsx_runtime_1.jsx)("span", { children: action.label })] }, action.id))) })), (0, jsx_runtime_1.jsx)(FloatingActionButton, { label: label, onClick: () => setOpen((state) => !state), children: "+" })] }));
|
|
159
|
+
}
|
|
160
|
+
function ImageList({ cols = 3, className, style, ...props }) {
|
|
161
|
+
return (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-image-list', className), style: { gridTemplateColumns: `repeat(${cols}, minmax(0, 1fr))`, ...style }, ...props });
|
|
162
|
+
}
|
|
163
|
+
function ImageListItem(props) {
|
|
164
|
+
return (0, jsx_runtime_1.jsx)("div", { className: "tokis-image-list-item", ...props });
|
|
165
|
+
}
|
|
166
|
+
function ClickAwayListener({ onClickAway, children }) {
|
|
167
|
+
const ref = (0, react_1.useRef)(null);
|
|
168
|
+
(0, react_1.useEffect)(() => {
|
|
169
|
+
const handler = (event) => {
|
|
170
|
+
if (!ref.current?.contains(event.target))
|
|
171
|
+
onClickAway();
|
|
172
|
+
};
|
|
173
|
+
document.addEventListener('mousedown', handler);
|
|
174
|
+
return () => document.removeEventListener('mousedown', handler);
|
|
175
|
+
}, [onClickAway]);
|
|
176
|
+
return react_1.default.cloneElement(children, {
|
|
177
|
+
ref: (node) => {
|
|
178
|
+
ref.current = node;
|
|
179
|
+
},
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
function OtpInput({ length = 6, value = '', onChange, disabled = false, error = false, label }) {
|
|
183
|
+
const digits = value.slice(0, length).padEnd(length, '').split('');
|
|
184
|
+
const inputsRef = (0, react_1.useRef)([]);
|
|
185
|
+
const handleChange = (index, char) => {
|
|
186
|
+
const filtered = char.replace(/\D/g, '').slice(0, 1);
|
|
187
|
+
const next = digits.map((d, i) => (i === index ? filtered : d)).join('').trimEnd();
|
|
188
|
+
onChange?.(next);
|
|
189
|
+
if (filtered && index < length - 1) {
|
|
190
|
+
inputsRef.current[index + 1]?.focus();
|
|
191
|
+
}
|
|
192
|
+
};
|
|
193
|
+
const handleKeyDown = (index, e) => {
|
|
194
|
+
if (e.key === 'Backspace' && !digits[index] && index > 0) {
|
|
195
|
+
inputsRef.current[index - 1]?.focus();
|
|
196
|
+
const next = digits.map((d, i) => (i === index - 1 ? '' : d)).join('').trimEnd();
|
|
197
|
+
onChange?.(next);
|
|
198
|
+
}
|
|
199
|
+
if (e.key === 'ArrowLeft' && index > 0)
|
|
200
|
+
inputsRef.current[index - 1]?.focus();
|
|
201
|
+
if (e.key === 'ArrowRight' && index < length - 1)
|
|
202
|
+
inputsRef.current[index + 1]?.focus();
|
|
203
|
+
};
|
|
204
|
+
const handlePaste = (e) => {
|
|
205
|
+
e.preventDefault();
|
|
206
|
+
const pasted = e.clipboardData.getData('text').replace(/\D/g, '').slice(0, length);
|
|
207
|
+
onChange?.(pasted);
|
|
208
|
+
const focusIndex = Math.min(pasted.length, length - 1);
|
|
209
|
+
inputsRef.current[focusIndex]?.focus();
|
|
210
|
+
};
|
|
211
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-otp-root", children: [label && (0, jsx_runtime_1.jsx)("label", { className: "tokis-label", style: { marginBottom: 'var(--tokis-spacing-2)', display: 'block' }, children: label }), (0, jsx_runtime_1.jsx)("div", { className: "tokis-otp-inputs", "aria-label": label ?? 'OTP Input', children: digits.map((digit, index) => ((0, jsx_runtime_1.jsx)("input", { ref: (el) => { inputsRef.current[index] = el; }, type: "text", inputMode: "numeric", pattern: "[0-9]*", maxLength: 1, value: digit.trim(), disabled: disabled, className: (0, cn_js_1.cn)('tokis-otp-cell', error && 'tokis-otp-cell--error', digit.trim() && 'tokis-otp-cell--filled'), "aria-label": `Digit ${index + 1} of ${length}`, onChange: (e) => handleChange(index, e.target.value), onKeyDown: (e) => handleKeyDown(index, e), onPaste: handlePaste, onFocus: (e) => e.target.select() }, index))) })] }));
|
|
212
|
+
}
|
|
213
|
+
function FileDropZone({ onFiles, accept, multiple = false, disabled = false, label = 'Drop files here or click to upload', hint, maxSize, }) {
|
|
214
|
+
const [dragging, setDragging] = (0, react_1.useState)(false);
|
|
215
|
+
const [files, setFiles] = (0, react_1.useState)([]);
|
|
216
|
+
const [error, setError] = (0, react_1.useState)(null);
|
|
217
|
+
const inputRef = (0, react_1.useRef)(null);
|
|
218
|
+
const process = (incoming) => {
|
|
219
|
+
if (!incoming)
|
|
220
|
+
return;
|
|
221
|
+
const arr = Array.from(incoming);
|
|
222
|
+
if (maxSize) {
|
|
223
|
+
const oversized = arr.find((f) => f.size > maxSize);
|
|
224
|
+
if (oversized) {
|
|
225
|
+
setError(`File "${oversized.name}" exceeds the ${Math.round(maxSize / 1024)}KB limit.`);
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
setError(null);
|
|
230
|
+
setFiles(arr);
|
|
231
|
+
onFiles?.(arr);
|
|
232
|
+
};
|
|
233
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-dropzone', dragging && 'tokis-dropzone--dragging', disabled && 'tokis-dropzone--disabled', error && 'tokis-dropzone--error'), role: "button", tabIndex: disabled ? -1 : 0, "aria-disabled": disabled, onClick: () => !disabled && inputRef.current?.click(), onKeyDown: (e) => { if (e.key === 'Enter' || e.key === ' ') {
|
|
234
|
+
e.preventDefault();
|
|
235
|
+
inputRef.current?.click();
|
|
236
|
+
} }, onDragOver: (e) => { e.preventDefault(); if (!disabled)
|
|
237
|
+
setDragging(true); }, onDragLeave: () => setDragging(false), onDrop: (e) => {
|
|
238
|
+
e.preventDefault();
|
|
239
|
+
setDragging(false);
|
|
240
|
+
if (!disabled)
|
|
241
|
+
process(e.dataTransfer.files);
|
|
242
|
+
}, children: [(0, jsx_runtime_1.jsx)("input", { ref: inputRef, type: "file", accept: accept, multiple: multiple, style: { display: 'none' }, onChange: (e) => process(e.target.files) }), (0, jsx_runtime_1.jsx)("div", { className: "tokis-dropzone__icon", "aria-hidden": "true", children: (0, jsx_runtime_1.jsxs)("svg", { width: "32", height: "32", viewBox: "0 0 32 32", fill: "none", children: [(0, jsx_runtime_1.jsx)("path", { d: "M6 22v3a1 1 0 0 0 1 1h18a1 1 0 0 0 1-1v-3", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }), (0, jsx_runtime_1.jsx)("path", { d: "M16 6v14M10 12l6-6 6 6", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" })] }) }), (0, jsx_runtime_1.jsx)("div", { className: "tokis-dropzone__label", children: label }), hint && !files.length && (0, jsx_runtime_1.jsx)("div", { className: "tokis-dropzone__hint", children: hint }), error && (0, jsx_runtime_1.jsx)("div", { className: "tokis-dropzone__error", children: error }), files.length > 0 && !error && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-dropzone__files", children: files.map((f) => ((0, jsx_runtime_1.jsx)("span", { className: "tokis-dropzone__file", children: f.name }, f.name))) }))] }));
|
|
243
|
+
}
|
|
244
|
+
function CssBaseline() {
|
|
245
|
+
return ((0, jsx_runtime_1.jsx)("style", { children: `*, *::before, *::after { box-sizing: border-box; } body { margin: 0; min-height: 100vh; }` }));
|
|
246
|
+
}
|
|
247
|
+
function InitColorSchemeScript() {
|
|
248
|
+
const script = `(() => {
|
|
249
|
+
const stored = localStorage.getItem('tokis-theme');
|
|
250
|
+
const mode = stored || (window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light');
|
|
251
|
+
document.documentElement.setAttribute('data-theme', mode);
|
|
252
|
+
})();`;
|
|
253
|
+
return (0, jsx_runtime_1.jsx)("script", { dangerouslySetInnerHTML: { __html: script } });
|
|
254
|
+
}
|
|
255
|
+
function Modal({ open, onClose, children }) {
|
|
256
|
+
if (!open)
|
|
257
|
+
return null;
|
|
258
|
+
return ((0, jsx_runtime_1.jsx)(index_js_3.Portal, { children: (0, jsx_runtime_1.jsx)("div", { className: "tokis-modal-root", role: "presentation", onClick: onClose, children: (0, jsx_runtime_1.jsx)("div", { className: "tokis-modal-content", role: "dialog", "aria-modal": "true", onClick: (e) => e.stopPropagation(), children: children }) }) }));
|
|
259
|
+
}
|
|
260
|
+
function NoSsr({ children, fallback = null }) {
|
|
261
|
+
const [mounted, setMounted] = (0, react_1.useState)(false);
|
|
262
|
+
(0, react_1.useEffect)(() => setMounted(true), []);
|
|
263
|
+
return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: mounted ? children : fallback });
|
|
264
|
+
}
|
|
265
|
+
function Popper({ anchorEl, open, children, placement = 'bottom-start' }) {
|
|
266
|
+
const [pos, setPos] = (0, react_1.useState)({ top: 0, left: 0 });
|
|
267
|
+
(0, react_1.useEffect)(() => {
|
|
268
|
+
if (!anchorEl || !open)
|
|
269
|
+
return;
|
|
270
|
+
const rect = anchorEl.getBoundingClientRect();
|
|
271
|
+
const isBottom = placement.startsWith('bottom');
|
|
272
|
+
setPos({
|
|
273
|
+
top: (isBottom ? rect.bottom : rect.top) + window.scrollY + (isBottom ? 8 : -8),
|
|
274
|
+
left: (placement.endsWith('start') ? rect.left : rect.right) + window.scrollX,
|
|
275
|
+
});
|
|
276
|
+
}, [anchorEl, open, placement]);
|
|
277
|
+
if (!open)
|
|
278
|
+
return null;
|
|
279
|
+
return ((0, jsx_runtime_1.jsx)(index_js_3.Portal, { children: (0, jsx_runtime_1.jsx)("div", { className: "tokis-popper", style: { top: pos.top, left: pos.left }, children: children }) }));
|
|
280
|
+
}
|
|
281
|
+
function TextareaAutosize({ minRows = 3, maxRows = 8, onChange, ...props }) {
|
|
282
|
+
const ref = (0, react_1.useRef)(null);
|
|
283
|
+
const resize = () => {
|
|
284
|
+
if (!ref.current)
|
|
285
|
+
return;
|
|
286
|
+
ref.current.style.height = 'auto';
|
|
287
|
+
const rowHeight = 24;
|
|
288
|
+
const minHeight = minRows * rowHeight;
|
|
289
|
+
const maxHeight = maxRows * rowHeight;
|
|
290
|
+
ref.current.style.height = `${Math.min(maxHeight, Math.max(minHeight, ref.current.scrollHeight))}px`;
|
|
291
|
+
};
|
|
292
|
+
(0, react_1.useEffect)(() => {
|
|
293
|
+
resize();
|
|
294
|
+
}, []);
|
|
295
|
+
return ((0, jsx_runtime_1.jsx)("textarea", { ref: ref, className: "tokis-textarea tokis-textarea-autosize", onChange: (event) => {
|
|
296
|
+
resize();
|
|
297
|
+
onChange?.(event);
|
|
298
|
+
}, ...props }));
|
|
299
|
+
}
|
|
300
|
+
function Fade({ in: visible, children }) {
|
|
301
|
+
return (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-fade', visible && 'tokis-fade--in'), children: children });
|
|
302
|
+
}
|
|
303
|
+
function useMediaQuery(query) {
|
|
304
|
+
const [matches, setMatches] = (0, react_1.useState)(false);
|
|
305
|
+
(0, react_1.useEffect)(() => {
|
|
306
|
+
const media = window.matchMedia(query);
|
|
307
|
+
setMatches(media.matches);
|
|
308
|
+
const listener = (event) => setMatches(event.matches);
|
|
309
|
+
media.addEventListener('change', listener);
|
|
310
|
+
return () => media.removeEventListener('change', listener);
|
|
311
|
+
}, [query]);
|
|
312
|
+
return matches;
|
|
313
|
+
}
|
|
314
|
+
function DataGrid({ columns, rows }) {
|
|
315
|
+
return ((0, jsx_runtime_1.jsxs)(index_js_5.Table, { children: [(0, jsx_runtime_1.jsx)(index_js_5.TableHead, { children: (0, jsx_runtime_1.jsx)(index_js_5.TableRow, { children: columns.map((column) => ((0, jsx_runtime_1.jsx)(index_js_5.TableHeaderCell, { children: column.headerName }, column.field))) }) }), (0, jsx_runtime_1.jsx)(index_js_5.TableBody, { children: rows.map((row, rowIndex) => ((0, jsx_runtime_1.jsx)(index_js_5.TableRow, { children: columns.map((column) => ((0, jsx_runtime_1.jsx)(index_js_5.TableCell, { children: row[column.field] }, column.field))) }, rowIndex))) })] }));
|
|
316
|
+
}
|
|
317
|
+
function DatePicker({ label, ...props }) {
|
|
318
|
+
return (0, jsx_runtime_1.jsx)(index_js_1.TextField, { type: "date", label: label, ...props });
|
|
319
|
+
}
|
|
320
|
+
function TimePicker({ label, ...props }) {
|
|
321
|
+
return (0, jsx_runtime_1.jsx)(index_js_1.TextField, { type: "time", label: label, ...props });
|
|
322
|
+
}
|
|
323
|
+
function DateTimePicker({ label, ...props }) {
|
|
324
|
+
return (0, jsx_runtime_1.jsx)(index_js_1.TextField, { type: "datetime-local", label: label, ...props });
|
|
325
|
+
}
|
|
326
|
+
function Charts({ data, labels = [] }) {
|
|
327
|
+
const max = Math.max(...data, 1);
|
|
328
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "tokis-chart", role: "img", "aria-label": "Bar chart", children: data.map((value, index) => ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-chart-bar-wrap", children: [(0, jsx_runtime_1.jsx)("div", { className: "tokis-chart-bar", style: { height: `${(value / max) * 100}%` }, title: `${labels[index] ?? index}: ${value}` }), (0, jsx_runtime_1.jsx)("span", { className: "tokis-chart-label", children: labels[index] ?? index + 1 })] }, index))) }));
|
|
329
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
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.HoverCard = HoverCard;
|
|
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 computePosition(anchor, placement) {
|
|
42
|
+
const gap = 8;
|
|
43
|
+
switch (placement) {
|
|
44
|
+
case 'top': return { top: anchor.top - gap, left: anchor.left + anchor.width / 2 };
|
|
45
|
+
case 'bottom': return { top: anchor.bottom + gap, left: anchor.left + anchor.width / 2 };
|
|
46
|
+
case 'left': return { top: anchor.top + anchor.height / 2, left: anchor.left - gap };
|
|
47
|
+
case 'right': return { top: anchor.top + anchor.height / 2, left: anchor.right + gap };
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
function HoverCard({ trigger, content, placement = 'bottom', openDelay = 300, closeDelay = 200, className, }) {
|
|
51
|
+
const [visible, setVisible] = (0, react_1.useState)(false);
|
|
52
|
+
const [positioned, setPositioned] = (0, react_1.useState)(false);
|
|
53
|
+
const [pos, setPos] = (0, react_1.useState)({ top: 0, left: 0 });
|
|
54
|
+
const anchorRef = (0, react_1.useRef)(null);
|
|
55
|
+
const openTimer = (0, react_1.useRef)();
|
|
56
|
+
const closeTimer = (0, react_1.useRef)();
|
|
57
|
+
const show = (0, react_1.useCallback)(() => {
|
|
58
|
+
clearTimeout(closeTimer.current);
|
|
59
|
+
openTimer.current = setTimeout(() => {
|
|
60
|
+
if (!anchorRef.current)
|
|
61
|
+
return;
|
|
62
|
+
const rect = anchorRef.current.getBoundingClientRect();
|
|
63
|
+
setPos(computePosition(rect, placement));
|
|
64
|
+
setVisible(true);
|
|
65
|
+
requestAnimationFrame(() => setPositioned(true));
|
|
66
|
+
}, openDelay);
|
|
67
|
+
}, [openDelay, placement]);
|
|
68
|
+
const hide = (0, react_1.useCallback)(() => {
|
|
69
|
+
clearTimeout(openTimer.current);
|
|
70
|
+
setPositioned(false);
|
|
71
|
+
closeTimer.current = setTimeout(() => setVisible(false), closeDelay);
|
|
72
|
+
}, [closeDelay]);
|
|
73
|
+
(0, react_1.useEffect)(() => () => { clearTimeout(openTimer.current); clearTimeout(closeTimer.current); }, []);
|
|
74
|
+
const transformMap = {
|
|
75
|
+
top: 'translateX(-50%) translateY(-100%)',
|
|
76
|
+
bottom: 'translateX(-50%)',
|
|
77
|
+
left: 'translateX(-100%) translateY(-50%)',
|
|
78
|
+
right: 'translateY(-50%)',
|
|
79
|
+
};
|
|
80
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [react_1.default.cloneElement(trigger, {
|
|
81
|
+
ref: anchorRef,
|
|
82
|
+
onMouseEnter: (...args) => {
|
|
83
|
+
show();
|
|
84
|
+
trigger.props.onMouseEnter?.(...args);
|
|
85
|
+
},
|
|
86
|
+
onMouseLeave: (...args) => {
|
|
87
|
+
hide();
|
|
88
|
+
trigger.props.onMouseLeave?.(...args);
|
|
89
|
+
},
|
|
90
|
+
onFocus: (...args) => {
|
|
91
|
+
show();
|
|
92
|
+
trigger.props.onFocus?.(...args);
|
|
93
|
+
},
|
|
94
|
+
onBlur: (...args) => {
|
|
95
|
+
hide();
|
|
96
|
+
trigger.props.onBlur?.(...args);
|
|
97
|
+
},
|
|
98
|
+
}), visible && ((0, jsx_runtime_1.jsx)(index_js_1.Portal, { children: (0, jsx_runtime_1.jsx)("div", { className: (0, cn_js_1.cn)('tokis-hover-card', `tokis-hover-card--${placement}`, className), style: {
|
|
99
|
+
position: 'fixed',
|
|
100
|
+
top: pos.top,
|
|
101
|
+
left: pos.left,
|
|
102
|
+
transform: transformMap[placement],
|
|
103
|
+
opacity: positioned ? undefined : 0,
|
|
104
|
+
pointerEvents: positioned ? undefined : 'none',
|
|
105
|
+
}, onMouseEnter: () => clearTimeout(closeTimer.current), onMouseLeave: hide, children: content }) }))] }));
|
|
106
|
+
}
|
|
107
|
+
HoverCard.displayName = 'HoverCard';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InfiniteScroll = InfiniteScroll;
|
|
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 InfiniteScroll({ children, hasMore, loading, onLoadMore, loadingComponent, endMessage, threshold = 0.1, className, }) {
|
|
8
|
+
const sentinelRef = (0, react_1.useRef)(null);
|
|
9
|
+
(0, react_1.useEffect)(() => {
|
|
10
|
+
if (!sentinelRef.current)
|
|
11
|
+
return;
|
|
12
|
+
const observer = new IntersectionObserver(([entry]) => {
|
|
13
|
+
if (entry.isIntersecting && hasMore && !loading)
|
|
14
|
+
onLoadMore();
|
|
15
|
+
}, { threshold });
|
|
16
|
+
observer.observe(sentinelRef.current);
|
|
17
|
+
return () => observer.disconnect();
|
|
18
|
+
}, [hasMore, loading, onLoadMore, threshold]);
|
|
19
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-infinite-scroll', className), children: [children, loading && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-infinite-scroll__loading", children: loadingComponent ?? (0, jsx_runtime_1.jsx)("span", { className: "tokis-infinite-scroll__spinner", "aria-label": "Loading more\u2026" }) })), !hasMore && !loading && endMessage && ((0, jsx_runtime_1.jsx)("div", { className: "tokis-infinite-scroll__end", children: endMessage })), (0, jsx_runtime_1.jsx)("div", { ref: sentinelRef, className: "tokis-infinite-scroll__sentinel", "aria-hidden": "true" })] }));
|
|
20
|
+
}
|
|
21
|
+
InfiniteScroll.displayName = 'InfiniteScroll';
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Textarea = exports.TextField = 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
|
+
// ─── TextField ────────────────────────────────────────────
|
|
8
|
+
const EyeShowIcon = () => ((0, jsx_runtime_1.jsxs)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: [(0, jsx_runtime_1.jsx)("path", { d: "M1 7s2-4 6-4 6 4 6 4-2 4-6 4-6-4-6-4z", stroke: "currentColor", strokeWidth: "1.3" }), (0, jsx_runtime_1.jsx)("circle", { cx: "7", cy: "7", r: "1.5", stroke: "currentColor", strokeWidth: "1.3" })] }));
|
|
9
|
+
const EyeHideIcon = () => ((0, jsx_runtime_1.jsxs)("svg", { width: "14", height: "14", viewBox: "0 0 14 14", fill: "none", "aria-hidden": "true", children: [(0, jsx_runtime_1.jsx)("path", { d: "M1 7s2-4 6-4 6 4 6 4-2 4-6 4-6-4-6-4z", stroke: "currentColor", strokeWidth: "1.3" }), (0, jsx_runtime_1.jsx)("circle", { cx: "7", cy: "7", r: "1.5", stroke: "currentColor", strokeWidth: "1.3" }), (0, jsx_runtime_1.jsx)("path", { d: "M2 2l10 10", stroke: "currentColor", strokeWidth: "1.3", strokeLinecap: "round" })] }));
|
|
10
|
+
exports.TextField = (0, react_1.forwardRef)(({ label, helperText, error = false, startAdornment, endAdornment, inputSize = 'md', required, id, className, disabled, type, ...props }, ref) => {
|
|
11
|
+
const autoId = (0, react_1.useId)();
|
|
12
|
+
const inputId = id ?? `field-${autoId}`;
|
|
13
|
+
const helperId = helperText ? `${inputId}-helper` : undefined;
|
|
14
|
+
const isPassword = type === 'password';
|
|
15
|
+
const [showPassword, setShowPassword] = (0, react_1.useState)(false);
|
|
16
|
+
const resolvedType = isPassword ? (showPassword ? 'text' : 'password') : type;
|
|
17
|
+
const passwordToggle = isPassword && !endAdornment ? ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "tokis-input-password-toggle", onClick: () => setShowPassword((v) => !v), "aria-label": showPassword ? 'Hide password' : 'Show password', tabIndex: -1, children: showPassword ? (0, jsx_runtime_1.jsx)(EyeHideIcon, {}) : (0, jsx_runtime_1.jsx)(EyeShowIcon, {}) })) : null;
|
|
18
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-field', className), children: [label && ((0, jsx_runtime_1.jsx)("label", { htmlFor: inputId, className: (0, cn_js_1.cn)('tokis-label', required && 'tokis-label--required'), children: label })), (0, jsx_runtime_1.jsxs)("div", { className: "tokis-input-wrapper", children: [startAdornment && ((0, jsx_runtime_1.jsx)("span", { className: "tokis-input-adornment tokis-input-adornment--start", children: startAdornment })), (0, jsx_runtime_1.jsx)("input", { ref: ref, id: inputId, disabled: disabled, required: required, type: resolvedType, "aria-invalid": error || undefined, "aria-describedby": helperId, className: (0, cn_js_1.cn)('tokis-input', inputSize !== 'md' && `tokis-input--${inputSize}`, !!startAdornment && 'tokis-input--with-start', !!(endAdornment || passwordToggle) && 'tokis-input--with-end'), ...props }), passwordToggle, endAdornment && ((0, jsx_runtime_1.jsx)("span", { className: "tokis-input-adornment tokis-input-adornment--end", children: endAdornment }))] }), helperText && ((0, jsx_runtime_1.jsx)("span", { id: helperId, className: (0, cn_js_1.cn)('tokis-helper-text', error && 'tokis-helper-text--error'), children: helperText }))] }));
|
|
19
|
+
});
|
|
20
|
+
exports.TextField.displayName = 'TextField';
|
|
21
|
+
exports.Textarea = (0, react_1.forwardRef)(({ label, helperText, error = false, required, id, className, ...props }, ref) => {
|
|
22
|
+
const autoId = (0, react_1.useId)();
|
|
23
|
+
const textareaId = id ?? `textarea-${autoId}`;
|
|
24
|
+
const helperId = helperText ? `${textareaId}-helper` : undefined;
|
|
25
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, cn_js_1.cn)('tokis-field', className), children: [label && ((0, jsx_runtime_1.jsx)("label", { htmlFor: textareaId, className: (0, cn_js_1.cn)('tokis-label', required && 'tokis-label--required'), children: label })), (0, jsx_runtime_1.jsx)("textarea", { ref: ref, id: textareaId, required: required, "aria-invalid": error || undefined, "aria-describedby": helperId, className: "tokis-textarea", ...props }), helperText && ((0, jsx_runtime_1.jsx)("span", { id: helperId, className: (0, cn_js_1.cn)('tokis-helper-text', error && 'tokis-helper-text--error'), children: helperText }))] }));
|
|
26
|
+
});
|
|
27
|
+
exports.Textarea.displayName = 'Textarea';
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Box = exports.Container = exports.Grid = exports.Stack = 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 gapVar = (g) => `var(--tokis-spacing-${g})`;
|
|
8
|
+
exports.Stack = (0, react_1.forwardRef)(({ direction = 'column', gap = 4, align, justify, wrap = false, as: Component = 'div', className, style, children, ...props }, ref) => ((0, jsx_runtime_1.jsx)(Component, { ref: ref, className: (0, cn_js_1.cn)('tokis-stack', direction === 'column' ? 'tokis-stack--v' : 'tokis-stack--h', wrap && 'tokis-stack--wrap', className), style: { gap: gapVar(gap), alignItems: align, justifyContent: justify, ...style }, ...props, children: children })));
|
|
9
|
+
exports.Stack.displayName = 'Stack';
|
|
10
|
+
exports.Grid = (0, react_1.forwardRef)(({ columns = 1, gap = 4, rowGap, columnGap, as: Component = 'div', className, style, children, ...props }, ref) => ((0, jsx_runtime_1.jsx)(Component, { ref: ref, className: (0, cn_js_1.cn)('tokis-grid', className), style: {
|
|
11
|
+
gridTemplateColumns: (typeof columns === 'number') ? `repeat(${columns}, minmax(0, 1fr))` : columns,
|
|
12
|
+
gap: gapVar(gap),
|
|
13
|
+
rowGap: rowGap !== undefined ? gapVar(rowGap) : undefined,
|
|
14
|
+
columnGap: columnGap !== undefined ? gapVar(columnGap) : undefined,
|
|
15
|
+
...style,
|
|
16
|
+
}, ...props, children: children })));
|
|
17
|
+
exports.Grid.displayName = 'Grid';
|
|
18
|
+
exports.Container = (0, react_1.forwardRef)(({ fluid = false, as: Component = 'div', className, ...props }, ref) => ((0, jsx_runtime_1.jsx)(Component, { ref: ref, className: (0, cn_js_1.cn)('tokis-container', fluid && 'tokis-container--fluid', className), ...props })));
|
|
19
|
+
exports.Container.displayName = 'Container';
|
|
20
|
+
exports.Box = (0, react_1.forwardRef)(({ as: Component = 'div', display, flex, gap, p, px, py, m, width, height, className, style, ...props }, ref) => ((0, jsx_runtime_1.jsx)(Component, { ref: ref, className: (0, cn_js_1.cn)('tokis-box', className), style: {
|
|
21
|
+
display,
|
|
22
|
+
flex,
|
|
23
|
+
gap: gap !== undefined ? gapVar(gap) : undefined,
|
|
24
|
+
padding: p !== undefined ? gapVar(p) : undefined,
|
|
25
|
+
paddingLeft: px !== undefined ? gapVar(px) : undefined,
|
|
26
|
+
paddingRight: px !== undefined ? gapVar(px) : undefined,
|
|
27
|
+
paddingTop: py !== undefined ? gapVar(py) : undefined,
|
|
28
|
+
paddingBottom: py !== undefined ? gapVar(py) : undefined,
|
|
29
|
+
margin: m !== undefined ? gapVar(m) : undefined,
|
|
30
|
+
width,
|
|
31
|
+
height,
|
|
32
|
+
...style,
|
|
33
|
+
}, ...props })));
|
|
34
|
+
exports.Box.displayName = 'Box';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Breadcrumbs = exports.Link = void 0;
|
|
4
|
+
// Re-export Link, Breadcrumbs from breadcrumbs (Pagination moved to pagination/)
|
|
5
|
+
var index_js_1 = require("../breadcrumbs/index");
|
|
6
|
+
Object.defineProperty(exports, "Link", { enumerable: true, get: function () { return index_js_1.Link; } });
|
|
7
|
+
Object.defineProperty(exports, "Breadcrumbs", { enumerable: true, get: function () { return index_js_1.Breadcrumbs; } });
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ListItem = exports.List = 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
|
+
// ─── List ────────────────────────────────────────────────
|
|
8
|
+
exports.List = (0, react_1.forwardRef)(({ className, role = 'list', ...props }, ref) => ((0, jsx_runtime_1.jsx)("div", { ref: ref, role: role, className: (0, cn_js_1.cn)('tokis-list', className), ...props })));
|
|
9
|
+
exports.List.displayName = 'List';
|
|
10
|
+
exports.ListItem = (0, react_1.forwardRef)(({ selected = false, disabled = false, icon, endContent, primary, secondary, clickable = false, className, children, onClick, ...props }, ref) => ((0, jsx_runtime_1.jsxs)("div", { ref: ref, role: clickable ? 'listitem' : 'listitem', tabIndex: clickable && !disabled ? 0 : undefined, "aria-selected": selected || undefined, "aria-disabled": disabled || undefined, className: (0, cn_js_1.cn)('tokis-list-item', (clickable || onClick) && 'tokis-list-item--clickable', selected && 'tokis-list-item--selected', className), onClick: !disabled ? onClick : undefined, onKeyDown: !disabled && onClick ? (e) => { if (e.key === 'Enter' || e.key === ' ') {
|
|
11
|
+
e.preventDefault();
|
|
12
|
+
onClick(e);
|
|
13
|
+
} } : undefined, ...props, children: [icon && (0, jsx_runtime_1.jsx)("span", { className: "tokis-list-item__icon", "aria-hidden": "true", children: icon }), (primary || secondary) ? ((0, jsx_runtime_1.jsxs)("div", { className: "tokis-list-item__content", children: [primary && (0, jsx_runtime_1.jsx)("div", { className: "tokis-list-item__primary", children: primary }), secondary && (0, jsx_runtime_1.jsx)("div", { className: "tokis-list-item__secondary", children: secondary })] })) : children, endContent && (0, jsx_runtime_1.jsx)("span", { className: "tokis-list-item__end", children: endContent })] })));
|
|
14
|
+
exports.ListItem.displayName = 'ListItem';
|