@tulip-systems/core 0.5.2 → 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 (366) hide show
  1. package/dist/components/common/icons.d.mts +2 -2
  2. package/dist/components/common/status.d.mts +3 -3
  3. package/dist/components/editor/components/content.client.d.mts +2 -2
  4. package/dist/components/editor/components/editor.client.d.mts +2 -2
  5. package/dist/components/editor/components/editor.client.mjs +2 -2
  6. package/dist/components/editor/components/editor.client.mjs.map +1 -1
  7. package/dist/components/editor/components/menu.client.d.mts +3 -3
  8. package/dist/components/editor/components/menu.client.mjs +3 -0
  9. package/dist/components/editor/components/menu.client.mjs.map +1 -1
  10. package/dist/components/editor/extensions/file-handler/extension.d.mts +21 -0
  11. package/dist/components/editor/extensions/file-handler/extension.d.mts.map +1 -0
  12. package/dist/components/editor/extensions/file-handler/extension.mjs +40 -0
  13. package/dist/components/editor/extensions/file-handler/extension.mjs.map +1 -0
  14. package/dist/components/editor/extensions/file-handler/strategy.d.mts +29 -0
  15. package/dist/components/editor/extensions/file-handler/strategy.d.mts.map +1 -0
  16. package/dist/components/editor/extensions/file-handler/strategy.mjs +111 -0
  17. package/dist/components/editor/extensions/file-handler/strategy.mjs.map +1 -0
  18. package/dist/components/editor/extensions/file-handler/utils.mjs +50 -0
  19. package/dist/components/editor/extensions/file-handler/utils.mjs.map +1 -0
  20. package/dist/components/editor/extensions/image/extension.d.mts +8 -0
  21. package/dist/components/editor/extensions/image/extension.d.mts.map +1 -0
  22. package/dist/components/editor/extensions/image/extension.mjs +52 -0
  23. package/dist/components/editor/extensions/image/extension.mjs.map +1 -0
  24. package/dist/components/editor/extensions/skeleton/extension.mjs +41 -0
  25. package/dist/components/editor/extensions/skeleton/extension.mjs.map +1 -0
  26. package/dist/components/editor/extensions/skeleton/renderer.mjs +25 -0
  27. package/dist/components/editor/extensions/skeleton/renderer.mjs.map +1 -0
  28. package/dist/components/editor/lib/constants.d.mts +29 -26
  29. package/dist/components/editor/lib/constants.d.mts.map +1 -1
  30. package/dist/components/editor/lib/constants.mjs +14 -2
  31. package/dist/components/editor/lib/constants.mjs.map +1 -1
  32. package/dist/components/editor/lib/extensions.d.mts +5 -1
  33. package/dist/components/editor/lib/extensions.d.mts.map +1 -1
  34. package/dist/components/editor/lib/extensions.mjs.map +1 -1
  35. package/dist/components/editor/lib/variants.mjs +10 -2
  36. package/dist/components/editor/lib/variants.mjs.map +1 -1
  37. package/dist/components/header/back-button.client.d.mts +2 -2
  38. package/dist/components/header/bottom-bar.client.d.mts +3 -3
  39. package/dist/components/header/breadcrumbs.client.d.mts +7 -7
  40. package/dist/components/header/header.client.d.mts +2 -2
  41. package/dist/components/header/mobile-nav-switcher.client.d.mts +2 -2
  42. package/dist/components/header/top-bar.client.d.mts +4 -4
  43. package/dist/components/layouts/admin-content.client.d.mts +2 -2
  44. package/dist/components/layouts/admin-layout.d.mts +2 -2
  45. package/dist/components/layouts/admin-layout.d.mts.map +1 -1
  46. package/dist/components/layouts/admin-loading.d.mts +2 -2
  47. package/dist/components/layouts/empty-page.d.mts +4 -4
  48. package/dist/components/layouts/list-layout.d.mts +2 -2
  49. package/dist/components/layouts/not-found-page.d.mts +3 -3
  50. package/dist/components/layouts/providers.client.d.mts +2 -2
  51. package/dist/components/layouts/root-layout.server.d.mts +2 -2
  52. package/dist/components/layouts/root-loading.d.mts +2 -2
  53. package/dist/components/layouts/tab-layout.d.mts +2 -2
  54. package/dist/components/lists/data-list.d.mts +5 -5
  55. package/dist/components/lists/data-stack.d.mts +8 -8
  56. package/dist/components/lists/data-stack.d.mts.map +1 -1
  57. package/dist/components/navigation/admin-sidebar-paths.client.d.mts +10 -10
  58. package/dist/components/ui/accordion.d.mts +5 -5
  59. package/dist/components/ui/accordion.d.mts.map +1 -1
  60. package/dist/components/ui/alert-dialog.d.mts +12 -12
  61. package/dist/components/ui/alert-dialog.d.mts.map +1 -1
  62. package/dist/components/ui/alert.d.mts +4 -4
  63. package/dist/components/ui/alert.d.mts.map +1 -1
  64. package/dist/components/ui/aspect-ratio.d.mts +2 -2
  65. package/dist/components/ui/aspect-ratio.d.mts.map +1 -1
  66. package/dist/components/ui/avatar.client.d.mts +4 -4
  67. package/dist/components/ui/badge.d.mts +2 -2
  68. package/dist/components/ui/badge.d.mts.map +1 -1
  69. package/dist/components/ui/breadcrumb.d.mts +8 -8
  70. package/dist/components/ui/breadcrumb.d.mts.map +1 -1
  71. package/dist/components/ui/button.d.mts +2 -2
  72. package/dist/components/ui/button.d.mts.map +1 -1
  73. package/dist/components/ui/calendar.d.mts +3 -3
  74. package/dist/components/ui/calendar.d.mts.map +1 -1
  75. package/dist/components/ui/card.d.mts +7 -7
  76. package/dist/components/ui/card.d.mts.map +1 -1
  77. package/dist/components/ui/carousel.d.mts +6 -6
  78. package/dist/components/ui/carousel.d.mts.map +1 -1
  79. package/dist/components/ui/chart.client.d.mts +5 -5
  80. package/dist/components/ui/checkbox.d.mts +2 -2
  81. package/dist/components/ui/checkbox.d.mts.map +1 -1
  82. package/dist/components/ui/collapsible.client.d.mts +4 -4
  83. package/dist/components/ui/color-picker.client.d.mts +2 -2
  84. package/dist/components/ui/combobox-dropdown.client.d.mts +2 -2
  85. package/dist/components/ui/combobox.client.d.mts +2 -2
  86. package/dist/components/ui/command.d.mts +10 -10
  87. package/dist/components/ui/command.d.mts.map +1 -1
  88. package/dist/components/ui/context-menu.d.mts +16 -16
  89. package/dist/components/ui/context-menu.d.mts.map +1 -1
  90. package/dist/components/ui/date-picker.client.d.mts +2 -2
  91. package/dist/components/ui/dialog.client.d.mts +11 -11
  92. package/dist/components/ui/drawer.client.d.mts +11 -11
  93. package/dist/components/ui/dropdown-menu.d.mts +16 -16
  94. package/dist/components/ui/form.client.d.mts +7 -7
  95. package/dist/components/ui/hover-card.client.d.mts +4 -4
  96. package/dist/components/ui/input-recipient.d.mts +2 -2
  97. package/dist/components/ui/input.d.mts +2 -2
  98. package/dist/components/ui/label.d.mts +2 -2
  99. package/dist/components/ui/navigation-menu.d.mts +9 -9
  100. package/dist/components/ui/pagination.d.mts +8 -8
  101. package/dist/components/ui/popover.d.mts +5 -5
  102. package/dist/components/ui/popover.d.mts.map +1 -1
  103. package/dist/components/ui/progress.client.d.mts +2 -2
  104. package/dist/components/ui/radio-group.d.mts +3 -3
  105. package/dist/components/ui/resizable.client.d.mts +4 -4
  106. package/dist/components/ui/scroll-area.d.mts +3 -3
  107. package/dist/components/ui/select.client.d.mts +11 -11
  108. package/dist/components/ui/separator.d.mts +2 -2
  109. package/dist/components/ui/sheet.client.d.mts +9 -9
  110. package/dist/components/ui/sidebar.client.d.mts +24 -24
  111. package/dist/components/ui/skeleton.d.mts +2 -2
  112. package/dist/components/ui/slider.d.mts +2 -2
  113. package/dist/components/ui/sonner.client.d.mts +2 -2
  114. package/dist/components/ui/switch.d.mts +2 -2
  115. package/dist/components/ui/tabs.d.mts +5 -5
  116. package/dist/components/ui/textarea.d.mts +2 -2
  117. package/dist/components/ui/time-input.client.d.mts +2 -2
  118. package/dist/components/ui/toggle-group.client.d.mts +3 -3
  119. package/dist/components/ui/toggle.d.mts +2 -2
  120. package/dist/components/ui/tooltip.client.d.mts +5 -5
  121. package/dist/components.d.mts +2 -1
  122. package/dist/components.mjs +3 -2
  123. package/dist/data-tables.d.mts +2 -2
  124. package/dist/data-tables.mjs +2 -2
  125. package/dist/inline-edit/client.d.mts +2 -3
  126. package/dist/inline-edit/client.mjs +1 -2
  127. package/dist/lib/client.d.mts +2 -2
  128. package/dist/lib/client.mjs +2 -2
  129. package/dist/lib/hooks/use-action.d.mts +2 -2
  130. package/dist/lib/hooks/use-indicator.d.mts +11 -3
  131. package/dist/lib/hooks/use-indicator.d.mts.map +1 -1
  132. package/dist/lib/hooks/use-indicator.mjs +19 -8
  133. package/dist/lib/hooks/use-indicator.mjs.map +1 -1
  134. package/dist/modules/auth/components/allowed.client.d.mts +2 -2
  135. package/dist/modules/auth/components/allowed.client.d.mts.map +1 -1
  136. package/dist/modules/auth/components/auth-layout.server.d.mts +2 -2
  137. package/dist/modules/auth/components/auth-layout.server.d.mts.map +1 -1
  138. package/dist/modules/auth/components/auth-loading.d.mts +2 -2
  139. package/dist/modules/auth/components/create-first-user-page.client.d.mts +2 -2
  140. package/dist/modules/auth/components/create-first-user-page.client.d.mts.map +1 -1
  141. package/dist/modules/auth/components/forget-password-page.client.d.mts +2 -2
  142. package/dist/modules/auth/components/forget-password-page.client.d.mts.map +1 -1
  143. package/dist/modules/auth/components/guard-first-user.server.d.mts +2 -2
  144. package/dist/modules/auth/components/guard-first-user.server.d.mts.map +1 -1
  145. package/dist/modules/auth/components/guard.server.d.mts +2 -2
  146. package/dist/modules/auth/components/guard.server.d.mts.map +1 -1
  147. package/dist/modules/auth/components/login-page.client.d.mts +2 -2
  148. package/dist/modules/auth/components/login-page.client.d.mts.map +1 -1
  149. package/dist/modules/auth/components/reset-password-page.client.d.mts +2 -2
  150. package/dist/modules/auth/components/reset-password-page.client.d.mts.map +1 -1
  151. package/dist/modules/auth/components/update-password-command.d.mts +2 -2
  152. package/dist/modules/auth/components/update-password-command.d.mts.map +1 -1
  153. package/dist/modules/auth/db/schema.d.mts +73 -73
  154. package/dist/modules/auth/db/schema.d.mts.map +1 -1
  155. package/dist/modules/auth/handler/client.client.d.mts +6 -6
  156. package/dist/modules/auth/hooks/use-permission.d.mts +2 -2
  157. package/dist/modules/auth/hooks/use-session.d.mts +4 -4
  158. package/dist/modules/auth/lib/validators.d.mts +2 -2
  159. package/dist/modules/auth/lib/validators.d.mts.map +1 -1
  160. package/dist/modules/commands/components/alert-dialog-command.client.d.mts +10 -10
  161. package/dist/modules/commands/components/alert-dialog-command.client.d.mts.map +1 -1
  162. package/dist/modules/commands/components/click-command.client.d.mts +2 -2
  163. package/dist/modules/commands/components/click-command.client.d.mts.map +1 -1
  164. package/dist/modules/commands/components/command-trigger.client.d.mts +6 -6
  165. package/dist/modules/commands/components/command-trigger.client.d.mts.map +1 -1
  166. package/dist/modules/commands/components/dialog-command.client.d.mts +8 -8
  167. package/dist/modules/commands/components/dialog-command.client.d.mts.map +1 -1
  168. package/dist/modules/commands/components/dropdown-command.client.d.mts +5 -5
  169. package/dist/modules/commands/components/dropdown-command.client.d.mts.map +1 -1
  170. package/dist/modules/commands/components/empty-command.client.d.mts +2 -2
  171. package/dist/modules/commands/components/empty-command.client.d.mts.map +1 -1
  172. package/dist/modules/commands/components/form-dialog-command.client.d.mts +11 -11
  173. package/dist/modules/commands/components/form-dialog-command.client.d.mts.map +1 -1
  174. package/dist/modules/commands/hooks/use-command-mutation.client.d.mts +2 -2
  175. package/dist/modules/commands/menus/context-menu.client.d.mts +2 -2
  176. package/dist/modules/commands/menus/context-menu.client.d.mts.map +1 -1
  177. package/dist/modules/commands/menus/dropdown-menu.client.d.mts +3 -3
  178. package/dist/modules/commands/menus/dropdown-menu.client.d.mts.map +1 -1
  179. package/dist/modules/commands/menus/inline-menu.client.d.mts +3 -3
  180. package/dist/modules/commands/menus/inline-menu.client.d.mts.map +1 -1
  181. package/dist/modules/commands/menus/responsive-menu.client.d.mts +3 -3
  182. package/dist/modules/commands/menus/responsive-menu.client.d.mts.map +1 -1
  183. package/dist/modules/commands/utils/archive-command.client.d.mts +3 -3
  184. package/dist/modules/commands/utils/archive-command.client.d.mts.map +1 -1
  185. package/dist/modules/commands/utils/delete-command.client.d.mts +3 -3
  186. package/dist/modules/commands/utils/delete-command.client.d.mts.map +1 -1
  187. package/dist/modules/config/db/helpers.d.mts +5 -5
  188. package/dist/modules/config/db/helpers.d.mts.map +1 -1
  189. package/dist/modules/data-tables/components/cell/common.client.d.mts +5 -5
  190. package/dist/modules/data-tables/components/column-header.d.mts +2 -2
  191. package/dist/modules/data-tables/components/column-header.d.mts.map +1 -1
  192. package/dist/modules/data-tables/components/filters/combobox.client.d.mts +2 -2
  193. package/dist/modules/data-tables/components/filters/slider.client.d.mts +2 -2
  194. package/dist/modules/data-tables/components/header.d.mts +4 -4
  195. package/dist/modules/data-tables/components/header.d.mts.map +1 -1
  196. package/dist/modules/data-tables/components/layout.d.mts +2 -2
  197. package/dist/modules/data-tables/components/layout.d.mts.map +1 -1
  198. package/dist/modules/data-tables/components/search-input.client.d.mts +2 -2
  199. package/dist/modules/data-tables/components/skeleton.d.mts +2 -2
  200. package/dist/modules/data-tables/components/skeleton.d.mts.map +1 -1
  201. package/dist/modules/data-tables/components/table.d.mts +7 -7
  202. package/dist/modules/data-tables/components/table.d.mts.map +1 -1
  203. package/dist/modules/data-tables/components/toolbar.d.mts +3 -3
  204. package/dist/modules/data-tables/components/toolbar.d.mts.map +1 -1
  205. package/dist/modules/data-tables/hooks/use-context.client.d.mts +2 -2
  206. package/dist/modules/data-tables/lib/filters/parsers.d.mts +6 -1
  207. package/dist/modules/data-tables/lib/filters/parsers.d.mts.map +1 -1
  208. package/dist/modules/data-tables/lib/filters/parsers.mjs +6 -1
  209. package/dist/modules/data-tables/lib/filters/parsers.mjs.map +1 -1
  210. package/dist/modules/data-tables/tables/data-table/components/table.d.mts +2 -2
  211. package/dist/modules/data-tables/tables/inline-table/components/cells/common.d.mts +2 -2
  212. package/dist/modules/data-tables/tables/inline-table/components/cells/drag-handle.client.d.mts +2 -2
  213. package/dist/modules/data-tables/tables/inline-table/components/inputs/advanced-select.client.d.mts +2 -2
  214. package/dist/modules/data-tables/tables/inline-table/components/inputs/combobox.client.d.mts +2 -2
  215. package/dist/modules/data-tables/tables/inline-table/components/inputs/input.client.d.mts +3 -3
  216. package/dist/modules/data-tables/tables/inline-table/components/inputs/read-only.d.mts +2 -2
  217. package/dist/modules/data-tables/tables/inline-table/components/inputs/select.client.d.mts +2 -2
  218. package/dist/modules/data-tables/tables/inline-table/components/table.d.mts +2 -2
  219. package/dist/modules/data-tables/tables/inline-table/hooks/context.client.d.mts +2 -2
  220. package/dist/modules/inline-edit/components/combobox-dropdown.client.d.mts +6 -4
  221. package/dist/modules/inline-edit/components/combobox-dropdown.client.d.mts.map +1 -1
  222. package/dist/modules/inline-edit/components/combobox-dropdown.client.mjs +11 -6
  223. package/dist/modules/inline-edit/components/combobox-dropdown.client.mjs.map +1 -1
  224. package/dist/modules/inline-edit/components/combobox.client.d.mts +6 -4
  225. package/dist/modules/inline-edit/components/combobox.client.d.mts.map +1 -1
  226. package/dist/modules/inline-edit/components/combobox.client.mjs +7 -5
  227. package/dist/modules/inline-edit/components/combobox.client.mjs.map +1 -1
  228. package/dist/modules/inline-edit/components/date-input.client.d.mts +5 -3
  229. package/dist/modules/inline-edit/components/date-input.client.d.mts.map +1 -1
  230. package/dist/modules/inline-edit/components/date-input.client.mjs +26 -13
  231. package/dist/modules/inline-edit/components/date-input.client.mjs.map +1 -1
  232. package/dist/modules/inline-edit/components/date-picker.client.d.mts +6 -4
  233. package/dist/modules/inline-edit/components/date-picker.client.d.mts.map +1 -1
  234. package/dist/modules/inline-edit/components/date-picker.client.mjs +12 -7
  235. package/dist/modules/inline-edit/components/date-picker.client.mjs.map +1 -1
  236. package/dist/modules/inline-edit/components/editor.client.d.mts +6 -4
  237. package/dist/modules/inline-edit/components/editor.client.d.mts.map +1 -1
  238. package/dist/modules/inline-edit/components/editor.client.mjs +11 -6
  239. package/dist/modules/inline-edit/components/editor.client.mjs.map +1 -1
  240. package/dist/modules/inline-edit/components/input-recipient.client.d.mts +6 -4
  241. package/dist/modules/inline-edit/components/input-recipient.client.d.mts.map +1 -1
  242. package/dist/modules/inline-edit/components/input-recipient.client.mjs +11 -6
  243. package/dist/modules/inline-edit/components/input-recipient.client.mjs.map +1 -1
  244. package/dist/modules/inline-edit/components/input-toggle.client.d.mts +6 -4
  245. package/dist/modules/inline-edit/components/input-toggle.client.d.mts.map +1 -1
  246. package/dist/modules/inline-edit/components/input-toggle.client.mjs +9 -7
  247. package/dist/modules/inline-edit/components/input-toggle.client.mjs.map +1 -1
  248. package/dist/modules/inline-edit/components/input.client.d.mts +13 -10
  249. package/dist/modules/inline-edit/components/input.client.d.mts.map +1 -1
  250. package/dist/modules/inline-edit/components/input.client.mjs +35 -19
  251. package/dist/modules/inline-edit/components/input.client.mjs.map +1 -1
  252. package/dist/modules/inline-edit/components/select.client.d.mts +10 -9
  253. package/dist/modules/inline-edit/components/select.client.d.mts.map +1 -1
  254. package/dist/modules/inline-edit/components/select.client.mjs +14 -7
  255. package/dist/modules/inline-edit/components/select.client.mjs.map +1 -1
  256. package/dist/modules/inline-edit/components/switch.client.d.mts +5 -3
  257. package/dist/modules/inline-edit/components/switch.client.d.mts.map +1 -1
  258. package/dist/modules/inline-edit/components/switch.client.mjs +8 -6
  259. package/dist/modules/inline-edit/components/switch.client.mjs.map +1 -1
  260. package/dist/modules/inline-edit/components/toggle.client.d.mts +6 -4
  261. package/dist/modules/inline-edit/components/toggle.client.d.mts.map +1 -1
  262. package/dist/modules/inline-edit/components/toggle.client.mjs +9 -7
  263. package/dist/modules/inline-edit/components/toggle.client.mjs.map +1 -1
  264. package/dist/modules/inline-edit/hooks/context.client.d.mts +2 -2
  265. package/dist/modules/inline-edit/hooks/context.client.d.mts.map +1 -1
  266. package/dist/modules/inline-edit/hooks/use-inline.client.d.mts +35 -3
  267. package/dist/modules/inline-edit/hooks/use-inline.client.d.mts.map +1 -1
  268. package/dist/modules/inline-edit/hooks/use-inline.client.mjs +71 -9
  269. package/dist/modules/inline-edit/hooks/use-inline.client.mjs.map +1 -1
  270. package/dist/modules/inline-edit/lib/variants.d.mts +1 -0
  271. package/dist/modules/inline-edit/lib/variants.d.mts.map +1 -1
  272. package/dist/modules/inline-edit/lib/variants.mjs +12 -4
  273. package/dist/modules/inline-edit/lib/variants.mjs.map +1 -1
  274. package/dist/modules/router/handler/init.server.d.mts +6 -6
  275. package/dist/modules/router/handler/init.server.d.mts.map +1 -1
  276. package/dist/modules/router/lib/query-client.server.d.mts +2 -2
  277. package/dist/modules/router/lib/query-client.server.d.mts.map +1 -1
  278. package/dist/modules/storage/components/dropzone-context.client.d.mts +2 -2
  279. package/dist/modules/storage/components/dropzone.client.d.mts +5 -5
  280. package/dist/modules/storage/components/dropzone.client.mjs +1 -1
  281. package/dist/modules/storage/components/image-grid.client.d.mts +3 -3
  282. package/dist/modules/storage/components/image-grid.client.mjs +3 -3
  283. package/dist/modules/storage/components/image-grid.client.mjs.map +1 -1
  284. package/dist/modules/storage/components/upload-zone-context.client.d.mts +3 -11
  285. package/dist/modules/storage/components/upload-zone-context.client.d.mts.map +1 -1
  286. package/dist/modules/storage/components/upload-zone-context.client.mjs.map +1 -1
  287. package/dist/modules/storage/components/upload-zone.client.d.mts +10 -33
  288. package/dist/modules/storage/components/upload-zone.client.d.mts.map +1 -1
  289. package/dist/modules/storage/components/upload-zone.client.mjs +19 -93
  290. package/dist/modules/storage/components/upload-zone.client.mjs.map +1 -1
  291. package/dist/modules/storage/config/filters.d.mts +1 -0
  292. package/dist/modules/storage/config/filters.d.mts.map +1 -1
  293. package/dist/modules/storage/config/filters.mjs +1 -0
  294. package/dist/modules/storage/config/filters.mjs.map +1 -1
  295. package/dist/modules/storage/lib/create-upload.client.d.mts +56 -0
  296. package/dist/modules/storage/lib/create-upload.client.d.mts.map +1 -0
  297. package/dist/modules/storage/lib/create-upload.client.mjs +98 -0
  298. package/dist/modules/storage/lib/create-upload.client.mjs.map +1 -0
  299. package/dist/modules/storage/lib/helpers.d.mts +1 -1
  300. package/dist/modules/storage/lib/router.server.d.mts +3265 -2345
  301. package/dist/modules/storage/lib/router.server.d.mts.map +1 -1
  302. package/dist/modules/storage/lib/router.server.mjs +5 -2
  303. package/dist/modules/storage/lib/router.server.mjs.map +1 -1
  304. package/dist/modules/storage/lib/schema.d.mts +124 -90
  305. package/dist/modules/storage/lib/schema.d.mts.map +1 -1
  306. package/dist/modules/storage/lib/schema.mjs +2 -1
  307. package/dist/modules/storage/lib/schema.mjs.map +1 -1
  308. package/dist/modules/storage/lib/service.server.d.mts +31 -42
  309. package/dist/modules/storage/lib/service.server.d.mts.map +1 -1
  310. package/dist/modules/storage/lib/service.server.mjs +5 -5
  311. package/dist/modules/storage/lib/service.server.mjs.map +1 -1
  312. package/dist/modules/storage/lib/validators.d.mts +170 -90
  313. package/dist/modules/storage/lib/validators.d.mts.map +1 -1
  314. package/dist/modules/storage/lib/validators.mjs +2 -1
  315. package/dist/modules/storage/lib/validators.mjs.map +1 -1
  316. package/dist/storage/client.d.mts +2 -1
  317. package/dist/storage/client.mjs +2 -8
  318. package/dist/storage.d.mts +2 -2
  319. package/dist/storage.mjs +1 -1
  320. package/package.json +4 -3
  321. package/src/components/editor/components/editor.client.tsx +7 -2
  322. package/src/components/editor/components/menu.client.tsx +26 -0
  323. package/src/components/editor/extensions/file-handler/extension.ts +69 -0
  324. package/src/components/editor/extensions/file-handler/strategy.ts +167 -0
  325. package/src/components/editor/extensions/file-handler/utils.ts +51 -0
  326. package/src/components/editor/extensions/image/extension.ts +57 -0
  327. package/src/components/editor/extensions/skeleton/extension.ts +35 -0
  328. package/src/components/editor/extensions/skeleton/renderer.tsx +14 -0
  329. package/src/components/editor/lib/constants.ts +16 -2
  330. package/src/components/editor/lib/extensions.ts +4 -1
  331. package/src/components/editor/lib/utils.ts +32 -0
  332. package/src/components/editor/lib/variants.ts +72 -1
  333. package/src/components/entry.ts +2 -1
  334. package/src/lib/hooks/use-indicator.tsx +27 -18
  335. package/src/modules/data-tables/lib/filters/parsers.ts +14 -0
  336. package/src/modules/inline-edit/components/combobox-dropdown.client.tsx +21 -12
  337. package/src/modules/inline-edit/components/combobox.client.tsx +13 -6
  338. package/src/modules/inline-edit/components/date-input.client.tsx +29 -13
  339. package/src/modules/inline-edit/components/date-picker.client.tsx +13 -9
  340. package/src/modules/inline-edit/components/editor.client.tsx +14 -14
  341. package/src/modules/inline-edit/components/input-recipient.client.tsx +15 -8
  342. package/src/modules/inline-edit/components/input-toggle.client.tsx +16 -9
  343. package/src/modules/inline-edit/components/input.client.tsx +38 -24
  344. package/src/modules/inline-edit/components/select.client.tsx +16 -9
  345. package/src/modules/inline-edit/components/switch.client.tsx +10 -6
  346. package/src/modules/inline-edit/components/toggle.client.tsx +13 -9
  347. package/src/modules/inline-edit/entry.client.ts +0 -1
  348. package/src/modules/inline-edit/hooks/use-inline.client copy.tsx +97 -0
  349. package/src/modules/inline-edit/hooks/use-inline.client.tsx +139 -20
  350. package/src/modules/inline-edit/lib/variants.ts +7 -0
  351. package/src/modules/storage/components/image-grid.client.tsx +2 -2
  352. package/src/modules/storage/components/upload-zone-context.client.tsx +3 -4
  353. package/src/modules/storage/components/upload-zone.client.tsx +17 -116
  354. package/src/modules/storage/config/filters.ts +1 -0
  355. package/src/modules/storage/entry.client.ts +2 -1
  356. package/src/modules/storage/lib/create-upload.client.ts +134 -0
  357. package/src/modules/storage/lib/router.server.ts +1 -0
  358. package/src/modules/storage/lib/schema.ts +1 -0
  359. package/src/modules/storage/lib/service.server.ts +10 -4
  360. package/src/modules/storage/lib/validators.ts +1 -0
  361. package/dist/modules/inline-edit/components/deprecated-editor.client.d.mts +0 -21
  362. package/dist/modules/inline-edit/components/deprecated-editor.client.d.mts.map +0 -1
  363. package/dist/modules/inline-edit/components/deprecated-editor.client.mjs +0 -37
  364. package/dist/modules/inline-edit/components/deprecated-editor.client.mjs.map +0 -1
  365. package/dist/storage/client.mjs.map +0 -1
  366. package/src/modules/inline-edit/components/deprecated-editor.client.tsx +0 -48
