@k3-universe/react-kit 0.0.9 → 0.0.11

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 (524) hide show
  1. package/dist/index.js +18167 -15061
  2. package/dist/kit/builder/form/components/FormBuilder.d.ts +46 -14
  3. package/dist/kit/builder/form/components/FormBuilder.d.ts.map +1 -1
  4. package/dist/kit/builder/form/components/FormBuilderField.d.ts.map +1 -1
  5. package/dist/kit/builder/form/components/fields/AutocompleteField.d.ts.map +1 -1
  6. package/dist/kit/builder/form/components/fields/DatePickerField.d.ts +3 -0
  7. package/dist/kit/builder/form/components/fields/DatePickerField.d.ts.map +1 -0
  8. package/dist/kit/builder/form/components/fields/DateRangePickerField.d.ts +3 -0
  9. package/dist/kit/builder/form/components/fields/DateRangePickerField.d.ts.map +1 -0
  10. package/dist/kit/builder/form/components/fields/DateTimePickerField.d.ts +4 -0
  11. package/dist/kit/builder/form/components/fields/DateTimePickerField.d.ts.map +1 -0
  12. package/dist/kit/builder/form/components/fields/DateTimeRangePickerField.d.ts +4 -0
  13. package/dist/kit/builder/form/components/fields/DateTimeRangePickerField.d.ts.map +1 -0
  14. package/dist/kit/builder/form/components/fields/MonthPickerField.d.ts +3 -0
  15. package/dist/kit/builder/form/components/fields/MonthPickerField.d.ts.map +1 -0
  16. package/dist/kit/builder/form/components/fields/MonthRangePickerField.d.ts +3 -0
  17. package/dist/kit/builder/form/components/fields/MonthRangePickerField.d.ts.map +1 -0
  18. package/dist/kit/builder/form/components/fields/TimePickerField.d.ts +4 -0
  19. package/dist/kit/builder/form/components/fields/TimePickerField.d.ts.map +1 -0
  20. package/dist/kit/builder/form/components/fields/TimeRangePickerField.d.ts +4 -0
  21. package/dist/kit/builder/form/components/fields/TimeRangePickerField.d.ts.map +1 -0
  22. package/dist/kit/builder/form/components/fields/index.d.ts +8 -0
  23. package/dist/kit/builder/form/components/fields/index.d.ts.map +1 -1
  24. package/dist/kit/builder/section/SectionBuilder.d.ts.map +1 -1
  25. package/dist/kit/builder/section/types.d.ts +12 -1
  26. package/dist/kit/builder/section/types.d.ts.map +1 -1
  27. package/dist/kit/builder/stack-dialog/context.d.ts +3 -0
  28. package/dist/kit/builder/stack-dialog/context.d.ts.map +1 -0
  29. package/dist/kit/builder/stack-dialog/hooks.d.ts +6 -0
  30. package/dist/kit/builder/stack-dialog/hooks.d.ts.map +1 -0
  31. package/dist/kit/builder/stack-dialog/index.d.ts +5 -0
  32. package/dist/kit/builder/stack-dialog/index.d.ts.map +1 -0
  33. package/dist/kit/builder/stack-dialog/provider.d.ts +3 -0
  34. package/dist/kit/builder/stack-dialog/provider.d.ts.map +1 -0
  35. package/dist/kit/builder/stack-dialog/renderer.d.ts +6 -0
  36. package/dist/kit/builder/stack-dialog/renderer.d.ts.map +1 -0
  37. package/dist/kit/builder/stack-dialog/types.d.ts +20 -0
  38. package/dist/kit/builder/stack-dialog/types.d.ts.map +1 -0
  39. package/dist/kit/components/autocomplete/Autocomplete.d.ts +35 -3
  40. package/dist/kit/components/autocomplete/Autocomplete.d.ts.map +1 -1
  41. package/dist/kit/components/autocomplete/index.d.ts +1 -0
  42. package/dist/kit/components/autocomplete/index.d.ts.map +1 -1
  43. package/dist/kit/components/datepicker/DatePicker.d.ts +27 -0
  44. package/dist/kit/components/datepicker/DatePicker.d.ts.map +1 -0
  45. package/dist/kit/components/datepicker/DateRangePicker.d.ts +41 -0
  46. package/dist/kit/components/datepicker/DateRangePicker.d.ts.map +1 -0
  47. package/dist/kit/components/datetimepicker/DateTimePicker.d.ts +32 -0
  48. package/dist/kit/components/datetimepicker/DateTimePicker.d.ts.map +1 -0
  49. package/dist/kit/components/datetimepicker/DateTimeRangePicker.d.ts +39 -0
  50. package/dist/kit/components/datetimepicker/DateTimeRangePicker.d.ts.map +1 -0
  51. package/dist/kit/components/datetimepicker/index.d.ts +5 -0
  52. package/dist/kit/components/datetimepicker/index.d.ts.map +1 -0
  53. package/dist/kit/components/monthpicker/MonthInput.d.ts +26 -0
  54. package/dist/kit/components/monthpicker/MonthInput.d.ts.map +1 -0
  55. package/dist/kit/components/monthpicker/MonthPicker.d.ts +32 -0
  56. package/dist/kit/components/monthpicker/MonthPicker.d.ts.map +1 -0
  57. package/dist/kit/components/monthpicker/MonthRangeInput.d.ts +31 -0
  58. package/dist/kit/components/monthpicker/MonthRangeInput.d.ts.map +1 -0
  59. package/dist/kit/components/monthpicker/MonthRangePicker.d.ts +48 -0
  60. package/dist/kit/components/monthpicker/MonthRangePicker.d.ts.map +1 -0
  61. package/dist/kit/components/timepicker/TimePicker.d.ts +26 -0
  62. package/dist/kit/components/timepicker/TimePicker.d.ts.map +1 -0
  63. package/dist/kit/components/timepicker/TimeRangePicker.d.ts +31 -0
  64. package/dist/kit/components/timepicker/TimeRangePicker.d.ts.map +1 -0
  65. package/dist/kit/components/timepicker/index.d.ts +5 -0
  66. package/dist/kit/components/timepicker/index.d.ts.map +1 -0
  67. package/dist/kit/themes/clean-slate.css +181 -1
  68. package/dist/kit/themes/default.css +181 -1
  69. package/dist/kit/themes/minimal-modern.css +181 -1
  70. package/dist/kit/themes/spotify.css +181 -1
  71. package/package.json +1 -1
  72. package/src/kit/builder/form/components/FormBuilder.tsx +380 -145
  73. package/src/kit/builder/form/components/FormBuilderField.tsx +100 -3
  74. package/src/kit/builder/form/components/fields/AutocompleteField.tsx +29 -1
  75. package/src/kit/builder/form/components/fields/DatePickerField.tsx +24 -0
  76. package/src/kit/builder/form/components/fields/DateRangePickerField.tsx +41 -0
  77. package/src/kit/builder/form/components/fields/DateTimePickerField.tsx +33 -0
  78. package/src/kit/builder/form/components/fields/DateTimeRangePickerField.tsx +42 -0
  79. package/src/kit/builder/form/components/fields/MonthPickerField.tsx +26 -0
  80. package/src/kit/builder/form/components/fields/MonthRangePickerField.tsx +35 -0
  81. package/src/kit/builder/form/components/fields/TimePickerField.tsx +30 -0
  82. package/src/kit/builder/form/components/fields/TimeRangePickerField.tsx +37 -0
  83. package/src/kit/builder/form/components/fields/index.ts +8 -0
  84. package/src/kit/builder/section/SectionBuilder.tsx +24 -2
  85. package/src/kit/builder/section/types.ts +15 -1
  86. package/src/kit/builder/stack-dialog/context.ts +9 -0
  87. package/src/kit/builder/stack-dialog/hooks.ts +11 -0
  88. package/src/kit/builder/stack-dialog/index.ts +13 -0
  89. package/src/kit/builder/stack-dialog/provider.tsx +55 -0
  90. package/src/kit/builder/stack-dialog/renderer.tsx +33 -0
  91. package/src/kit/builder/stack-dialog/types.ts +22 -0
  92. package/src/kit/components/autocomplete/Autocomplete.tsx +783 -233
  93. package/src/kit/components/autocomplete/index.ts +1 -0
  94. package/src/kit/components/datepicker/DatePicker.tsx +149 -0
  95. package/src/kit/components/datepicker/DateRangePicker.tsx +454 -0
  96. package/src/kit/components/datetimepicker/DateTimePicker.tsx +314 -0
  97. package/src/kit/components/datetimepicker/DateTimeRangePicker.tsx +486 -0
  98. package/src/kit/components/datetimepicker/index.ts +3 -0
  99. package/src/kit/components/monthpicker/MonthInput.tsx +122 -0
  100. package/src/kit/components/monthpicker/MonthPicker.tsx +223 -0
  101. package/src/kit/components/monthpicker/MonthRangeInput.tsx +132 -0
  102. package/src/kit/components/monthpicker/MonthRangePicker.tsx +407 -0
  103. package/src/kit/components/timepicker/TimePicker.tsx +311 -0
  104. package/src/kit/components/timepicker/TimeRangePicker.tsx +291 -0
  105. package/src/kit/components/timepicker/index.ts +3 -0
  106. package/src/stories/kit/builder/Form.Autocomplete.stories.tsx +210 -0
  107. package/src/stories/kit/builder/Form.Complex.stories.tsx +101 -0
  108. package/src/stories/kit/builder/Form.DateTime.stories.tsx +66 -0
  109. package/src/stories/kit/builder/Form.Dynamic.stories.tsx +149 -0
  110. package/src/stories/kit/builder/Form.Pickers.stories.tsx +71 -0
  111. package/src/stories/kit/builder/Form.Time.stories.tsx +64 -0
  112. package/src/stories/kit/builder/Section.stories.tsx +58 -2
  113. package/src/stories/kit/components/Autocomplete.stories.tsx +27 -0
  114. package/src/stories/kit/components/DatePicker.stories.tsx +128 -0
  115. package/src/stories/kit/components/DateRangePicker.stories.tsx +154 -0
  116. package/src/stories/kit/components/MonthPicker.stories.tsx +80 -0
  117. package/src/stories/kit/components/MonthRangePicker.stories.tsx +98 -0
  118. package/src/stories/kit/components/TimePicker.stories.tsx +69 -0
  119. package/src/stories/kit/components/TimeRangePicker.stories.tsx +37 -0
  120. package/storybook-static/assets/Accordion.stories-KU4JBR8U.js +52 -0
  121. package/storybook-static/assets/AdminLayout-CPvVCwfY.js +53 -0
  122. package/storybook-static/assets/AdminLayout.Basic.stories-DkP2UVXe.js +4 -0
  123. package/storybook-static/assets/AdminLayout.Collapsible.stories-BuuVjtpW.js +4 -0
  124. package/storybook-static/assets/AdminLayout.Complex.stories-D-k4H0hJ.js +29 -0
  125. package/storybook-static/assets/AdminLayout.CustomSidebarHeaderComponent.stories-B_0IEDd4.js +9 -0
  126. package/storybook-static/assets/AdminLayout.CustomSidebarTitleAndIcon.stories-CvAeXUyA.js +4 -0
  127. package/storybook-static/assets/AdminLayout.HeaderSlots.stories-RBFHoSZK.js +7 -0
  128. package/storybook-static/assets/Alert.stories-DKxKtIc0.js +27 -0
  129. package/storybook-static/assets/AlertDialog.stories-BqTpZ_nG.js +43 -0
  130. package/storybook-static/assets/AspectRatio.stories-DPO9QQ5F.js +22 -0
  131. package/storybook-static/assets/Autocomplete-Cpg4CaJe.js +56 -0
  132. package/storybook-static/assets/Autocomplete.stories-CWj4G5fh.js +56 -0
  133. package/storybook-static/assets/Avatar.stories-DPhov_2g.js +12 -0
  134. package/storybook-static/assets/Badge.stories-DFKrRdXq.js +12 -0
  135. package/storybook-static/assets/Breadcrumb.stories-CTE6CZUC.js +25 -0
  136. package/storybook-static/assets/Button.stories-cbt2InL-.js +26 -0
  137. package/storybook-static/assets/Calendar.stories-DRhTw_43.js +3 -0
  138. package/storybook-static/assets/Card.stories-Isf6n_K3.js +15 -0
  139. package/storybook-static/assets/Carousel.stories-Cmg0I3fR.js +15 -0
  140. package/storybook-static/assets/Chart.stories-aQ-fNijT.js +126 -0
  141. package/storybook-static/assets/Checkbox.stories-B7YMXPDc.js +12 -0
  142. package/storybook-static/assets/Collapsible.stories-BUzl17ZZ.js +18 -0
  143. package/storybook-static/assets/Combination-BdQWAuko.js +41 -0
  144. package/storybook-static/assets/Command.stories-DzBlWQs0.js +30 -0
  145. package/storybook-static/assets/ContextMenu.stories-CJlBQyXc.js +31 -0
  146. package/storybook-static/assets/DataTable.Basic.stories-BWYKFDmK.js +6 -0
  147. package/storybook-static/assets/DataTable.Filters.stories-uZdtJk8t.js +21 -0
  148. package/storybook-static/assets/DataTable.Pagination.stories-C5N1khkp.js +24 -0
  149. package/storybook-static/assets/DataTable.SelectionAndActions.stories-FhCqZKvO.js +26 -0
  150. package/storybook-static/assets/DataTable.Sorting.stories-D-k7EtRj.js +6 -0
  151. package/storybook-static/assets/Dialog.stories-C62AF-Gx.js +54 -0
  152. package/storybook-static/assets/Dialog.stories-lrjRwOus.js +18 -0
  153. package/storybook-static/assets/Drawer.stories-CGjkdJeV.js +24 -0
  154. package/storybook-static/assets/DropdownMenu.stories-DkGClRAA.js +35 -0
  155. package/storybook-static/assets/Form.ArrayLayouts.stories-C5d_062d.js +130 -0
  156. package/storybook-static/assets/Form.Autocomplete.stories-CPZPkk4o.js +142 -0
  157. package/storybook-static/assets/Form.Basic.stories-Bhcu3-3n.js +58 -0
  158. package/storybook-static/assets/Form.Complex.stories-QnXh5a7Q.js +361 -0
  159. package/storybook-static/assets/Form.Dynamic.stories-DFW6wIuT.js +502 -0
  160. package/storybook-static/assets/Form.Simple.stories-BhJcyhbE.js +53 -0
  161. package/storybook-static/assets/Form.stories-PFNsMYxO.js +3 -0
  162. package/storybook-static/assets/FormBuilder-BQBBxo_k.js +5 -0
  163. package/storybook-static/assets/HoverCard.stories-CAlQEVn8.js +21 -0
  164. package/storybook-static/assets/Input.stories-CEhODt0V.js +16 -0
  165. package/storybook-static/assets/InputOtp.stories-DSvNP4dS.js +42 -0
  166. package/storybook-static/assets/Label.stories-B3pa8ZLY.js +14 -0
  167. package/storybook-static/assets/Login.stories-C7KQkmR_.js +37 -0
  168. package/storybook-static/assets/Menubar.stories-CHXhSHxc.js +44 -0
  169. package/storybook-static/assets/MonthPicker.stories-BnrOc4fm.js +99 -0
  170. package/storybook-static/assets/MonthRangePicker.stories-55Gk1t-7.js +134 -0
  171. package/storybook-static/assets/NavigationMenu.stories-CXoS080P.js +30 -0
  172. package/storybook-static/assets/Page.stories-GdSJgZ6-.js +91 -0
  173. package/storybook-static/assets/Pagination.stories-BEBwqH4N.js +29 -0
  174. package/storybook-static/assets/Popover.stories-BICy98Cw.js +15 -0
  175. package/storybook-static/assets/Progress.stories-DECHNOME.js +8 -0
  176. package/storybook-static/assets/RadioGroup.stories-DA7-uKfV.js +16 -0
  177. package/storybook-static/assets/Resizable.stories-B99kWkH7.js +25 -0
  178. package/storybook-static/assets/ScrollArea.stories-BqvUAXqU.js +12 -0
  179. package/storybook-static/assets/Section.stories-lFMlFBQn.js +277 -0
  180. package/storybook-static/assets/SectionBuilder-BQW705x0.js +1 -0
  181. package/storybook-static/assets/Select.stories-BsKyZ6Io.js +17 -0
  182. package/storybook-static/assets/Separator.stories-BTDOaOM2.js +17 -0
  183. package/storybook-static/assets/Sheet.stories-Cam1gR6G.js +24 -0
  184. package/storybook-static/assets/Sidebar.stories-DnOa6G7y.js +106 -0
  185. package/storybook-static/assets/Skeleton.stories-BQNIuIe5.js +9 -0
  186. package/storybook-static/assets/Slider.stories-Bslq7hjq.js +6 -0
  187. package/storybook-static/assets/Sonner.stories-D34pBBtI.js +18 -0
  188. package/storybook-static/assets/Switch.stories-Puyb1-Bx.js +3 -0
  189. package/storybook-static/assets/Table.stories-ClZxAhut.js +35 -0
  190. package/storybook-static/assets/Tabs.stories-CURNTETB.js +10 -0
  191. package/storybook-static/assets/Textarea.stories-Cf1ZBrWw.js +17 -0
  192. package/storybook-static/assets/Toggle.stories-CdMHY_bi.js +3 -0
  193. package/storybook-static/assets/ToggleGroup.stories-BM68m1dX.js +13 -0
  194. package/storybook-static/assets/Tooltip.stories-DiQv64dM.js +10 -0
  195. package/storybook-static/assets/accordion-DVgwQcnw.js +1 -0
  196. package/storybook-static/assets/alert-dialog-DCUEwpqm.js +7 -0
  197. package/storybook-static/assets/avatar-BzwOE-mi.js +1 -0
  198. package/storybook-static/assets/axe-HmUsR1st.js +30 -0
  199. package/storybook-static/assets/badge-BnQWua6u.js +1 -0
  200. package/storybook-static/assets/button-0oMkiryo.js +1 -0
  201. package/storybook-static/assets/card-BJpPOzP8.js +1 -0
  202. package/storybook-static/assets/chart-column-DZGb4ZZS.js +6 -0
  203. package/storybook-static/assets/check-B9hBGj6o.js +6 -0
  204. package/storybook-static/assets/checkbox-CyIeaWHX.js +1 -0
  205. package/storybook-static/assets/chevron-down-D_37S6il.js +6 -0
  206. package/storybook-static/assets/chevron-left-BBoN0vbI.js +6 -0
  207. package/storybook-static/assets/chevron-right-B5vIMLxK.js +6 -0
  208. package/storybook-static/assets/circle-C5Lzx6Nx.js +6 -0
  209. package/storybook-static/assets/clean-slate-D1HmMFJM.css +1 -0
  210. package/storybook-static/assets/command-Csa9p8_a.js +6 -0
  211. package/storybook-static/assets/createLucideIcon-BrHXro7t.js +21 -0
  212. package/storybook-static/assets/default-CN_Fo1GY.css +1 -0
  213. package/storybook-static/assets/dependencies-ctrV69dx.js +1 -0
  214. package/storybook-static/assets/dialog-CsnqITTn.js +1 -0
  215. package/storybook-static/assets/dropdown-menu-BWxxwPHL.js +1 -0
  216. package/storybook-static/assets/ellipsis-BRS038RR.js +6 -0
  217. package/storybook-static/assets/grip-vertical-BxXG8KNA.js +6 -0
  218. package/storybook-static/assets/iframe-C9bogcIc.css +1 -0
  219. package/storybook-static/assets/iframe-v7iAhKit.js +1555 -0
  220. package/storybook-static/assets/index-0-qMRXou.js +1 -0
  221. package/storybook-static/assets/index-AvwFFKJc.js +1 -0
  222. package/storybook-static/assets/index-BVDb4dFc.js +1 -0
  223. package/storybook-static/assets/index-B_qx7A5T.js +1 -0
  224. package/storybook-static/assets/index-BdQq_4o_.js +1 -0
  225. package/storybook-static/assets/index-BfiCOk42.js +1 -0
  226. package/storybook-static/assets/index-Bv9yk470.js +1 -0
  227. package/storybook-static/assets/index-Bw1A27Kp.js +1 -0
  228. package/storybook-static/assets/index-ByqivBWx.js +1 -0
  229. package/storybook-static/assets/index-C9Ta0ZTH.js +1 -0
  230. package/storybook-static/assets/index-CDY5kTx5.js +1 -0
  231. package/storybook-static/assets/index-CGnyVRgB.js +1 -0
  232. package/storybook-static/assets/index-CGrAONsN.js +1 -0
  233. package/storybook-static/assets/index-CWjrGFAQ.js +1 -0
  234. package/storybook-static/assets/index-CwBdPBFz.js +9 -0
  235. package/storybook-static/assets/index-D8RXF03I.js +1 -0
  236. package/storybook-static/assets/index-DLIxT4Z7.js +1 -0
  237. package/storybook-static/assets/index-DW48STyt.js +1 -0
  238. package/storybook-static/assets/index-DbaA6-o1.js +1 -0
  239. package/storybook-static/assets/index-Dph_5COR.js +1 -0
  240. package/storybook-static/assets/index-DrN5n71E.js +1 -0
  241. package/storybook-static/assets/index-Tp9IdbR8.js +1 -0
  242. package/storybook-static/assets/index-WyF3-wTE.js +9 -0
  243. package/storybook-static/assets/index-XSmPROEP.js +1 -0
  244. package/storybook-static/assets/index-Z6wF44KX.js +5 -0
  245. package/storybook-static/assets/index-_RPqOjlQ.js +1 -0
  246. package/storybook-static/assets/index-jrimW4QO.js +1 -0
  247. package/storybook-static/assets/index-nqc17SX4.js +1 -0
  248. package/storybook-static/assets/input-11YRd9gD.js +1 -0
  249. package/storybook-static/assets/jsx-runtime-D_zvdyIk.js +9 -0
  250. package/storybook-static/assets/label-Do8ODIVk.js +1 -0
  251. package/storybook-static/assets/lodash-DDwpuhPG.js +73 -0
  252. package/storybook-static/assets/matchers-7Z3WT2CE-T3xScrR7.js +14 -0
  253. package/storybook-static/assets/minimal-modern-BlYVzfQU.css +1 -0
  254. package/storybook-static/assets/popover-CcciSWAw.js +1 -0
  255. package/storybook-static/assets/preload-helper-Dp1pzeXC.js +1 -0
  256. package/storybook-static/assets/radio-group-DiJ0Y_KQ.js +1 -0
  257. package/storybook-static/assets/react-18-Cr9fq_Ip.js +25 -0
  258. package/storybook-static/assets/react-icons.esm-B_ULMmNU.js +1 -0
  259. package/storybook-static/assets/refresh-cw-BmRDhIV_.js +6 -0
  260. package/storybook-static/assets/schemas-CGNYCiJ6.js +18 -0
  261. package/storybook-static/assets/section-factories-DCCY9R35.js +1 -0
  262. package/storybook-static/assets/select-DDrkxaOg.js +6 -0
  263. package/storybook-static/assets/separator-o5SAUnaJ.js +1 -0
  264. package/storybook-static/assets/settings-2-xWGvvbG6.js +6 -0
  265. package/storybook-static/assets/sheet-C7jhU3XE.js +1 -0
  266. package/storybook-static/assets/shopping-cart-BFlrufvo.js +11 -0
  267. package/storybook-static/assets/sidebar-C8hU1Mxy.js +6 -0
  268. package/storybook-static/assets/skeleton-CjDnQs43.js +1 -0
  269. package/storybook-static/assets/spotify-CUDj7g8m.css +1 -0
  270. package/storybook-static/assets/switch-CKGRuk3u.js +1 -0
  271. package/storybook-static/assets/table-CP3vMqFn.js +1 -0
  272. package/storybook-static/assets/tabs-CopK2m3j.js +1 -0
  273. package/storybook-static/assets/textarea-Dw2vruMl.js +1 -0
  274. package/storybook-static/assets/toggle-DmHbWetf.js +16 -0
  275. package/storybook-static/assets/tooltip-_LqYEYFw.js +1 -0
  276. package/storybook-static/assets/trash-2-xdbApPby.js +11 -0
  277. package/storybook-static/assets/utils-D-KgF5mV.js +1 -0
  278. package/storybook-static/assets/x-B1a4fyWM.js +6 -0
  279. package/storybook-static/favicon-wrapper.svg +46 -0
  280. package/storybook-static/favicon.svg +1 -0
  281. package/storybook-static/iframe.html +687 -0
  282. package/storybook-static/index.d.ts +64 -0
  283. package/storybook-static/index.d.ts.map +1 -0
  284. package/storybook-static/index.html +166 -0
  285. package/storybook-static/index.json +1 -0
  286. package/storybook-static/kit/builder/data-table/components/DataTable.d.ts +37 -0
  287. package/storybook-static/kit/builder/data-table/components/DataTable.d.ts.map +1 -0
  288. package/storybook-static/kit/builder/data-table/components/DataTableColumnHeader.d.ts +8 -0
  289. package/storybook-static/kit/builder/data-table/components/DataTableColumnHeader.d.ts.map +1 -0
  290. package/storybook-static/kit/builder/data-table/components/DataTablePagination.d.ts +6 -0
  291. package/storybook-static/kit/builder/data-table/components/DataTablePagination.d.ts.map +1 -0
  292. package/storybook-static/kit/builder/data-table/components/DataTableViewOptions.d.ts +5 -0
  293. package/storybook-static/kit/builder/data-table/components/DataTableViewOptions.d.ts.map +1 -0
  294. package/storybook-static/kit/builder/data-table/index.d.ts +7 -0
  295. package/storybook-static/kit/builder/data-table/index.d.ts.map +1 -0
  296. package/storybook-static/kit/builder/data-table/types.d.ts +27 -0
  297. package/storybook-static/kit/builder/data-table/types.d.ts.map +1 -0
  298. package/storybook-static/kit/builder/data-table/utils/dotAccessor.d.ts +2 -0
  299. package/storybook-static/kit/builder/data-table/utils/dotAccessor.d.ts.map +1 -0
  300. package/storybook-static/kit/builder/dialog/index.d.ts +3 -0
  301. package/storybook-static/kit/builder/dialog/index.d.ts.map +1 -0
  302. package/storybook-static/kit/builder/dialog/provider.d.ts +26 -0
  303. package/storybook-static/kit/builder/dialog/provider.d.ts.map +1 -0
  304. package/storybook-static/kit/builder/form/components/FormBuilder.d.ts +137 -0
  305. package/storybook-static/kit/builder/form/components/FormBuilder.d.ts.map +1 -0
  306. package/storybook-static/kit/builder/form/components/FormBuilderActions.d.ts +20 -0
  307. package/storybook-static/kit/builder/form/components/FormBuilderActions.d.ts.map +1 -0
  308. package/storybook-static/kit/builder/form/components/FormBuilderField.d.ts +12 -0
  309. package/storybook-static/kit/builder/form/components/FormBuilderField.d.ts.map +1 -0
  310. package/storybook-static/kit/builder/form/components/fields/ArrayField.d.ts +3 -0
  311. package/storybook-static/kit/builder/form/components/fields/ArrayField.d.ts.map +1 -0
  312. package/storybook-static/kit/builder/form/components/fields/AutocompleteField.d.ts +3 -0
  313. package/storybook-static/kit/builder/form/components/fields/AutocompleteField.d.ts.map +1 -0
  314. package/storybook-static/kit/builder/form/components/fields/CheckboxField.d.ts +3 -0
  315. package/storybook-static/kit/builder/form/components/fields/CheckboxField.d.ts.map +1 -0
  316. package/storybook-static/kit/builder/form/components/fields/DateField.d.ts +3 -0
  317. package/storybook-static/kit/builder/form/components/fields/DateField.d.ts.map +1 -0
  318. package/storybook-static/kit/builder/form/components/fields/FileField.d.ts +3 -0
  319. package/storybook-static/kit/builder/form/components/fields/FileField.d.ts.map +1 -0
  320. package/storybook-static/kit/builder/form/components/fields/NumberField.d.ts +3 -0
  321. package/storybook-static/kit/builder/form/components/fields/NumberField.d.ts.map +1 -0
  322. package/storybook-static/kit/builder/form/components/fields/ObjectField.d.ts +3 -0
  323. package/storybook-static/kit/builder/form/components/fields/ObjectField.d.ts.map +1 -0
  324. package/storybook-static/kit/builder/form/components/fields/RadioField.d.ts +3 -0
  325. package/storybook-static/kit/builder/form/components/fields/RadioField.d.ts.map +1 -0
  326. package/storybook-static/kit/builder/form/components/fields/SelectField.d.ts +3 -0
  327. package/storybook-static/kit/builder/form/components/fields/SelectField.d.ts.map +1 -0
  328. package/storybook-static/kit/builder/form/components/fields/SwitchField.d.ts +3 -0
  329. package/storybook-static/kit/builder/form/components/fields/SwitchField.d.ts.map +1 -0
  330. package/storybook-static/kit/builder/form/components/fields/TextField.d.ts +3 -0
  331. package/storybook-static/kit/builder/form/components/fields/TextField.d.ts.map +1 -0
  332. package/storybook-static/kit/builder/form/components/fields/TextareaField.d.ts +3 -0
  333. package/storybook-static/kit/builder/form/components/fields/TextareaField.d.ts.map +1 -0
  334. package/storybook-static/kit/builder/form/components/fields/index.d.ts +14 -0
  335. package/storybook-static/kit/builder/form/components/fields/index.d.ts.map +1 -0
  336. package/storybook-static/kit/builder/form/components/fields/types.d.ts +14 -0
  337. package/storybook-static/kit/builder/form/components/fields/types.d.ts.map +1 -0
  338. package/storybook-static/kit/builder/form/components/index.d.ts +4 -0
  339. package/storybook-static/kit/builder/form/components/index.d.ts.map +1 -0
  340. package/storybook-static/kit/builder/form/index.d.ts +3 -0
  341. package/storybook-static/kit/builder/form/index.d.ts.map +1 -0
  342. package/storybook-static/kit/builder/form/utils/common-forms.d.ts +7 -0
  343. package/storybook-static/kit/builder/form/utils/common-forms.d.ts.map +1 -0
  344. package/storybook-static/kit/builder/form/utils/dependencies.d.ts +41 -0
  345. package/storybook-static/kit/builder/form/utils/dependencies.d.ts.map +1 -0
  346. package/storybook-static/kit/builder/form/utils/field-factories.d.ts +23 -0
  347. package/storybook-static/kit/builder/form/utils/field-factories.d.ts.map +1 -0
  348. package/storybook-static/kit/builder/form/utils/index.d.ts +15 -0
  349. package/storybook-static/kit/builder/form/utils/index.d.ts.map +1 -0
  350. package/storybook-static/kit/builder/form/utils/section-factories.d.ts +7 -0
  351. package/storybook-static/kit/builder/form/utils/section-factories.d.ts.map +1 -0
  352. package/storybook-static/kit/builder/form/utils/transformers.d.ts +6 -0
  353. package/storybook-static/kit/builder/form/utils/transformers.d.ts.map +1 -0
  354. package/storybook-static/kit/builder/form/utils/validations.d.ts +13 -0
  355. package/storybook-static/kit/builder/form/utils/validations.d.ts.map +1 -0
  356. package/storybook-static/kit/builder/form/utils/validators.d.ts +8 -0
  357. package/storybook-static/kit/builder/form/utils/validators.d.ts.map +1 -0
  358. package/storybook-static/kit/builder/page/Page.d.ts +48 -0
  359. package/storybook-static/kit/builder/page/Page.d.ts.map +1 -0
  360. package/storybook-static/kit/builder/page/index.d.ts +2 -0
  361. package/storybook-static/kit/builder/page/index.d.ts.map +1 -0
  362. package/storybook-static/kit/builder/section/SectionBuilder.d.ts +3 -0
  363. package/storybook-static/kit/builder/section/SectionBuilder.d.ts.map +1 -0
  364. package/storybook-static/kit/builder/section/index.d.ts +3 -0
  365. package/storybook-static/kit/builder/section/index.d.ts.map +1 -0
  366. package/storybook-static/kit/builder/section/types.d.ts +70 -0
  367. package/storybook-static/kit/builder/section/types.d.ts.map +1 -0
  368. package/storybook-static/kit/builder/stack-dialog/context.d.ts +3 -0
  369. package/storybook-static/kit/builder/stack-dialog/context.d.ts.map +1 -0
  370. package/storybook-static/kit/builder/stack-dialog/hooks.d.ts +6 -0
  371. package/storybook-static/kit/builder/stack-dialog/hooks.d.ts.map +1 -0
  372. package/storybook-static/kit/builder/stack-dialog/index.d.ts +5 -0
  373. package/storybook-static/kit/builder/stack-dialog/index.d.ts.map +1 -0
  374. package/storybook-static/kit/builder/stack-dialog/provider.d.ts +3 -0
  375. package/storybook-static/kit/builder/stack-dialog/provider.d.ts.map +1 -0
  376. package/storybook-static/kit/builder/stack-dialog/renderer.d.ts +6 -0
  377. package/storybook-static/kit/builder/stack-dialog/renderer.d.ts.map +1 -0
  378. package/storybook-static/kit/builder/stack-dialog/types.d.ts +20 -0
  379. package/storybook-static/kit/builder/stack-dialog/types.d.ts.map +1 -0
  380. package/storybook-static/kit/components/autocomplete/Autocomplete.d.ts +53 -0
  381. package/storybook-static/kit/components/autocomplete/Autocomplete.d.ts.map +1 -0
  382. package/storybook-static/kit/components/autocomplete/index.d.ts +4 -0
  383. package/storybook-static/kit/components/autocomplete/index.d.ts.map +1 -0
  384. package/storybook-static/kit/components/autocomplete/types.d.ts +19 -0
  385. package/storybook-static/kit/components/autocomplete/types.d.ts.map +1 -0
  386. package/storybook-static/kit/components/login/Login.d.ts +29 -0
  387. package/storybook-static/kit/components/login/Login.d.ts.map +1 -0
  388. package/storybook-static/kit/components/login/index.d.ts +2 -0
  389. package/storybook-static/kit/components/login/index.d.ts.map +1 -0
  390. package/storybook-static/kit/components/monthpicker/MonthPicker.d.ts +32 -0
  391. package/storybook-static/kit/components/monthpicker/MonthPicker.d.ts.map +1 -0
  392. package/storybook-static/kit/components/monthpicker/MonthRangePicker.d.ts +48 -0
  393. package/storybook-static/kit/components/monthpicker/MonthRangePicker.d.ts.map +1 -0
  394. package/storybook-static/kit/layouts/admin/components/AdminLayout.d.ts +17 -0
  395. package/storybook-static/kit/layouts/admin/components/AdminLayout.d.ts.map +1 -0
  396. package/storybook-static/kit/layouts/admin/components/ThemeToggle.d.ts +5 -0
  397. package/storybook-static/kit/layouts/admin/components/ThemeToggle.d.ts.map +1 -0
  398. package/storybook-static/kit/layouts/admin/hooks/menu.d.ts +13 -0
  399. package/storybook-static/kit/layouts/admin/hooks/menu.d.ts.map +1 -0
  400. package/storybook-static/kit/layouts/admin/providers/AdminMenuProvider.d.ts +7 -0
  401. package/storybook-static/kit/layouts/admin/providers/AdminMenuProvider.d.ts.map +1 -0
  402. package/storybook-static/kit/layouts/admin/types/index.d.ts +27 -0
  403. package/storybook-static/kit/layouts/admin/types/index.d.ts.map +1 -0
  404. package/storybook-static/kit/providers/ThemeProvider.d.ts +14 -0
  405. package/storybook-static/kit/providers/ThemeProvider.d.ts.map +1 -0
  406. package/storybook-static/nunito-sans-bold-italic.woff2 +0 -0
  407. package/storybook-static/nunito-sans-bold.woff2 +0 -0
  408. package/storybook-static/nunito-sans-italic.woff2 +0 -0
  409. package/storybook-static/nunito-sans-regular.woff2 +0 -0
  410. package/storybook-static/project.json +1 -0
  411. package/storybook-static/sb-addons/a11y-5/manager-bundle.js +5 -0
  412. package/storybook-static/sb-addons/essentials-backgrounds-1/manager-bundle.js +3 -0
  413. package/storybook-static/sb-addons/essentials-measure-2/manager-bundle.js +3 -0
  414. package/storybook-static/sb-addons/essentials-outline-3/manager-bundle.js +3 -0
  415. package/storybook-static/sb-addons/interactions-4/manager-bundle.js +57 -0
  416. package/storybook-static/sb-addons/storybook-core-server-presets-0/common-manager-bundle.js +971 -0
  417. package/storybook-static/sb-addons/storysource-6/manager-bundle.js +3 -0
  418. package/storybook-static/sb-common-assets/favicon-wrapper.svg +46 -0
  419. package/storybook-static/sb-common-assets/favicon.svg +1 -0
  420. package/storybook-static/sb-common-assets/nunito-sans-bold-italic.woff2 +0 -0
  421. package/storybook-static/sb-common-assets/nunito-sans-bold.woff2 +0 -0
  422. package/storybook-static/sb-common-assets/nunito-sans-italic.woff2 +0 -0
  423. package/storybook-static/sb-common-assets/nunito-sans-regular.woff2 +0 -0
  424. package/storybook-static/sb-manager/globals-module-info.js +797 -0
  425. package/storybook-static/sb-manager/globals-runtime.js +69653 -0
  426. package/storybook-static/sb-manager/globals.js +34 -0
  427. package/storybook-static/sb-manager/runtime.js +13181 -0
  428. package/storybook-static/shadcn/hooks/use-mobile.d.ts +2 -0
  429. package/storybook-static/shadcn/hooks/use-mobile.d.ts.map +1 -0
  430. package/storybook-static/shadcn/lib/utils.d.ts +3 -0
  431. package/storybook-static/shadcn/lib/utils.d.ts.map +1 -0
  432. package/storybook-static/shadcn/ui/accordion.d.ts +8 -0
  433. package/storybook-static/shadcn/ui/accordion.d.ts.map +1 -0
  434. package/storybook-static/shadcn/ui/alert-dialog.d.ts +15 -0
  435. package/storybook-static/shadcn/ui/alert-dialog.d.ts.map +1 -0
  436. package/storybook-static/shadcn/ui/alert.d.ts +10 -0
  437. package/storybook-static/shadcn/ui/alert.d.ts.map +1 -0
  438. package/storybook-static/shadcn/ui/aspect-ratio.d.ts +4 -0
  439. package/storybook-static/shadcn/ui/aspect-ratio.d.ts.map +1 -0
  440. package/storybook-static/shadcn/ui/avatar.d.ts +7 -0
  441. package/storybook-static/shadcn/ui/avatar.d.ts.map +1 -0
  442. package/storybook-static/shadcn/ui/badge.d.ts +10 -0
  443. package/storybook-static/shadcn/ui/badge.d.ts.map +1 -0
  444. package/storybook-static/shadcn/ui/breadcrumb.d.ts +12 -0
  445. package/storybook-static/shadcn/ui/breadcrumb.d.ts.map +1 -0
  446. package/storybook-static/shadcn/ui/button.d.ts +11 -0
  447. package/storybook-static/shadcn/ui/button.d.ts.map +1 -0
  448. package/storybook-static/shadcn/ui/calendar.d.ts +9 -0
  449. package/storybook-static/shadcn/ui/calendar.d.ts.map +1 -0
  450. package/storybook-static/shadcn/ui/card.d.ts +10 -0
  451. package/storybook-static/shadcn/ui/card.d.ts.map +1 -0
  452. package/storybook-static/shadcn/ui/carousel.d.ts +20 -0
  453. package/storybook-static/shadcn/ui/carousel.d.ts.map +1 -0
  454. package/storybook-static/shadcn/ui/chart.d.ts +41 -0
  455. package/storybook-static/shadcn/ui/chart.d.ts.map +1 -0
  456. package/storybook-static/shadcn/ui/checkbox.d.ts +5 -0
  457. package/storybook-static/shadcn/ui/checkbox.d.ts.map +1 -0
  458. package/storybook-static/shadcn/ui/collapsible.d.ts +6 -0
  459. package/storybook-static/shadcn/ui/collapsible.d.ts.map +1 -0
  460. package/storybook-static/shadcn/ui/command.d.ts +19 -0
  461. package/storybook-static/shadcn/ui/command.d.ts.map +1 -0
  462. package/storybook-static/shadcn/ui/context-menu.d.ts +26 -0
  463. package/storybook-static/shadcn/ui/context-menu.d.ts.map +1 -0
  464. package/storybook-static/shadcn/ui/dialog.d.ts +16 -0
  465. package/storybook-static/shadcn/ui/dialog.d.ts.map +1 -0
  466. package/storybook-static/shadcn/ui/drawer.d.ts +14 -0
  467. package/storybook-static/shadcn/ui/drawer.d.ts.map +1 -0
  468. package/storybook-static/shadcn/ui/dropdown-menu.d.ts +26 -0
  469. package/storybook-static/shadcn/ui/dropdown-menu.d.ts.map +1 -0
  470. package/storybook-static/shadcn/ui/form.d.ts +25 -0
  471. package/storybook-static/shadcn/ui/form.d.ts.map +1 -0
  472. package/storybook-static/shadcn/ui/hover-card.d.ts +7 -0
  473. package/storybook-static/shadcn/ui/hover-card.d.ts.map +1 -0
  474. package/storybook-static/shadcn/ui/input-otp.d.ts +12 -0
  475. package/storybook-static/shadcn/ui/input-otp.d.ts.map +1 -0
  476. package/storybook-static/shadcn/ui/input.d.ts +4 -0
  477. package/storybook-static/shadcn/ui/input.d.ts.map +1 -0
  478. package/storybook-static/shadcn/ui/label.d.ts +5 -0
  479. package/storybook-static/shadcn/ui/label.d.ts.map +1 -0
  480. package/storybook-static/shadcn/ui/menubar.d.ts +27 -0
  481. package/storybook-static/shadcn/ui/menubar.d.ts.map +1 -0
  482. package/storybook-static/shadcn/ui/navigation-menu.d.ts +15 -0
  483. package/storybook-static/shadcn/ui/navigation-menu.d.ts.map +1 -0
  484. package/storybook-static/shadcn/ui/pagination.d.ts +14 -0
  485. package/storybook-static/shadcn/ui/pagination.d.ts.map +1 -0
  486. package/storybook-static/shadcn/ui/popover.d.ts +8 -0
  487. package/storybook-static/shadcn/ui/popover.d.ts.map +1 -0
  488. package/storybook-static/shadcn/ui/progress.d.ts +5 -0
  489. package/storybook-static/shadcn/ui/progress.d.ts.map +1 -0
  490. package/storybook-static/shadcn/ui/radio-group.d.ts +6 -0
  491. package/storybook-static/shadcn/ui/radio-group.d.ts.map +1 -0
  492. package/storybook-static/shadcn/ui/resizable.d.ts +9 -0
  493. package/storybook-static/shadcn/ui/resizable.d.ts.map +1 -0
  494. package/storybook-static/shadcn/ui/scroll-area.d.ts +6 -0
  495. package/storybook-static/shadcn/ui/scroll-area.d.ts.map +1 -0
  496. package/storybook-static/shadcn/ui/select.d.ts +16 -0
  497. package/storybook-static/shadcn/ui/select.d.ts.map +1 -0
  498. package/storybook-static/shadcn/ui/separator.d.ts +5 -0
  499. package/storybook-static/shadcn/ui/separator.d.ts.map +1 -0
  500. package/storybook-static/shadcn/ui/sheet.d.ts +14 -0
  501. package/storybook-static/shadcn/ui/sheet.d.ts.map +1 -0
  502. package/storybook-static/shadcn/ui/sidebar.d.ts +70 -0
  503. package/storybook-static/shadcn/ui/sidebar.d.ts.map +1 -0
  504. package/storybook-static/shadcn/ui/skeleton.d.ts +3 -0
  505. package/storybook-static/shadcn/ui/skeleton.d.ts.map +1 -0
  506. package/storybook-static/shadcn/ui/slider.d.ts +5 -0
  507. package/storybook-static/shadcn/ui/slider.d.ts.map +1 -0
  508. package/storybook-static/shadcn/ui/sonner.d.ts +4 -0
  509. package/storybook-static/shadcn/ui/sonner.d.ts.map +1 -0
  510. package/storybook-static/shadcn/ui/switch.d.ts +5 -0
  511. package/storybook-static/shadcn/ui/switch.d.ts.map +1 -0
  512. package/storybook-static/shadcn/ui/table.d.ts +11 -0
  513. package/storybook-static/shadcn/ui/table.d.ts.map +1 -0
  514. package/storybook-static/shadcn/ui/tabs.d.ts +8 -0
  515. package/storybook-static/shadcn/ui/tabs.d.ts.map +1 -0
  516. package/storybook-static/shadcn/ui/textarea.d.ts +4 -0
  517. package/storybook-static/shadcn/ui/textarea.d.ts.map +1 -0
  518. package/storybook-static/shadcn/ui/toggle-group.d.ts +8 -0
  519. package/storybook-static/shadcn/ui/toggle-group.d.ts.map +1 -0
  520. package/storybook-static/shadcn/ui/toggle.d.ts +10 -0
  521. package/storybook-static/shadcn/ui/toggle.d.ts.map +1 -0
  522. package/storybook-static/shadcn/ui/tooltip.d.ts +8 -0
  523. package/storybook-static/shadcn/ui/tooltip.d.ts.map +1 -0
  524. package/storybook-static/vite-inject-mocker-entry.js +18 -0
