@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,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';