@k3-universe/react-kit 0.0.1

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 (703) hide show
  1. package/.babelrc +12 -0
  2. package/.storybook/main.ts +22 -0
  3. package/.storybook/preview.ts +190 -0
  4. package/Dockerfile.storybook +43 -0
  5. package/README.md +7 -0
  6. package/components.json +20 -0
  7. package/dist/index.d.ts +1 -0
  8. package/dist/index.d.ts.map +1 -0
  9. package/dist/index.js +1 -0
  10. package/dist/kit/builder/data-table/components/DataTable.d.ts +34 -0
  11. package/dist/kit/builder/data-table/components/DataTable.d.ts.map +1 -0
  12. package/dist/kit/builder/data-table/components/DataTableColumnHeader.d.ts +8 -0
  13. package/dist/kit/builder/data-table/components/DataTableColumnHeader.d.ts.map +1 -0
  14. package/dist/kit/builder/data-table/components/DataTablePagination.d.ts +6 -0
  15. package/dist/kit/builder/data-table/components/DataTablePagination.d.ts.map +1 -0
  16. package/dist/kit/builder/data-table/components/DataTableViewOptions.d.ts +5 -0
  17. package/dist/kit/builder/data-table/components/DataTableViewOptions.d.ts.map +1 -0
  18. package/dist/kit/builder/data-table/index.d.ts +6 -0
  19. package/dist/kit/builder/data-table/index.d.ts.map +1 -0
  20. package/dist/kit/builder/data-table/types.d.ts +27 -0
  21. package/dist/kit/builder/data-table/types.d.ts.map +1 -0
  22. package/dist/kit/builder/data-table/utils/dotAccessor.d.ts +2 -0
  23. package/dist/kit/builder/data-table/utils/dotAccessor.d.ts.map +1 -0
  24. package/dist/kit/builder/dialog/index.d.ts +3 -0
  25. package/dist/kit/builder/dialog/index.d.ts.map +1 -0
  26. package/dist/kit/builder/dialog/provider.d.ts +26 -0
  27. package/dist/kit/builder/dialog/provider.d.ts.map +1 -0
  28. package/dist/kit/builder/form/components/FormActions.d.ts +20 -0
  29. package/dist/kit/builder/form/components/FormActions.d.ts.map +1 -0
  30. package/dist/kit/builder/form/components/FormBuilder.d.ts +97 -0
  31. package/dist/kit/builder/form/components/FormBuilder.d.ts.map +1 -0
  32. package/dist/kit/builder/form/components/FormField.d.ts +12 -0
  33. package/dist/kit/builder/form/components/FormField.d.ts.map +1 -0
  34. package/dist/kit/builder/form/components/FormSection.d.ts +15 -0
  35. package/dist/kit/builder/form/components/FormSection.d.ts.map +1 -0
  36. package/dist/kit/builder/form/components/index.d.ts +5 -0
  37. package/dist/kit/builder/form/components/index.d.ts.map +1 -0
  38. package/dist/kit/builder/form/index.d.ts +3 -0
  39. package/dist/kit/builder/form/index.d.ts.map +1 -0
  40. package/dist/kit/builder/form/utils/common-forms.d.ts +7 -0
  41. package/dist/kit/builder/form/utils/common-forms.d.ts.map +1 -0
  42. package/dist/kit/builder/form/utils/dependencies.d.ts +41 -0
  43. package/dist/kit/builder/form/utils/dependencies.d.ts.map +1 -0
  44. package/dist/kit/builder/form/utils/field-factories.d.ts +22 -0
  45. package/dist/kit/builder/form/utils/field-factories.d.ts.map +1 -0
  46. package/dist/kit/builder/form/utils/index.d.ts +15 -0
  47. package/dist/kit/builder/form/utils/index.d.ts.map +1 -0
  48. package/dist/kit/builder/form/utils/section-factories.d.ts +7 -0
  49. package/dist/kit/builder/form/utils/section-factories.d.ts.map +1 -0
  50. package/dist/kit/builder/form/utils/transformers.d.ts +6 -0
  51. package/dist/kit/builder/form/utils/transformers.d.ts.map +1 -0
  52. package/dist/kit/builder/form/utils/validations.d.ts +13 -0
  53. package/dist/kit/builder/form/utils/validations.d.ts.map +1 -0
  54. package/dist/kit/builder/form/utils/validators.d.ts +8 -0
  55. package/dist/kit/builder/form/utils/validators.d.ts.map +1 -0
  56. package/dist/kit/builder/page/Page.d.ts +48 -0
  57. package/dist/kit/builder/page/Page.d.ts.map +1 -0
  58. package/dist/kit/builder/page/index.d.ts +2 -0
  59. package/dist/kit/builder/page/index.d.ts.map +1 -0
  60. package/dist/kit/builder/section/SectionBuilder.d.ts +3 -0
  61. package/dist/kit/builder/section/SectionBuilder.d.ts.map +1 -0
  62. package/dist/kit/builder/section/index.d.ts +3 -0
  63. package/dist/kit/builder/section/index.d.ts.map +1 -0
  64. package/dist/kit/builder/section/types.d.ts +59 -0
  65. package/dist/kit/builder/section/types.d.ts.map +1 -0
  66. package/dist/kit/components/autocomplete/Autocomplete.d.ts +21 -0
  67. package/dist/kit/components/autocomplete/Autocomplete.d.ts.map +1 -0
  68. package/dist/kit/components/autocomplete/index.d.ts +3 -0
  69. package/dist/kit/components/autocomplete/index.d.ts.map +1 -0
  70. package/dist/kit/components/autocomplete/types.d.ts +19 -0
  71. package/dist/kit/components/autocomplete/types.d.ts.map +1 -0
  72. package/dist/kit/components/login/Login.d.ts +29 -0
  73. package/dist/kit/components/login/Login.d.ts.map +1 -0
  74. package/dist/kit/components/login/index.d.ts +2 -0
  75. package/dist/kit/components/login/index.d.ts.map +1 -0
  76. package/dist/kit/layouts/admin/components/AdminLayout.d.ts +17 -0
  77. package/dist/kit/layouts/admin/components/AdminLayout.d.ts.map +1 -0
  78. package/dist/kit/layouts/admin/components/ThemeToggle.d.ts +5 -0
  79. package/dist/kit/layouts/admin/components/ThemeToggle.d.ts.map +1 -0
  80. package/dist/kit/layouts/admin/hooks/menu.d.ts +12 -0
  81. package/dist/kit/layouts/admin/hooks/menu.d.ts.map +1 -0
  82. package/dist/kit/layouts/admin/providers/AdminMenuProvider.d.ts +7 -0
  83. package/dist/kit/layouts/admin/providers/AdminMenuProvider.d.ts.map +1 -0
  84. package/dist/kit/layouts/admin/types/index.d.ts +27 -0
  85. package/dist/kit/layouts/admin/types/index.d.ts.map +1 -0
  86. package/dist/kit/providers/ThemeProvider.d.ts +14 -0
  87. package/dist/kit/providers/ThemeProvider.d.ts.map +1 -0
  88. package/dist/shadcn/hooks/use-mobile.d.ts +2 -0
  89. package/dist/shadcn/hooks/use-mobile.d.ts.map +1 -0
  90. package/dist/shadcn/lib/utils.d.ts +3 -0
  91. package/dist/shadcn/lib/utils.d.ts.map +1 -0
  92. package/dist/shadcn/ui/accordion.d.ts +8 -0
  93. package/dist/shadcn/ui/accordion.d.ts.map +1 -0
  94. package/dist/shadcn/ui/alert-dialog.d.ts +15 -0
  95. package/dist/shadcn/ui/alert-dialog.d.ts.map +1 -0
  96. package/dist/shadcn/ui/alert.d.ts +10 -0
  97. package/dist/shadcn/ui/alert.d.ts.map +1 -0
  98. package/dist/shadcn/ui/aspect-ratio.d.ts +4 -0
  99. package/dist/shadcn/ui/aspect-ratio.d.ts.map +1 -0
  100. package/dist/shadcn/ui/avatar.d.ts +7 -0
  101. package/dist/shadcn/ui/avatar.d.ts.map +1 -0
  102. package/dist/shadcn/ui/badge.d.ts +10 -0
  103. package/dist/shadcn/ui/badge.d.ts.map +1 -0
  104. package/dist/shadcn/ui/breadcrumb.d.ts +12 -0
  105. package/dist/shadcn/ui/breadcrumb.d.ts.map +1 -0
  106. package/dist/shadcn/ui/button.d.ts +11 -0
  107. package/dist/shadcn/ui/button.d.ts.map +1 -0
  108. package/dist/shadcn/ui/calendar.d.ts +9 -0
  109. package/dist/shadcn/ui/calendar.d.ts.map +1 -0
  110. package/dist/shadcn/ui/card.d.ts +10 -0
  111. package/dist/shadcn/ui/card.d.ts.map +1 -0
  112. package/dist/shadcn/ui/carousel.d.ts +20 -0
  113. package/dist/shadcn/ui/carousel.d.ts.map +1 -0
  114. package/dist/shadcn/ui/chart.d.ts +41 -0
  115. package/dist/shadcn/ui/chart.d.ts.map +1 -0
  116. package/dist/shadcn/ui/checkbox.d.ts +5 -0
  117. package/dist/shadcn/ui/checkbox.d.ts.map +1 -0
  118. package/dist/shadcn/ui/collapsible.d.ts +6 -0
  119. package/dist/shadcn/ui/collapsible.d.ts.map +1 -0
  120. package/dist/shadcn/ui/command.d.ts +19 -0
  121. package/dist/shadcn/ui/command.d.ts.map +1 -0
  122. package/dist/shadcn/ui/context-menu.d.ts +26 -0
  123. package/dist/shadcn/ui/context-menu.d.ts.map +1 -0
  124. package/dist/shadcn/ui/dialog.d.ts +16 -0
  125. package/dist/shadcn/ui/dialog.d.ts.map +1 -0
  126. package/dist/shadcn/ui/drawer.d.ts +14 -0
  127. package/dist/shadcn/ui/drawer.d.ts.map +1 -0
  128. package/dist/shadcn/ui/dropdown-menu.d.ts +26 -0
  129. package/dist/shadcn/ui/dropdown-menu.d.ts.map +1 -0
  130. package/dist/shadcn/ui/form.d.ts +25 -0
  131. package/dist/shadcn/ui/form.d.ts.map +1 -0
  132. package/dist/shadcn/ui/hover-card.d.ts +7 -0
  133. package/dist/shadcn/ui/hover-card.d.ts.map +1 -0
  134. package/dist/shadcn/ui/input-otp.d.ts +12 -0
  135. package/dist/shadcn/ui/input-otp.d.ts.map +1 -0
  136. package/dist/shadcn/ui/input.d.ts +4 -0
  137. package/dist/shadcn/ui/input.d.ts.map +1 -0
  138. package/dist/shadcn/ui/label.d.ts +5 -0
  139. package/dist/shadcn/ui/label.d.ts.map +1 -0
  140. package/dist/shadcn/ui/menubar.d.ts +27 -0
  141. package/dist/shadcn/ui/menubar.d.ts.map +1 -0
  142. package/dist/shadcn/ui/navigation-menu.d.ts +15 -0
  143. package/dist/shadcn/ui/navigation-menu.d.ts.map +1 -0
  144. package/dist/shadcn/ui/pagination.d.ts +14 -0
  145. package/dist/shadcn/ui/pagination.d.ts.map +1 -0
  146. package/dist/shadcn/ui/popover.d.ts +8 -0
  147. package/dist/shadcn/ui/popover.d.ts.map +1 -0
  148. package/dist/shadcn/ui/progress.d.ts +5 -0
  149. package/dist/shadcn/ui/progress.d.ts.map +1 -0
  150. package/dist/shadcn/ui/radio-group.d.ts +6 -0
  151. package/dist/shadcn/ui/radio-group.d.ts.map +1 -0
  152. package/dist/shadcn/ui/resizable.d.ts +9 -0
  153. package/dist/shadcn/ui/resizable.d.ts.map +1 -0
  154. package/dist/shadcn/ui/scroll-area.d.ts +6 -0
  155. package/dist/shadcn/ui/scroll-area.d.ts.map +1 -0
  156. package/dist/shadcn/ui/select.d.ts +16 -0
  157. package/dist/shadcn/ui/select.d.ts.map +1 -0
  158. package/dist/shadcn/ui/separator.d.ts +5 -0
  159. package/dist/shadcn/ui/separator.d.ts.map +1 -0
  160. package/dist/shadcn/ui/sheet.d.ts +14 -0
  161. package/dist/shadcn/ui/sheet.d.ts.map +1 -0
  162. package/dist/shadcn/ui/sidebar.d.ts +70 -0
  163. package/dist/shadcn/ui/sidebar.d.ts.map +1 -0
  164. package/dist/shadcn/ui/skeleton.d.ts +3 -0
  165. package/dist/shadcn/ui/skeleton.d.ts.map +1 -0
  166. package/dist/shadcn/ui/slider.d.ts +5 -0
  167. package/dist/shadcn/ui/slider.d.ts.map +1 -0
  168. package/dist/shadcn/ui/sonner.d.ts +4 -0
  169. package/dist/shadcn/ui/sonner.d.ts.map +1 -0
  170. package/dist/shadcn/ui/switch.d.ts +5 -0
  171. package/dist/shadcn/ui/switch.d.ts.map +1 -0
  172. package/dist/shadcn/ui/table.d.ts +11 -0
  173. package/dist/shadcn/ui/table.d.ts.map +1 -0
  174. package/dist/shadcn/ui/tabs.d.ts +8 -0
  175. package/dist/shadcn/ui/tabs.d.ts.map +1 -0
  176. package/dist/shadcn/ui/textarea.d.ts +4 -0
  177. package/dist/shadcn/ui/textarea.d.ts.map +1 -0
  178. package/dist/shadcn/ui/toggle-group.d.ts +8 -0
  179. package/dist/shadcn/ui/toggle-group.d.ts.map +1 -0
  180. package/dist/shadcn/ui/toggle.d.ts +10 -0
  181. package/dist/shadcn/ui/toggle.d.ts.map +1 -0
  182. package/dist/shadcn/ui/tooltip.d.ts +8 -0
  183. package/dist/shadcn/ui/tooltip.d.ts.map +1 -0
  184. package/eslint.config.mjs +19 -0
  185. package/package.json +82 -0
  186. package/src/index.css +11 -0
  187. package/src/index.ts +0 -0
  188. package/src/kit/builder/data-table/components/DataTable.tsx +375 -0
  189. package/src/kit/builder/data-table/components/DataTableColumnHeader.tsx +63 -0
  190. package/src/kit/builder/data-table/components/DataTablePagination.tsx +86 -0
  191. package/src/kit/builder/data-table/components/DataTableViewOptions.tsx +42 -0
  192. package/src/kit/builder/data-table/index.ts +5 -0
  193. package/src/kit/builder/data-table/types.ts +29 -0
  194. package/src/kit/builder/data-table/utils/dotAccessor.ts +6 -0
  195. package/src/kit/builder/dialog/index.ts +2 -0
  196. package/src/kit/builder/dialog/provider.tsx +141 -0
  197. package/src/kit/builder/form/components/FormActions.tsx +78 -0
  198. package/src/kit/builder/form/components/FormBuilder.tsx +456 -0
  199. package/src/kit/builder/form/components/FormField.tsx +395 -0
  200. package/src/kit/builder/form/components/FormSection.tsx +88 -0
  201. package/src/kit/builder/form/components/index.ts +4 -0
  202. package/src/kit/builder/form/index.ts +2 -0
  203. package/src/kit/builder/form/utils/common-forms.ts +68 -0
  204. package/src/kit/builder/form/utils/dependencies.ts +56 -0
  205. package/src/kit/builder/form/utils/field-factories.ts +164 -0
  206. package/src/kit/builder/form/utils/index.ts +17 -0
  207. package/src/kit/builder/form/utils/section-factories.ts +35 -0
  208. package/src/kit/builder/form/utils/transformers.ts +100 -0
  209. package/src/kit/builder/form/utils/validations.ts +22 -0
  210. package/src/kit/builder/form/utils/validators.ts +20 -0
  211. package/src/kit/builder/page/Page.tsx +182 -0
  212. package/src/kit/builder/page/index.ts +1 -0
  213. package/src/kit/builder/section/SectionBuilder.tsx +213 -0
  214. package/src/kit/builder/section/index.ts +2 -0
  215. package/src/kit/builder/section/types.ts +66 -0
  216. package/src/kit/components/autocomplete/Autocomplete.tsx +247 -0
  217. package/src/kit/components/autocomplete/index.ts +2 -0
  218. package/src/kit/components/autocomplete/types.ts +24 -0
  219. package/src/kit/components/login/Login.tsx +119 -0
  220. package/src/kit/components/login/index.ts +1 -0
  221. package/src/kit/layouts/admin/components/AdminLayout.tsx +251 -0
  222. package/src/kit/layouts/admin/components/ThemeToggle.tsx +60 -0
  223. package/src/kit/layouts/admin/hooks/menu.ts +26 -0
  224. package/src/kit/layouts/admin/providers/AdminMenuProvider.tsx +58 -0
  225. package/src/kit/layouts/admin/types/index.ts +26 -0
  226. package/src/kit/providers/ThemeProvider.tsx +90 -0
  227. package/src/kit/themes/clean-slate.css +147 -0
  228. package/src/kit/themes/default.css +182 -0
  229. package/src/kit/themes/minimal-modern.css +147 -0
  230. package/src/kit/themes/spotify.css +147 -0
  231. package/src/shadcn/hooks/use-mobile.ts +19 -0
  232. package/src/shadcn/lib/utils.ts +6 -0
  233. package/src/shadcn/ui/accordion.tsx +66 -0
  234. package/src/shadcn/ui/alert-dialog.tsx +157 -0
  235. package/src/shadcn/ui/alert.tsx +66 -0
  236. package/src/shadcn/ui/aspect-ratio.tsx +11 -0
  237. package/src/shadcn/ui/avatar.tsx +53 -0
  238. package/src/shadcn/ui/badge.tsx +46 -0
  239. package/src/shadcn/ui/breadcrumb.tsx +108 -0
  240. package/src/shadcn/ui/button.tsx +59 -0
  241. package/src/shadcn/ui/calendar.tsx +213 -0
  242. package/src/shadcn/ui/card.tsx +92 -0
  243. package/src/shadcn/ui/carousel.tsx +240 -0
  244. package/src/shadcn/ui/chart.tsx +353 -0
  245. package/src/shadcn/ui/checkbox.tsx +32 -0
  246. package/src/shadcn/ui/collapsible.tsx +33 -0
  247. package/src/shadcn/ui/command.tsx +184 -0
  248. package/src/shadcn/ui/context-menu.tsx +252 -0
  249. package/src/shadcn/ui/dialog.tsx +143 -0
  250. package/src/shadcn/ui/drawer.tsx +135 -0
  251. package/src/shadcn/ui/dropdown-menu.tsx +257 -0
  252. package/src/shadcn/ui/form.tsx +167 -0
  253. package/src/shadcn/ui/hover-card.tsx +44 -0
  254. package/src/shadcn/ui/input-otp.tsx +77 -0
  255. package/src/shadcn/ui/input.tsx +21 -0
  256. package/src/shadcn/ui/label.tsx +24 -0
  257. package/src/shadcn/ui/menubar.tsx +276 -0
  258. package/src/shadcn/ui/navigation-menu.tsx +168 -0
  259. package/src/shadcn/ui/pagination.tsx +127 -0
  260. package/src/shadcn/ui/popover.tsx +48 -0
  261. package/src/shadcn/ui/progress.tsx +31 -0
  262. package/src/shadcn/ui/radio-group.tsx +45 -0
  263. package/src/shadcn/ui/resizable.tsx +56 -0
  264. package/src/shadcn/ui/scroll-area.tsx +58 -0
  265. package/src/shadcn/ui/select.tsx +185 -0
  266. package/src/shadcn/ui/separator.tsx +28 -0
  267. package/src/shadcn/ui/sheet.tsx +139 -0
  268. package/src/shadcn/ui/sidebar.tsx +726 -0
  269. package/src/shadcn/ui/skeleton.tsx +13 -0
  270. package/src/shadcn/ui/slider.tsx +63 -0
  271. package/src/shadcn/ui/sonner.tsx +25 -0
  272. package/src/shadcn/ui/switch.tsx +31 -0
  273. package/src/shadcn/ui/table.tsx +116 -0
  274. package/src/shadcn/ui/tabs.tsx +66 -0
  275. package/src/shadcn/ui/textarea.tsx +18 -0
  276. package/src/shadcn/ui/toggle-group.tsx +73 -0
  277. package/src/shadcn/ui/toggle.tsx +47 -0
  278. package/src/shadcn/ui/tooltip.tsx +61 -0
  279. package/src/stories/kit/builder/DataTable.Basic.stories.tsx +61 -0
  280. package/src/stories/kit/builder/DataTable.Filters.stories.tsx +76 -0
  281. package/src/stories/kit/builder/DataTable.Pagination.stories.tsx +72 -0
  282. package/src/stories/kit/builder/DataTable.SelectionAndActions.stories.tsx +63 -0
  283. package/src/stories/kit/builder/DataTable.Sorting.stories.tsx +56 -0
  284. package/src/stories/kit/builder/Dialog.stories.tsx +84 -0
  285. package/src/stories/kit/builder/Form.Basic.stories.tsx +45 -0
  286. package/src/stories/kit/builder/Form.Complex.stories.tsx +223 -0
  287. package/src/stories/kit/builder/Form.Dynamic.stories.tsx +214 -0
  288. package/src/stories/kit/builder/Form.Simple.stories.tsx +78 -0
  289. package/src/stories/kit/builder/Page.stories.tsx +89 -0
  290. package/src/stories/kit/builder/Section.stories.tsx +179 -0
  291. package/src/stories/kit/components/Autocomplete.stories.tsx +98 -0
  292. package/src/stories/kit/components/Login.stories.tsx +161 -0
  293. package/src/stories/kit/layouts/admin/AdminLayout.Basic.stories.tsx +93 -0
  294. package/src/stories/kit/layouts/admin/AdminLayout.Collapsible.stories.tsx +58 -0
  295. package/src/stories/kit/layouts/admin/AdminLayout.Complex.stories.tsx +166 -0
  296. package/src/stories/kit/layouts/admin/AdminLayout.CustomSidebarHeaderComponent.stories.tsx +64 -0
  297. package/src/stories/kit/layouts/admin/AdminLayout.CustomSidebarTitleAndIcon.stories.tsx +55 -0
  298. package/src/stories/kit/layouts/admin/AdminLayout.HeaderSlots.stories.tsx +63 -0
  299. package/src/stories/shadcn/ui/Accordion.stories.tsx +94 -0
  300. package/src/stories/shadcn/ui/Alert.stories.tsx +36 -0
  301. package/src/stories/shadcn/ui/AlertDialog.stories.tsx +71 -0
  302. package/src/stories/shadcn/ui/AspectRatio.stories.tsx +58 -0
  303. package/src/stories/shadcn/ui/Avatar.stories.tsx +26 -0
  304. package/src/stories/shadcn/ui/Badge.stories.tsx +28 -0
  305. package/src/stories/shadcn/ui/Breadcrumb.stories.tsx +47 -0
  306. package/src/stories/shadcn/ui/Button.stories.tsx +49 -0
  307. package/src/stories/shadcn/ui/Calendar.stories.tsx +28 -0
  308. package/src/stories/shadcn/ui/Card.stories.tsx +30 -0
  309. package/src/stories/shadcn/ui/Carousel.stories.tsx +37 -0
  310. package/src/stories/shadcn/ui/Chart.stories.tsx +72 -0
  311. package/src/stories/shadcn/ui/Checkbox.stories.tsx +56 -0
  312. package/src/stories/shadcn/ui/Collapsible.stories.tsx +33 -0
  313. package/src/stories/shadcn/ui/Command.stories.tsx +53 -0
  314. package/src/stories/shadcn/ui/ContextMenu.stories.tsx +59 -0
  315. package/src/stories/shadcn/ui/Dialog.stories.tsx +33 -0
  316. package/src/stories/shadcn/ui/Drawer.stories.tsx +46 -0
  317. package/src/stories/shadcn/ui/DropdownMenu.stories.tsx +65 -0
  318. package/src/stories/shadcn/ui/Form.stories.tsx +90 -0
  319. package/src/stories/shadcn/ui/HoverCard.stories.tsx +37 -0
  320. package/src/stories/shadcn/ui/Input.stories.tsx +39 -0
  321. package/src/stories/shadcn/ui/InputOtp.stories.tsx +32 -0
  322. package/src/stories/shadcn/ui/Label.stories.tsx +29 -0
  323. package/src/stories/shadcn/ui/Menubar.stories.tsx +73 -0
  324. package/src/stories/shadcn/ui/NavigationMenu.stories.tsx +53 -0
  325. package/src/stories/shadcn/ui/Pagination.stories.tsx +51 -0
  326. package/src/stories/shadcn/ui/Popover.stories.tsx +47 -0
  327. package/src/stories/shadcn/ui/Progress.stories.tsx +30 -0
  328. package/src/stories/shadcn/ui/RadioGroup.stories.tsx +31 -0
  329. package/src/stories/shadcn/ui/Resizable.stories.tsx +43 -0
  330. package/src/stories/shadcn/ui/ScrollArea.stories.tsx +32 -0
  331. package/src/stories/shadcn/ui/Select.stories.tsx +55 -0
  332. package/src/stories/shadcn/ui/Separator.stories.tsx +35 -0
  333. package/src/stories/shadcn/ui/Sheet.stories.tsx +47 -0
  334. package/src/stories/shadcn/ui/Sidebar.stories.tsx +120 -0
  335. package/src/stories/shadcn/ui/Skeleton.stories.tsx +23 -0
  336. package/src/stories/shadcn/ui/Slider.stories.tsx +21 -0
  337. package/src/stories/shadcn/ui/Sonner.stories.tsx +39 -0
  338. package/src/stories/shadcn/ui/Switch.stories.tsx +28 -0
  339. package/src/stories/shadcn/ui/Table.stories.tsx +315 -0
  340. package/src/stories/shadcn/ui/Tabs.stories.tsx +24 -0
  341. package/src/stories/shadcn/ui/Textarea.stories.tsx +40 -0
  342. package/src/stories/shadcn/ui/Toggle.stories.tsx +36 -0
  343. package/src/stories/shadcn/ui/ToggleGroup.stories.tsx +28 -0
  344. package/src/stories/shadcn/ui/Tooltip.stories.tsx +25 -0
  345. package/storybook-static/assets/Accordion.stories-N1auke5L.js +52 -0
  346. package/storybook-static/assets/AdminLayout-Cxd0-A_L.js +53 -0
  347. package/storybook-static/assets/AdminLayout.Basic.stories-C_I6rWuq.js +4 -0
  348. package/storybook-static/assets/AdminLayout.Collapsible.stories-CsU3DwTo.js +4 -0
  349. package/storybook-static/assets/AdminLayout.Complex.stories-BbY1Ue6d.js +29 -0
  350. package/storybook-static/assets/AdminLayout.CustomSidebarHeaderComponent.stories-LFVi-aIv.js +9 -0
  351. package/storybook-static/assets/AdminLayout.CustomSidebarTitleAndIcon.stories-BqP6UVc7.js +4 -0
  352. package/storybook-static/assets/AdminLayout.HeaderSlots.stories-BactzgkF.js +7 -0
  353. package/storybook-static/assets/Alert.stories-_FtuixdR.js +27 -0
  354. package/storybook-static/assets/AlertDialog.stories-6NY3BjwR.js +43 -0
  355. package/storybook-static/assets/AspectRatio.stories-DAT11y02.js +22 -0
  356. package/storybook-static/assets/Autocomplete-DngjqsCM.js +35 -0
  357. package/storybook-static/assets/Autocomplete.stories-BCaOrgTR.js +33 -0
  358. package/storybook-static/assets/Avatar.stories-DlzxSLJ-.js +12 -0
  359. package/storybook-static/assets/Badge.stories-DKHXsoV5.js +12 -0
  360. package/storybook-static/assets/Breadcrumb.stories-D8eUHpf7.js +25 -0
  361. package/storybook-static/assets/Button.stories-kvPdKxdw.js +26 -0
  362. package/storybook-static/assets/Calendar.stories-D-hUtQQI.js +3 -0
  363. package/storybook-static/assets/Card.stories-y8Z7NgrQ.js +15 -0
  364. package/storybook-static/assets/Carousel.stories-CFcHYKgp.js +15 -0
  365. package/storybook-static/assets/Chart.stories-BJwLNKfE.js +126 -0
  366. package/storybook-static/assets/Checkbox.stories-B22Fbwx1.js +12 -0
  367. package/storybook-static/assets/Collapsible.stories-BgcRp8Rk.js +18 -0
  368. package/storybook-static/assets/Combination-BT_gXe1L.js +41 -0
  369. package/storybook-static/assets/Command.stories-Dp4CtSQR.js +30 -0
  370. package/storybook-static/assets/ContextMenu.stories-DnVnIi-T.js +31 -0
  371. package/storybook-static/assets/DataTable.Basic.stories-DBF5VYq9.js +6 -0
  372. package/storybook-static/assets/DataTable.Filters.stories-CO0ipuGm.js +21 -0
  373. package/storybook-static/assets/DataTable.Pagination.stories-DNwCw64e.js +24 -0
  374. package/storybook-static/assets/DataTable.SelectionAndActions.stories-DGgdEbsf.js +26 -0
  375. package/storybook-static/assets/DataTable.Sorting.stories-CWpqloAB.js +6 -0
  376. package/storybook-static/assets/Dialog.stories-DQkYN8ht.js +18 -0
  377. package/storybook-static/assets/Dialog.stories-DXZINEgo.js +54 -0
  378. package/storybook-static/assets/Drawer.stories-DMH_vZgi.js +24 -0
  379. package/storybook-static/assets/DropdownMenu.stories-Dl8y-N7T.js +35 -0
  380. package/storybook-static/assets/Form.Basic.stories-CJugIYsx.js +45 -0
  381. package/storybook-static/assets/Form.Complex.stories-BPogRp6F.js +230 -0
  382. package/storybook-static/assets/Form.Dynamic.stories-Boway5AK.js +247 -0
  383. package/storybook-static/assets/Form.Simple.stories-_OXGXXpE.js +50 -0
  384. package/storybook-static/assets/Form.stories-BoHyR8ho.js +3 -0
  385. package/storybook-static/assets/FormBuilder-BGgeY8ik.js +5 -0
  386. package/storybook-static/assets/HoverCard.stories-1HM92M79.js +21 -0
  387. package/storybook-static/assets/Input.stories-sQ4EUlWt.js +16 -0
  388. package/storybook-static/assets/InputOtp.stories-Cpk_EmLx.js +42 -0
  389. package/storybook-static/assets/Label.stories-MjABHKSw.js +14 -0
  390. package/storybook-static/assets/Login.stories-BY4OYGk3.js +37 -0
  391. package/storybook-static/assets/Menubar.stories-B_60TWNE.js +44 -0
  392. package/storybook-static/assets/NavigationMenu.stories-DyuaBvvq.js +30 -0
  393. package/storybook-static/assets/Page.stories-DQKMxrPZ.js +91 -0
  394. package/storybook-static/assets/Pagination.stories-CBo7UrNd.js +29 -0
  395. package/storybook-static/assets/Popover.stories-D98_JrxN.js +15 -0
  396. package/storybook-static/assets/Progress.stories-Dejt5v3z.js +8 -0
  397. package/storybook-static/assets/RadioGroup.stories-Tz2LW6O6.js +16 -0
  398. package/storybook-static/assets/Resizable.stories-DhP2GKN7.js +25 -0
  399. package/storybook-static/assets/ScrollArea.stories-CF7-8wbM.js +12 -0
  400. package/storybook-static/assets/Section.stories-BpurjHIQ.js +196 -0
  401. package/storybook-static/assets/SectionBuilder-Bav4WrnT.js +1 -0
  402. package/storybook-static/assets/Select.stories-DJrU-mi0.js +17 -0
  403. package/storybook-static/assets/Separator.stories-BYH_o8QM.js +17 -0
  404. package/storybook-static/assets/Sheet.stories-BNJ7BIb-.js +24 -0
  405. package/storybook-static/assets/Sidebar.stories-BbjcJuOg.js +106 -0
  406. package/storybook-static/assets/Skeleton.stories-BQNIuIe5.js +9 -0
  407. package/storybook-static/assets/Slider.stories-CWOjKHKD.js +6 -0
  408. package/storybook-static/assets/Sonner.stories-CXSZs5yN.js +18 -0
  409. package/storybook-static/assets/Switch.stories-BUQjobWe.js +3 -0
  410. package/storybook-static/assets/Table.stories-DJcV7M9R.js +35 -0
  411. package/storybook-static/assets/Tabs.stories-ByeVrP18.js +10 -0
  412. package/storybook-static/assets/Textarea.stories-CKsDPHYc.js +17 -0
  413. package/storybook-static/assets/Toggle.stories-DutEzZ8k.js +3 -0
  414. package/storybook-static/assets/ToggleGroup.stories-C9fzJTh-.js +13 -0
  415. package/storybook-static/assets/Tooltip.stories-CngnJbP7.js +10 -0
  416. package/storybook-static/assets/accordion-bQe9Rep4.js +1 -0
  417. package/storybook-static/assets/alert-dialog-CypF_yaW.js +7 -0
  418. package/storybook-static/assets/avatar-CukM9hXu.js +1 -0
  419. package/storybook-static/assets/axe-W8QMjM0E.js +30 -0
  420. package/storybook-static/assets/button-BTWmFXop.js +1 -0
  421. package/storybook-static/assets/card-BJpPOzP8.js +1 -0
  422. package/storybook-static/assets/chart-column-Bzh5arua.js +6 -0
  423. package/storybook-static/assets/check-BgWXKGqi.js +6 -0
  424. package/storybook-static/assets/checkbox-QlugAqJY.js +1 -0
  425. package/storybook-static/assets/chevron-down-BqLjUn1_.js +6 -0
  426. package/storybook-static/assets/chevron-left-BR_0lKnE.js +6 -0
  427. package/storybook-static/assets/chevron-right-DpCIoMaJ.js +6 -0
  428. package/storybook-static/assets/circle-DVJTkDI7.js +6 -0
  429. package/storybook-static/assets/clean-slate-BR-XvZPt.css +1 -0
  430. package/storybook-static/assets/command-BERL33lL.js +6 -0
  431. package/storybook-static/assets/createLucideIcon-1ZwIAs_l.js +21 -0
  432. package/storybook-static/assets/default-M24vcGB8.css +1 -0
  433. package/storybook-static/assets/dependencies-ctrV69dx.js +1 -0
  434. package/storybook-static/assets/dialog-DM9YJ1JD.js +1 -0
  435. package/storybook-static/assets/dropdown-menu-TfFll7G9.js +1 -0
  436. package/storybook-static/assets/ellipsis-BSY8VuLI.js +6 -0
  437. package/storybook-static/assets/grip-vertical-Buja1rv9.js +6 -0
  438. package/storybook-static/assets/iframe-C9bogcIc.css +1 -0
  439. package/storybook-static/assets/iframe-G-6sM9Mt.js +1555 -0
  440. package/storybook-static/assets/index-1v1lhNFD.js +1 -0
  441. package/storybook-static/assets/index-7yNAGow7.js +1 -0
  442. package/storybook-static/assets/index-B-fXBfyD.js +1 -0
  443. package/storybook-static/assets/index-BDwnENHR.js +1 -0
  444. package/storybook-static/assets/index-BdQq_4o_.js +1 -0
  445. package/storybook-static/assets/index-Bq6UNRVc.js +1 -0
  446. package/storybook-static/assets/index-CAwQR9Pv.js +1 -0
  447. package/storybook-static/assets/index-CGrAONsN.js +1 -0
  448. package/storybook-static/assets/index-CLmN5G1a.js +1 -0
  449. package/storybook-static/assets/index-CMmbDm5O.js +1 -0
  450. package/storybook-static/assets/index-CZaD3imo.js +9 -0
  451. package/storybook-static/assets/index-CayhpKmv.js +1 -0
  452. package/storybook-static/assets/index-ClNNG_ys.js +1 -0
  453. package/storybook-static/assets/index-CzJf-yyP.js +5 -0
  454. package/storybook-static/assets/index-DNAxNqEO.js +1 -0
  455. package/storybook-static/assets/index-DW48STyt.js +1 -0
  456. package/storybook-static/assets/index-DhoByIgc.js +1 -0
  457. package/storybook-static/assets/index-DqWzLCH-.js +1 -0
  458. package/storybook-static/assets/index-DvM9azdj.js +1 -0
  459. package/storybook-static/assets/index-DySHPxMy.js +1 -0
  460. package/storybook-static/assets/index-HghBIZeg.js +1 -0
  461. package/storybook-static/assets/index-I343IfOC.js +1 -0
  462. package/storybook-static/assets/index-SxI7_jxe.js +9 -0
  463. package/storybook-static/assets/index-_crRFOM5.js +1 -0
  464. package/storybook-static/assets/index-d_S6mtzU.js +1 -0
  465. package/storybook-static/assets/index-ev1RjzGv.js +1 -0
  466. package/storybook-static/assets/index-lH-AZpAn.js +1 -0
  467. package/storybook-static/assets/input-11YRd9gD.js +1 -0
  468. package/storybook-static/assets/jsx-runtime-D_zvdyIk.js +9 -0
  469. package/storybook-static/assets/label-C5vJTTwH.js +1 -0
  470. package/storybook-static/assets/lodash-Q9aGJGMb.js +73 -0
  471. package/storybook-static/assets/matchers-7Z3WT2CE-T3xScrR7.js +14 -0
  472. package/storybook-static/assets/minimal-modern-BmvR5wyr.css +1 -0
  473. package/storybook-static/assets/popover-DW1K4QCO.js +1 -0
  474. package/storybook-static/assets/preload-helper-Dp1pzeXC.js +1 -0
  475. package/storybook-static/assets/radio-group-iPL-8jvw.js +1 -0
  476. package/storybook-static/assets/react-18-CK1-M7n3.js +25 -0
  477. package/storybook-static/assets/react-icons.esm-n2MUhK0n.js +1 -0
  478. package/storybook-static/assets/refresh-cw-FYEbhX1i.js +6 -0
  479. package/storybook-static/assets/schemas-S_Tg7JYp.js +18 -0
  480. package/storybook-static/assets/section-factories-CC6eFfbk.js +1 -0
  481. package/storybook-static/assets/select-DbLzULCJ.js +6 -0
  482. package/storybook-static/assets/separator-DoUX1TNx.js +1 -0
  483. package/storybook-static/assets/settings-2-CpOcGlDm.js +6 -0
  484. package/storybook-static/assets/sheet-n5VQ25jh.js +1 -0
  485. package/storybook-static/assets/shopping-cart-9kOJ1UDd.js +11 -0
  486. package/storybook-static/assets/sidebar-CvUiZOJe.js +6 -0
  487. package/storybook-static/assets/skeleton-CjDnQs43.js +1 -0
  488. package/storybook-static/assets/spotify-DpbeJq1r.css +1 -0
  489. package/storybook-static/assets/table-CP3vMqFn.js +1 -0
  490. package/storybook-static/assets/textarea-Dw2vruMl.js +1 -0
  491. package/storybook-static/assets/toggle-B-YKWMF8.js +16 -0
  492. package/storybook-static/assets/tooltip-CNONbPiI.js +1 -0
  493. package/storybook-static/assets/trash-2-Bt5LMclM.js +11 -0
  494. package/storybook-static/assets/utils-D-KgF5mV.js +1 -0
  495. package/storybook-static/assets/x-DG9mLFAg.js +6 -0
  496. package/storybook-static/favicon-wrapper.svg +46 -0
  497. package/storybook-static/favicon.svg +1 -0
  498. package/storybook-static/iframe.html +687 -0
  499. package/storybook-static/index.d.ts +1 -0
  500. package/storybook-static/index.d.ts.map +1 -0
  501. package/storybook-static/index.html +166 -0
  502. package/storybook-static/index.json +1 -0
  503. package/storybook-static/kit/builder/data-table/components/DataTable.d.ts +34 -0
  504. package/storybook-static/kit/builder/data-table/components/DataTable.d.ts.map +1 -0
  505. package/storybook-static/kit/builder/data-table/components/DataTableColumnHeader.d.ts +8 -0
  506. package/storybook-static/kit/builder/data-table/components/DataTableColumnHeader.d.ts.map +1 -0
  507. package/storybook-static/kit/builder/data-table/components/DataTablePagination.d.ts +6 -0
  508. package/storybook-static/kit/builder/data-table/components/DataTablePagination.d.ts.map +1 -0
  509. package/storybook-static/kit/builder/data-table/components/DataTableViewOptions.d.ts +5 -0
  510. package/storybook-static/kit/builder/data-table/components/DataTableViewOptions.d.ts.map +1 -0
  511. package/storybook-static/kit/builder/data-table/index.d.ts +6 -0
  512. package/storybook-static/kit/builder/data-table/index.d.ts.map +1 -0
  513. package/storybook-static/kit/builder/data-table/types.d.ts +27 -0
  514. package/storybook-static/kit/builder/data-table/types.d.ts.map +1 -0
  515. package/storybook-static/kit/builder/data-table/utils/dotAccessor.d.ts +2 -0
  516. package/storybook-static/kit/builder/data-table/utils/dotAccessor.d.ts.map +1 -0
  517. package/storybook-static/kit/builder/dialog/index.d.ts +3 -0
  518. package/storybook-static/kit/builder/dialog/index.d.ts.map +1 -0
  519. package/storybook-static/kit/builder/dialog/provider.d.ts +26 -0
  520. package/storybook-static/kit/builder/dialog/provider.d.ts.map +1 -0
  521. package/storybook-static/kit/builder/form/components/FormActions.d.ts +20 -0
  522. package/storybook-static/kit/builder/form/components/FormActions.d.ts.map +1 -0
  523. package/storybook-static/kit/builder/form/components/FormBuilder.d.ts +97 -0
  524. package/storybook-static/kit/builder/form/components/FormBuilder.d.ts.map +1 -0
  525. package/storybook-static/kit/builder/form/components/FormField.d.ts +12 -0
  526. package/storybook-static/kit/builder/form/components/FormField.d.ts.map +1 -0
  527. package/storybook-static/kit/builder/form/components/FormSection.d.ts +15 -0
  528. package/storybook-static/kit/builder/form/components/FormSection.d.ts.map +1 -0
  529. package/storybook-static/kit/builder/form/components/index.d.ts +5 -0
  530. package/storybook-static/kit/builder/form/components/index.d.ts.map +1 -0
  531. package/storybook-static/kit/builder/form/index.d.ts +3 -0
  532. package/storybook-static/kit/builder/form/index.d.ts.map +1 -0
  533. package/storybook-static/kit/builder/form/utils/common-forms.d.ts +7 -0
  534. package/storybook-static/kit/builder/form/utils/common-forms.d.ts.map +1 -0
  535. package/storybook-static/kit/builder/form/utils/dependencies.d.ts +41 -0
  536. package/storybook-static/kit/builder/form/utils/dependencies.d.ts.map +1 -0
  537. package/storybook-static/kit/builder/form/utils/field-factories.d.ts +22 -0
  538. package/storybook-static/kit/builder/form/utils/field-factories.d.ts.map +1 -0
  539. package/storybook-static/kit/builder/form/utils/index.d.ts +15 -0
  540. package/storybook-static/kit/builder/form/utils/index.d.ts.map +1 -0
  541. package/storybook-static/kit/builder/form/utils/section-factories.d.ts +7 -0
  542. package/storybook-static/kit/builder/form/utils/section-factories.d.ts.map +1 -0
  543. package/storybook-static/kit/builder/form/utils/transformers.d.ts +6 -0
  544. package/storybook-static/kit/builder/form/utils/transformers.d.ts.map +1 -0
  545. package/storybook-static/kit/builder/form/utils/validations.d.ts +13 -0
  546. package/storybook-static/kit/builder/form/utils/validations.d.ts.map +1 -0
  547. package/storybook-static/kit/builder/form/utils/validators.d.ts +8 -0
  548. package/storybook-static/kit/builder/form/utils/validators.d.ts.map +1 -0
  549. package/storybook-static/kit/builder/page/Page.d.ts +48 -0
  550. package/storybook-static/kit/builder/page/Page.d.ts.map +1 -0
  551. package/storybook-static/kit/builder/page/index.d.ts +2 -0
  552. package/storybook-static/kit/builder/page/index.d.ts.map +1 -0
  553. package/storybook-static/kit/builder/section/SectionBuilder.d.ts +3 -0
  554. package/storybook-static/kit/builder/section/SectionBuilder.d.ts.map +1 -0
  555. package/storybook-static/kit/builder/section/index.d.ts +3 -0
  556. package/storybook-static/kit/builder/section/index.d.ts.map +1 -0
  557. package/storybook-static/kit/builder/section/types.d.ts +59 -0
  558. package/storybook-static/kit/builder/section/types.d.ts.map +1 -0
  559. package/storybook-static/kit/components/autocomplete/Autocomplete.d.ts +21 -0
  560. package/storybook-static/kit/components/autocomplete/Autocomplete.d.ts.map +1 -0
  561. package/storybook-static/kit/components/autocomplete/index.d.ts +3 -0
  562. package/storybook-static/kit/components/autocomplete/index.d.ts.map +1 -0
  563. package/storybook-static/kit/components/autocomplete/types.d.ts +19 -0
  564. package/storybook-static/kit/components/autocomplete/types.d.ts.map +1 -0
  565. package/storybook-static/kit/components/login/Login.d.ts +29 -0
  566. package/storybook-static/kit/components/login/Login.d.ts.map +1 -0
  567. package/storybook-static/kit/components/login/index.d.ts +2 -0
  568. package/storybook-static/kit/components/login/index.d.ts.map +1 -0
  569. package/storybook-static/kit/layouts/admin/components/AdminLayout.d.ts +17 -0
  570. package/storybook-static/kit/layouts/admin/components/AdminLayout.d.ts.map +1 -0
  571. package/storybook-static/kit/layouts/admin/components/ThemeToggle.d.ts +5 -0
  572. package/storybook-static/kit/layouts/admin/components/ThemeToggle.d.ts.map +1 -0
  573. package/storybook-static/kit/layouts/admin/hooks/menu.d.ts +12 -0
  574. package/storybook-static/kit/layouts/admin/hooks/menu.d.ts.map +1 -0
  575. package/storybook-static/kit/layouts/admin/providers/AdminMenuProvider.d.ts +7 -0
  576. package/storybook-static/kit/layouts/admin/providers/AdminMenuProvider.d.ts.map +1 -0
  577. package/storybook-static/kit/layouts/admin/types/index.d.ts +27 -0
  578. package/storybook-static/kit/layouts/admin/types/index.d.ts.map +1 -0
  579. package/storybook-static/kit/providers/ThemeProvider.d.ts +14 -0
  580. package/storybook-static/kit/providers/ThemeProvider.d.ts.map +1 -0
  581. package/storybook-static/nunito-sans-bold-italic.woff2 +0 -0
  582. package/storybook-static/nunito-sans-bold.woff2 +0 -0
  583. package/storybook-static/nunito-sans-italic.woff2 +0 -0
  584. package/storybook-static/nunito-sans-regular.woff2 +0 -0
  585. package/storybook-static/project.json +1 -0
  586. package/storybook-static/sb-addons/a11y-5/manager-bundle.js +5 -0
  587. package/storybook-static/sb-addons/essentials-backgrounds-1/manager-bundle.js +3 -0
  588. package/storybook-static/sb-addons/essentials-measure-2/manager-bundle.js +3 -0
  589. package/storybook-static/sb-addons/essentials-outline-3/manager-bundle.js +3 -0
  590. package/storybook-static/sb-addons/interactions-4/manager-bundle.js +57 -0
  591. package/storybook-static/sb-addons/storybook-core-server-presets-0/common-manager-bundle.js +971 -0
  592. package/storybook-static/sb-addons/storysource-6/manager-bundle.js +3 -0
  593. package/storybook-static/sb-common-assets/favicon-wrapper.svg +46 -0
  594. package/storybook-static/sb-common-assets/favicon.svg +1 -0
  595. package/storybook-static/sb-common-assets/nunito-sans-bold-italic.woff2 +0 -0
  596. package/storybook-static/sb-common-assets/nunito-sans-bold.woff2 +0 -0
  597. package/storybook-static/sb-common-assets/nunito-sans-italic.woff2 +0 -0
  598. package/storybook-static/sb-common-assets/nunito-sans-regular.woff2 +0 -0
  599. package/storybook-static/sb-manager/globals-module-info.js +797 -0
  600. package/storybook-static/sb-manager/globals-runtime.js +69653 -0
  601. package/storybook-static/sb-manager/globals.js +34 -0
  602. package/storybook-static/sb-manager/runtime.js +13181 -0
  603. package/storybook-static/shadcn/hooks/use-mobile.d.ts +2 -0
  604. package/storybook-static/shadcn/hooks/use-mobile.d.ts.map +1 -0
  605. package/storybook-static/shadcn/lib/utils.d.ts +3 -0
  606. package/storybook-static/shadcn/lib/utils.d.ts.map +1 -0
  607. package/storybook-static/shadcn/ui/accordion.d.ts +8 -0
  608. package/storybook-static/shadcn/ui/accordion.d.ts.map +1 -0
  609. package/storybook-static/shadcn/ui/alert-dialog.d.ts +15 -0
  610. package/storybook-static/shadcn/ui/alert-dialog.d.ts.map +1 -0
  611. package/storybook-static/shadcn/ui/alert.d.ts +10 -0
  612. package/storybook-static/shadcn/ui/alert.d.ts.map +1 -0
  613. package/storybook-static/shadcn/ui/aspect-ratio.d.ts +4 -0
  614. package/storybook-static/shadcn/ui/aspect-ratio.d.ts.map +1 -0
  615. package/storybook-static/shadcn/ui/avatar.d.ts +7 -0
  616. package/storybook-static/shadcn/ui/avatar.d.ts.map +1 -0
  617. package/storybook-static/shadcn/ui/badge.d.ts +10 -0
  618. package/storybook-static/shadcn/ui/badge.d.ts.map +1 -0
  619. package/storybook-static/shadcn/ui/breadcrumb.d.ts +12 -0
  620. package/storybook-static/shadcn/ui/breadcrumb.d.ts.map +1 -0
  621. package/storybook-static/shadcn/ui/button.d.ts +11 -0
  622. package/storybook-static/shadcn/ui/button.d.ts.map +1 -0
  623. package/storybook-static/shadcn/ui/calendar.d.ts +9 -0
  624. package/storybook-static/shadcn/ui/calendar.d.ts.map +1 -0
  625. package/storybook-static/shadcn/ui/card.d.ts +10 -0
  626. package/storybook-static/shadcn/ui/card.d.ts.map +1 -0
  627. package/storybook-static/shadcn/ui/carousel.d.ts +20 -0
  628. package/storybook-static/shadcn/ui/carousel.d.ts.map +1 -0
  629. package/storybook-static/shadcn/ui/chart.d.ts +41 -0
  630. package/storybook-static/shadcn/ui/chart.d.ts.map +1 -0
  631. package/storybook-static/shadcn/ui/checkbox.d.ts +5 -0
  632. package/storybook-static/shadcn/ui/checkbox.d.ts.map +1 -0
  633. package/storybook-static/shadcn/ui/collapsible.d.ts +6 -0
  634. package/storybook-static/shadcn/ui/collapsible.d.ts.map +1 -0
  635. package/storybook-static/shadcn/ui/command.d.ts +19 -0
  636. package/storybook-static/shadcn/ui/command.d.ts.map +1 -0
  637. package/storybook-static/shadcn/ui/context-menu.d.ts +26 -0
  638. package/storybook-static/shadcn/ui/context-menu.d.ts.map +1 -0
  639. package/storybook-static/shadcn/ui/dialog.d.ts +16 -0
  640. package/storybook-static/shadcn/ui/dialog.d.ts.map +1 -0
  641. package/storybook-static/shadcn/ui/drawer.d.ts +14 -0
  642. package/storybook-static/shadcn/ui/drawer.d.ts.map +1 -0
  643. package/storybook-static/shadcn/ui/dropdown-menu.d.ts +26 -0
  644. package/storybook-static/shadcn/ui/dropdown-menu.d.ts.map +1 -0
  645. package/storybook-static/shadcn/ui/form.d.ts +25 -0
  646. package/storybook-static/shadcn/ui/form.d.ts.map +1 -0
  647. package/storybook-static/shadcn/ui/hover-card.d.ts +7 -0
  648. package/storybook-static/shadcn/ui/hover-card.d.ts.map +1 -0
  649. package/storybook-static/shadcn/ui/input-otp.d.ts +12 -0
  650. package/storybook-static/shadcn/ui/input-otp.d.ts.map +1 -0
  651. package/storybook-static/shadcn/ui/input.d.ts +4 -0
  652. package/storybook-static/shadcn/ui/input.d.ts.map +1 -0
  653. package/storybook-static/shadcn/ui/label.d.ts +5 -0
  654. package/storybook-static/shadcn/ui/label.d.ts.map +1 -0
  655. package/storybook-static/shadcn/ui/menubar.d.ts +27 -0
  656. package/storybook-static/shadcn/ui/menubar.d.ts.map +1 -0
  657. package/storybook-static/shadcn/ui/navigation-menu.d.ts +15 -0
  658. package/storybook-static/shadcn/ui/navigation-menu.d.ts.map +1 -0
  659. package/storybook-static/shadcn/ui/pagination.d.ts +14 -0
  660. package/storybook-static/shadcn/ui/pagination.d.ts.map +1 -0
  661. package/storybook-static/shadcn/ui/popover.d.ts +8 -0
  662. package/storybook-static/shadcn/ui/popover.d.ts.map +1 -0
  663. package/storybook-static/shadcn/ui/progress.d.ts +5 -0
  664. package/storybook-static/shadcn/ui/progress.d.ts.map +1 -0
  665. package/storybook-static/shadcn/ui/radio-group.d.ts +6 -0
  666. package/storybook-static/shadcn/ui/radio-group.d.ts.map +1 -0
  667. package/storybook-static/shadcn/ui/resizable.d.ts +9 -0
  668. package/storybook-static/shadcn/ui/resizable.d.ts.map +1 -0
  669. package/storybook-static/shadcn/ui/scroll-area.d.ts +6 -0
  670. package/storybook-static/shadcn/ui/scroll-area.d.ts.map +1 -0
  671. package/storybook-static/shadcn/ui/select.d.ts +16 -0
  672. package/storybook-static/shadcn/ui/select.d.ts.map +1 -0
  673. package/storybook-static/shadcn/ui/separator.d.ts +5 -0
  674. package/storybook-static/shadcn/ui/separator.d.ts.map +1 -0
  675. package/storybook-static/shadcn/ui/sheet.d.ts +14 -0
  676. package/storybook-static/shadcn/ui/sheet.d.ts.map +1 -0
  677. package/storybook-static/shadcn/ui/sidebar.d.ts +70 -0
  678. package/storybook-static/shadcn/ui/sidebar.d.ts.map +1 -0
  679. package/storybook-static/shadcn/ui/skeleton.d.ts +3 -0
  680. package/storybook-static/shadcn/ui/skeleton.d.ts.map +1 -0
  681. package/storybook-static/shadcn/ui/slider.d.ts +5 -0
  682. package/storybook-static/shadcn/ui/slider.d.ts.map +1 -0
  683. package/storybook-static/shadcn/ui/sonner.d.ts +4 -0
  684. package/storybook-static/shadcn/ui/sonner.d.ts.map +1 -0
  685. package/storybook-static/shadcn/ui/switch.d.ts +5 -0
  686. package/storybook-static/shadcn/ui/switch.d.ts.map +1 -0
  687. package/storybook-static/shadcn/ui/table.d.ts +11 -0
  688. package/storybook-static/shadcn/ui/table.d.ts.map +1 -0
  689. package/storybook-static/shadcn/ui/tabs.d.ts +8 -0
  690. package/storybook-static/shadcn/ui/tabs.d.ts.map +1 -0
  691. package/storybook-static/shadcn/ui/textarea.d.ts +4 -0
  692. package/storybook-static/shadcn/ui/textarea.d.ts.map +1 -0
  693. package/storybook-static/shadcn/ui/toggle-group.d.ts +8 -0
  694. package/storybook-static/shadcn/ui/toggle-group.d.ts.map +1 -0
  695. package/storybook-static/shadcn/ui/toggle.d.ts +10 -0
  696. package/storybook-static/shadcn/ui/toggle.d.ts.map +1 -0
  697. package/storybook-static/shadcn/ui/tooltip.d.ts +8 -0
  698. package/storybook-static/shadcn/ui/tooltip.d.ts.map +1 -0
  699. package/storybook-static/vite-inject-mocker-entry.js +18 -0
  700. package/tsconfig.json +24 -0
  701. package/tsconfig.lib.json +52 -0
  702. package/tsconfig.spec.json +38 -0
  703. package/vite.config.ts +63 -0