@@ -0,0 +1,486 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ import { Calendar as CalendarIcon } from 'lucide-react';
5
+ import { cn } from '../../../shadcn/lib/utils';
6
+ import { Button } from '../../../shadcn/ui/button';
7
+ import { Popover, PopoverContent, PopoverTrigger } from '../../../shadcn/ui/popover';
8
+ import { Calendar } from '../../../shadcn/ui/calendar';
9
+ import {
10
+ Select,
11
+ SelectContent,
12
+ SelectItem,
13
+ SelectTrigger,
14
+ SelectValue,
15
+ } from '../../../shadcn/ui/select';
16
+
17
+ export type TimePrecision = 'hour' | 'minute' | 'second';
18
+
19
+ export interface DateTimeRangeValue {
20
+ from?: Date | null;
21
+ to?: Date | null;
22
+ }
23
+
24
+ export interface DateTimeRangePickerProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {
25
+ value?: DateTimeRangeValue | null;
26
+ onChange?: (range: DateTimeRangeValue | null) => void;
27
+ placeholder?: string;
28
+ disabled?: boolean;
29
+ minDate?: Date;
30
+ maxDate?: Date;
31
+ disabledDates?: Array<Date | { from: Date; to: Date }>;
32
+ numberOfMonths?: number;
33
+ popoverSide?: 'top' | 'right' | 'bottom' | 'left';
34
+ // time config
35
+ timePrecision?: TimePrecision; // default 'minute'
36
+ hourCycle?: 12 | 24; // default 24
37
+ minuteStep?: number; // default 5
38
+ secondStep?: number; // default 5
39
+ buttonVariant?: React.ComponentProps<typeof Button>['variant'];
40
+ open?: boolean;
41
+ onOpenChange?: (open: boolean) => void;
42
+ showFooter?: boolean; // default true
43
+ cancelLabel?: string; // default 'Cancel'
44
+ applyLabel?: string; // default 'Apply'
45
+ clearLabel?: string; // default 'Clear'
46
+ contentClassName?: string; // custom classes for the inner content container
47
+ }
48
+
49
+ const pad2 = (n: number) => String(n).padStart(2, '0');
50
+ function startOfDay(d: Date) { return new Date(d.getFullYear(), d.getMonth(), d.getDate()); }
51
+ function sameDay(a: Date, b: Date) { return a.getFullYear() === b.getFullYear() && a.getMonth() === b.getMonth() && a.getDate() === b.getDate(); }
52
+ function isBefore(date: Date, min?: Date) { return !!(min && date < startOfDay(min)); }
53
+ function isAfter(date: Date, max?: Date) { return !!(max && date > startOfDay(max)); }
54
+ function inDisabled(date: Date, items?: Array<Date | { from: Date; to: Date }>) {
55
+ if (!items || items.length === 0) return false;
56
+ const d = startOfDay(date);
57
+ for (const it of items) {
58
+ if (it instanceof Date) {
59
+ if (sameDay(d, it)) return true;
60
+ } else if (it && 'from' in it && 'to' in it) {
61
+ const from = startOfDay(it.from);
62
+ const to = startOfDay(it.to);
63
+ if (d >= from && d <= to) return true;
64
+ }
65
+ }
66
+ return false;
67
+ }
68
+ function rangeContainsDisabled(from?: Date, to?: Date, items?: Array<Date | { from: Date; to: Date }>) {
69
+ if (!from || !to) return false;
70
+ if (!items || items.length === 0) return false;
71
+ const a = startOfDay(from); const b = startOfDay(to);
72
+ const start = a <= b ? a : b; const end = a <= b ? b : a;
73
+ let cur = start;
74
+ while (cur <= end) {
75
+ if (inDisabled(cur, items)) return true;
76
+ cur = new Date(cur.getFullYear(), cur.getMonth(), cur.getDate() + 1);
77
+ }
78
+ return false;
79
+ }
80
+
81
+ function TimeSelectors({
82
+ label,
83
+ value,
84
+ onChange,
85
+ precision,
86
+ hourCycle,
87
+ minuteStep,
88
+ secondStep,
89
+ disabled,
90
+ compact,
91
+ }: {
92
+ label: string;
93
+ value: Date | null | undefined;
94
+ onChange: (val: Date | null) => void;
95
+ precision: TimePrecision;
96
+ hourCycle: 12 | 24;
97
+ minuteStep: number;
98
+ secondStep: number;
99
+ disabled?: boolean;
100
+ compact?: boolean;
101
+ }) {
102
+ const hours = React.useMemo(() => (hourCycle === 12 ? Array.from({ length: 12 }, (_, i) => i + 1) : Array.from({ length: 24 }, (_, i) => i)), [hourCycle]);
103
+ const minutes = React.useMemo(() => Array.from({ length: Math.ceil(60 / minuteStep) }, (_, i) => i * minuteStep), [minuteStep]);
104
+ const seconds = React.useMemo(() => Array.from({ length: Math.ceil(60 / secondStep) }, (_, i) => i * secondStep), [secondStep]);
105
+ const selectedHour = React.useMemo(() => {
106
+ if (!value) return hourCycle === 12 ? 12 : 0;
107
+ const h = value.getHours();
108
+ return hourCycle === 12 ? (h % 12 === 0 ? 12 : h % 12) : h;
109
+ }, [value, hourCycle]);
110
+ const selectedMinute = value?.getMinutes() ?? 0;
111
+ const selectedSecond = value?.getSeconds() ?? 0;
112
+ const selectedPeriod: 'AM' | 'PM' = value && value.getHours() >= 12 ? 'PM' : 'AM';
113
+
114
+ const setPart = (part: 'hour' | 'minute' | 'second' | 'period', v: number | 'AM' | 'PM') => {
115
+ const base = value
116
+ ? new Date(value)
117
+ : (() => {
118
+ const n = new Date();
119
+ return new Date(n.getFullYear(), n.getMonth(), n.getDate(), 0, 0, 0, 0);
120
+ })();
121
+ if (part === 'hour') {
122
+ let h = Number(v);
123
+ if (hourCycle === 12) {
124
+ const isPM = base.getHours() >= 12;
125
+ h = h % 12;
126
+ base.setHours(isPM ? (h === 12 ? 12 : h + 12) : (h === 12 ? 0 : h));
127
+ } else {
128
+ base.setHours(h);
129
+ }
130
+ } else if (part === 'minute') {
131
+ base.setMinutes(Number(v));
132
+ } else if (part === 'second') {
133
+ base.setSeconds(Number(v));
134
+ } else if (part === 'period' && (v === 'AM' || v === 'PM')) {
135
+ const curH = base.getHours();
136
+ const isAMNow = curH < 12;
137
+ if (v === 'AM' && !isAMNow) base.setHours(curH - 12);
138
+ if (v === 'PM' && isAMNow) base.setHours(curH + 12);
139
+ }
140
+ base.setMilliseconds(0);
141
+ onChange(base);
142
+ };
143
+
144
+ const widthClass = compact ? 'w-16' : 'w-24';
145
+ return (
146
+ <div className={compact ? '' : 'space-y-1'}>
147
+ {!compact && <div className="text-xs text-muted-foreground">{label}</div>}
148
+ <div className="flex items-end gap-2">
149
+ <div className={widthClass}>
150
+ {!compact && <div className="mb-1 block text-xs text-muted-foreground">Hour</div>}
151
+ <Select disabled={disabled} value={String(selectedHour)} onValueChange={(v) => setPart('hour', Number(v))}>
152
+ <SelectTrigger aria-label={`${label} hour`}>
153
+ <SelectValue />
154
+ </SelectTrigger>
155
+ <SelectContent>
156
+ {hours.map((h) => (
157
+ <SelectItem key={h} value={String(h)}>{hourCycle === 12 ? h : pad2(h)}</SelectItem>
158
+ ))}
159
+ </SelectContent>
160
+ </Select>
161
+ </div>
162
+ {(precision === 'minute' || precision === 'second') && (
163
+ <div className={widthClass}>
164
+ {!compact && <div className="mb-1 block text-xs text-muted-foreground">Minute</div>}
165
+ <Select disabled={disabled} value={String(selectedMinute - (selectedMinute % minuteStep))} onValueChange={(v) => setPart('minute', Number(v))}>
166
+ <SelectTrigger aria-label={`${label} minute`}>
167
+ <SelectValue />
168
+ </SelectTrigger>
169
+ <SelectContent>
170
+ {minutes.map((m) => (
171
+ <SelectItem key={m} value={String(m)}>{pad2(m)}</SelectItem>
172
+ ))}
173
+ </SelectContent>
174
+ </Select>
175
+ </div>
176
+ )}
177
+ {precision === 'second' && (
178
+ <div className={widthClass}>
179
+ {!compact && <div className="mb-1 block text-xs text-muted-foreground">Second</div>}
180
+ <Select disabled={disabled} value={String(selectedSecond - (selectedSecond % secondStep))} onValueChange={(v) => setPart('second', Number(v))}>
181
+ <SelectTrigger aria-label={`${label} second`}>
182
+ <SelectValue />
183
+ </SelectTrigger>
184
+ <SelectContent>
185
+ {seconds.map((s) => (
186
+ <SelectItem key={s} value={String(s)}>{pad2(s)}</SelectItem>
187
+ ))}
188
+ </SelectContent>
189
+ </Select>
190
+ </div>
191
+ )}
192
+ {hourCycle === 12 && (
193
+ <div className={widthClass}>
194
+ {!compact && <div className="mb-1 block text-xs text-muted-foreground">Period</div>}
195
+ <Select disabled={disabled} value={selectedPeriod} onValueChange={(v) => setPart('period', v as 'AM' | 'PM')}>
196
+ <SelectTrigger aria-label={`${label} period`}>
197
+ <SelectValue />
198
+ </SelectTrigger>
199
+ <SelectContent>
200
+ <SelectItem value="AM">AM</SelectItem>
201
+ <SelectItem value="PM">PM</SelectItem>
202
+ </SelectContent>
203
+ </Select>
204
+ </div>
205
+ )}
206
+ </div>
207
+ </div>
208
+ );
209
+ }
210
+
211
+ export function DateTimeRangePicker({
212
+ value,
213
+ onChange,
214
+ placeholder = 'Pick a date & time range',
215
+ disabled,
216
+ minDate,
217
+ maxDate,
218
+ disabledDates,
219
+ numberOfMonths = 2,
220
+ popoverSide,
221
+ timePrecision = 'minute',
222
+ hourCycle = 24,
223
+ minuteStep = 5,
224
+ secondStep = 5,
225
+ className,
226
+ buttonVariant = 'outline',
227
+ contentClassName,
228
+ ...props
229
+ }: DateTimeRangePickerProps) {
230
+ const [internalOpen, setInternalOpen] = React.useState(false);
231
+ const isOpen = typeof props.open === 'boolean' ? props.open : internalOpen;
232
+ const setOpen = (o: boolean) => (props.onOpenChange ? props.onOpenChange(o) : setInternalOpen(o));
233
+ const [draft, setDraft] = React.useState<DateTimeRangeValue | null>(value ?? null);
234
+
235
+ React.useEffect(() => {
236
+ if (isOpen) setDraft(value ?? null);
237
+ }, [isOpen, value]);
238
+
239
+ const fmtTime = React.useCallback((d?: Date | null) => {
240
+ if (!d) return '';
241
+ const h = d.getHours();
242
+ const m = d.getMinutes();
243
+ const s = d.getSeconds();
244
+ return hourCycle === 12
245
+ ? `${((h % 12) || 12)}:${pad2(m)}${timePrecision === 'second' ? `:${pad2(s)}` : ''} ${h >= 12 ? 'PM' : 'AM'}`
246
+ : `${pad2(h)}:${pad2(m)}${timePrecision === 'second' ? `:${pad2(s)}` : ''}`;
247
+ }, [hourCycle, timePrecision]);
248
+
249
+ const label = React.useMemo(() => {
250
+ const f = draft?.from ?? value?.from ?? null;
251
+ const t = draft?.to ?? value?.to ?? null;
252
+ if (f && t) {
253
+ const fd = f.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: '2-digit' });
254
+ const td = t.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: '2-digit' });
255
+ return `${fd} ${fmtTime(f)} – ${td} ${fmtTime(t)}`;
256
+ }
257
+ return placeholder;
258
+ }, [draft, value, placeholder, fmtTime]);
259
+
260
+ // Date inputs and parsing (DD / MM / YYYY)
261
+ const fmtDate = React.useCallback((d?: Date | null) => {
262
+ if (!d) return '';
263
+ const dd = String(d.getDate()).padStart(2, '0');
264
+ const mm = String(d.getMonth() + 1).padStart(2, '0');
265
+ const yyyy = d.getFullYear();
266
+ return `${dd} / ${mm} / ${yyyy}`;
267
+ }, []);
268
+ const [fromInput, setFromInput] = React.useState<string>(fmtDate(draft?.from ?? value?.from ?? null));
269
+ const [toInput, setToInput] = React.useState<string>(fmtDate(draft?.to ?? value?.to ?? null));
270
+ React.useEffect(() => {
271
+ if (isOpen) {
272
+ setFromInput(fmtDate(value?.from ?? null));
273
+ setToInput(fmtDate(value?.to ?? null));
274
+ }
275
+ }, [isOpen, value, fmtDate]);
276
+ const maskDate = (raw: string) => {
277
+ const digits = raw.replace(/\D/g, '').slice(0, 8);
278
+ const parts: string[] = [];
279
+ const dd = digits.slice(0, Math.min(2, digits.length)); if (dd) parts.push(dd);
280
+ const mm = digits.length > 2 ? digits.slice(2, Math.min(4, digits.length)) : ''; if (mm) parts.push(mm);
281
+ const yyyy = digits.length > 4 ? digits.slice(4) : ''; if (yyyy) parts.push(yyyy);
282
+ return parts.join(' / ');
283
+ };
284
+ const parseMasked = (masked: string): Date | undefined => {
285
+ const m = masked.match(/^(\d{1,2})\s*\/\s*(\d{1,2})\s*\/\s*(\d{4})$/);
286
+ if (!m) return undefined;
287
+ const dd = Number(m[1]); const mm = Number(m[2]); const yyyy = Number(m[3]);
288
+ if (mm < 1 || mm > 12) return undefined;
289
+ const lastDay = new Date(yyyy, mm, 0).getDate();
290
+ if (dd < 1 || dd > lastDay) return undefined;
291
+ const out = new Date(yyyy, mm - 1, dd);
292
+ if (isBefore(out, minDate) || isAfter(out, maxDate) || inDisabled(out, disabledDates)) return undefined;
293
+ return out;
294
+ };
295
+ const fromParsed = parseMasked(fromInput);
296
+ const toParsed = parseMasked(toInput);
297
+ const mergedFrom = React.useMemo(() => {
298
+ if (fromParsed) {
299
+ const base = draft?.from ?? value?.from ?? null;
300
+ if (base) {
301
+ return new Date(
302
+ fromParsed.getFullYear(),
303
+ fromParsed.getMonth(),
304
+ fromParsed.getDate(),
305
+ base.getHours(),
306
+ base.getMinutes(),
307
+ base.getSeconds()
308
+ );
309
+ }
310
+ return fromParsed;
311
+ }
312
+ return draft?.from ?? undefined;
313
+ }, [fromParsed, draft, value]);
314
+ const mergedTo = React.useMemo(() => {
315
+ if (toParsed) {
316
+ const base = draft?.to ?? value?.to ?? null;
317
+ if (base) {
318
+ return new Date(
319
+ toParsed.getFullYear(),
320
+ toParsed.getMonth(),
321
+ toParsed.getDate(),
322
+ base.getHours(),
323
+ base.getMinutes(),
324
+ base.getSeconds()
325
+ );
326
+ }
327
+ return toParsed;
328
+ }
329
+ return draft?.to ?? undefined;
330
+ }, [toParsed, draft, value]);
331
+ const invalidRange = !mergedFrom || !mergedTo || isBefore(mergedFrom, minDate) || isAfter(mergedTo, maxDate) || mergedFrom > mergedTo || rangeContainsDisabled(mergedFrom, mergedTo, disabledDates);
332
+
333
+ return (
334
+ <div className={cn('w-fit', className)} {...props}>
335
+ <Popover open={isOpen} onOpenChange={setOpen}>
336
+ <PopoverTrigger asChild>
337
+ <Button type="button" disabled={disabled} variant={buttonVariant} className={cn('w-[360px] justify-start text-left font-normal', !value && 'text-muted-foreground')}>
338
+ <CalendarIcon className="mr-2 h-4 w-4" />
339
+ {label}
340
+ </Button>
341
+ </PopoverTrigger>
342
+ <PopoverContent className="w-auto max-w-none p-4" align="start" side={popoverSide ?? 'bottom'} sideOffset={8}>
343
+ <div className={cn('w-fit min-w-0', contentClassName)}>
344
+ {/* Header row: date inputs with inline time selectors beside each */}
345
+ <div className="mb-3 rounded-md border border-input bg-background/50 px-3 py-2">
346
+ <div className="flex flex-wrap items-end gap-3">
347
+ <div className="flex items-end gap-2">
348
+ <input
349
+ type="text"
350
+ inputMode="numeric"
351
+ value={fromInput}
352
+ onChange={(e) => setFromInput(maskDate(e.target.value))}
353
+ onBlur={() => {
354
+ const p = parseMasked(fromInput);
355
+ if (p) {
356
+ const prev = draft?.from ?? null;
357
+ const withTime = new Date(
358
+ p.getFullYear(),
359
+ p.getMonth(),
360
+ p.getDate(),
361
+ prev ? prev.getHours() : 0,
362
+ prev ? prev.getMinutes() : 0,
363
+ prev ? prev.getSeconds() : 0
364
+ );
365
+ setDraft((d) => ({ ...(d ?? {}), from: withTime }));
366
+ }
367
+ }}
368
+ placeholder="dd/mm/yyyy"
369
+ className="h-9 w-40 rounded-md border bg-background px-3 text-sm shadow-xs outline-hidden"
370
+ />
371
+ <TimeSelectors
372
+ label="From"
373
+ compact
374
+ value={draft?.from ?? null}
375
+ onChange={(d) => setDraft((prev) => ({ ...(prev ?? {}), from: d }))}
376
+ precision={timePrecision}
377
+ hourCycle={hourCycle}
378
+ minuteStep={minuteStep}
379
+ secondStep={secondStep}
380
+ disabled={disabled}
381
+ />
382
+ </div>
383
+ <span className="text-muted-foreground">–</span>
384
+ <div className="flex items-end gap-2">
385
+ <input
386
+ type="text"
387
+ inputMode="numeric"
388
+ value={toInput}
389
+ onChange={(e) => setToInput(maskDate(e.target.value))}
390
+ onBlur={() => {
391
+ const p = parseMasked(toInput);
392
+ if (p) {
393
+ const prev = draft?.to ?? null;
394
+ const withTime = new Date(
395
+ p.getFullYear(),
396
+ p.getMonth(),
397
+ p.getDate(),
398
+ prev ? prev.getHours() : 0,
399
+ prev ? prev.getMinutes() : 0,
400
+ prev ? prev.getSeconds() : 0
401
+ );
402
+ setDraft((d) => ({ ...(d ?? {}), to: withTime }));
403
+ }
404
+ }}
405
+ placeholder="dd/mm/yyyy"
406
+ className="h-9 w-40 rounded-md border bg-background px-3 text-sm shadow-xs outline-hidden"
407
+ />
408
+ <TimeSelectors
409
+ label="To"
410
+ compact
411
+ value={draft?.to ?? null}
412
+ onChange={(d) => setDraft((prev) => ({ ...(prev ?? {}), to: d }))}
413
+ precision={timePrecision}
414
+ hourCycle={hourCycle}
415
+ minuteStep={minuteStep}
416
+ secondStep={secondStep}
417
+ disabled={disabled}
418
+ />
419
+ </div>
420
+ </div>
421
+ </div>
422
+
423
+ {/* Calendar */}
424
+ <Calendar
425
+ mode="range"
426
+ numberOfMonths={numberOfMonths}
427
+ selected={draft?.from && draft?.to ? { from: draft.from, to: draft.to } : undefined}
428
+ onSelect={(range) => {
429
+ if (disabled) return;
430
+ if (!range) { setDraft(null); return; }
431
+ const { from, to } = range as { from?: Date; to?: Date };
432
+ if (from && (isBefore(from, minDate) || isAfter(from, maxDate))) return;
433
+ if (to && (isBefore(to, minDate) || isAfter(to, maxDate))) return;
434
+ if (from && to && rangeContainsDisabled(from, to, disabledDates)) return;
435
+ const prevFrom = draft?.from ?? from;
436
+ const prevTo = draft?.to ?? to;
437
+ const nextFrom = from
438
+ ? new Date(from.getFullYear(), from.getMonth(), from.getDate(), prevFrom?.getHours?.() ?? 0, prevFrom?.getMinutes?.() ?? 0, prevFrom?.getSeconds?.() ?? 0)
439
+ : undefined;
440
+ const nextTo = to
441
+ ? new Date(to.getFullYear(), to.getMonth(), to.getDate(), prevTo?.getHours?.() ?? 0, prevTo?.getMinutes?.() ?? 0, prevTo?.getSeconds?.() ?? 0)
442
+ : undefined;
443
+ setDraft({ from: nextFrom ?? null, to: nextTo ?? null });
444
+ setFromInput(fmtDate(nextFrom ?? null));
445
+ setToInput(fmtDate(nextTo ?? null));
446
+ }}
447
+ defaultMonth={draft?.from ?? value?.from ?? new Date()}
448
+ disabled={(d) => isBefore(d, minDate) || isAfter(d, maxDate) || inDisabled(d, disabledDates)}
449
+ buttonVariant="ghost"
450
+ showOutsideDays
451
+ />
452
+ </div>
453
+ {(props.showFooter ?? true) && (
454
+ <div className="flex items-center justify-between gap-2 pt-3 mt-3 border-t">
455
+ <Button type="button" variant="outline" size="sm" onClick={() => setOpen(false)} disabled={disabled}>
456
+ {props.cancelLabel ?? 'Cancel'}
457
+ </Button>
458
+ <div className="flex gap-2">
459
+ <Button type="button" variant="ghost" size="sm" onClick={() => onChange?.(null)} disabled={disabled}>
460
+ {props.clearLabel ?? 'Clear'}
461
+ </Button>
462
+ <Button
463
+ type="button"
464
+ variant="default"
465
+ size="sm"
466
+ onClick={() => {
467
+ if (invalidRange || !mergedFrom || !mergedTo) return;
468
+ onChange?.({ from: mergedFrom, to: mergedTo });
469
+ setOpen(false);
470
+ }}
471
+ disabled={disabled || invalidRange}
472
+ >
473
+ {props.applyLabel ?? 'Apply'}
474
+ </Button>
475
+ </div>
476
+ </div>
477
+ )}
478
+ </PopoverContent>
479
+ </Popover>
480
+ </div>
481
+ );
482
+ }
483
+
484
+ DateTimeRangePicker.displayName = 'DateTimeRangePicker';
485
+
486
+ export default DateTimeRangePicker;
@@ -0,0 +1,3 @@
1
+ export { DateTimePicker } from './DateTimePicker'
2
+ export { DateTimeRangePicker } from './DateTimeRangePicker'
3
+ export default void 0
@@ -0,0 +1,122 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ import { Calendar as CalendarIcon } from 'lucide-react';
5
+ import { cn } from '../../../shadcn/lib/utils';
6
+ import { Button } from '../../../shadcn/ui/button';
7
+ import { Popover, PopoverContent, PopoverTrigger } from '../../../shadcn/ui/popover';
8
+ import { MonthPicker } from './MonthPicker';
9
+
10
+ export interface MonthInputProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {
11
+ value?: Date | null;
12
+ onChange?: (date: Date | null) => void;
13
+ placeholder?: string;
14
+ disabled?: boolean;
15
+ minDate?: Date;
16
+ maxDate?: Date;
17
+ disabledDates?: Date[];
18
+ format?: (date: Date) => string;
19
+ buttonVariant?: React.ComponentProps<typeof Button>['variant'];
20
+ open?: boolean;
21
+ onOpenChange?: (open: boolean) => void;
22
+ showFooter?: boolean; // default true
23
+ cancelLabel?: string; // default 'Cancel'
24
+ applyLabel?: string; // default 'Apply'
25
+ // Back-compat aliases
26
+ clearLabel?: string;
27
+ closeLabel?: string;
28
+ }
29
+
30
+ export function MonthInput({
31
+ value,
32
+ onChange,
33
+ placeholder = 'Pick a month',
34
+ disabled,
35
+ minDate,
36
+ maxDate,
37
+ disabledDates,
38
+ format,
39
+ className,
40
+ buttonVariant = 'outline',
41
+ ...props
42
+ }: MonthInputProps) {
43
+ const [internalOpen, setInternalOpen] = React.useState(false);
44
+ const isOpen = typeof props.open === 'boolean' ? props.open : internalOpen;
45
+ const setOpen = (o: boolean) => (props.onOpenChange ? props.onOpenChange(o) : setInternalOpen(o));
46
+ const [draft, setDraft] = React.useState<Date | null>(value ?? null);
47
+
48
+ React.useEffect(() => {
49
+ if (isOpen) {
50
+ // Reset draft when opening to current value
51
+ setDraft(value ?? null);
52
+ }
53
+ }, [isOpen, value]);
54
+
55
+ const label = value
56
+ ? format
57
+ ? format(value)
58
+ : value.toLocaleDateString(undefined, { year: 'numeric', month: 'short' })
59
+ : placeholder;
60
+
61
+ return (
62
+ <div className={cn('w-fit', className)} {...props}>
63
+ <Popover open={isOpen} onOpenChange={setOpen}>
64
+ <PopoverTrigger asChild>
65
+ <Button
66
+ type="button"
67
+ disabled={disabled}
68
+ variant={buttonVariant}
69
+ className={cn('w-[240px] justify-start text-left font-normal', !value && 'text-muted-foreground')}
70
+ >
71
+ <CalendarIcon className="mr-2 h-4 w-4" />
72
+ {label}
73
+ </Button>
74
+ </PopoverTrigger>
75
+ <PopoverContent className="p-0" align="start">
76
+ <MonthPicker
77
+ selectedMonth={draft ?? undefined}
78
+ onMonthSelect={(d) => {
79
+ if (disabled) return;
80
+ setDraft(d ?? null);
81
+ }}
82
+ minDate={minDate}
83
+ maxDate={maxDate}
84
+ disabledDates={disabledDates}
85
+ variant={{
86
+ calendar: { main: 'ghost', selected: 'default' },
87
+ chevrons: 'outline',
88
+ }}
89
+ />
90
+ {(props.showFooter ?? true) && (
91
+ <div className="flex items-center justify-between gap-2 p-2 border-t">
92
+ <Button
93
+ type="button"
94
+ variant="outline"
95
+ size="sm"
96
+ onClick={() => setOpen(false)}
97
+ disabled={disabled}
98
+ >
99
+ {props.cancelLabel ?? props.clearLabel ?? 'Cancel'}
100
+ </Button>
101
+ <Button
102
+ type="button"
103
+ variant="default"
104
+ size="sm"
105
+ onClick={() => {
106
+ onChange?.(draft ?? null);
107
+ setOpen(false);
108
+ }}
109
+ >
110
+ {props.applyLabel ?? props.closeLabel ?? 'Apply'}
111
+ </Button>
112
+ </div>
113
+ )}
114
+ </PopoverContent>
115
+ </Popover>
116
+ </div>
117
+ );
118
+ }
119
+
120
+ MonthInput.displayName = 'MonthInput';
121
+
122
+ export default MonthInput;