@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.
Files changed (354) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +50 -0
  3. package/dist/cjs/components/accordion/index.js +36 -0
  4. package/dist/cjs/components/alert/index.js +14 -0
  5. package/dist/cjs/components/app-bar/index.js +9 -0
  6. package/dist/cjs/components/avatar/index.js +64 -0
  7. package/dist/cjs/components/badge/index.js +6 -0
  8. package/dist/cjs/components/bottom-nav/index.js +12 -0
  9. package/dist/cjs/components/breadcrumbs/index.js +19 -0
  10. package/dist/cjs/components/button/ButtonIcon.js +9 -0
  11. package/dist/cjs/components/button/ButtonLabel.js +9 -0
  12. package/dist/cjs/components/button/ButtonRoot.js +23 -0
  13. package/dist/cjs/components/button/index.js +11 -0
  14. package/dist/cjs/components/button/useButton.js +14 -0
  15. package/dist/cjs/components/card/index.js +25 -0
  16. package/dist/cjs/components/charts/index.js +214 -0
  17. package/dist/cjs/components/checkbox/index.js +18 -0
  18. package/dist/cjs/components/chip/index.js +6 -0
  19. package/dist/cjs/components/circular-progress/index.js +28 -0
  20. package/dist/cjs/components/codeblock/CodeBlock.js +35 -0
  21. package/dist/cjs/components/codeblock/index.js +5 -0
  22. package/dist/cjs/components/command-palette/index.js +84 -0
  23. package/dist/cjs/components/confirm-dialog/index.js +10 -0
  24. package/dist/cjs/components/context-menu/index.js +82 -0
  25. package/dist/cjs/components/dialog/index.js +43 -0
  26. package/dist/cjs/components/divider/index.js +6 -0
  27. package/dist/cjs/components/drawer/index.js +37 -0
  28. package/dist/cjs/components/dropdown/index.js +104 -0
  29. package/dist/cjs/components/emptystate/index.js +9 -0
  30. package/dist/cjs/components/extended/index.js +329 -0
  31. package/dist/cjs/components/hover-card/index.js +107 -0
  32. package/dist/cjs/components/infinite-scroll/index.js +21 -0
  33. package/dist/cjs/components/input/index.js +27 -0
  34. package/dist/cjs/components/layout/index.js +34 -0
  35. package/dist/cjs/components/link/index.js +7 -0
  36. package/dist/cjs/components/list/index.js +14 -0
  37. package/dist/cjs/components/menu/index.js +120 -0
  38. package/dist/cjs/components/nav-rail/index.js +12 -0
  39. package/dist/cjs/components/pagination/index.js +46 -0
  40. package/dist/cjs/components/popover/index.js +114 -0
  41. package/dist/cjs/components/portal/index.js +10 -0
  42. package/dist/cjs/components/progress/index.js +21 -0
  43. package/dist/cjs/components/radio/index.js +60 -0
  44. package/dist/cjs/components/result/index.js +25 -0
  45. package/dist/cjs/components/search-field/index.js +30 -0
  46. package/dist/cjs/components/select/index.js +88 -0
  47. package/dist/cjs/components/skeleton/index.js +6 -0
  48. package/dist/cjs/components/slider/index.js +73 -0
  49. package/dist/cjs/components/snackbar/index.js +41 -0
  50. package/dist/cjs/components/spinner/index.js +6 -0
  51. package/dist/cjs/components/statistic/index.js +17 -0
  52. package/dist/cjs/components/stepper/index.js +24 -0
  53. package/dist/cjs/components/switch/index.js +19 -0
  54. package/dist/cjs/components/table/index.js +26 -0
  55. package/dist/cjs/components/tabs/index.js +44 -0
  56. package/dist/cjs/components/tag/index.js +6 -0
  57. package/dist/cjs/components/timeline/index.js +12 -0
  58. package/dist/cjs/components/toggle/index.js +32 -0
  59. package/dist/cjs/components/tooltip/index.js +116 -0
  60. package/dist/cjs/components/treeview/index.js +89 -0
  61. package/dist/cjs/components/typography/index.js +20 -0
  62. package/dist/cjs/components/virtual-list/index.js +25 -0
  63. package/dist/cjs/context/ConfigProvider.js +22 -0
  64. package/dist/cjs/context/ThemeContext.js +25 -0
  65. package/dist/cjs/hooks/useControllableState.js +31 -0
  66. package/dist/cjs/hooks/useDialog.js +35 -0
  67. package/dist/cjs/hooks/useId.js +13 -0
  68. package/dist/cjs/hooks/useMenu.js +64 -0
  69. package/dist/cjs/hooks/usePopover.js +32 -0
  70. package/dist/cjs/hooks/useTabs.js +51 -0
  71. package/dist/cjs/index.js +102 -0
  72. package/dist/cjs/package.json +3 -0
  73. package/dist/cjs/utils/cn.js +10 -0
  74. package/dist/components/accordion/index.d.ts +19 -0
  75. package/dist/components/accordion/index.d.ts.map +1 -0
  76. package/dist/components/accordion/index.js +34 -0
  77. package/dist/components/accordion/index.js.map +1 -0
  78. package/dist/components/alert/index.d.ts +11 -0
  79. package/dist/components/alert/index.d.ts.map +1 -0
  80. package/dist/components/alert/index.js +12 -0
  81. package/dist/components/alert/index.js.map +1 -0
  82. package/dist/components/app-bar/index.d.ts +17 -0
  83. package/dist/components/app-bar/index.d.ts.map +1 -0
  84. package/dist/components/app-bar/index.js +7 -0
  85. package/dist/components/app-bar/index.js.map +1 -0
  86. package/dist/components/avatar/index.d.ts +33 -0
  87. package/dist/components/avatar/index.d.ts.map +1 -0
  88. package/dist/components/avatar/index.js +28 -0
  89. package/dist/components/avatar/index.js.map +1 -0
  90. package/dist/components/badge/index.d.ts +3 -0
  91. package/dist/components/badge/index.d.ts.map +1 -0
  92. package/dist/components/badge/index.js +3 -0
  93. package/dist/components/badge/index.js.map +1 -0
  94. package/dist/components/bottom-nav/index.d.ts +18 -0
  95. package/dist/components/bottom-nav/index.d.ts.map +1 -0
  96. package/dist/components/bottom-nav/index.js +10 -0
  97. package/dist/components/bottom-nav/index.js.map +1 -0
  98. package/dist/components/breadcrumbs/index.d.ts +19 -0
  99. package/dist/components/breadcrumbs/index.d.ts.map +1 -0
  100. package/dist/components/breadcrumbs/index.js +17 -0
  101. package/dist/components/breadcrumbs/index.js.map +1 -0
  102. package/dist/components/button/ButtonIcon.d.ts +8 -0
  103. package/dist/components/button/ButtonIcon.d.ts.map +1 -0
  104. package/dist/components/button/ButtonIcon.js +6 -0
  105. package/dist/components/button/ButtonIcon.js.map +1 -0
  106. package/dist/components/button/ButtonLabel.d.ts +6 -0
  107. package/dist/components/button/ButtonLabel.d.ts.map +1 -0
  108. package/dist/components/button/ButtonLabel.js +6 -0
  109. package/dist/components/button/ButtonLabel.js.map +1 -0
  110. package/dist/components/button/ButtonRoot.d.ts +15 -0
  111. package/dist/components/button/ButtonRoot.d.ts.map +1 -0
  112. package/dist/components/button/ButtonRoot.js +21 -0
  113. package/dist/components/button/ButtonRoot.js.map +1 -0
  114. package/dist/components/button/index.d.ts +9 -0
  115. package/dist/components/button/index.d.ts.map +1 -0
  116. package/dist/components/button/index.js +5 -0
  117. package/dist/components/button/index.js.map +1 -0
  118. package/dist/components/button/useButton.d.ts +16 -0
  119. package/dist/components/button/useButton.d.ts.map +1 -0
  120. package/dist/components/button/useButton.js +12 -0
  121. package/dist/components/button/useButton.js.map +1 -0
  122. package/dist/components/card/index.d.ts +17 -0
  123. package/dist/components/card/index.d.ts.map +1 -0
  124. package/dist/components/card/index.js +23 -0
  125. package/dist/components/card/index.js.map +1 -0
  126. package/dist/components/charts/index.d.ts +60 -0
  127. package/dist/components/charts/index.d.ts.map +1 -0
  128. package/dist/components/charts/index.js +209 -0
  129. package/dist/components/charts/index.js.map +1 -0
  130. package/dist/components/checkbox/index.d.ts +17 -0
  131. package/dist/components/checkbox/index.d.ts.map +1 -0
  132. package/dist/components/checkbox/index.js +16 -0
  133. package/dist/components/checkbox/index.js.map +1 -0
  134. package/dist/components/chip/index.d.ts +3 -0
  135. package/dist/components/chip/index.d.ts.map +1 -0
  136. package/dist/components/chip/index.js +3 -0
  137. package/dist/components/chip/index.js.map +1 -0
  138. package/dist/components/circular-progress/index.d.ts +15 -0
  139. package/dist/components/circular-progress/index.d.ts.map +1 -0
  140. package/dist/components/circular-progress/index.js +26 -0
  141. package/dist/components/circular-progress/index.js.map +1 -0
  142. package/dist/components/codeblock/CodeBlock.d.ts +13 -0
  143. package/dist/components/codeblock/CodeBlock.d.ts.map +1 -0
  144. package/dist/components/codeblock/CodeBlock.js +32 -0
  145. package/dist/components/codeblock/CodeBlock.js.map +1 -0
  146. package/dist/components/codeblock/index.d.ts +3 -0
  147. package/dist/components/codeblock/index.d.ts.map +1 -0
  148. package/dist/components/codeblock/index.js +2 -0
  149. package/dist/components/codeblock/index.js.map +1 -0
  150. package/dist/components/command-palette/index.d.ts +22 -0
  151. package/dist/components/command-palette/index.d.ts.map +1 -0
  152. package/dist/components/command-palette/index.js +82 -0
  153. package/dist/components/command-palette/index.js.map +1 -0
  154. package/dist/components/confirm-dialog/index.d.ts +17 -0
  155. package/dist/components/confirm-dialog/index.d.ts.map +1 -0
  156. package/dist/components/confirm-dialog/index.js +8 -0
  157. package/dist/components/confirm-dialog/index.js.map +1 -0
  158. package/dist/components/context-menu/index.d.ts +19 -0
  159. package/dist/components/context-menu/index.d.ts.map +1 -0
  160. package/dist/components/context-menu/index.js +47 -0
  161. package/dist/components/context-menu/index.js.map +1 -0
  162. package/dist/components/dialog/index.d.ts +16 -0
  163. package/dist/components/dialog/index.d.ts.map +1 -0
  164. package/dist/components/dialog/index.js +41 -0
  165. package/dist/components/dialog/index.js.map +1 -0
  166. package/dist/components/divider/index.d.ts +3 -0
  167. package/dist/components/divider/index.d.ts.map +1 -0
  168. package/dist/components/divider/index.js +3 -0
  169. package/dist/components/divider/index.js.map +1 -0
  170. package/dist/components/drawer/index.d.ts +16 -0
  171. package/dist/components/drawer/index.d.ts.map +1 -0
  172. package/dist/components/drawer/index.js +35 -0
  173. package/dist/components/drawer/index.js.map +1 -0
  174. package/dist/components/dropdown/index.d.ts +16 -0
  175. package/dist/components/dropdown/index.d.ts.map +1 -0
  176. package/dist/components/dropdown/index.js +69 -0
  177. package/dist/components/dropdown/index.js.map +1 -0
  178. package/dist/components/emptystate/index.d.ts +13 -0
  179. package/dist/components/emptystate/index.d.ts.map +1 -0
  180. package/dist/components/emptystate/index.js +7 -0
  181. package/dist/components/emptystate/index.js.map +1 -0
  182. package/dist/components/extended/index.d.ts +163 -0
  183. package/dist/components/extended/index.d.ts.map +1 -0
  184. package/dist/components/extended/index.js +267 -0
  185. package/dist/components/extended/index.js.map +1 -0
  186. package/dist/components/hover-card/index.d.ts +14 -0
  187. package/dist/components/hover-card/index.d.ts.map +1 -0
  188. package/dist/components/hover-card/index.js +72 -0
  189. package/dist/components/hover-card/index.js.map +1 -0
  190. package/dist/components/infinite-scroll/index.d.ts +16 -0
  191. package/dist/components/infinite-scroll/index.d.ts.map +1 -0
  192. package/dist/components/infinite-scroll/index.js +19 -0
  193. package/dist/components/infinite-scroll/index.js.map +1 -0
  194. package/dist/components/input/index.d.ts +19 -0
  195. package/dist/components/input/index.d.ts.map +1 -0
  196. package/dist/components/input/index.js +25 -0
  197. package/dist/components/input/index.js.map +1 -0
  198. package/dist/components/layout/index.d.ts +39 -0
  199. package/dist/components/layout/index.d.ts.map +1 -0
  200. package/dist/components/layout/index.js +32 -0
  201. package/dist/components/layout/index.js.map +1 -0
  202. package/dist/components/link/index.d.ts +3 -0
  203. package/dist/components/link/index.d.ts.map +1 -0
  204. package/dist/components/link/index.js +3 -0
  205. package/dist/components/link/index.js.map +1 -0
  206. package/dist/components/list/index.d.ts +13 -0
  207. package/dist/components/list/index.d.ts.map +1 -0
  208. package/dist/components/list/index.js +12 -0
  209. package/dist/components/list/index.js.map +1 -0
  210. package/dist/components/menu/index.d.ts +19 -0
  211. package/dist/components/menu/index.d.ts.map +1 -0
  212. package/dist/components/menu/index.js +85 -0
  213. package/dist/components/menu/index.js.map +1 -0
  214. package/dist/components/nav-rail/index.d.ts +20 -0
  215. package/dist/components/nav-rail/index.d.ts.map +1 -0
  216. package/dist/components/nav-rail/index.js +10 -0
  217. package/dist/components/nav-rail/index.js.map +1 -0
  218. package/dist/components/pagination/index.d.ts +9 -0
  219. package/dist/components/pagination/index.d.ts.map +1 -0
  220. package/dist/components/pagination/index.js +44 -0
  221. package/dist/components/pagination/index.js.map +1 -0
  222. package/dist/components/popover/index.d.ts +16 -0
  223. package/dist/components/popover/index.d.ts.map +1 -0
  224. package/dist/components/popover/index.js +79 -0
  225. package/dist/components/popover/index.js.map +1 -0
  226. package/dist/components/portal/index.d.ts +7 -0
  227. package/dist/components/portal/index.d.ts.map +1 -0
  228. package/dist/components/portal/index.js +8 -0
  229. package/dist/components/portal/index.js.map +1 -0
  230. package/dist/components/progress/index.d.ts +25 -0
  231. package/dist/components/progress/index.d.ts.map +1 -0
  232. package/dist/components/progress/index.js +19 -0
  233. package/dist/components/progress/index.js.map +1 -0
  234. package/dist/components/radio/index.d.ts +25 -0
  235. package/dist/components/radio/index.d.ts.map +1 -0
  236. package/dist/components/radio/index.js +24 -0
  237. package/dist/components/radio/index.js.map +1 -0
  238. package/dist/components/result/index.d.ts +14 -0
  239. package/dist/components/result/index.d.ts.map +1 -0
  240. package/dist/components/result/index.js +23 -0
  241. package/dist/components/result/index.js.map +1 -0
  242. package/dist/components/search-field/index.d.ts +15 -0
  243. package/dist/components/search-field/index.d.ts.map +1 -0
  244. package/dist/components/search-field/index.js +28 -0
  245. package/dist/components/search-field/index.js.map +1 -0
  246. package/dist/components/select/index.d.ts +23 -0
  247. package/dist/components/select/index.d.ts.map +1 -0
  248. package/dist/components/select/index.js +86 -0
  249. package/dist/components/select/index.js.map +1 -0
  250. package/dist/components/skeleton/index.d.ts +3 -0
  251. package/dist/components/skeleton/index.d.ts.map +1 -0
  252. package/dist/components/skeleton/index.js +3 -0
  253. package/dist/components/skeleton/index.js.map +1 -0
  254. package/dist/components/slider/index.d.ts +18 -0
  255. package/dist/components/slider/index.d.ts.map +1 -0
  256. package/dist/components/slider/index.js +71 -0
  257. package/dist/components/slider/index.js.map +1 -0
  258. package/dist/components/snackbar/index.d.ts +27 -0
  259. package/dist/components/snackbar/index.d.ts.map +1 -0
  260. package/dist/components/snackbar/index.js +38 -0
  261. package/dist/components/snackbar/index.js.map +1 -0
  262. package/dist/components/spinner/index.d.ts +3 -0
  263. package/dist/components/spinner/index.d.ts.map +1 -0
  264. package/dist/components/spinner/index.js +3 -0
  265. package/dist/components/spinner/index.js.map +1 -0
  266. package/dist/components/statistic/index.d.ts +13 -0
  267. package/dist/components/statistic/index.d.ts.map +1 -0
  268. package/dist/components/statistic/index.js +15 -0
  269. package/dist/components/statistic/index.js.map +1 -0
  270. package/dist/components/stepper/index.d.ts +17 -0
  271. package/dist/components/stepper/index.d.ts.map +1 -0
  272. package/dist/components/stepper/index.js +22 -0
  273. package/dist/components/stepper/index.js.map +1 -0
  274. package/dist/components/switch/index.d.ts +16 -0
  275. package/dist/components/switch/index.d.ts.map +1 -0
  276. package/dist/components/switch/index.js +17 -0
  277. package/dist/components/switch/index.js.map +1 -0
  278. package/dist/components/table/index.d.ts +17 -0
  279. package/dist/components/table/index.d.ts.map +1 -0
  280. package/dist/components/table/index.js +24 -0
  281. package/dist/components/table/index.js.map +1 -0
  282. package/dist/components/tabs/index.d.ts +19 -0
  283. package/dist/components/tabs/index.d.ts.map +1 -0
  284. package/dist/components/tabs/index.js +42 -0
  285. package/dist/components/tabs/index.js.map +1 -0
  286. package/dist/components/tag/index.d.ts +3 -0
  287. package/dist/components/tag/index.d.ts.map +1 -0
  288. package/dist/components/tag/index.js +3 -0
  289. package/dist/components/tag/index.js.map +1 -0
  290. package/dist/components/timeline/index.d.ts +16 -0
  291. package/dist/components/timeline/index.d.ts.map +1 -0
  292. package/dist/components/timeline/index.js +10 -0
  293. package/dist/components/timeline/index.js.map +1 -0
  294. package/dist/components/toggle/index.d.ts +32 -0
  295. package/dist/components/toggle/index.d.ts.map +1 -0
  296. package/dist/components/toggle/index.js +29 -0
  297. package/dist/components/toggle/index.js.map +1 -0
  298. package/dist/components/tooltip/index.d.ts +11 -0
  299. package/dist/components/tooltip/index.d.ts.map +1 -0
  300. package/dist/components/tooltip/index.js +81 -0
  301. package/dist/components/tooltip/index.js.map +1 -0
  302. package/dist/components/treeview/index.d.ts +19 -0
  303. package/dist/components/treeview/index.d.ts.map +1 -0
  304. package/dist/components/treeview/index.js +87 -0
  305. package/dist/components/treeview/index.js.map +1 -0
  306. package/dist/components/typography/index.d.ts +11 -0
  307. package/dist/components/typography/index.d.ts.map +1 -0
  308. package/dist/components/typography/index.js +18 -0
  309. package/dist/components/typography/index.js.map +1 -0
  310. package/dist/components/virtual-list/index.d.ts +15 -0
  311. package/dist/components/virtual-list/index.d.ts.map +1 -0
  312. package/dist/components/virtual-list/index.js +23 -0
  313. package/dist/components/virtual-list/index.js.map +1 -0
  314. package/dist/context/ConfigProvider.d.ts +12 -0
  315. package/dist/context/ConfigProvider.d.ts.map +1 -0
  316. package/dist/context/ConfigProvider.js +18 -0
  317. package/dist/context/ConfigProvider.js.map +1 -0
  318. package/dist/context/ThemeContext.d.ts +15 -0
  319. package/dist/context/ThemeContext.d.ts.map +1 -0
  320. package/dist/context/ThemeContext.js +21 -0
  321. package/dist/context/ThemeContext.js.map +1 -0
  322. package/dist/hooks/useControllableState.d.ts +10 -0
  323. package/dist/hooks/useControllableState.d.ts.map +1 -0
  324. package/dist/hooks/useControllableState.js +29 -0
  325. package/dist/hooks/useControllableState.js.map +1 -0
  326. package/dist/hooks/useDialog.d.ts +24 -0
  327. package/dist/hooks/useDialog.d.ts.map +1 -0
  328. package/dist/hooks/useDialog.js +33 -0
  329. package/dist/hooks/useDialog.js.map +1 -0
  330. package/dist/hooks/useId.d.ts +7 -0
  331. package/dist/hooks/useId.d.ts.map +1 -0
  332. package/dist/hooks/useId.js +11 -0
  333. package/dist/hooks/useId.js.map +1 -0
  334. package/dist/hooks/useMenu.d.ts +21 -0
  335. package/dist/hooks/useMenu.d.ts.map +1 -0
  336. package/dist/hooks/useMenu.js +62 -0
  337. package/dist/hooks/useMenu.js.map +1 -0
  338. package/dist/hooks/usePopover.d.ts +22 -0
  339. package/dist/hooks/usePopover.d.ts.map +1 -0
  340. package/dist/hooks/usePopover.js +30 -0
  341. package/dist/hooks/usePopover.js.map +1 -0
  342. package/dist/hooks/useTabs.d.ts +22 -0
  343. package/dist/hooks/useTabs.d.ts.map +1 -0
  344. package/dist/hooks/useTabs.js +49 -0
  345. package/dist/hooks/useTabs.js.map +1 -0
  346. package/dist/index.d.ts +65 -0
  347. package/dist/index.d.ts.map +1 -0
  348. package/dist/index.js +85 -0
  349. package/dist/index.js.map +1 -0
  350. package/dist/utils/cn.d.ts +6 -0
  351. package/dist/utils/cn.d.ts.map +1 -0
  352. package/dist/utils/cn.js +8 -0
  353. package/dist/utils/cn.js.map +1 -0
  354. 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
+ }