@tulip-systems/core 0.5.1 → 0.5.3

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 (381) hide show
  1. package/dist/components/common/icons.d.mts +52 -52
  2. package/dist/components/common/icons.d.mts.map +1 -1
  3. package/dist/components/common/status.d.mts +3 -3
  4. package/dist/components/common/status.d.mts.map +1 -1
  5. package/dist/components/editor/components/content.client.d.mts +2 -2
  6. package/dist/components/editor/components/editor.client.d.mts +4 -4
  7. package/dist/components/editor/components/editor.client.mjs +2 -2
  8. package/dist/components/editor/components/editor.client.mjs.map +1 -1
  9. package/dist/components/editor/components/menu.client.d.mts +3 -3
  10. package/dist/components/editor/components/menu.client.mjs +3 -0
  11. package/dist/components/editor/components/menu.client.mjs.map +1 -1
  12. package/dist/components/editor/extensions/file-handler/extension.d.mts +21 -0
  13. package/dist/components/editor/extensions/file-handler/extension.d.mts.map +1 -0
  14. package/dist/components/editor/extensions/file-handler/extension.mjs +40 -0
  15. package/dist/components/editor/extensions/file-handler/extension.mjs.map +1 -0
  16. package/dist/components/editor/extensions/file-handler/strategy.d.mts +29 -0
  17. package/dist/components/editor/extensions/file-handler/strategy.d.mts.map +1 -0
  18. package/dist/components/editor/extensions/file-handler/strategy.mjs +111 -0
  19. package/dist/components/editor/extensions/file-handler/strategy.mjs.map +1 -0
  20. package/dist/components/editor/extensions/file-handler/utils.mjs +50 -0
  21. package/dist/components/editor/extensions/file-handler/utils.mjs.map +1 -0
  22. package/dist/components/editor/extensions/image/extension.d.mts +8 -0
  23. package/dist/components/editor/extensions/image/extension.d.mts.map +1 -0
  24. package/dist/components/editor/extensions/image/extension.mjs +52 -0
  25. package/dist/components/editor/extensions/image/extension.mjs.map +1 -0
  26. package/dist/components/editor/extensions/skeleton/extension.mjs +41 -0
  27. package/dist/components/editor/extensions/skeleton/extension.mjs.map +1 -0
  28. package/dist/components/editor/extensions/skeleton/renderer.mjs +25 -0
  29. package/dist/components/editor/extensions/skeleton/renderer.mjs.map +1 -0
  30. package/dist/components/editor/lib/constants.d.mts +29 -26
  31. package/dist/components/editor/lib/constants.d.mts.map +1 -1
  32. package/dist/components/editor/lib/constants.mjs +14 -2
  33. package/dist/components/editor/lib/constants.mjs.map +1 -1
  34. package/dist/components/editor/lib/extensions.d.mts +5 -1
  35. package/dist/components/editor/lib/extensions.d.mts.map +1 -1
  36. package/dist/components/editor/lib/extensions.mjs.map +1 -1
  37. package/dist/components/editor/lib/variants.mjs +10 -2
  38. package/dist/components/editor/lib/variants.mjs.map +1 -1
  39. package/dist/components/header/back-button.client.d.mts +2 -2
  40. package/dist/components/header/bottom-bar.client.d.mts +3 -3
  41. package/dist/components/header/breadcrumbs.client.d.mts +7 -7
  42. package/dist/components/header/header.client.d.mts +2 -2
  43. package/dist/components/header/mobile-nav-switcher.client.d.mts +2 -2
  44. package/dist/components/header/top-bar.client.d.mts +4 -4
  45. package/dist/components/layouts/admin-content.client.d.mts +2 -2
  46. package/dist/components/layouts/admin-layout.d.mts +2 -2
  47. package/dist/components/layouts/admin-loading.d.mts +2 -2
  48. package/dist/components/layouts/admin-loading.d.mts.map +1 -1
  49. package/dist/components/layouts/empty-page.d.mts +4 -4
  50. package/dist/components/layouts/empty-page.d.mts.map +1 -1
  51. package/dist/components/layouts/list-layout.d.mts +2 -2
  52. package/dist/components/layouts/list-layout.d.mts.map +1 -1
  53. package/dist/components/layouts/not-found-page.d.mts +3 -3
  54. package/dist/components/layouts/not-found-page.d.mts.map +1 -1
  55. package/dist/components/layouts/providers.client.d.mts +2 -2
  56. package/dist/components/layouts/root-layout.server.d.mts +2 -2
  57. package/dist/components/layouts/root-layout.server.d.mts.map +1 -1
  58. package/dist/components/layouts/root-loading.d.mts +2 -2
  59. package/dist/components/layouts/root-loading.d.mts.map +1 -1
  60. package/dist/components/layouts/tab-layout.d.mts +2 -2
  61. package/dist/components/layouts/tab-layout.d.mts.map +1 -1
  62. package/dist/components/lists/data-list.d.mts +5 -5
  63. package/dist/components/lists/data-list.d.mts.map +1 -1
  64. package/dist/components/lists/data-stack.d.mts +8 -8
  65. package/dist/components/navigation/admin-sidebar-paths.client.d.mts +10 -10
  66. package/dist/components/ui/accordion.d.mts +5 -5
  67. package/dist/components/ui/alert-dialog.d.mts +12 -12
  68. package/dist/components/ui/alert.d.mts +6 -6
  69. package/dist/components/ui/aspect-ratio.d.mts +2 -2
  70. package/dist/components/ui/avatar.client.d.mts +4 -4
  71. package/dist/components/ui/badge.d.mts +4 -4
  72. package/dist/components/ui/breadcrumb.d.mts +8 -8
  73. package/dist/components/ui/breadcrumb.d.mts.map +1 -1
  74. package/dist/components/ui/button.d.mts +5 -5
  75. package/dist/components/ui/button.d.mts.map +1 -1
  76. package/dist/components/ui/calendar.d.mts +3 -3
  77. package/dist/components/ui/calendar.d.mts.map +1 -1
  78. package/dist/components/ui/card.d.mts +7 -7
  79. package/dist/components/ui/card.d.mts.map +1 -1
  80. package/dist/components/ui/carousel.d.mts +6 -6
  81. package/dist/components/ui/carousel.d.mts.map +1 -1
  82. package/dist/components/ui/chart.client.d.mts +5 -5
  83. package/dist/components/ui/checkbox.d.mts +2 -2
  84. package/dist/components/ui/checkbox.d.mts.map +1 -1
  85. package/dist/components/ui/collapsible.client.d.mts +4 -4
  86. package/dist/components/ui/color-picker.client.d.mts +2 -2
  87. package/dist/components/ui/combobox-dropdown.client.d.mts +2 -2
  88. package/dist/components/ui/combobox.client.d.mts +2 -2
  89. package/dist/components/ui/command.d.mts +10 -10
  90. package/dist/components/ui/command.d.mts.map +1 -1
  91. package/dist/components/ui/context-menu.d.mts +16 -16
  92. package/dist/components/ui/date-picker.client.d.mts +2 -2
  93. package/dist/components/ui/dialog.client.d.mts +11 -11
  94. package/dist/components/ui/drawer.client.d.mts +11 -11
  95. package/dist/components/ui/dropdown-menu.d.mts +16 -16
  96. package/dist/components/ui/form.client.d.mts +7 -7
  97. package/dist/components/ui/hover-card.client.d.mts +4 -4
  98. package/dist/components/ui/input-recipient.d.mts +2 -2
  99. package/dist/components/ui/input.d.mts +2 -2
  100. package/dist/components/ui/label.d.mts +2 -2
  101. package/dist/components/ui/navigation-menu.d.mts +11 -11
  102. package/dist/components/ui/pagination.d.mts +8 -8
  103. package/dist/components/ui/popover.d.mts +5 -5
  104. package/dist/components/ui/popover.d.mts.map +1 -1
  105. package/dist/components/ui/progress.client.d.mts +2 -2
  106. package/dist/components/ui/radio-group.d.mts +3 -3
  107. package/dist/components/ui/resizable.client.d.mts +4 -4
  108. package/dist/components/ui/scroll-area.d.mts +3 -3
  109. package/dist/components/ui/select.client.d.mts +11 -11
  110. package/dist/components/ui/separator.d.mts +2 -2
  111. package/dist/components/ui/sheet.client.d.mts +9 -9
  112. package/dist/components/ui/sidebar.client.d.mts +24 -24
  113. package/dist/components/ui/skeleton.d.mts +2 -2
  114. package/dist/components/ui/slider.d.mts +2 -2
  115. package/dist/components/ui/sonner.client.d.mts +2 -2
  116. package/dist/components/ui/switch.d.mts +2 -2
  117. package/dist/components/ui/tabs.d.mts +5 -5
  118. package/dist/components/ui/textarea.d.mts +2 -2
  119. package/dist/components/ui/time-input.client.d.mts +2 -2
  120. package/dist/components/ui/toggle-group.client.d.mts +3 -3
  121. package/dist/components/ui/toggle.d.mts +2 -2
  122. package/dist/components/ui/tooltip.client.d.mts +5 -5
  123. package/dist/components.d.mts +2 -1
  124. package/dist/components.mjs +3 -2
  125. package/dist/data-tables.d.mts +2 -2
  126. package/dist/data-tables.mjs +2 -2
  127. package/dist/inline-edit/client.d.mts +2 -3
  128. package/dist/inline-edit/client.mjs +1 -2
  129. package/dist/lib/client.d.mts +2 -2
  130. package/dist/lib/client.mjs +2 -2
  131. package/dist/lib/hooks/use-action.d.mts +2 -2
  132. package/dist/lib/hooks/use-indicator.d.mts +11 -3
  133. package/dist/lib/hooks/use-indicator.d.mts.map +1 -1
  134. package/dist/lib/hooks/use-indicator.mjs +19 -8
  135. package/dist/lib/hooks/use-indicator.mjs.map +1 -1
  136. package/dist/modules/auth/components/allowed.client.d.mts +2 -2
  137. package/dist/modules/auth/components/allowed.client.d.mts.map +1 -1
  138. package/dist/modules/auth/components/auth-layout.server.d.mts +2 -2
  139. package/dist/modules/auth/components/auth-layout.server.d.mts.map +1 -1
  140. package/dist/modules/auth/components/auth-loading.d.mts +2 -2
  141. package/dist/modules/auth/components/create-first-user-page.client.d.mts +2 -2
  142. package/dist/modules/auth/components/create-first-user-page.client.d.mts.map +1 -1
  143. package/dist/modules/auth/components/forget-password-page.client.d.mts +2 -2
  144. package/dist/modules/auth/components/forget-password-page.client.d.mts.map +1 -1
  145. package/dist/modules/auth/components/guard-first-user.server.d.mts +2 -2
  146. package/dist/modules/auth/components/guard-first-user.server.d.mts.map +1 -1
  147. package/dist/modules/auth/components/guard.server.d.mts +2 -2
  148. package/dist/modules/auth/components/guard.server.d.mts.map +1 -1
  149. package/dist/modules/auth/components/login-page.client.d.mts +2 -2
  150. package/dist/modules/auth/components/login-page.client.d.mts.map +1 -1
  151. package/dist/modules/auth/components/reset-password-page.client.d.mts +2 -2
  152. package/dist/modules/auth/components/reset-password-page.client.d.mts.map +1 -1
  153. package/dist/modules/auth/components/update-password-command.d.mts +2 -2
  154. package/dist/modules/auth/components/update-password-command.d.mts.map +1 -1
  155. package/dist/modules/auth/db/schema.d.mts +73 -73
  156. package/dist/modules/auth/db/schema.d.mts.map +1 -1
  157. package/dist/modules/auth/handler/client.client.d.mts +8 -8
  158. package/dist/modules/auth/hooks/use-permission.d.mts +2 -2
  159. package/dist/modules/auth/hooks/use-session.d.mts +4 -4
  160. package/dist/modules/auth/lib/validators.d.mts +2 -2
  161. package/dist/modules/auth/lib/validators.d.mts.map +1 -1
  162. package/dist/modules/commands/components/alert-dialog-command.client.d.mts +10 -10
  163. package/dist/modules/commands/components/alert-dialog-command.client.d.mts.map +1 -1
  164. package/dist/modules/commands/components/click-command.client.d.mts +2 -2
  165. package/dist/modules/commands/components/click-command.client.d.mts.map +1 -1
  166. package/dist/modules/commands/components/command-trigger.client.d.mts +6 -6
  167. package/dist/modules/commands/components/command-trigger.client.d.mts.map +1 -1
  168. package/dist/modules/commands/components/dialog-command.client.d.mts +8 -8
  169. package/dist/modules/commands/components/dialog-command.client.d.mts.map +1 -1
  170. package/dist/modules/commands/components/dropdown-command.client.d.mts +5 -5
  171. package/dist/modules/commands/components/dropdown-command.client.d.mts.map +1 -1
  172. package/dist/modules/commands/components/empty-command.client.d.mts +2 -2
  173. package/dist/modules/commands/components/empty-command.client.d.mts.map +1 -1
  174. package/dist/modules/commands/components/form-dialog-command.client.d.mts +11 -11
  175. package/dist/modules/commands/components/form-dialog-command.client.d.mts.map +1 -1
  176. package/dist/modules/commands/hooks/use-command-mutation.client.d.mts +2 -2
  177. package/dist/modules/commands/menus/context-menu.client.d.mts +2 -2
  178. package/dist/modules/commands/menus/context-menu.client.d.mts.map +1 -1
  179. package/dist/modules/commands/menus/dropdown-menu.client.d.mts +3 -3
  180. package/dist/modules/commands/menus/dropdown-menu.client.d.mts.map +1 -1
  181. package/dist/modules/commands/menus/inline-menu.client.d.mts +3 -3
  182. package/dist/modules/commands/menus/inline-menu.client.d.mts.map +1 -1
  183. package/dist/modules/commands/menus/responsive-menu.client.d.mts +3 -3
  184. package/dist/modules/commands/menus/responsive-menu.client.d.mts.map +1 -1
  185. package/dist/modules/commands/utils/archive-command.client.d.mts +3 -3
  186. package/dist/modules/commands/utils/archive-command.client.d.mts.map +1 -1
  187. package/dist/modules/commands/utils/delete-command.client.d.mts +3 -3
  188. package/dist/modules/commands/utils/delete-command.client.d.mts.map +1 -1
  189. package/dist/modules/config/db/helpers.d.mts +5 -5
  190. package/dist/modules/config/db/helpers.d.mts.map +1 -1
  191. package/dist/modules/data-tables/components/cell/common.client.d.mts +5 -5
  192. package/dist/modules/data-tables/components/cell/common.client.d.mts.map +1 -1
  193. package/dist/modules/data-tables/components/column-header.d.mts +2 -2
  194. package/dist/modules/data-tables/components/filters/combobox.client.d.mts +2 -2
  195. package/dist/modules/data-tables/components/filters/combobox.client.d.mts.map +1 -1
  196. package/dist/modules/data-tables/components/filters/slider.client.d.mts +2 -2
  197. package/dist/modules/data-tables/components/filters/slider.client.d.mts.map +1 -1
  198. package/dist/modules/data-tables/components/header.d.mts +4 -4
  199. package/dist/modules/data-tables/components/layout.d.mts +2 -2
  200. package/dist/modules/data-tables/components/search-input.client.d.mts +2 -2
  201. package/dist/modules/data-tables/components/search-input.client.d.mts.map +1 -1
  202. package/dist/modules/data-tables/components/skeleton.d.mts +2 -2
  203. package/dist/modules/data-tables/components/table.d.mts +7 -7
  204. package/dist/modules/data-tables/components/toolbar.d.mts +3 -3
  205. package/dist/modules/data-tables/hooks/use-context.client.d.mts +2 -2
  206. package/dist/modules/data-tables/hooks/use-context.client.d.mts.map +1 -1
  207. package/dist/modules/data-tables/lib/filters/parsers.d.mts +6 -1
  208. package/dist/modules/data-tables/lib/filters/parsers.d.mts.map +1 -1
  209. package/dist/modules/data-tables/lib/filters/parsers.mjs +6 -1
  210. package/dist/modules/data-tables/lib/filters/parsers.mjs.map +1 -1
  211. package/dist/modules/data-tables/tables/data-table/components/table.d.mts +2 -2
  212. package/dist/modules/data-tables/tables/data-table/components/table.d.mts.map +1 -1
  213. package/dist/modules/data-tables/tables/inline-table/components/cells/common.d.mts +2 -2
  214. package/dist/modules/data-tables/tables/inline-table/components/cells/common.d.mts.map +1 -1
  215. package/dist/modules/data-tables/tables/inline-table/components/cells/drag-handle.client.d.mts +2 -2
  216. package/dist/modules/data-tables/tables/inline-table/components/cells/drag-handle.client.d.mts.map +1 -1
  217. package/dist/modules/data-tables/tables/inline-table/components/inputs/advanced-select.client.d.mts +2 -2
  218. package/dist/modules/data-tables/tables/inline-table/components/inputs/advanced-select.client.d.mts.map +1 -1
  219. package/dist/modules/data-tables/tables/inline-table/components/inputs/combobox.client.d.mts +2 -2
  220. package/dist/modules/data-tables/tables/inline-table/components/inputs/combobox.client.d.mts.map +1 -1
  221. package/dist/modules/data-tables/tables/inline-table/components/inputs/input.client.d.mts +3 -3
  222. package/dist/modules/data-tables/tables/inline-table/components/inputs/input.client.d.mts.map +1 -1
  223. package/dist/modules/data-tables/tables/inline-table/components/inputs/read-only.d.mts +2 -2
  224. package/dist/modules/data-tables/tables/inline-table/components/inputs/read-only.d.mts.map +1 -1
  225. package/dist/modules/data-tables/tables/inline-table/components/inputs/select.client.d.mts +2 -2
  226. package/dist/modules/data-tables/tables/inline-table/components/inputs/select.client.d.mts.map +1 -1
  227. package/dist/modules/data-tables/tables/inline-table/components/table.d.mts +2 -2
  228. package/dist/modules/data-tables/tables/inline-table/components/table.d.mts.map +1 -1
  229. package/dist/modules/data-tables/tables/inline-table/hooks/context.client.d.mts +2 -2
  230. package/dist/modules/data-tables/tables/inline-table/hooks/context.client.d.mts.map +1 -1
  231. package/dist/modules/inline-edit/components/combobox-dropdown.client.d.mts +6 -4
  232. package/dist/modules/inline-edit/components/combobox-dropdown.client.d.mts.map +1 -1
  233. package/dist/modules/inline-edit/components/combobox-dropdown.client.mjs +11 -6
  234. package/dist/modules/inline-edit/components/combobox-dropdown.client.mjs.map +1 -1
  235. package/dist/modules/inline-edit/components/combobox.client.d.mts +6 -4
  236. package/dist/modules/inline-edit/components/combobox.client.d.mts.map +1 -1
  237. package/dist/modules/inline-edit/components/combobox.client.mjs +7 -5
  238. package/dist/modules/inline-edit/components/combobox.client.mjs.map +1 -1
  239. package/dist/modules/inline-edit/components/date-input.client.d.mts +5 -3
  240. package/dist/modules/inline-edit/components/date-input.client.d.mts.map +1 -1
  241. package/dist/modules/inline-edit/components/date-input.client.mjs +26 -13
  242. package/dist/modules/inline-edit/components/date-input.client.mjs.map +1 -1
  243. package/dist/modules/inline-edit/components/date-picker.client.d.mts +6 -4
  244. package/dist/modules/inline-edit/components/date-picker.client.d.mts.map +1 -1
  245. package/dist/modules/inline-edit/components/date-picker.client.mjs +12 -7
  246. package/dist/modules/inline-edit/components/date-picker.client.mjs.map +1 -1
  247. package/dist/modules/inline-edit/components/editor.client.d.mts +6 -4
  248. package/dist/modules/inline-edit/components/editor.client.d.mts.map +1 -1
  249. package/dist/modules/inline-edit/components/editor.client.mjs +11 -6
  250. package/dist/modules/inline-edit/components/editor.client.mjs.map +1 -1
  251. package/dist/modules/inline-edit/components/input-recipient.client.d.mts +6 -4
  252. package/dist/modules/inline-edit/components/input-recipient.client.d.mts.map +1 -1
  253. package/dist/modules/inline-edit/components/input-recipient.client.mjs +11 -6
  254. package/dist/modules/inline-edit/components/input-recipient.client.mjs.map +1 -1
  255. package/dist/modules/inline-edit/components/input-toggle.client.d.mts +6 -4
  256. package/dist/modules/inline-edit/components/input-toggle.client.d.mts.map +1 -1
  257. package/dist/modules/inline-edit/components/input-toggle.client.mjs +9 -7
  258. package/dist/modules/inline-edit/components/input-toggle.client.mjs.map +1 -1
  259. package/dist/modules/inline-edit/components/input.client.d.mts +13 -10
  260. package/dist/modules/inline-edit/components/input.client.d.mts.map +1 -1
  261. package/dist/modules/inline-edit/components/input.client.mjs +35 -19
  262. package/dist/modules/inline-edit/components/input.client.mjs.map +1 -1
  263. package/dist/modules/inline-edit/components/select.client.d.mts +10 -9
  264. package/dist/modules/inline-edit/components/select.client.d.mts.map +1 -1
  265. package/dist/modules/inline-edit/components/select.client.mjs +14 -7
  266. package/dist/modules/inline-edit/components/select.client.mjs.map +1 -1
  267. package/dist/modules/inline-edit/components/switch.client.d.mts +5 -3
  268. package/dist/modules/inline-edit/components/switch.client.d.mts.map +1 -1
  269. package/dist/modules/inline-edit/components/switch.client.mjs +8 -6
  270. package/dist/modules/inline-edit/components/switch.client.mjs.map +1 -1
  271. package/dist/modules/inline-edit/components/toggle.client.d.mts +6 -4
  272. package/dist/modules/inline-edit/components/toggle.client.d.mts.map +1 -1
  273. package/dist/modules/inline-edit/components/toggle.client.mjs +9 -7
  274. package/dist/modules/inline-edit/components/toggle.client.mjs.map +1 -1
  275. package/dist/modules/inline-edit/hooks/use-inline.client.d.mts +35 -3
  276. package/dist/modules/inline-edit/hooks/use-inline.client.d.mts.map +1 -1
  277. package/dist/modules/inline-edit/hooks/use-inline.client.mjs +71 -9
  278. package/dist/modules/inline-edit/hooks/use-inline.client.mjs.map +1 -1
  279. package/dist/modules/inline-edit/lib/variants.d.mts +1 -0
  280. package/dist/modules/inline-edit/lib/variants.d.mts.map +1 -1
  281. package/dist/modules/inline-edit/lib/variants.mjs +12 -4
  282. package/dist/modules/inline-edit/lib/variants.mjs.map +1 -1
  283. package/dist/modules/router/handler/init.server.d.mts +6 -6
  284. package/dist/modules/router/handler/init.server.d.mts.map +1 -1
  285. package/dist/modules/router/lib/query-client.server.d.mts +2 -2
  286. package/dist/modules/storage/components/dropzone-context.client.d.mts +2 -2
  287. package/dist/modules/storage/components/dropzone-context.client.d.mts.map +1 -1
  288. package/dist/modules/storage/components/dropzone.client.d.mts +5 -5
  289. package/dist/modules/storage/components/dropzone.client.d.mts.map +1 -1
  290. package/dist/modules/storage/components/dropzone.client.mjs +1 -1
  291. package/dist/modules/storage/components/image-grid.client.d.mts +3 -3
  292. package/dist/modules/storage/components/image-grid.client.d.mts.map +1 -1
  293. package/dist/modules/storage/components/image-grid.client.mjs +3 -3
  294. package/dist/modules/storage/components/image-grid.client.mjs.map +1 -1
  295. package/dist/modules/storage/components/upload-zone-context.client.d.mts +3 -11
  296. package/dist/modules/storage/components/upload-zone-context.client.d.mts.map +1 -1
  297. package/dist/modules/storage/components/upload-zone-context.client.mjs.map +1 -1
  298. package/dist/modules/storage/components/upload-zone.client.d.mts +10 -31
  299. package/dist/modules/storage/components/upload-zone.client.d.mts.map +1 -1
  300. package/dist/modules/storage/components/upload-zone.client.mjs +19 -91
  301. package/dist/modules/storage/components/upload-zone.client.mjs.map +1 -1
  302. package/dist/modules/storage/config/filters.d.mts +2 -0
  303. package/dist/modules/storage/config/filters.d.mts.map +1 -1
  304. package/dist/modules/storage/config/filters.mjs +3 -1
  305. package/dist/modules/storage/config/filters.mjs.map +1 -1
  306. package/dist/modules/storage/lib/create-upload.client.d.mts +56 -0
  307. package/dist/modules/storage/lib/create-upload.client.d.mts.map +1 -0
  308. package/dist/modules/storage/lib/create-upload.client.mjs +98 -0
  309. package/dist/modules/storage/lib/create-upload.client.mjs.map +1 -0
  310. package/dist/modules/storage/lib/helpers.d.mts +2 -2
  311. package/dist/modules/storage/lib/helpers.d.mts.map +1 -1
  312. package/dist/modules/storage/lib/helpers.mjs +1 -0
  313. package/dist/modules/storage/lib/helpers.mjs.map +1 -1
  314. package/dist/modules/storage/lib/router.server.d.mts +4181 -2283
  315. package/dist/modules/storage/lib/router.server.d.mts.map +1 -1
  316. package/dist/modules/storage/lib/router.server.mjs +5 -2
  317. package/dist/modules/storage/lib/router.server.mjs.map +1 -1
  318. package/dist/modules/storage/lib/schema.d.mts +156 -88
  319. package/dist/modules/storage/lib/schema.d.mts.map +1 -1
  320. package/dist/modules/storage/lib/schema.mjs +3 -1
  321. package/dist/modules/storage/lib/schema.mjs.map +1 -1
  322. package/dist/modules/storage/lib/service.server.d.mts +54 -38
  323. package/dist/modules/storage/lib/service.server.d.mts.map +1 -1
  324. package/dist/modules/storage/lib/service.server.mjs +11 -5
  325. package/dist/modules/storage/lib/service.server.mjs.map +1 -1
  326. package/dist/modules/storage/lib/validators.d.mts +232 -71
  327. package/dist/modules/storage/lib/validators.d.mts.map +1 -1
  328. package/dist/modules/storage/lib/validators.mjs +16 -25
  329. package/dist/modules/storage/lib/validators.mjs.map +1 -1
  330. package/dist/storage/client.d.mts +2 -1
  331. package/dist/storage/client.mjs +2 -8
  332. package/dist/storage.d.mts +3 -3
  333. package/dist/storage.mjs +3 -3
  334. package/package.json +2 -1
  335. package/src/components/editor/components/editor.client.tsx +7 -2
  336. package/src/components/editor/components/menu.client.tsx +26 -0
  337. package/src/components/editor/extensions/file-handler/extension.ts +69 -0
  338. package/src/components/editor/extensions/file-handler/strategy.ts +167 -0
  339. package/src/components/editor/extensions/file-handler/utils.ts +51 -0
  340. package/src/components/editor/extensions/image/extension.ts +57 -0
  341. package/src/components/editor/extensions/skeleton/extension.ts +35 -0
  342. package/src/components/editor/extensions/skeleton/renderer.tsx +14 -0
  343. package/src/components/editor/lib/constants.ts +16 -2
  344. package/src/components/editor/lib/extensions.ts +4 -1
  345. package/src/components/editor/lib/utils.ts +32 -0
  346. package/src/components/editor/lib/variants.ts +72 -1
  347. package/src/components/entry.ts +2 -1
  348. package/src/lib/hooks/use-indicator.tsx +27 -18
  349. package/src/modules/data-tables/lib/filters/parsers.ts +14 -0
  350. package/src/modules/inline-edit/components/combobox-dropdown.client.tsx +21 -12
  351. package/src/modules/inline-edit/components/combobox.client.tsx +13 -6
  352. package/src/modules/inline-edit/components/date-input.client.tsx +29 -13
  353. package/src/modules/inline-edit/components/date-picker.client.tsx +13 -9
  354. package/src/modules/inline-edit/components/editor.client.tsx +14 -14
  355. package/src/modules/inline-edit/components/input-recipient.client.tsx +15 -8
  356. package/src/modules/inline-edit/components/input-toggle.client.tsx +16 -9
  357. package/src/modules/inline-edit/components/input.client.tsx +38 -24
  358. package/src/modules/inline-edit/components/select.client.tsx +16 -9
  359. package/src/modules/inline-edit/components/switch.client.tsx +10 -6
  360. package/src/modules/inline-edit/components/toggle.client.tsx +13 -9
  361. package/src/modules/inline-edit/entry.client.ts +0 -1
  362. package/src/modules/inline-edit/hooks/use-inline.client copy.tsx +97 -0
  363. package/src/modules/inline-edit/hooks/use-inline.client.tsx +139 -20
  364. package/src/modules/inline-edit/lib/variants.ts +7 -0
  365. package/src/modules/storage/components/image-grid.client.tsx +2 -2
  366. package/src/modules/storage/components/upload-zone-context.client.tsx +3 -4
  367. package/src/modules/storage/components/upload-zone.client.tsx +17 -113
  368. package/src/modules/storage/config/filters.ts +2 -0
  369. package/src/modules/storage/entry.client.ts +2 -1
  370. package/src/modules/storage/lib/create-upload.client.ts +134 -0
  371. package/src/modules/storage/lib/helpers.ts +3 -2
  372. package/src/modules/storage/lib/router.server.ts +1 -0
  373. package/src/modules/storage/lib/schema.ts +2 -0
  374. package/src/modules/storage/lib/service.server.ts +18 -4
  375. package/src/modules/storage/lib/validators.ts +21 -31
  376. package/dist/modules/inline-edit/components/deprecated-editor.client.d.mts +0 -21
  377. package/dist/modules/inline-edit/components/deprecated-editor.client.d.mts.map +0 -1
  378. package/dist/modules/inline-edit/components/deprecated-editor.client.mjs +0 -37
  379. package/dist/modules/inline-edit/components/deprecated-editor.client.mjs.map +0 -1
  380. package/dist/storage/client.mjs.map +0 -1
  381. package/src/modules/inline-edit/components/deprecated-editor.client.tsx +0 -48