@@ -0,0 +1,375 @@
1
+ import * as React from 'react';
2
+ import {
3
+ flexRender,
4
+ getCoreRowModel,
5
+ getPaginationRowModel,
6
+ getSortedRowModel,
7
+ getFilteredRowModel,
8
+ useReactTable,
9
+ type ColumnDef,
10
+ type ColumnFiltersState,
11
+ type Table as ReactTable,
12
+ type SortingState,
13
+ type VisibilityState,
14
+ type PaginationState,
15
+ } from '@tanstack/react-table';
16
+ import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from '../../../../shadcn/ui/table';
17
+ import { cn } from '../../../../shadcn/lib/utils';
18
+ import { Checkbox } from '../../../../shadcn/ui/checkbox';
19
+ import { Button } from '../../../../shadcn/ui/button';
20
+ import { Skeleton } from '../../../../shadcn/ui/skeleton';
21
+ import { FormBuilder, type FormBuilderSectionConfig } from '../../form/components/FormBuilder';
22
+ import type { DataTableFiltersProp, DataTableAction, DataTableBatchAction } from '../types';
23
+ import { Accordion, AccordionContent, AccordionItem, AccordionTrigger } from '../../../../shadcn/ui/accordion';
24
+ import { RefreshCw, Loader2 } from 'lucide-react';
25
+ import { DataTablePagination } from './DataTablePagination';
26
+ import { DataTableViewOptions } from './DataTableViewOptions';
27
+
28
+ export interface DataTableProps<TData, TValue> {
29
+ columns: ColumnDef<TData, TValue>[];
30
+ data: TData[];
31
+ // Optional controlled states
32
+ loading: boolean;
33
+ sorting?: boolean;
34
+ sortingState?: SortingState;
35
+ onSortingChange?: (newState: SortingState) => void;
36
+ columnFilters?: boolean;
37
+ columnFiltersState?: ColumnFiltersState;
38
+ onColumnFiltersChange?: (newState: ColumnFiltersState) => void;
39
+ rowCount?: number;
40
+ pagination?: boolean;
41
+ paginationState?: PaginationState;
42
+ onPaginationChange?: (newState: PaginationState) => void;
43
+ columnVisibility?: boolean;
44
+ columnVisibilityState?: VisibilityState;
45
+ onColumnVisibilityChange?: (newState: VisibilityState) => void;
46
+ // Expose table instance
47
+ onTable?: (table: ReactTable<TData>) => void;
48
+ // UI
49
+ className?: string;
50
+ emptyText?: string;
51
+ // Filters UI (section-based or simple)
52
+ formFilters?: DataTableFiltersProp;
53
+ formFilterValues?: Record<string, unknown> | null;
54
+ onFormFilterChange?: (values: Record<string, unknown>) => void;
55
+ // Selection & Actions
56
+ selectable?: boolean;
57
+ actions?: DataTableAction[];
58
+ batchActions?: DataTableBatchAction<TData>[];
59
+ // Standard actions
60
+ showStandardActions?: boolean;
61
+ onRefresh?: () => void | Promise<void>;
62
+ // Row interactions
63
+ onRowClick?: (row: TData) => void;
64
+ }
65
+
66
+ export default function DataTable<TData, TValue>({
67
+ columns,
68
+ data,
69
+ loading,
70
+ sorting,
71
+ sortingState,
72
+ onSortingChange,
73
+ columnFilters,
74
+ columnFiltersState,
75
+ onColumnFiltersChange,
76
+ rowCount,
77
+ pagination,
78
+ onPaginationChange,
79
+ paginationState,
80
+ columnVisibility,
81
+ columnVisibilityState,
82
+ onColumnVisibilityChange,
83
+ onTable,
84
+ className,
85
+ emptyText = 'No results.',
86
+ formFilters,
87
+ formFilterValues,
88
+ onFormFilterChange,
89
+ selectable,
90
+ actions,
91
+ batchActions,
92
+ showStandardActions,
93
+ onRefresh,
94
+ onRowClick,
95
+ }: DataTableProps<TData, TValue>) {
96
+ const [rowSelection, setRowSelection] = React.useState<Record<string, boolean>>({});
97
+ const [internalSortingState, setInternalSortingState] = React.useState<SortingState>([]);
98
+ const [internalFiltersState, setInternalFiltersState] = React.useState<ColumnFiltersState>([]);
99
+ const [internalPaginationState, setInternalPaginationState] = React.useState<PaginationState>({ pageIndex: 0, pageSize: 10 });
100
+ const [internalVisibilityState, setInternalVisibilityState] = React.useState<VisibilityState>({});
101
+
102
+ const effectiveSortingState = sortingState ?? internalSortingState;
103
+ const effectiveFiltersState = columnFiltersState ?? internalFiltersState;
104
+ const effectiveVisibilityState = columnVisibilityState ?? internalVisibilityState;
105
+ const effectivePaginationState = paginationState ?? internalPaginationState;
106
+
107
+ const isPaginationEnabled = pagination;
108
+ const isManualPaginationEnabled = paginationState !== undefined && onPaginationChange !== undefined;
109
+ const isSortingEnabled = sorting;
110
+ const isColumnFiltersEnabled = columnFilters;
111
+ const isColumnVisibilityEnabled = columnVisibility;
112
+
113
+ // Build selection-aware columns by injecting a selection column at the start
114
+ const selectionColumn = React.useMemo<ColumnDef<TData, unknown>>(() => ({
115
+ id: '__select',
116
+ header: ({ table }) => (
117
+ <Checkbox
118
+ checked={table.getIsAllPageRowsSelected() || (table.getIsSomePageRowsSelected() && 'indeterminate')}
119
+ onCheckedChange={val => table.toggleAllPageRowsSelected(!!val)}
120
+ aria-label="Select all"
121
+ />
122
+ ),
123
+ cell: ({ row }) => (
124
+ <Checkbox
125
+ checked={row.getIsSelected()}
126
+ onCheckedChange={val => row.toggleSelected(!!val)}
127
+ aria-label="Select row"
128
+ onClick={e => e.stopPropagation()}
129
+ />
130
+ ),
131
+ enableSorting: false,
132
+ enableHiding: false,
133
+ size: 32,
134
+ minSize: 32,
135
+ maxSize: 32,
136
+ }), []);
137
+
138
+ const renderedColumns = React.useMemo(
139
+ () => (selectable ? [selectionColumn as unknown as ColumnDef<TData, TValue>, ...columns] : columns),
140
+ [selectable, selectionColumn, columns]
141
+ );
142
+
143
+ const table = useReactTable({
144
+ data,
145
+ columns: renderedColumns,
146
+ initialState: {
147
+ pagination: effectivePaginationState,
148
+ },
149
+ rowCount,
150
+ state: {
151
+ sorting: effectiveSortingState,
152
+ columnFilters: effectiveFiltersState,
153
+ pagination: effectivePaginationState,
154
+ columnVisibility: effectiveVisibilityState,
155
+ ...(selectable ? { rowSelection } : {}),
156
+ },
157
+ enableRowSelection: !!selectable,
158
+ onRowSelectionChange: selectable ? setRowSelection : undefined,
159
+ manualPagination: isManualPaginationEnabled,
160
+ enableSorting: isSortingEnabled,
161
+ enableColumnFilters: isColumnFiltersEnabled,
162
+ onSortingChange: isSortingEnabled ? updater => {
163
+ const next = typeof updater === 'function' ? (updater as (old: SortingState) => SortingState)(effectiveSortingState) : updater;
164
+ setInternalSortingState(next);
165
+ onSortingChange?.(next);
166
+ } : undefined,
167
+ onColumnFiltersChange: isColumnFiltersEnabled ? updater => {
168
+ const next = typeof updater === 'function' ? (updater as (old: ColumnFiltersState) => ColumnFiltersState)(effectiveFiltersState) : updater;
169
+ setInternalFiltersState(next);
170
+ onColumnFiltersChange?.(next);
171
+ } : undefined,
172
+ onPaginationChange: isPaginationEnabled ? updater => {
173
+ const next = typeof updater === 'function' ? (updater as (old: PaginationState) => PaginationState)(effectivePaginationState) : updater;
174
+ setInternalPaginationState(next);
175
+ onPaginationChange?.(next);
176
+ } : undefined,
177
+ onColumnVisibilityChange: updater => {
178
+ const next = typeof updater === 'function' ? (updater as (old: VisibilityState) => VisibilityState)(effectiveVisibilityState) : updater;
179
+ setInternalVisibilityState(next);
180
+ onColumnVisibilityChange?.(next);
181
+ },
182
+ getCoreRowModel: getCoreRowModel(),
183
+ getSortedRowModel: getSortedRowModel(),
184
+ getFilteredRowModel: getFilteredRowModel(),
185
+ getPaginationRowModel: getPaginationRowModel(),
186
+ });
187
+
188
+ // Notify parent of table instance
189
+ React.useEffect(() => {
190
+ if (onTable) onTable(table);
191
+ }, [onTable, table]);
192
+
193
+ // Selected rows convenience
194
+ const selectedRows = table.getSelectedRowModel().rows.map(r => r.original as TData);
195
+
196
+ // Safe action arrays to avoid array literal defaults in props
197
+ const safeActions = React.useMemo(() => actions ?? [], [actions]);
198
+ const safeBatchActions = React.useMemo(() => batchActions ?? [], [batchActions]);
199
+
200
+ // Skeleton row keys (avoid using array index as key)
201
+ const skeletonRowKeys = React.useMemo(
202
+ () => Array.from({ length: Math.max(3, effectivePaginationState.pageSize ?? 10) }, () => Math.random().toString(36).slice(2)),
203
+ [effectivePaginationState.pageSize]
204
+ );
205
+
206
+ // Standard actions state
207
+ const handleRefresh = React.useCallback(async () => {
208
+ if (!onRefresh) return;
209
+ await onRefresh();
210
+ }, [onRefresh]);
211
+
212
+ // Render a button from action definition
213
+ const renderActionButton = (action: DataTableAction, key: React.Key) => {
214
+ if (action.element) return <React.Fragment key={key}>{action.element}</React.Fragment>;
215
+ const content = (
216
+ <>
217
+ {action.icon && action.iconPosition !== 'right' && <span className="mr-2">{action.icon}</span>}
218
+ {action.label}
219
+ {action.icon && action.iconPosition === 'right' && <span className="ml-2">{action.icon}</span>}
220
+ </>
221
+ );
222
+ return (
223
+ <Button
224
+ key={key}
225
+ size="sm"
226
+ variant={action.variant ?? 'default'}
227
+ disabled={action.disabled}
228
+ onClick={action.onClick}
229
+ className="h-8"
230
+ >
231
+ {content}
232
+ </Button>
233
+ );
234
+ };
235
+
236
+ const renderBatchButton = (action: DataTableBatchAction<TData>, key: React.Key) => {
237
+ if (action.element) return <React.Fragment key={key}>{action.element}</React.Fragment>;
238
+ const onClick = () => action.onClick?.({ selectedRows, clearSelection: () => table.resetRowSelection() });
239
+ const content = (
240
+ <>
241
+ {action.icon && action.iconPosition !== 'right' && <span className="mr-2">{action.icon}</span>}
242
+ {action.label}
243
+ {action.icon && action.iconPosition === 'right' && <span className="ml-2">{action.icon}</span>}
244
+ </>
245
+ );
246
+ return (
247
+ <Button
248
+ key={key}
249
+ size="sm"
250
+ variant={action.variant ?? 'default'}
251
+ disabled={action.disabled}
252
+ onClick={onClick}
253
+ className="h-8"
254
+ >
255
+ {content}
256
+ </Button>
257
+ );
258
+ };
259
+
260
+ return (
261
+ <div className={cn('space-y-3', className)}>
262
+ {formFilters && formFilters.length && (
263
+ <div className="rounded-md border">
264
+ <Accordion type="single" collapsible className="w-full" defaultValue="filters">
265
+ <AccordionItem value="filters">
266
+ <AccordionTrigger className="px-4 py-3 border-b text-md">Filters</AccordionTrigger>
267
+ <AccordionContent className="px-4 pb-4 pt-5">
268
+ <FormBuilder
269
+ key={JSON.stringify(formFilterValues ?? {})}
270
+ sections={formFilters as FormBuilderSectionConfig[]}
271
+ defaultValues={formFilterValues}
272
+ onSubmit={data => onFormFilterChange?.(data as Record<string, unknown>)}
273
+ onReset={() => onFormFilterChange?.({})}
274
+ showActions
275
+ submitLabel="Apply"
276
+ resetLabel="Clear"
277
+ />
278
+ </AccordionContent>
279
+ </AccordionItem>
280
+ </Accordion>
281
+ </div>
282
+ )}
283
+ {/* Actions Bar */}
284
+ {(safeActions.length || showStandardActions || (selectable && table.getSelectedRowModel().rows.length > 0 && safeBatchActions.length)) && (
285
+ <div className="rounded-md border p-2">
286
+ <div className="flex items-center justify-between">
287
+ <div className="flex items-center gap-2">
288
+ {selectable && table.getSelectedRowModel().rows.length > 0 && safeBatchActions.map((a) => renderBatchButton(a, a.key))}
289
+ </div>
290
+ <div className="flex items-center gap-2">
291
+ {showStandardActions && onRefresh && (
292
+ <Button
293
+ variant="outline"
294
+ size="sm"
295
+ onClick={handleRefresh}
296
+ disabled={loading}
297
+ className="h-8"
298
+ title="Refresh"
299
+ >
300
+ <RefreshCw className={cn('h-4 w-4', loading && 'animate-spin')} /> Refresh
301
+ </Button>
302
+ )}
303
+ {isColumnVisibilityEnabled ? (
304
+ <DataTableViewOptions table={table} />
305
+ ) : null}
306
+ {safeActions.map((a) => renderActionButton(a, a.key))}
307
+ </div>
308
+ </div>
309
+ </div>
310
+ )}
311
+ <div className="relative overflow-hidden rounded-md border" aria-busy={loading || undefined}>
312
+ {loading && (
313
+ <div className="pointer-events-none absolute inset-0 z-10 flex items-start justify-end p-2">
314
+ <span className="inline-flex items-center gap-2 rounded bg-background/80 px-2 py-1 text-xs shadow-sm ring-1 ring-border">
315
+ <Loader2 className="h-3.5 w-3.5 animate-spin" /> Loading...
316
+ </span>
317
+ </div>
318
+ )}
319
+ <Table>
320
+ <TableHeader>
321
+ {table.getHeaderGroups().map(headerGroup => (
322
+ <TableRow key={headerGroup.id}>
323
+ {headerGroup.headers.map(header => (
324
+ <TableHead key={header.id}>
325
+ {header.isPlaceholder
326
+ ? null
327
+ : flexRender(header.column.columnDef.header, header.getContext())}
328
+ </TableHead>
329
+ ))}
330
+ </TableRow>
331
+ ))}
332
+ </TableHeader>
333
+ <TableBody>
334
+ {loading ? (
335
+ skeletonRowKeys.map((rowKey) => (
336
+ <TableRow key={`skeleton-${rowKey}`}>
337
+ {table.getVisibleLeafColumns().map((col) => (
338
+ <TableCell key={`skeleton-cell-${rowKey}-${col.id}`}>
339
+ <Skeleton className="h-4 w-full" />
340
+ </TableCell>
341
+ ))}
342
+ </TableRow>
343
+ ))
344
+ ) : table.getRowModel().rows?.length ? (
345
+ table.getRowModel().rows.map(row => (
346
+ <TableRow
347
+ key={row.id}
348
+ data-state={row.getIsSelected() && 'selected'}
349
+ className={cn(onRowClick && 'cursor-pointer hover:bg-muted/50')}
350
+ onClick={onRowClick ? () => onRowClick(row.original as TData) : undefined}
351
+ >
352
+ {row.getVisibleCells().map(cell => (
353
+ <TableCell key={cell.id}>
354
+ {flexRender(cell.column.columnDef.cell, cell.getContext())}
355
+ </TableCell>
356
+ ))}
357
+ </TableRow>
358
+ ))
359
+ ) : (
360
+ <TableRow>
361
+ <TableCell colSpan={table.getVisibleLeafColumns().length} className="h-24 text-center">
362
+ {emptyText}
363
+ </TableCell>
364
+ </TableRow>
365
+ )}
366
+ </TableBody>
367
+ </Table>
368
+ </div>
369
+
370
+ {isPaginationEnabled && (
371
+ <DataTablePagination table={table} />
372
+ )}
373
+ </div>
374
+ );
375
+ }
@@ -0,0 +1,63 @@
1
+ import * as React from 'react';
2
+ import { type Column } from '@tanstack/react-table';
3
+ import { ArrowDown, ArrowUp, ChevronsUpDown, EyeOff } from 'lucide-react';
4
+ import { cn } from '../../../../shadcn/lib/utils';
5
+ import { Button } from '../../../../shadcn/ui/button';
6
+ import {
7
+ DropdownMenu,
8
+ DropdownMenuContent,
9
+ DropdownMenuItem,
10
+ DropdownMenuSeparator,
11
+ DropdownMenuTrigger,
12
+ } from '../../../../shadcn/ui/dropdown-menu';
13
+
14
+ export interface DataTableColumnHeaderProps<TData, TValue>
15
+ extends React.HTMLAttributes<HTMLDivElement> {
16
+ column: Column<TData, TValue>;
17
+ label?: string;
18
+ }
19
+
20
+ export function DataTableColumnHeader<TData, TValue>({
21
+ column,
22
+ label,
23
+ className,
24
+ }: DataTableColumnHeaderProps<TData, TValue>) {
25
+ label = (column.columnDef.meta as { label?: string })?.label ?? label;
26
+
27
+ if (!column.getCanSort()) {
28
+ return <div className={cn(className)}>{label}</div>;
29
+ }
30
+
31
+ return (
32
+ <div className={cn('flex items-center gap-2', className)}>
33
+ <DropdownMenu>
34
+ <DropdownMenuTrigger asChild>
35
+ <Button variant="ghost" size="sm" className="data-[state=open]:bg-accent -ml-3 h-8">
36
+ <span>{label}</span>
37
+ {column.getIsSorted() === 'desc' ? (
38
+ <ArrowDown className="ml-2 size-4" />
39
+ ) : column.getIsSorted() === 'asc' ? (
40
+ <ArrowUp className="ml-2 size-4" />
41
+ ) : (
42
+ <ChevronsUpDown className="ml-2 size-4" />
43
+ )}
44
+ </Button>
45
+ </DropdownMenuTrigger>
46
+ <DropdownMenuContent align="start">
47
+ <DropdownMenuItem onClick={() => column.toggleSorting(false)}>
48
+ <ArrowUp className="mr-2 size-4" /> Asc
49
+ </DropdownMenuItem>
50
+ <DropdownMenuItem onClick={() => column.toggleSorting(true)}>
51
+ <ArrowDown className="mr-2 size-4" /> Desc
52
+ </DropdownMenuItem>
53
+ <DropdownMenuSeparator />
54
+ {column.getCanHide() && (
55
+ <DropdownMenuItem onClick={() => column.toggleVisibility(false)}>
56
+ <EyeOff className="mr-2 size-4" /> Hide
57
+ </DropdownMenuItem>
58
+ )}
59
+ </DropdownMenuContent>
60
+ </DropdownMenu>
61
+ </div>
62
+ );
63
+ }
@@ -0,0 +1,86 @@
1
+ import { type Table } from '@tanstack/react-table';
2
+ import { ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight } from 'lucide-react';
3
+ import { Button } from '../../../../shadcn/ui/button';
4
+ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '../../../../shadcn/ui/select';
5
+
6
+ export interface DataTablePaginationProps<TData> {
7
+ table: Table<TData>;
8
+ }
9
+
10
+ export function DataTablePagination<TData>({ table }: DataTablePaginationProps<TData>) {
11
+ const pagination = table.getState().pagination ?? { pageIndex: 0, pageSize: 10 };
12
+
13
+ return (
14
+ <div className="flex items-center justify-between px-2">
15
+ <div className="text-muted-foreground flex-1 text-sm">
16
+ {table.getFilteredSelectedRowModel().rows.length} of{' '}
17
+ {table.getFilteredRowModel().rows.length} row(s) selected.
18
+ </div>
19
+ <div className="flex items-center space-x-6 lg:space-x-8">
20
+ <div className="flex items-center space-x-2">
21
+ <p className="text-sm font-medium">Rows per page</p>
22
+ <Select
23
+ value={`${pagination.pageSize}`}
24
+ onValueChange={(value) => table.setPageSize(Number(value))}
25
+ >
26
+ <SelectTrigger className="h-8 w-[70px]">
27
+ <SelectValue placeholder={pagination.pageSize} />
28
+ </SelectTrigger>
29
+ <SelectContent side="top">
30
+ {[10, 20, 25, 30, 40, 50].map((pageSize) => (
31
+ <SelectItem key={pageSize} value={`${pageSize}`}>
32
+ {pageSize}
33
+ </SelectItem>
34
+ ))}
35
+ </SelectContent>
36
+ </Select>
37
+ </div>
38
+ <div className="flex w-[100px] items-center justify-center text-sm font-medium">
39
+ Page {pagination.pageIndex + 1} of {table.getPageCount()}
40
+ </div>
41
+ <div className="flex items-center space-x-2">
42
+ <Button
43
+ variant="outline"
44
+ size="icon"
45
+ className="hidden size-8 lg:flex"
46
+ onClick={() => table.setPageIndex(0)}
47
+ disabled={!table.getCanPreviousPage()}
48
+ >
49
+ <span className="sr-only">Go to first page</span>
50
+ <ChevronsLeft className="size-4" />
51
+ </Button>
52
+ <Button
53
+ variant="outline"
54
+ size="icon"
55
+ className="size-8"
56
+ onClick={() => table.previousPage()}
57
+ disabled={!table.getCanPreviousPage()}
58
+ >
59
+ <span className="sr-only">Go to previous page</span>
60
+ <ChevronLeft className="size-4" />
61
+ </Button>
62
+ <Button
63
+ variant="outline"
64
+ size="icon"
65
+ className="size-8"
66
+ onClick={() => table.nextPage()}
67
+ disabled={!table.getCanNextPage()}
68
+ >
69
+ <span className="sr-only">Go to next page</span>
70
+ <ChevronRight className="size-4" />
71
+ </Button>
72
+ <Button
73
+ variant="outline"
74
+ size="icon"
75
+ className="hidden size-8 lg:flex"
76
+ onClick={() => table.setPageIndex(table.getPageCount() - 1)}
77
+ disabled={!table.getCanNextPage()}
78
+ >
79
+ <span className="sr-only">Go to last page</span>
80
+ <ChevronsRight className="size-4" />
81
+ </Button>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ );
86
+ }
@@ -0,0 +1,42 @@
1
+ import { type Table } from '@tanstack/react-table';
2
+ import { Settings2 } from 'lucide-react';
3
+ import { Button } from '../../../../shadcn/ui/button';
4
+ import {
5
+ DropdownMenu,
6
+ DropdownMenuCheckboxItem,
7
+ DropdownMenuContent,
8
+ DropdownMenuLabel,
9
+ DropdownMenuSeparator,
10
+ DropdownMenuTrigger,
11
+ } from '../../../../shadcn/ui/dropdown-menu';
12
+
13
+ export function DataTableViewOptions<TData>({ table }: { table: Table<TData> }) {
14
+ return (
15
+ <DropdownMenu>
16
+ <DropdownMenuTrigger asChild>
17
+ <Button variant="outline" size="sm" className="ml-auto hidden h-8 lg:flex">
18
+ <Settings2 className="mr-2 size-4" /> View
19
+ </Button>
20
+ </DropdownMenuTrigger>
21
+ <DropdownMenuContent align="end" className="w-[180px]">
22
+ <DropdownMenuLabel>Toggle columns</DropdownMenuLabel>
23
+ <DropdownMenuSeparator />
24
+ {table
25
+ .getAllColumns()
26
+ .filter((column) => column.getCanHide())
27
+ .map((column) => {
28
+ return (
29
+ <DropdownMenuCheckboxItem
30
+ key={column.id}
31
+ className="capitalize"
32
+ checked={column.getIsVisible()}
33
+ onCheckedChange={(value) => column.toggleVisibility(!!value)}
34
+ >
35
+ {(column?.columnDef.meta as { label?: string })?.label ?? column.id}
36
+ </DropdownMenuCheckboxItem>
37
+ );
38
+ })}
39
+ </DropdownMenuContent>
40
+ </DropdownMenu>
41
+ );
42
+ }
@@ -0,0 +1,5 @@
1
+ export { default as DataTable } from './components/DataTable';
2
+ export { DataTableColumnHeader } from './components/DataTableColumnHeader';
3
+ export { DataTablePagination } from './components/DataTablePagination';
4
+ export { DataTableViewOptions } from './components/DataTableViewOptions';
5
+ export { dotAccessor } from './utils/dotAccessor';
@@ -0,0 +1,29 @@
1
+ import type { FormBuilderSectionConfig } from '../form/components/FormBuilder';
2
+
3
+ export type DataTableFiltersProp = FormBuilderSectionConfig[];
4
+
5
+ export type IconPosition = 'left' | 'right';
6
+
7
+ export interface DataTableAction {
8
+ key: string;
9
+ label?: React.ReactNode; // string or component
10
+ icon?: React.ReactNode;
11
+ iconPosition?: IconPosition;
12
+ variant?: 'default' | 'destructive' | 'outline' | 'secondary' | 'ghost' | 'link';
13
+ disabled?: boolean;
14
+ onClick?: () => void | Promise<void>;
15
+ // If provided, this element will be rendered directly instead of constructing a Button
16
+ element?: React.ReactNode;
17
+ }
18
+
19
+ export interface DataTableBatchAction<TData = unknown> {
20
+ key: string;
21
+ label?: React.ReactNode;
22
+ icon?: React.ReactNode;
23
+ iconPosition?: IconPosition;
24
+ variant?: 'default' | 'destructive' | 'outline' | 'secondary' | 'ghost' | 'link';
25
+ disabled?: boolean;
26
+ // Receives selected rows and helpers
27
+ onClick?: (args: { selectedRows: TData[]; clearSelection: () => void }) => void | Promise<void>;
28
+ element?: React.ReactNode;
29
+ }
@@ -0,0 +1,6 @@
1
+ import { get } from 'lodash';
2
+
3
+ export function dotAccessor<TData, TValue = unknown>(path: string) {
4
+ return (row: TData) =>
5
+ get(row as unknown as Record<string, unknown>, path) as TValue;
6
+ }
@@ -0,0 +1,2 @@
1
+ export { default as DialogProvider, useDialog, useDialogController } from './provider';
2
+ export type { ConfirmOptions, CustomModalOptions } from './provider';