@@ -4,7 +4,6 @@ import { HardBreakOptions } from "@tiptap/extension-hard-break";
4
4
  import { HeadingOptions } from "@tiptap/extension-heading";
5
5
  import { HighlightOptions } from "@tiptap/extension-highlight";
6
6
  import { HorizontalRuleOptions } from "@tiptap/extension-horizontal-rule";
7
- import { ImageOptions } from "@tiptap/extension-image";
8
7
  import { ItalicOptions } from "@tiptap/extension-italic";
9
8
  import { LinkOptions } from "@tiptap/extension-link";
10
9
  import {
@@ -20,6 +19,8 @@ import { UnderlineOptions } from "@tiptap/extension-underline";
20
19
  import { DropcursorOptions, TrailingNodeOptions, UndoRedoOptions } from "@tiptap/extensions";
21
20
  import { Extension } from "@tiptap/react";
22
21
  import deepmerge from "deepmerge";
22
+ import { FileHandlerOptions } from "../extensions/file-handler/extension";
23
+ import { ImageOptions } from "../extensions/image/extension";
23
24
  import {
24
25
  EDITOR_EXTENSIONS,
25
26
  EDITOR_EXTENSIONS_CONFIG,
@@ -48,6 +49,8 @@ export type EditorExtensionsConfig = {
48
49
  paragraph: Partial<ParagraphOptions> | boolean;
49
50
  text: Partial<TextStyleOptions> | boolean;
50
51
  image: Partial<ImageOptions> | boolean;
52
+ fileHandler: Partial<FileHandlerOptions> | boolean;
53
+ skeleton: boolean;
51
54
  /**
52
55
  * Marks
53
56
  */
@@ -1,3 +1,5 @@
1
+ import type { Node as PMNode } from "@tiptap/pm/model";
2
+
1
3
  type ShortcutKeyResult = {
2
4
  symbol: string;
3
5
  readable: string;
@@ -199,3 +201,33 @@ export const filterFiles = <T extends FileInput>(
199
201
 
200
202
  return [validFiles, errors];
201
203
  };
204
+
205
+ /**
206
+ * Helper for iterating through the nodes in a document that changed compared
207
+ * to the given previous document. Useful for avoiding duplicate work on each transaction.
208
+ * Source: https://github.com/ProseMirror/prosemirror-tables/blob/master/src/fixtables.js
209
+ */
210
+ export function changedDescendants(
211
+ old: PMNode,
212
+ cur: PMNode,
213
+ offset: number,
214
+ f: (node: PMNode, pos: number) => void,
215
+ ) {
216
+ const oldSize = old.childCount,
217
+ curSize = cur.childCount;
218
+ outer: for (let i = 0, j = 0; i < curSize; i++) {
219
+ const child = cur.child(i);
220
+ for (let scan = j, e = Math.min(oldSize, i + 3); scan < e; scan++) {
221
+ if (old.child(scan) == child) {
222
+ j = scan + 1;
223
+ offset += child.nodeSize;
224
+ continue outer;
225
+ }
226
+ }
227
+ f(child, offset);
228
+ if (j < oldSize && old.child(j).sameMarkup(child))
229
+ changedDescendants(old.child(j), child, offset + 1, f);
230
+ else child.nodesBetween(0, child.content.size, f, offset + 1);
231
+ offset += child.nodeSize;
232
+ }
233
+ }
@@ -1,5 +1,76 @@
1
+ import { cn } from "@/lib/utils/cn";
1
2
  import { cva } from "class-variance-authority";
2
3
 
4
+ /**
5
+ * Prose variants
6
+ */
3
7
  export const editorProseVariants = cva(
4
- "prose dark:prose-invert prose-a:text-primary prose-li:marker:text-primary",
8
+ cn(
9
+ "prose dark:prose-invert",
10
+ "prose-a:text-primary",
11
+ "prose-headings:scroll-mt-20",
12
+ "prose-h1:mt-6 prose-h1:mb-3",
13
+ "prose-h2:mt-6 prose-h2:mb-3",
14
+ "prose-h3:mt-5 prose-h3:mb-2",
15
+ "prose-h4:mt-4 prose-h4:mb-2",
16
+ "prose-ul:my-3 prose-ol:my-3",
17
+ "prose-ul:pl-6 prose-ol:pl-6",
18
+ "prose-li:my-1",
19
+ "prose-li:marker:text-primary",
20
+ "prose-li:p-0",
21
+ "prose-img:my-0 prose-img:rounded-lg",
22
+ "prose-blockquote:my-4 prose-blockquote:py-1",
23
+ "prose-hr:my-6",
24
+ "prose-pre:my-4",
25
+ ),
26
+ );
27
+
28
+ /**
29
+ * Image variants
30
+ */
31
+ export const editorImageVariants = cva(
32
+ cn(
33
+ // wrapper (TipTap sets display:block inline → override with !)
34
+ "[&_[data-resize-wrapper]]:!inline-block",
35
+ "[&_[data-resize-wrapper]]:!relative",
36
+ "[&_[data-resize-wrapper]]:max-w-full",
37
+ "[&_[data-resize-wrapper]]:overflow-hidden",
38
+
39
+ // handle base
40
+ "[&_[data-resize-handle]]:absolute",
41
+ "[&_[data-resize-handle]]:z-10",
42
+ "[&_[data-resize-handle]]:rounded-full",
43
+ "[&_[data-resize-handle]]:bg-muted/40",
44
+ "[&_[data-resize-handle]]:w-1.5",
45
+ "[&_[data-resize-handle]]:cursor-ew-resize",
46
+ "[&_[data-resize-handle]]:opacity-0",
47
+ "[&_[data-resize-handle]]:transition-opacity",
48
+
49
+ // show on hover / active
50
+ "[&:hover_[data-resize-handle]]:opacity-100",
51
+ "[&_[data-resize-state='true']_[data-resize-handle]]:opacity-100",
52
+
53
+ // ✅ override TipTap inline: top:0; bottom:0;
54
+ "[&_[data-resize-handle]]:!top-1/2",
55
+ "[&_[data-resize-handle]]:!bottom-auto",
56
+ "[&_[data-resize-handle]]:!-translate-y-1/2",
57
+
58
+ // ✅ half height (also must beat inline)
59
+ "[&_[data-resize-handle]]:!h-1/2",
60
+
61
+ // ✅ spacing from edge (beat inline left:0 / right:0)
62
+ "[&_[data-resize-handle='left']]:!left-2",
63
+ "[&_[data-resize-handle='right']]:!right-2",
64
+
65
+ // ✅ override inline visibility:hidden on the resize container while pending
66
+ "[&_[data-resize-container]:has(img[data-pending='true'])]:[visibility:visible!important]",
67
+ "[&_[data-resize-container]:has(img[data-pending='true'])]:[pointer-events:auto!important]",
68
+
69
+ // Pending img should behave like a skeleton block (even before wrapper exists)
70
+ "[&_img[data-pending='true']]:bg-primary/10",
71
+ "[&_img[data-pending='true']]:animate-pulse",
72
+ "[&_img[data-pending='true']]:rounded-md",
73
+ "[&_img[data-pending='true']]:opacity-0",
74
+ "[&_img[data-pending='true']]:min-h-[500px]",
75
+ ),
5
76
  );
@@ -3,8 +3,9 @@
3
3
  */
4
4
  export * from "./common/icons";
5
5
  export * from "./common/status";
6
- export * from "./editor/lib/types";
6
+ export * from "./editor/extensions/file-handler/strategy";
7
7
  export * from "./editor/lib/helpers";
8
+ export * from "./editor/lib/types";
8
9
 
9
10
  /**
10
11
  * Components Layouts
@@ -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
  }