@@ -9,25 +9,9 @@ import { createContext, useContext, useEffect, useState, useTransition } from "r
9
9
  export type IndicatorStatus = "idle" | "pending" | "success" | "error";
10
10
 
11
11
  /**
12
- * Indicator context
12
+ * Use local indicator
13
13
  */
14
- type IndicatorContextType = {
15
- status: IndicatorStatus;
16
- setStatus: React.Dispatch<React.SetStateAction<IndicatorStatus>>;
17
- startTransition: React.TransitionStartFunction;
18
- };
19
-
20
- export const IndicatorContext = createContext<IndicatorContextType>({} as IndicatorContextType);
21
-
22
- /**
23
- * Inline edit indicator context
24
- */
25
- export const useIndicator = () => useContext(IndicatorContext);
26
-
27
- /**
28
- * Indicator context provider
29
- */
30
- export function IndicatorContextProvider({ children }: { children: React.ReactNode }) {
14
+ export function useLocalIndicator() {
31
15
  /**
32
16
  * Start transition
33
17
  */
@@ -54,6 +38,31 @@ export function IndicatorContextProvider({ children }: { children: React.ReactNo
54
38
  if (status === "error") setTimeout(() => setStatus("idle"), 2000);
55
39
  }, [status]);
56
40
 
41
+ return { status, setStatus, startTransition };
42
+ }
43
+
44
+ /**
45
+ * Indicator context
46
+ */
47
+ type IndicatorContextType = {
48
+ status: IndicatorStatus;
49
+ setStatus: React.Dispatch<React.SetStateAction<IndicatorStatus>>;
50
+ startTransition: React.TransitionStartFunction;
51
+ };
52
+
53
+ export const IndicatorContext = createContext<IndicatorContextType>({} as IndicatorContextType);
54
+
55
+ /**
56
+ * Inline edit indicator context
57
+ */
58
+ export const useIndicator = () => useContext(IndicatorContext);
59
+
60
+ /**
61
+ * Indicator context provider
62
+ */
63
+ export function IndicatorContextProvider({ children }: { children: React.ReactNode }) {
64
+ const { status, setStatus, startTransition } = useLocalIndicator();
65
+
57
66
  return (
58
67
  <IndicatorContext.Provider value={{ status, setStatus, startTransition }}>
59
68
  {children}
@@ -65,6 +65,20 @@ export const parseFilterBoolean = <TSchema extends z.ZodType<boolean>>(
65
65
  encode: (decoded) => (decoded ? "true" : "false"),
66
66
  });
67
67
 
68
+ /**
69
+ * Filter datetime value
70
+ */
71
+ export type ParseFilterDatetimeSchema = z.ZodDate;
72
+
73
+ export const parseFilterDatetime = <TSchema extends ParseFilterDatetimeSchema>(
74
+ schema: TSchema,
75
+ ): ParseFilter<TSchema> => ({
76
+ schema: schema.nullable(),
77
+ decode: (encoded) => (encoded ? new Date(encoded) : null) as unknown as z.input<TSchema>,
78
+ encode: (decoded) => (decoded ? decoded.toISOString() : ""),
79
+ });
80
+
81
+
68
82
  /**
69
83
  * Filter range value
70
84
  */
@@ -9,14 +9,19 @@ import { cn } from "@/lib/utils/cn";
9
9
  import { useInlineEdit, type useInlineEditOptions } from "../hooks/use-inline.client";
10
10
  import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
11
11
 
12
- export type InlineEditComboboxDropdownProps<TValue extends ComboboxDropdownItem> =
13
- useInlineEditOptions<string> &
14
- InlineEditVariantsProps &
15
- Omit<ComboboxDropdownProps<TValue>, "onSelect"> & {
16
- onSelect?: ComboboxDropdownProps<TValue>["onSelect"];
17
- };
12
+ export type InlineEditComboboxDropdownProps<
13
+ TValue extends ComboboxDropdownItem,
14
+ Required extends boolean = false,
15
+ > = useInlineEditOptions<string, Required> &
16
+ InlineEditVariantsProps &
17
+ Omit<ComboboxDropdownProps<TValue>, "onSelect"> & {
18
+ onSelect?: ComboboxDropdownProps<TValue>["onSelect"];
19
+ };
18
20
 
19
- export function InlineComboboxDropdown<TValue extends ComboboxDropdownItem>({
21
+ export function InlineComboboxDropdown<
22
+ TValue extends ComboboxDropdownItem,
23
+ Required extends boolean,
24
+ >({
20
25
  selectedItem,
21
26
  variant,
22
27
  className,
@@ -24,13 +29,17 @@ export function InlineComboboxDropdown<TValue extends ComboboxDropdownItem>({
24
29
  initialValue,
25
30
  action,
26
31
  permission,
32
+ updateStrategy,
33
+ isRequired,
27
34
  disabled,
28
35
  ...props
29
- }: InlineEditComboboxDropdownProps<TValue>) {
30
- const { setValue, handleUpdate, isAllowed } = useInlineEdit({
36
+ }: InlineEditComboboxDropdownProps<TValue, Required>) {
37
+ const { handleChange, handleBlur, isAllowed, status } = useInlineEdit({
31
38
  initialValue,
32
39
  action,
33
40
  permission,
41
+ updateStrategy,
42
+ isRequired,
34
43
  });
35
44
 
36
45
  const initialSelectedItem = props.items.find((item) => item.id === initialValue);
@@ -38,12 +47,12 @@ export function InlineComboboxDropdown<TValue extends ComboboxDropdownItem>({
38
47
  return (
39
48
  <ComboboxDropdown
40
49
  {...props}
41
- className={cn(inlineEditVariants({ variant }), className)}
50
+ className={cn(inlineEditVariants({ variant, status }), className)}
42
51
  disabled={disabled || !isAllowed}
43
52
  selectedItem={selectedItem ?? initialSelectedItem}
44
53
  onSelect={(event) => {
45
- setValue(event.id);
46
- handleUpdate(event.id);
54
+ handleChange(event.id ?? null);
55
+ handleBlur(event.id ?? null);
47
56
  onSelect?.(event);
48
57
  }}
49
58
  />
@@ -3,22 +3,29 @@
3
3
  import { Combobox, ComboboxProps } from "@/components/ui/combobox.client";
4
4
  import { useInlineEdit, useInlineEditOptions } from "../hooks/use-inline.client";
5
5
 
6
- export type InlineComboboxProps<TValue> = useInlineEditOptions<string> &
6
+ export type InlineComboboxProps<TValue, Required extends boolean = false> = useInlineEditOptions<
7
+ string,
8
+ Required
9
+ > &
7
10
  Omit<ComboboxProps<TValue>, "value">;
8
11
 
9
- export function InlineCombobox<TValue>({
12
+ export function InlineCombobox<TValue, Required extends boolean>({
10
13
  initialValue,
11
14
  action,
12
15
  permission,
13
16
  onSelect,
14
17
  onBlur,
15
18
  disabled,
19
+ updateStrategy,
20
+ isRequired,
16
21
  ...props
17
- }: InlineComboboxProps<TValue>) {
18
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit({
22
+ }: InlineComboboxProps<TValue, Required>) {
23
+ const { value, handleChange, handleBlur, isAllowed } = useInlineEdit({
19
24
  initialValue,
20
25
  action,
21
26
  permission,
27
+ updateStrategy,
28
+ isRequired,
22
29
  });
23
30
 
24
31
  return (
@@ -27,11 +34,11 @@ export function InlineCombobox<TValue>({
27
34
  value={value}
28
35
  disabled={disabled || !isAllowed}
29
36
  onSelect={(value) => {
30
- setValue(value);
37
+ handleChange(value ?? null);
31
38
  onSelect?.(value as TValue);
32
39
  }}
33
40
  onBlur={(e) => {
34
- handleUpdate(e.target.value);
41
+ handleBlur(e.target.value ?? null);
35
42
  onBlur?.(e);
36
43
  }}
37
44
  />
@@ -13,41 +13,53 @@ import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
13
13
 
14
14
  const formatDate = (value: Date) => format(value, "dd/MM/yyyy");
15
15
  const parseDate = (value: string) => new Date(value.split("/").reverse().join("-"));
16
+ const isValidDate = (date: Date) => date instanceof Date && date.toString() !== "Invalid Date";
16
17
 
17
- export function InlineDateInput({
18
+ export function InlineDateInput<Required extends boolean = false>({
18
19
  initialValue,
19
20
  action,
20
21
  permission,
21
22
  variant,
22
23
  className,
24
+ updateStrategy,
25
+ isRequired,
23
26
  ...props
24
- }: ComponentProps<"div"> & useInlineEditOptions<Date> & InlineEditVariantsProps) {
27
+ }: ComponentProps<"div"> & useInlineEditOptions<Date, Required> & InlineEditVariantsProps) {
25
28
  const [inValid, setInValid] = React.useState<boolean>(false);
26
29
 
27
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit({
30
+ const { value, setValue, handleChange, handleBlur, status, isAllowed } = useInlineEdit({
28
31
  initialValue,
29
32
  action,
30
33
  permission,
34
+ updateStrategy,
35
+ isRequired,
31
36
  });
32
37
 
33
38
  const [stringDate, setStringDate] = React.useState<string>(
34
39
  initialValue ? formatDate(initialValue) : "",
35
40
  );
36
41
 
42
+ /**
43
+ * Update string date when value changes
44
+ */
45
+ React.useEffect(() => {
46
+ if (value) setStringDate(formatDate(value));
47
+ }, [value]);
48
+
37
49
  return (
38
50
  <Popover>
39
- <div {...props} className={cn("relative h-full", inlineEditVariants({ variant }), className)}>
51
+ <div {...props} className={cn("relative h-full", className)}>
40
52
  <Input
41
53
  data-input
42
54
  type="string"
43
55
  value={stringDate}
44
- className={cn(inValid && "text-destructive")}
56
+ className={cn(inlineEditVariants({ variant, status }), inValid && "text-destructive")}
45
57
  disabled={!isAllowed}
46
58
  onChange={(e) => {
47
59
  setStringDate(e.target.value);
48
60
  const parsedDate = parseDate(e.target.value);
49
61
 
50
- if (parsedDate.toString() === "Invalid Date") {
62
+ if (!isValidDate(parsedDate)) {
51
63
  setInValid(true);
52
64
  setValue(undefined);
53
65
  } else {
@@ -57,7 +69,7 @@ export function InlineDateInput({
57
69
  }}
58
70
  onBlur={(e) => {
59
71
  const parsedDate = parseDate(e.target.value);
60
- handleUpdate(parsedDate);
72
+ handleBlur(isValidDate(parsedDate) ? parsedDate : null);
61
73
  }}
62
74
  />
63
75
 
@@ -75,18 +87,22 @@ export function InlineDateInput({
75
87
  </Button>
76
88
  </PopoverTrigger>
77
89
  </div>
90
+
78
91
  <PopoverContent className="w-auto p-0">
79
92
  <Calendar
80
93
  mode="single"
81
- initialFocus
82
- selected={value}
83
- defaultMonth={value}
84
- disabled={status === "pending"}
94
+ autoFocus
95
+ selected={value ?? undefined}
96
+ defaultMonth={value ?? undefined}
97
+ disabled={!isAllowed}
85
98
  onSelect={(selectedDate) => {
86
99
  if (!selectedDate) return;
87
- setValue(selectedDate);
100
+
88
101
  setStringDate(formatDate(selectedDate));
89
- handleUpdate(selectedDate);
102
+
103
+ handleChange(selectedDate ?? null);
104
+ handleBlur(selectedDate ?? null);
105
+
90
106
  setInValid(false);
91
107
  }}
92
108
  />
@@ -10,25 +10,29 @@ import React, { ComponentProps } from "react";
10
10
  import { useInlineEdit, type useInlineEditOptions } from "../hooks/use-inline.client";
11
11
  import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
12
12
 
13
- type InlineEditDatePickerProps = ComponentProps<typeof Button> &
14
- useInlineEditOptions<Date> &
13
+ type InlineEditDatePickerProps<Required extends boolean> = ComponentProps<typeof Button> &
14
+ useInlineEditOptions<Date, Required> &
15
15
  InlineEditVariantsProps;
16
16
 
17
- export function InlineDatePicker({
17
+ export function InlineDatePicker<Required extends boolean = false>({
18
18
  initialValue,
19
19
  action,
20
20
  permission,
21
21
  variant,
22
22
  className,
23
23
  disabled,
24
+ updateStrategy,
25
+ isRequired,
24
26
  ...props
25
- }: InlineEditDatePickerProps) {
27
+ }: InlineEditDatePickerProps<Required>) {
26
28
  const [open, setOpen] = React.useState(false);
27
29
 
28
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit({
30
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
29
31
  initialValue,
30
32
  action,
31
33
  permission,
34
+ updateStrategy,
35
+ isRequired,
32
36
  });
33
37
 
34
38
  return (
@@ -36,7 +40,7 @@ export function InlineDatePicker({
36
40
  open={open}
37
41
  onOpenChange={(open) => {
38
42
  setOpen(open);
39
- if (!open && value) handleUpdate(value);
43
+ if (!open && value) handleBlur(value);
40
44
  }}
41
45
  >
42
46
  <PopoverTrigger asChild>
@@ -44,7 +48,7 @@ export function InlineDatePicker({
44
48
  {...props}
45
49
  type="button"
46
50
  variant="outline"
47
- className={cn("w-full", inlineEditVariants({ variant }), className)}
51
+ className={cn("w-full", inlineEditVariants({ variant, status }), className)}
48
52
  disabled={disabled || !isAllowed}
49
53
  >
50
54
  <CalendarIcon className="mr-2 h-4 w-4" />
@@ -55,9 +59,9 @@ export function InlineDatePicker({
55
59
  <PopoverContent className="w-auto p-0">
56
60
  <Calendar
57
61
  mode="single"
62
+ autoFocus
58
63
  selected={value ? new Date(value) : undefined}
59
- onSelect={(date) => date && setValue(date)}
60
- initialFocus
64
+ onSelect={(date) => handleChange(date ?? null)}
61
65
  />
62
66
  </PopoverContent>
63
67
  </Popover>
@@ -6,40 +6,40 @@ import { cn } from "@/lib/utils/cn";
6
6
  import { useInlineEdit, type useInlineEditOptions } from "../hooks/use-inline.client";
7
7
  import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
8
8
 
9
- export type InlineEditorProps = useInlineEditOptions<EditorJSONContent> &
9
+ export type InlineEditorProps<Required extends boolean = false> = useInlineEditOptions<
10
+ EditorJSONContent,
11
+ Required
12
+ > &
10
13
  InlineEditVariantsProps &
11
14
  Omit<EditorProps, "value" | "onUpdate" | "onBlur" | "variant">;
12
15
 
13
- export function InlineEditor({
16
+ export function InlineEditor<Required extends boolean = false>({
14
17
  initialValue,
15
18
  action,
16
19
  extensions,
17
20
  variant,
18
21
  disabled,
19
22
  permission,
23
+ updateStrategy,
24
+ isRequired,
20
25
  className,
21
26
  children,
22
- }: InlineEditorProps) {
23
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit<EditorJSONContent>({
27
+ }: InlineEditorProps<Required>) {
28
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
24
29
  initialValue,
25
30
  action,
26
31
  permission,
32
+ updateStrategy,
33
+ isRequired,
27
34
  });
28
35
 
29
- // const [debouncedValue] = useDebounce(value, 500);
30
- // useEffect(() => {
31
- // if (!value) return;
32
- // handleUpdate(value);
33
- // // eslint-disable-next-line react-hooks/exhaustive-deps
34
- // }, [debouncedValue]);
35
-
36
36
  return (
37
37
  <Editor
38
38
  value={value}
39
39
  extensions={extensions}
40
- onUpdate={(value) => setValue(value)}
41
- onBlur={(value) => handleUpdate(value)}
42
- className={cn(inlineEditVariants({ variant }), className)}
40
+ onUpdate={(value) => handleChange(value)}
41
+ onBlur={(value) => handleBlur(value)}
42
+ className={cn(inlineEditVariants({ variant, status }), className)}
43
43
  disabled={disabled || !isAllowed}
44
44
  variant={variant}
45
45
  >
@@ -6,8 +6,11 @@ import { ComponentProps } from "react";
6
6
  import { useInlineEdit, type useInlineEditOptions } from "../hooks/use-inline.client";
7
7
  import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
8
8
 
9
- type InlineRecipientInputProps = Omit<ComponentProps<typeof RecipientInput>, "value" | "onChange"> &
10
- useInlineEditOptions<string[]> &
9
+ type InlineRecipientInputProps<Required extends boolean = false> = Omit<
10
+ ComponentProps<typeof RecipientInput>,
11
+ "value" | "onChange"
12
+ > &
13
+ useInlineEditOptions<string[], Required> &
11
14
  InlineEditVariantsProps & {
12
15
  contacts: Contact[];
13
16
  };
@@ -15,20 +18,24 @@ type InlineRecipientInputProps = Omit<ComponentProps<typeof RecipientInput>, "va
15
18
  /**
16
19
  * The inline edit recipient input component.
17
20
  */
18
- export function InlineRecipientInput({
21
+ export function InlineRecipientInput<Required extends boolean = false>({
19
22
  initialValue,
20
23
  action,
21
24
  variant,
22
25
  disabled,
23
26
  contacts,
24
27
  permission,
28
+ updateStrategy,
29
+ isRequired,
25
30
  className,
26
31
  ...props
27
- }: InlineRecipientInputProps) {
28
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit<string[]>({
32
+ }: InlineRecipientInputProps<Required>) {
33
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
29
34
  initialValue,
30
35
  action,
31
36
  permission,
37
+ updateStrategy,
38
+ isRequired,
32
39
  });
33
40
 
34
41
  return (
@@ -37,11 +44,11 @@ export function InlineRecipientInput({
37
44
  contacts={contacts}
38
45
  value={value ?? []}
39
46
  onChange={(newValue) => {
40
- setValue(newValue);
41
- handleUpdate(newValue);
47
+ handleChange(newValue);
48
+ handleBlur(newValue);
42
49
  }}
43
50
  disabled={disabled || !isAllowed}
44
- className={cn(inlineEditVariants({ variant }), className)}
51
+ className={cn(inlineEditVariants({ variant, status }), className)}
45
52
  />
46
53
  );
47
54
  }
@@ -7,30 +7,37 @@ import { CheckIcon, XIcon } from "lucide-react";
7
7
  import { ComponentProps, useState } from "react";
8
8
  import { useInlineEdit, useInlineEditOptions } from "../hooks/use-inline.client";
9
9
 
10
- type InlineStringInputToggleProps<TValue> = Omit<ComponentProps<typeof Input>, "type"> &
11
- useInlineEditOptions<TValue>;
10
+ type InlineStringInputToggleProps<Required extends boolean = false> = Omit<
11
+ ComponentProps<typeof Input>,
12
+ "type"
13
+ > &
14
+ useInlineEditOptions<string, Required>;
12
15
 
13
- export function InlineStringInputToggle({
16
+ export function InlineStringInputToggle<Required extends boolean>({
14
17
  initialValue,
15
18
  action,
16
19
  disabled,
17
20
  permission,
21
+ updateStrategy,
22
+ isRequired,
18
23
  className,
19
24
  ...props
20
- }: InlineStringInputToggleProps<string>) {
25
+ }: InlineStringInputToggleProps<Required>) {
21
26
  const [enabled, setEnabled] = useState(!!initialValue);
22
27
 
23
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit({
28
+ const { value, handleChange, handleBlur, isAllowed } = useInlineEdit({
24
29
  initialValue,
25
30
  action,
26
31
  permission,
32
+ updateStrategy,
33
+ isRequired,
27
34
  });
28
35
 
29
36
  function handleToggle() {
30
37
  setEnabled(!enabled);
31
38
  if (!enabled) return;
32
39
 
33
- handleUpdate("");
40
+ handleBlur(null);
34
41
  }
35
42
 
36
43
  const isDisabled = !enabled || disabled || !isAllowed;
@@ -40,10 +47,10 @@ export function InlineStringInputToggle({
40
47
  <Input
41
48
  {...props}
42
49
  type="text"
43
- value={value}
50
+ value={value ?? undefined}
44
51
  disabled={isDisabled}
45
- onChange={(e) => setValue(e.target.value)}
46
- onBlur={(e) => handleUpdate(e.target.value)}
52
+ onChange={(e) => handleChange(e.target.value ? e.target.value : null)}
53
+ onBlur={(e) => handleBlur(e.target.value ? e.target.value : null)}
47
54
  className={cn("border-border/70 hover:border-border w-full", className)}
48
55
  />
49
56
 
@@ -6,39 +6,46 @@ import { ComponentProps } from "react";
6
6
  import { useInlineEdit, type useInlineEditOptions } from "../hooks/use-inline.client";
7
7
  import { inlineEditVariants, InlineEditVariantsProps } from "../lib/variants";
8
8
 
9
- type InlineEditInputProps<TValue> = Omit<ComponentProps<typeof Input>, "type"> &
10
- useInlineEditOptions<TValue> &
9
+ type InlineEditInputProps<TValue, Required extends boolean = false> = Omit<
10
+ ComponentProps<typeof Input>,
11
+ "type"
12
+ > &
13
+ useInlineEditOptions<TValue, Required> &
11
14
  InlineEditVariantsProps;
12
15
 
13
16
  /**
14
17
  * The inline edit string input component.
15
18
  */
16
- export function InlineStringInput({
19
+ export function InlineStringInput<Required extends boolean = false>({
17
20
  initialValue,
18
21
  action,
19
22
  variant,
20
23
  className,
21
24
  permission,
25
+ updateStrategy,
26
+ isRequired,
22
27
  disabled,
23
28
  ...props
24
- }: InlineEditInputProps<string | undefined>) {
25
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit<string | undefined>({
29
+ }: InlineEditInputProps<string, Required>) {
30
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
26
31
  initialValue,
27
32
  action,
28
33
  permission,
34
+ updateStrategy,
35
+ isRequired,
29
36
  });
30
37
 
31
38
  return (
32
39
  <Input
33
40
  {...props}
34
41
  type="text"
35
- value={value}
42
+ value={value ?? undefined}
36
43
  disabled={disabled || !isAllowed}
37
- onChange={(e) => setValue(e.target.value)}
38
- onBlur={(e) => handleUpdate(e.target.value)}
44
+ onChange={(e) => handleChange(e.target.value ? e.target.value : null)}
45
+ onBlur={(e) => handleBlur(e.target.value ? e.target.value : null)}
39
46
  className={cn(
40
47
  "border-border/70 hover:border-border w-full",
41
- inlineEditVariants({ variant }),
48
+ inlineEditVariants({ variant, status }),
42
49
  className,
43
50
  )}
44
51
  />
@@ -48,19 +55,26 @@ export function InlineStringInput({
48
55
  /**
49
56
  * The inline edit number input component.
50
57
  */
51
- export function InlineNumberInput({
58
+ const parseValueAsNumber = (valueAsNumber: number): number | null =>
59
+ !isNaN(Number(valueAsNumber)) ? valueAsNumber : null;
60
+
61
+ export function InlineNumberInput<Required extends boolean = false>({
52
62
  initialValue,
53
63
  action,
54
64
  variant,
55
65
  className,
56
66
  permission,
67
+ updateStrategy,
68
+ isRequired,
57
69
  disabled,
58
70
  ...props
59
- }: InlineEditInputProps<number | undefined>) {
60
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit<number | undefined>({
71
+ }: InlineEditInputProps<number, Required>) {
72
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
61
73
  initialValue,
62
74
  action,
63
75
  permission,
76
+ updateStrategy,
77
+ isRequired,
64
78
  });
65
79
 
66
80
  return (
@@ -69,15 +83,11 @@ export function InlineNumberInput({
69
83
  type="number"
70
84
  value={value ?? undefined}
71
85
  disabled={disabled || !isAllowed}
72
- onChange={(e) =>
73
- setValue(!isNaN(e.target.valueAsNumber) ? e.target.valueAsNumber : undefined)
74
- }
75
- onBlur={(e) =>
76
- handleUpdate(!isNaN(e.target.valueAsNumber) ? e.target.valueAsNumber : undefined)
77
- }
86
+ onChange={(e) => handleChange(parseValueAsNumber(e.target.valueAsNumber))}
87
+ onBlur={(e) => handleBlur(parseValueAsNumber(e.target.valueAsNumber))}
78
88
  className={cn(
79
89
  "border-border/70 hover:border-border w-full",
80
- inlineEditVariants({ variant }),
90
+ inlineEditVariants({ variant, status }),
81
91
  className,
82
92
  )}
83
93
  />
@@ -93,13 +103,17 @@ export function InlineDecimalInput({
93
103
  variant,
94
104
  className,
95
105
  permission,
106
+ updateStrategy,
107
+ isRequired,
96
108
  disabled,
97
109
  ...props
98
- }: InlineEditInputProps<string | undefined>) {
99
- const { value, setValue, handleUpdate, isAllowed } = useInlineEdit<string | undefined>({
110
+ }: InlineEditInputProps<string>) {
111
+ const { value, handleChange, handleBlur, isAllowed, status } = useInlineEdit({
100
112
  initialValue,
101
113
  action,
102
114
  permission,
115
+ updateStrategy,
116
+ isRequired,
103
117
  });
104
118
 
105
119
  return (
@@ -108,11 +122,11 @@ export function InlineDecimalInput({
108
122
  type="number"
109
123
  value={value ?? undefined}
110
124
  disabled={disabled || !isAllowed}
111
- onChange={(e) => setValue(e.target.value)}
112
- onBlur={(e) => handleUpdate(e.target.value ? e.target.value : undefined)}
125
+ onChange={(e) => handleChange(e.target.value ? e.target.value : null)}
126
+ onBlur={(e) => handleBlur(e.target.value ? e.target.value : null)}
113
127
  className={cn(
114
128
  "border-border/70 hover:border-border w-full",
115
- inlineEditVariants({ variant }),
129
+ inlineEditVariants({ variant, status }),
116
130
  className,
117
131
  )}
118
132
  />