@actuate-media/cms-admin 0.8.0 → 0.8.2

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 (433) hide show
  1. package/dist/AdminRoot.d.ts.map +1 -1
  2. package/dist/AdminRoot.js +44 -42
  3. package/dist/AdminRoot.js.map +1 -1
  4. package/dist/__tests__/lib/search.test.js +10 -10
  5. package/dist/__tests__/lib/search.test.js.map +1 -1
  6. package/dist/__tests__/lib/utils.test.js.map +1 -1
  7. package/dist/__tests__/router/match-route.test.js.map +1 -1
  8. package/dist/__tests__/router/strip-base.test.js.map +1 -1
  9. package/dist/actuate-admin.css +1 -1
  10. package/dist/components/Breadcrumbs.d.ts.map +1 -1
  11. package/dist/components/Breadcrumbs.js +2 -4
  12. package/dist/components/Breadcrumbs.js.map +1 -1
  13. package/dist/components/CommandPalette.d.ts.map +1 -1
  14. package/dist/components/CommandPalette.js +7 -3
  15. package/dist/components/CommandPalette.js.map +1 -1
  16. package/dist/components/ContentOverviewChart.d.ts.map +1 -1
  17. package/dist/components/ContentOverviewChart.js.map +1 -1
  18. package/dist/components/ErrorBoundary.d.ts.map +1 -1
  19. package/dist/components/ErrorBoundary.js.map +1 -1
  20. package/dist/components/FocalPointPicker.d.ts.map +1 -1
  21. package/dist/components/FocalPointPicker.js +4 -2
  22. package/dist/components/FocalPointPicker.js.map +1 -1
  23. package/dist/components/FolderTree.d.ts.map +1 -1
  24. package/dist/components/FolderTree.js +18 -10
  25. package/dist/components/FolderTree.js.map +1 -1
  26. package/dist/components/LivePreview.d.ts +1 -1
  27. package/dist/components/LivePreview.d.ts.map +1 -1
  28. package/dist/components/LivePreview.js +6 -2
  29. package/dist/components/LivePreview.js.map +1 -1
  30. package/dist/components/LocaleProvider.d.ts.map +1 -1
  31. package/dist/components/LocaleProvider.js.map +1 -1
  32. package/dist/components/LocaleSwitcher.d.ts.map +1 -1
  33. package/dist/components/LocaleSwitcher.js +1 -1
  34. package/dist/components/LocaleSwitcher.js.map +1 -1
  35. package/dist/components/MediaPickerModal.d.ts.map +1 -1
  36. package/dist/components/MediaPickerModal.js.map +1 -1
  37. package/dist/components/PresenceIndicator.d.ts.map +1 -1
  38. package/dist/components/PresenceIndicator.js +5 -2
  39. package/dist/components/PresenceIndicator.js.map +1 -1
  40. package/dist/components/SEOPanel.d.ts +1 -1
  41. package/dist/components/SEOPanel.d.ts.map +1 -1
  42. package/dist/components/SEOPanel.js +110 -24
  43. package/dist/components/SEOPanel.js.map +1 -1
  44. package/dist/components/SEOPerformance.d.ts.map +1 -1
  45. package/dist/components/SEOPerformance.js +2 -2
  46. package/dist/components/SEOPerformance.js.map +1 -1
  47. package/dist/components/ThemeProvider.d.ts.map +1 -1
  48. package/dist/components/ThemeProvider.js.map +1 -1
  49. package/dist/components/TipTapEditor.d.ts.map +1 -1
  50. package/dist/components/TipTapEditor.js +5 -1
  51. package/dist/components/TipTapEditor.js.map +1 -1
  52. package/dist/components/VersionHistory.d.ts +1 -1
  53. package/dist/components/VersionHistory.d.ts.map +1 -1
  54. package/dist/components/VersionHistory.js +1 -1
  55. package/dist/components/VersionHistory.js.map +1 -1
  56. package/dist/components/ui/Avatar.d.ts.map +1 -1
  57. package/dist/components/ui/Avatar.js.map +1 -1
  58. package/dist/components/ui/Badge.d.ts.map +1 -1
  59. package/dist/components/ui/Badge.js.map +1 -1
  60. package/dist/components/ui/Button.d.ts.map +1 -1
  61. package/dist/components/ui/Button.js.map +1 -1
  62. package/dist/components/ui/CommandPalette.d.ts.map +1 -1
  63. package/dist/components/ui/CommandPalette.js +8 -2
  64. package/dist/components/ui/CommandPalette.js.map +1 -1
  65. package/dist/components/ui/ConfirmDialog.d.ts.map +1 -1
  66. package/dist/components/ui/ConfirmDialog.js.map +1 -1
  67. package/dist/components/ui/DataTable.d.ts.map +1 -1
  68. package/dist/components/ui/DataTable.js +1 -3
  69. package/dist/components/ui/DataTable.js.map +1 -1
  70. package/dist/components/ui/EmptyState.d.ts.map +1 -1
  71. package/dist/components/ui/EmptyState.js +1 -1
  72. package/dist/components/ui/EmptyState.js.map +1 -1
  73. package/dist/components/ui/Modal.d.ts.map +1 -1
  74. package/dist/components/ui/Modal.js.map +1 -1
  75. package/dist/components/ui/Pagination.d.ts +1 -1
  76. package/dist/components/ui/Pagination.d.ts.map +1 -1
  77. package/dist/components/ui/Pagination.js +7 -2
  78. package/dist/components/ui/Pagination.js.map +1 -1
  79. package/dist/components/ui/SearchInput.d.ts.map +1 -1
  80. package/dist/components/ui/SearchInput.js.map +1 -1
  81. package/dist/components/ui/Skeleton.d.ts.map +1 -1
  82. package/dist/components/ui/Skeleton.js.map +1 -1
  83. package/dist/components/ui/Toast.d.ts.map +1 -1
  84. package/dist/components/ui/Toast.js.map +1 -1
  85. package/dist/components/ui/index.d.ts.map +1 -1
  86. package/dist/components/ui/index.js.map +1 -1
  87. package/dist/fields/ArrayField.d.ts.map +1 -1
  88. package/dist/fields/ArrayField.js +1 -1
  89. package/dist/fields/ArrayField.js.map +1 -1
  90. package/dist/fields/BlockBuilderField.d.ts.map +1 -1
  91. package/dist/fields/BlockBuilderField.js +7 -7
  92. package/dist/fields/BlockBuilderField.js.map +1 -1
  93. package/dist/fields/DateField.d.ts.map +1 -1
  94. package/dist/fields/DateField.js +1 -1
  95. package/dist/fields/DateField.js.map +1 -1
  96. package/dist/fields/FieldRenderer.d.ts.map +1 -1
  97. package/dist/fields/FieldRenderer.js.map +1 -1
  98. package/dist/fields/GroupField.d.ts.map +1 -1
  99. package/dist/fields/GroupField.js +1 -1
  100. package/dist/fields/GroupField.js.map +1 -1
  101. package/dist/fields/MediaField.d.ts.map +1 -1
  102. package/dist/fields/MediaField.js +1 -1
  103. package/dist/fields/MediaField.js.map +1 -1
  104. package/dist/fields/NavBuilderField.d.ts.map +1 -1
  105. package/dist/fields/NavBuilderField.js +2 -5
  106. package/dist/fields/NavBuilderField.js.map +1 -1
  107. package/dist/fields/NumberField.d.ts +1 -1
  108. package/dist/fields/NumberField.d.ts.map +1 -1
  109. package/dist/fields/NumberField.js +2 -2
  110. package/dist/fields/NumberField.js.map +1 -1
  111. package/dist/fields/RelationshipField.d.ts.map +1 -1
  112. package/dist/fields/RelationshipField.js +7 -3
  113. package/dist/fields/RelationshipField.js.map +1 -1
  114. package/dist/fields/RichTextField.d.ts +1 -1
  115. package/dist/fields/RichTextField.d.ts.map +1 -1
  116. package/dist/fields/RichTextField.js +2 -2
  117. package/dist/fields/RichTextField.js.map +1 -1
  118. package/dist/fields/SelectField.d.ts.map +1 -1
  119. package/dist/fields/SelectField.js +9 -7
  120. package/dist/fields/SelectField.js.map +1 -1
  121. package/dist/fields/SlugField.d.ts.map +1 -1
  122. package/dist/fields/SlugField.js +1 -1
  123. package/dist/fields/SlugField.js.map +1 -1
  124. package/dist/fields/TextField.d.ts +1 -1
  125. package/dist/fields/TextField.d.ts.map +1 -1
  126. package/dist/fields/TextField.js +2 -2
  127. package/dist/fields/TextField.js.map +1 -1
  128. package/dist/fields/ToggleField.d.ts.map +1 -1
  129. package/dist/fields/ToggleField.js +1 -1
  130. package/dist/fields/ToggleField.js.map +1 -1
  131. package/dist/fields/block-types.d.ts.map +1 -1
  132. package/dist/fields/block-types.js +28 -8
  133. package/dist/fields/block-types.js.map +1 -1
  134. package/dist/fields/index.d.ts.map +1 -1
  135. package/dist/fields/index.js.map +1 -1
  136. package/dist/hooks/useBuilderState.d.ts.map +1 -1
  137. package/dist/hooks/useBuilderState.js.map +1 -1
  138. package/dist/hooks/useContentLock.d.ts.map +1 -1
  139. package/dist/hooks/useContentLock.js.map +1 -1
  140. package/dist/hooks/useDebounce.js.map +1 -1
  141. package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -1
  142. package/dist/hooks/useKeyboardShortcuts.js.map +1 -1
  143. package/dist/index.d.ts +2 -2
  144. package/dist/index.d.ts.map +1 -1
  145. package/dist/index.js.map +1 -1
  146. package/dist/layout/Header.d.ts.map +1 -1
  147. package/dist/layout/Header.js.map +1 -1
  148. package/dist/layout/Layout.d.ts.map +1 -1
  149. package/dist/layout/Layout.js.map +1 -1
  150. package/dist/layout/Sidebar.d.ts +1 -1
  151. package/dist/layout/Sidebar.d.ts.map +1 -1
  152. package/dist/layout/Sidebar.js +5 -8
  153. package/dist/layout/Sidebar.js.map +1 -1
  154. package/dist/lib/api.js.map +1 -1
  155. package/dist/lib/search.d.ts.map +1 -1
  156. package/dist/lib/search.js +3 -5
  157. package/dist/lib/search.js.map +1 -1
  158. package/dist/lib/useApiData.d.ts.map +1 -1
  159. package/dist/lib/useApiData.js.map +1 -1
  160. package/dist/lib/utils.d.ts.map +1 -1
  161. package/dist/lib/utils.js.map +1 -1
  162. package/dist/router/index.d.ts.map +1 -1
  163. package/dist/router/index.js +1 -3
  164. package/dist/router/index.js.map +1 -1
  165. package/dist/views/CollectionList.d.ts.map +1 -1
  166. package/dist/views/CollectionList.js +56 -17
  167. package/dist/views/CollectionList.js.map +1 -1
  168. package/dist/views/Dashboard.d.ts.map +1 -1
  169. package/dist/views/Dashboard.js +26 -13
  170. package/dist/views/Dashboard.js.map +1 -1
  171. package/dist/views/DocumentEdit.d.ts +1 -1
  172. package/dist/views/DocumentEdit.d.ts.map +1 -1
  173. package/dist/views/DocumentEdit.js +33 -15
  174. package/dist/views/DocumentEdit.js.map +1 -1
  175. package/dist/views/ForgotPassword.d.ts.map +1 -1
  176. package/dist/views/ForgotPassword.js.map +1 -1
  177. package/dist/views/FormEditor.d.ts.map +1 -1
  178. package/dist/views/FormEditor.js +8 -2
  179. package/dist/views/FormEditor.js.map +1 -1
  180. package/dist/views/FormSubmissions.d.ts.map +1 -1
  181. package/dist/views/FormSubmissions.js +6 -6
  182. package/dist/views/FormSubmissions.js.map +1 -1
  183. package/dist/views/Forms.d.ts.map +1 -1
  184. package/dist/views/Forms.js.map +1 -1
  185. package/dist/views/Login.d.ts.map +1 -1
  186. package/dist/views/Login.js +5 -2
  187. package/dist/views/Login.js.map +1 -1
  188. package/dist/views/MediaBrowser.d.ts.map +1 -1
  189. package/dist/views/MediaBrowser.js +39 -19
  190. package/dist/views/MediaBrowser.js.map +1 -1
  191. package/dist/views/PageEditor.d.ts.map +1 -1
  192. package/dist/views/PageEditor.js.map +1 -1
  193. package/dist/views/Pages.d.ts.map +1 -1
  194. package/dist/views/Pages.js +20 -10
  195. package/dist/views/Pages.js.map +1 -1
  196. package/dist/views/PostEditor.d.ts.map +1 -1
  197. package/dist/views/PostEditor.js.map +1 -1
  198. package/dist/views/Posts.d.ts.map +1 -1
  199. package/dist/views/Posts.js +13 -7
  200. package/dist/views/Posts.js.map +1 -1
  201. package/dist/views/Redirects.d.ts.map +1 -1
  202. package/dist/views/Redirects.js +17 -5
  203. package/dist/views/Redirects.js.map +1 -1
  204. package/dist/views/ResetPassword.d.ts.map +1 -1
  205. package/dist/views/ResetPassword.js.map +1 -1
  206. package/dist/views/SEO.d.ts.map +1 -1
  207. package/dist/views/SEO.js +40 -17
  208. package/dist/views/SEO.js.map +1 -1
  209. package/dist/views/ScriptTagEditor.d.ts.map +1 -1
  210. package/dist/views/ScriptTagEditor.js +2 -1
  211. package/dist/views/ScriptTagEditor.js.map +1 -1
  212. package/dist/views/ScriptTags.d.ts.map +1 -1
  213. package/dist/views/ScriptTags.js.map +1 -1
  214. package/dist/views/Settings.d.ts.map +1 -1
  215. package/dist/views/Settings.js +38 -11
  216. package/dist/views/Settings.js.map +1 -1
  217. package/dist/views/SetupWizard.d.ts.map +1 -1
  218. package/dist/views/SetupWizard.js.map +1 -1
  219. package/dist/views/Users.d.ts.map +1 -1
  220. package/dist/views/Users.js +5 -3
  221. package/dist/views/Users.js.map +1 -1
  222. package/dist/views/page-builder/AIBlockAssist.d.ts.map +1 -1
  223. package/dist/views/page-builder/AIBlockAssist.js +1 -1
  224. package/dist/views/page-builder/AIBlockAssist.js.map +1 -1
  225. package/dist/views/page-builder/AIGenerateDialog.d.ts.map +1 -1
  226. package/dist/views/page-builder/AIGenerateDialog.js +4 -1
  227. package/dist/views/page-builder/AIGenerateDialog.js.map +1 -1
  228. package/dist/views/page-builder/BlockEditor.d.ts.map +1 -1
  229. package/dist/views/page-builder/BlockEditor.js +1 -1
  230. package/dist/views/page-builder/BlockEditor.js.map +1 -1
  231. package/dist/views/page-builder/BlockPicker.d.ts.map +1 -1
  232. package/dist/views/page-builder/BlockPicker.js.map +1 -1
  233. package/dist/views/page-builder/BottomBar.d.ts.map +1 -1
  234. package/dist/views/page-builder/BottomBar.js.map +1 -1
  235. package/dist/views/page-builder/BuilderToolbar.d.ts.map +1 -1
  236. package/dist/views/page-builder/BuilderToolbar.js.map +1 -1
  237. package/dist/views/page-builder/ContextPanel.d.ts.map +1 -1
  238. package/dist/views/page-builder/ContextPanel.js +4 -1
  239. package/dist/views/page-builder/ContextPanel.js.map +1 -1
  240. package/dist/views/page-builder/DesignScore.d.ts.map +1 -1
  241. package/dist/views/page-builder/DesignScore.js.map +1 -1
  242. package/dist/views/page-builder/NodeSettings.d.ts.map +1 -1
  243. package/dist/views/page-builder/NodeSettings.js +1 -1
  244. package/dist/views/page-builder/NodeSettings.js.map +1 -1
  245. package/dist/views/page-builder/PageBuilder.d.ts +1 -1
  246. package/dist/views/page-builder/PageBuilder.d.ts.map +1 -1
  247. package/dist/views/page-builder/PageBuilder.js +4 -2
  248. package/dist/views/page-builder/PageBuilder.js.map +1 -1
  249. package/dist/views/page-builder/PageSettings.d.ts.map +1 -1
  250. package/dist/views/page-builder/PageSettings.js.map +1 -1
  251. package/dist/views/page-builder/PageTemplates.d.ts.map +1 -1
  252. package/dist/views/page-builder/PageTemplates.js.map +1 -1
  253. package/dist/views/page-builder/SEOPanel.d.ts.map +1 -1
  254. package/dist/views/page-builder/SEOPanel.js +1 -3
  255. package/dist/views/page-builder/SEOPanel.js.map +1 -1
  256. package/dist/views/page-builder/SavedSections.d.ts.map +1 -1
  257. package/dist/views/page-builder/SavedSections.js +3 -7
  258. package/dist/views/page-builder/SavedSections.js.map +1 -1
  259. package/dist/views/page-builder/TemplatePicker.d.ts.map +1 -1
  260. package/dist/views/page-builder/TemplatePicker.js.map +1 -1
  261. package/dist/views/page-builder/block-renderers/CTAPreview.d.ts.map +1 -1
  262. package/dist/views/page-builder/block-renderers/CTAPreview.js +1 -1
  263. package/dist/views/page-builder/block-renderers/CTAPreview.js.map +1 -1
  264. package/dist/views/page-builder/block-renderers/CardsPreview.d.ts.map +1 -1
  265. package/dist/views/page-builder/block-renderers/CardsPreview.js +1 -1
  266. package/dist/views/page-builder/block-renderers/CardsPreview.js.map +1 -1
  267. package/dist/views/page-builder/block-renderers/CodePreview.d.ts.map +1 -1
  268. package/dist/views/page-builder/block-renderers/CodePreview.js +1 -5
  269. package/dist/views/page-builder/block-renderers/CodePreview.js.map +1 -1
  270. package/dist/views/page-builder/block-renderers/FAQPreview.d.ts.map +1 -1
  271. package/dist/views/page-builder/block-renderers/FAQPreview.js +4 -1
  272. package/dist/views/page-builder/block-renderers/FAQPreview.js.map +1 -1
  273. package/dist/views/page-builder/block-renderers/FallbackPreview.d.ts.map +1 -1
  274. package/dist/views/page-builder/block-renderers/FallbackPreview.js.map +1 -1
  275. package/dist/views/page-builder/block-renderers/FormPreview.d.ts.map +1 -1
  276. package/dist/views/page-builder/block-renderers/FormPreview.js +2 -2
  277. package/dist/views/page-builder/block-renderers/FormPreview.js.map +1 -1
  278. package/dist/views/page-builder/block-renderers/GalleryPreview.d.ts.map +1 -1
  279. package/dist/views/page-builder/block-renderers/GalleryPreview.js +1 -3
  280. package/dist/views/page-builder/block-renderers/GalleryPreview.js.map +1 -1
  281. package/dist/views/page-builder/block-renderers/HeroPreview.d.ts.map +1 -1
  282. package/dist/views/page-builder/block-renderers/HeroPreview.js.map +1 -1
  283. package/dist/views/page-builder/block-renderers/ImagePreview.d.ts.map +1 -1
  284. package/dist/views/page-builder/block-renderers/ImagePreview.js.map +1 -1
  285. package/dist/views/page-builder/block-renderers/TextPreview.d.ts.map +1 -1
  286. package/dist/views/page-builder/block-renderers/TextPreview.js +2 -6
  287. package/dist/views/page-builder/block-renderers/TextPreview.js.map +1 -1
  288. package/dist/views/page-builder/block-renderers/VideoPreview.d.ts.map +1 -1
  289. package/dist/views/page-builder/block-renderers/VideoPreview.js +2 -5
  290. package/dist/views/page-builder/block-renderers/VideoPreview.js.map +1 -1
  291. package/dist/views/page-builder/block-renderers/index.d.ts.map +1 -1
  292. package/dist/views/page-builder/block-renderers/index.js.map +1 -1
  293. package/dist/views/page-builder/canvas/BlockRenderer.d.ts.map +1 -1
  294. package/dist/views/page-builder/canvas/BlockRenderer.js +1 -5
  295. package/dist/views/page-builder/canvas/BlockRenderer.js.map +1 -1
  296. package/dist/views/page-builder/canvas/BuilderCanvas.d.ts.map +1 -1
  297. package/dist/views/page-builder/canvas/BuilderCanvas.js.map +1 -1
  298. package/dist/views/page-builder/canvas/ColumnRenderer.d.ts.map +1 -1
  299. package/dist/views/page-builder/canvas/ColumnRenderer.js +1 -5
  300. package/dist/views/page-builder/canvas/ColumnRenderer.js.map +1 -1
  301. package/dist/views/page-builder/canvas/ContainerRenderer.d.ts.map +1 -1
  302. package/dist/views/page-builder/canvas/ContainerRenderer.js +1 -5
  303. package/dist/views/page-builder/canvas/ContainerRenderer.js.map +1 -1
  304. package/dist/views/page-builder/canvas/RowRenderer.d.ts.map +1 -1
  305. package/dist/views/page-builder/canvas/RowRenderer.js +1 -5
  306. package/dist/views/page-builder/canvas/RowRenderer.js.map +1 -1
  307. package/dist/views/page-builder/canvas/SectionRenderer.d.ts.map +1 -1
  308. package/dist/views/page-builder/canvas/SectionRenderer.js +1 -5
  309. package/dist/views/page-builder/canvas/SectionRenderer.js.map +1 -1
  310. package/dist/views/page-builder/canvas/index.d.ts.map +1 -1
  311. package/dist/views/page-builder/canvas/index.js.map +1 -1
  312. package/package.json +2 -2
  313. package/src/AdminRoot.tsx +263 -191
  314. package/src/__tests__/lib/search.test.ts +60 -69
  315. package/src/__tests__/lib/utils.test.ts +12 -12
  316. package/src/__tests__/router/match-route.test.ts +24 -26
  317. package/src/__tests__/router/strip-base.test.ts +15 -15
  318. package/src/components/Breadcrumbs.tsx +27 -24
  319. package/src/components/CommandPalette.tsx +115 -99
  320. package/src/components/ContentOverviewChart.tsx +19 -14
  321. package/src/components/ErrorBoundary.tsx +13 -13
  322. package/src/components/FocalPointPicker.tsx +31 -20
  323. package/src/components/FolderTree.tsx +172 -139
  324. package/src/components/LivePreview.tsx +68 -41
  325. package/src/components/LocaleProvider.tsx +26 -20
  326. package/src/components/LocaleSwitcher.tsx +9 -11
  327. package/src/components/MediaPickerModal.tsx +46 -45
  328. package/src/components/PresenceIndicator.tsx +30 -27
  329. package/src/components/SEOPanel.tsx +378 -228
  330. package/src/components/SEOPerformance.tsx +52 -30
  331. package/src/components/ThemeProvider.tsx +46 -46
  332. package/src/components/TipTapEditor.tsx +60 -64
  333. package/src/components/VersionHistory.tsx +63 -52
  334. package/src/components/ui/Avatar.tsx +8 -8
  335. package/src/components/ui/Badge.tsx +7 -5
  336. package/src/components/ui/Button.tsx +24 -13
  337. package/src/components/ui/CommandPalette.tsx +56 -42
  338. package/src/components/ui/ConfirmDialog.tsx +14 -14
  339. package/src/components/ui/DataTable.tsx +37 -39
  340. package/src/components/ui/EmptyState.tsx +9 -11
  341. package/src/components/ui/Modal.tsx +21 -15
  342. package/src/components/ui/Pagination.tsx +34 -19
  343. package/src/components/ui/SearchInput.tsx +17 -7
  344. package/src/components/ui/Skeleton.tsx +7 -7
  345. package/src/components/ui/Toast.tsx +29 -22
  346. package/src/components/ui/index.ts +24 -24
  347. package/src/fields/ArrayField.tsx +43 -25
  348. package/src/fields/BlockBuilderField.tsx +80 -99
  349. package/src/fields/DateField.tsx +20 -12
  350. package/src/fields/FieldRenderer.tsx +34 -34
  351. package/src/fields/GroupField.tsx +8 -10
  352. package/src/fields/MediaField.tsx +8 -10
  353. package/src/fields/NavBuilderField.tsx +24 -25
  354. package/src/fields/NumberField.tsx +21 -14
  355. package/src/fields/RelationshipField.tsx +105 -91
  356. package/src/fields/RichTextField.tsx +16 -12
  357. package/src/fields/SelectField.tsx +42 -34
  358. package/src/fields/SlugField.tsx +29 -17
  359. package/src/fields/TextField.tsx +24 -16
  360. package/src/fields/ToggleField.tsx +7 -9
  361. package/src/fields/block-types.ts +50 -24
  362. package/src/fields/index.ts +17 -17
  363. package/src/hooks/useBuilderState.ts +260 -221
  364. package/src/hooks/useContentLock.ts +23 -20
  365. package/src/hooks/useDebounce.ts +7 -7
  366. package/src/hooks/useKeyboardShortcuts.ts +16 -16
  367. package/src/index.ts +69 -58
  368. package/src/layout/Header.tsx +21 -20
  369. package/src/layout/Layout.tsx +22 -24
  370. package/src/layout/Sidebar.tsx +107 -72
  371. package/src/lib/api.ts +34 -34
  372. package/src/lib/search.ts +30 -34
  373. package/src/lib/useApiData.ts +65 -62
  374. package/src/lib/utils.ts +3 -3
  375. package/src/router/index.ts +33 -35
  376. package/src/styles/build-input.css +2 -2
  377. package/src/styles/tailwind.css +1 -1
  378. package/src/styles/theme.css +26 -2
  379. package/src/views/CollectionList.tsx +275 -121
  380. package/src/views/Dashboard.tsx +164 -117
  381. package/src/views/DocumentEdit.tsx +298 -253
  382. package/src/views/ForgotPassword.tsx +27 -23
  383. package/src/views/FormEditor.tsx +165 -99
  384. package/src/views/FormSubmissions.tsx +261 -117
  385. package/src/views/Forms.tsx +56 -26
  386. package/src/views/Login.tsx +107 -84
  387. package/src/views/MediaBrowser.tsx +717 -523
  388. package/src/views/PageEditor.tsx +44 -46
  389. package/src/views/Pages.tsx +312 -149
  390. package/src/views/PostEditor.tsx +57 -51
  391. package/src/views/Posts.tsx +206 -74
  392. package/src/views/Redirects.tsx +173 -117
  393. package/src/views/ResetPassword.tsx +43 -32
  394. package/src/views/SEO.tsx +607 -160
  395. package/src/views/ScriptTagEditor.tsx +69 -69
  396. package/src/views/ScriptTags.tsx +54 -42
  397. package/src/views/Settings.tsx +430 -220
  398. package/src/views/SetupWizard.tsx +69 -46
  399. package/src/views/Users.tsx +154 -120
  400. package/src/views/page-builder/AIBlockAssist.tsx +21 -25
  401. package/src/views/page-builder/AIGenerateDialog.tsx +134 -127
  402. package/src/views/page-builder/BlockEditor.tsx +94 -96
  403. package/src/views/page-builder/BlockPicker.tsx +73 -88
  404. package/src/views/page-builder/BottomBar.tsx +15 -11
  405. package/src/views/page-builder/BuilderToolbar.tsx +32 -29
  406. package/src/views/page-builder/ContextPanel.tsx +57 -57
  407. package/src/views/page-builder/DesignScore.tsx +52 -59
  408. package/src/views/page-builder/NodeSettings.tsx +59 -59
  409. package/src/views/page-builder/PageBuilder.tsx +156 -155
  410. package/src/views/page-builder/PageSettings.tsx +16 -15
  411. package/src/views/page-builder/PageTemplates.tsx +23 -17
  412. package/src/views/page-builder/SEOPanel.tsx +90 -111
  413. package/src/views/page-builder/SavedSections.tsx +99 -105
  414. package/src/views/page-builder/TemplatePicker.tsx +44 -48
  415. package/src/views/page-builder/block-renderers/CTAPreview.tsx +11 -13
  416. package/src/views/page-builder/block-renderers/CardsPreview.tsx +13 -15
  417. package/src/views/page-builder/block-renderers/CodePreview.tsx +16 -16
  418. package/src/views/page-builder/block-renderers/FAQPreview.tsx +20 -23
  419. package/src/views/page-builder/block-renderers/FallbackPreview.tsx +5 -5
  420. package/src/views/page-builder/block-renderers/FormPreview.tsx +9 -13
  421. package/src/views/page-builder/block-renderers/GalleryPreview.tsx +22 -28
  422. package/src/views/page-builder/block-renderers/HeroPreview.tsx +17 -30
  423. package/src/views/page-builder/block-renderers/ImagePreview.tsx +12 -12
  424. package/src/views/page-builder/block-renderers/TextPreview.tsx +22 -22
  425. package/src/views/page-builder/block-renderers/VideoPreview.tsx +13 -18
  426. package/src/views/page-builder/block-renderers/index.ts +17 -17
  427. package/src/views/page-builder/canvas/BlockRenderer.tsx +19 -23
  428. package/src/views/page-builder/canvas/BuilderCanvas.tsx +17 -20
  429. package/src/views/page-builder/canvas/ColumnRenderer.tsx +22 -26
  430. package/src/views/page-builder/canvas/ContainerRenderer.tsx +20 -24
  431. package/src/views/page-builder/canvas/RowRenderer.tsx +19 -23
  432. package/src/views/page-builder/canvas/SectionRenderer.tsx +30 -34
  433. package/src/views/page-builder/canvas/index.ts +2 -2
@@ -1,36 +1,36 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState, useRef, useEffect } from 'react';
3
+ import { useState, useRef, useEffect } from 'react'
4
4
 
5
5
  interface Column {
6
- key: string;
7
- label: string;
8
- sortable?: boolean;
6
+ key: string
7
+ label: string
8
+ sortable?: boolean
9
9
  }
10
10
 
11
11
  interface Row {
12
- id: string;
13
- [key: string]: any;
12
+ id: string
13
+ [key: string]: any
14
14
  }
15
15
 
16
16
  export interface RowAction {
17
- key: string;
18
- label: string;
19
- icon?: React.ReactNode;
20
- destructive?: boolean;
21
- onClick: (row: Row) => void;
17
+ key: string
18
+ label: string
19
+ icon?: React.ReactNode
20
+ destructive?: boolean
21
+ onClick: (row: Row) => void
22
22
  }
23
23
 
24
24
  export interface DataTableProps {
25
- columns: Column[];
26
- rows: Row[];
27
- selectedIds: string[];
28
- onSelectionChange: (ids: string[]) => void;
29
- sortField?: string;
30
- sortDir?: 'asc' | 'desc';
31
- onSort?: (field: string) => void;
32
- rowActions?: RowAction[];
33
- onRowClick?: (row: Row) => void;
25
+ columns: Column[]
26
+ rows: Row[]
27
+ selectedIds: string[]
28
+ onSelectionChange: (ids: string[]) => void
29
+ sortField?: string
30
+ sortDir?: 'asc' | 'desc'
31
+ onSort?: (field: string) => void
32
+ rowActions?: RowAction[]
33
+ onRowClick?: (row: Row) => void
34
34
  }
35
35
 
36
36
  export function DataTable({
@@ -44,18 +44,16 @@ export function DataTable({
44
44
  rowActions,
45
45
  onRowClick,
46
46
  }: DataTableProps) {
47
- const allSelected = rows.length > 0 && selectedIds.length === rows.length;
47
+ const allSelected = rows.length > 0 && selectedIds.length === rows.length
48
48
 
49
49
  function toggleAll() {
50
- onSelectionChange(allSelected ? [] : rows.map((r) => r.id));
50
+ onSelectionChange(allSelected ? [] : rows.map((r) => r.id))
51
51
  }
52
52
 
53
53
  function toggleRow(id: string) {
54
54
  onSelectionChange(
55
- selectedIds.includes(id)
56
- ? selectedIds.filter((s) => s !== id)
57
- : [...selectedIds, id],
58
- );
55
+ selectedIds.includes(id) ? selectedIds.filter((s) => s !== id) : [...selectedIds, id],
56
+ )
59
57
  }
60
58
 
61
59
  return (
@@ -122,23 +120,23 @@ export function DataTable({
122
120
  </tbody>
123
121
  </table>
124
122
  </div>
125
- );
123
+ )
126
124
  }
127
125
 
128
126
  function RowActionsMenu({ actions, row }: { actions: RowAction[]; row: Row }) {
129
- const [open, setOpen] = useState(false);
130
- const ref = useRef<HTMLDivElement>(null);
127
+ const [open, setOpen] = useState(false)
128
+ const ref = useRef<HTMLDivElement>(null)
131
129
 
132
130
  useEffect(() => {
133
- if (!open) return;
131
+ if (!open) return
134
132
  function handleClickOutside(e: MouseEvent) {
135
133
  if (ref.current && !ref.current.contains(e.target as Node)) {
136
- setOpen(false);
134
+ setOpen(false)
137
135
  }
138
136
  }
139
- document.addEventListener('mousedown', handleClickOutside);
140
- return () => document.removeEventListener('mousedown', handleClickOutside);
141
- }, [open]);
137
+ document.addEventListener('mousedown', handleClickOutside)
138
+ return () => document.removeEventListener('mousedown', handleClickOutside)
139
+ }, [open])
142
140
 
143
141
  return (
144
142
  <div className="relative flex items-center justify-end gap-1" ref={ref}>
@@ -171,8 +169,8 @@ function RowActionsMenu({ actions, row }: { actions: RowAction[]; row: Row }) {
171
169
  action.destructive ? 'text-[var(--destructive)]' : ''
172
170
  }`}
173
171
  onClick={() => {
174
- action.onClick(row);
175
- setOpen(false);
172
+ action.onClick(row)
173
+ setOpen(false)
176
174
  }}
177
175
  >
178
176
  {action.icon && <span className="h-4 w-4">{action.icon}</span>}
@@ -182,7 +180,7 @@ function RowActionsMenu({ actions, row }: { actions: RowAction[]; row: Row }) {
182
180
  </div>
183
181
  )}
184
182
  </div>
185
- );
183
+ )
186
184
  }
187
185
 
188
186
  function MoreVerticalIcon() {
@@ -190,5 +188,5 @@ function MoreVerticalIcon() {
190
188
  <svg className="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
191
189
  <path strokeLinecap="round" strokeLinejoin="round" d="M12 5v.01M12 12v.01M12 19v.01" />
192
190
  </svg>
193
- );
191
+ )
194
192
  }
@@ -1,20 +1,18 @@
1
- import { type ReactNode } from 'react';
2
- import { Button } from './Button.js';
1
+ import { type ReactNode } from 'react'
2
+ import { Button } from './Button.js'
3
3
 
4
4
  export interface EmptyStateProps {
5
- icon?: ReactNode;
6
- title: string;
7
- description?: string;
8
- actionLabel?: string;
9
- onAction?: () => void;
5
+ icon?: ReactNode
6
+ title: string
7
+ description?: string
8
+ actionLabel?: string
9
+ onAction?: () => void
10
10
  }
11
11
 
12
12
  export function EmptyState({ icon, title, description, actionLabel, onAction }: EmptyStateProps) {
13
13
  return (
14
14
  <div className="flex flex-col items-center justify-center py-16 text-center">
15
- {icon && (
16
- <div className="mb-4 text-[var(--muted-foreground)]">{icon}</div>
17
- )}
15
+ {icon && <div className="mb-4 text-[var(--muted-foreground)]">{icon}</div>}
18
16
  <h3 className="text-lg font-semibold">{title}</h3>
19
17
  {description && (
20
18
  <p className="mt-1 max-w-sm text-sm text-[var(--muted-foreground)]">{description}</p>
@@ -25,5 +23,5 @@ export function EmptyState({ icon, title, description, actionLabel, onAction }:
25
23
  </Button>
26
24
  )}
27
25
  </div>
28
- );
26
+ )
29
27
  }
@@ -1,28 +1,28 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useEffect, type ReactNode } from 'react';
3
+ import { useEffect, type ReactNode } from 'react'
4
4
 
5
5
  export interface ModalProps {
6
- open: boolean;
7
- onClose: () => void;
8
- title: string;
9
- children: ReactNode;
10
- actions?: ReactNode;
6
+ open: boolean
7
+ onClose: () => void
8
+ title: string
9
+ children: ReactNode
10
+ actions?: ReactNode
11
11
  }
12
12
 
13
13
  export function Modal({ open, onClose, title, children, actions }: ModalProps) {
14
14
  useEffect(() => {
15
- if (!open) return;
15
+ if (!open) return
16
16
 
17
17
  function handleKey(e: KeyboardEvent) {
18
- if (e.key === 'Escape') onClose();
18
+ if (e.key === 'Escape') onClose()
19
19
  }
20
20
 
21
- document.addEventListener('keydown', handleKey);
22
- return () => document.removeEventListener('keydown', handleKey);
23
- }, [open, onClose]);
21
+ document.addEventListener('keydown', handleKey)
22
+ return () => document.removeEventListener('keydown', handleKey)
23
+ }, [open, onClose])
24
24
 
25
- if (!open) return null;
25
+ if (!open) return null
26
26
 
27
27
  return (
28
28
  <div className="fixed inset-0 z-[60] flex items-center justify-center">
@@ -31,7 +31,13 @@ export function Modal({ open, onClose, title, children, actions }: ModalProps) {
31
31
  <div className="flex items-center justify-between border-b border-[var(--border)] px-6 py-4">
32
32
  <h2 className="text-lg font-semibold">{title}</h2>
33
33
  <button onClick={onClose} className="rounded-md p-1 hover:bg-[var(--accent)]">
34
- <svg className="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
34
+ <svg
35
+ className="h-4 w-4"
36
+ fill="none"
37
+ viewBox="0 0 24 24"
38
+ stroke="currentColor"
39
+ strokeWidth={2}
40
+ >
35
41
  <path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" />
36
42
  </svg>
37
43
  </button>
@@ -44,5 +50,5 @@ export function Modal({ open, onClose, title, children, actions }: ModalProps) {
44
50
  )}
45
51
  </div>
46
52
  </div>
47
- );
53
+ )
48
54
  }
@@ -1,28 +1,34 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
3
  export interface PaginationProps {
4
- page: number;
5
- perPage: number;
6
- total: number;
7
- onPageChange: (page: number) => void;
8
- onPerPageChange: (perPage: number) => void;
4
+ page: number
5
+ perPage: number
6
+ total: number
7
+ onPageChange: (page: number) => void
8
+ onPerPageChange: (perPage: number) => void
9
9
  }
10
10
 
11
- export function Pagination({ page, perPage, total, onPageChange, onPerPageChange }: PaginationProps) {
12
- const totalPages = Math.max(1, Math.ceil(total / perPage));
13
- const start = (page - 1) * perPage + 1;
14
- const end = Math.min(page * perPage, total);
11
+ export function Pagination({
12
+ page,
13
+ perPage,
14
+ total,
15
+ onPageChange,
16
+ onPerPageChange,
17
+ }: PaginationProps) {
18
+ const totalPages = Math.max(1, Math.ceil(total / perPage))
19
+ const start = (page - 1) * perPage + 1
20
+ const end = Math.min(page * perPage, total)
15
21
 
16
22
  function pageNumbers(): (number | 'ellipsis')[] {
17
- const pages: (number | 'ellipsis')[] = [];
23
+ const pages: (number | 'ellipsis')[] = []
18
24
  for (let i = 1; i <= totalPages; i++) {
19
25
  if (i === 1 || i === totalPages || Math.abs(i - page) <= 1) {
20
- pages.push(i);
26
+ pages.push(i)
21
27
  } else if (pages[pages.length - 1] !== 'ellipsis') {
22
- pages.push('ellipsis');
28
+ pages.push('ellipsis')
23
29
  }
24
30
  }
25
- return pages;
31
+ return pages
26
32
  }
27
33
 
28
34
  return (
@@ -34,11 +40,16 @@ export function Pagination({ page, perPage, total, onPageChange, onPerPageChange
34
40
  <div className="flex items-center gap-2">
35
41
  <select
36
42
  value={perPage}
37
- onChange={(e) => { onPerPageChange(Number(e.target.value)); onPageChange(1); }}
43
+ onChange={(e) => {
44
+ onPerPageChange(Number(e.target.value))
45
+ onPageChange(1)
46
+ }}
38
47
  className="rounded-md border border-[var(--border)] bg-[var(--input-background)] px-2 py-1 text-sm"
39
48
  >
40
49
  {[10, 25, 50, 100].map((n) => (
41
- <option key={n} value={n}>{n} / page</option>
50
+ <option key={n} value={n}>
51
+ {n} / page
52
+ </option>
42
53
  ))}
43
54
  </select>
44
55
 
@@ -52,13 +63,17 @@ export function Pagination({ page, perPage, total, onPageChange, onPerPageChange
52
63
  </button>
53
64
  {pageNumbers().map((p, i) =>
54
65
  p === 'ellipsis' ? (
55
- <span key={`e${i}`} className="px-1 text-[var(--muted-foreground)]">…</span>
66
+ <span key={`e${i}`} className="px-1 text-[var(--muted-foreground)]">
67
+
68
+ </span>
56
69
  ) : (
57
70
  <button
58
71
  key={p}
59
72
  onClick={() => onPageChange(p)}
60
73
  className={`min-w-[2rem] rounded-md px-2 py-1 ${
61
- p === page ? 'bg-[var(--primary)] text-[var(--primary-foreground)]' : 'hover:bg-[var(--accent)]'
74
+ p === page
75
+ ? 'bg-[var(--primary)] text-[var(--primary-foreground)]'
76
+ : 'hover:bg-[var(--accent)]'
62
77
  }`}
63
78
  >
64
79
  {p}
@@ -75,5 +90,5 @@ export function Pagination({ page, perPage, total, onPageChange, onPerPageChange
75
90
  </nav>
76
91
  </div>
77
92
  </div>
78
- );
93
+ )
79
94
  }
@@ -1,9 +1,9 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
3
  export interface SearchInputProps {
4
- value: string;
5
- onChange: (value: string) => void;
6
- placeholder?: string;
4
+ value: string
5
+ onChange: (value: string) => void
6
+ placeholder?: string
7
7
  }
8
8
 
9
9
  export function SearchInput({ value, onChange, placeholder = 'Search...' }: SearchInputProps) {
@@ -16,7 +16,11 @@ export function SearchInput({ value, onChange, placeholder = 'Search...' }: Sear
16
16
  stroke="currentColor"
17
17
  strokeWidth={2}
18
18
  >
19
- <path strokeLinecap="round" strokeLinejoin="round" d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
19
+ <path
20
+ strokeLinecap="round"
21
+ strokeLinejoin="round"
22
+ d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z"
23
+ />
20
24
  </svg>
21
25
  <input
22
26
  type="text"
@@ -31,7 +35,13 @@ export function SearchInput({ value, onChange, placeholder = 'Search...' }: Sear
31
35
  className="absolute right-2 top-1/2 -translate-y-1/2 rounded p-0.5 text-[var(--muted-foreground)] hover:text-[var(--foreground)]"
32
36
  aria-label="Clear search"
33
37
  >
34
- <svg className="h-3.5 w-3.5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
38
+ <svg
39
+ className="h-3.5 w-3.5"
40
+ fill="none"
41
+ viewBox="0 0 24 24"
42
+ stroke="currentColor"
43
+ strokeWidth={2}
44
+ >
35
45
  <path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" />
36
46
  </svg>
37
47
  </button>
@@ -40,5 +50,5 @@ export function SearchInput({ value, onChange, placeholder = 'Search...' }: Sear
40
50
  ⌘K
41
51
  </kbd>
42
52
  </div>
43
- );
53
+ )
44
54
  }
@@ -1,9 +1,9 @@
1
- type SkeletonVariant = 'text' | 'card' | 'table-row';
1
+ type SkeletonVariant = 'text' | 'card' | 'table-row'
2
2
 
3
3
  export interface SkeletonProps {
4
- variant?: SkeletonVariant;
5
- lines?: number;
6
- className?: string;
4
+ variant?: SkeletonVariant
5
+ lines?: number
6
+ className?: string
7
7
  }
8
8
 
9
9
  export function Skeleton({ variant = 'text', lines = 3, className = '' }: SkeletonProps) {
@@ -16,7 +16,7 @@ export function Skeleton({ variant = 'text', lines = 3, className = '' }: Skelet
16
16
  <div className="h-3 w-2/3 rounded bg-[var(--muted)]" />
17
17
  </div>
18
18
  </div>
19
- );
19
+ )
20
20
  }
21
21
 
22
22
  if (variant === 'table-row') {
@@ -31,7 +31,7 @@ export function Skeleton({ variant = 'text', lines = 3, className = '' }: Skelet
31
31
  </div>
32
32
  ))}
33
33
  </div>
34
- );
34
+ )
35
35
  }
36
36
 
37
37
  return (
@@ -44,5 +44,5 @@ export function Skeleton({ variant = 'text', lines = 3, className = '' }: Skelet
44
44
  />
45
45
  ))}
46
46
  </div>
47
- );
47
+ )
48
48
  }
@@ -1,47 +1,48 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState, useCallback } from 'react';
3
+ import { useState, useCallback } from 'react'
4
4
 
5
- type ToastType = 'success' | 'error' | 'warning' | 'info';
5
+ type ToastType = 'success' | 'error' | 'warning' | 'info'
6
6
 
7
7
  interface Toast {
8
- id: string;
9
- type: ToastType;
10
- message: string;
8
+ id: string
9
+ type: ToastType
10
+ message: string
11
11
  }
12
12
 
13
13
  const typeClasses: Record<ToastType, string> = {
14
- success: 'border-emerald-500 bg-emerald-50 text-emerald-900 dark:bg-emerald-900/20 dark:text-emerald-300',
14
+ success:
15
+ 'border-emerald-500 bg-emerald-50 text-emerald-900 dark:bg-emerald-900/20 dark:text-emerald-300',
15
16
  error: 'border-red-500 bg-red-50 text-red-900 dark:bg-red-900/20 dark:text-red-300',
16
17
  warning: 'border-amber-500 bg-amber-50 text-amber-900 dark:bg-amber-900/20 dark:text-amber-300',
17
18
  info: 'border-blue-500 bg-blue-50 text-blue-900 dark:bg-blue-900/20 dark:text-blue-300',
18
- };
19
+ }
19
20
 
20
21
  export function useToast() {
21
- const [toasts, setToasts] = useState<Toast[]>([]);
22
+ const [toasts, setToasts] = useState<Toast[]>([])
22
23
 
23
24
  const addToast = useCallback((type: ToastType, message: string) => {
24
- const id = crypto.randomUUID();
25
- setToasts((prev) => [...prev, { id, type, message }]);
25
+ const id = crypto.randomUUID()
26
+ setToasts((prev) => [...prev, { id, type, message }])
26
27
  setTimeout(() => {
27
- setToasts((prev) => prev.filter((t) => t.id !== id));
28
- }, 5000);
29
- }, []);
28
+ setToasts((prev) => prev.filter((t) => t.id !== id))
29
+ }, 5000)
30
+ }, [])
30
31
 
31
32
  const dismissToast = useCallback((id: string) => {
32
- setToasts((prev) => prev.filter((t) => t.id !== id));
33
- }, []);
33
+ setToasts((prev) => prev.filter((t) => t.id !== id))
34
+ }, [])
34
35
 
35
- return { toasts, addToast, dismissToast };
36
+ return { toasts, addToast, dismissToast }
36
37
  }
37
38
 
38
39
  export interface ToastContainerProps {
39
- toasts: Toast[];
40
- onDismiss: (id: string) => void;
40
+ toasts: Toast[]
41
+ onDismiss: (id: string) => void
41
42
  }
42
43
 
43
44
  export function ToastContainer({ toasts, onDismiss }: ToastContainerProps) {
44
- if (toasts.length === 0) return null;
45
+ if (toasts.length === 0) return null
45
46
 
46
47
  return (
47
48
  <div className="fixed bottom-4 right-4 z-[100] flex flex-col gap-2">
@@ -55,12 +56,18 @@ export function ToastContainer({ toasts, onDismiss }: ToastContainerProps) {
55
56
  onClick={() => onDismiss(toast.id)}
56
57
  className="shrink-0 opacity-60 hover:opacity-100"
57
58
  >
58
- <svg className="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
59
+ <svg
60
+ className="h-4 w-4"
61
+ fill="none"
62
+ viewBox="0 0 24 24"
63
+ stroke="currentColor"
64
+ strokeWidth={2}
65
+ >
59
66
  <path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" />
60
67
  </svg>
61
68
  </button>
62
69
  </div>
63
70
  ))}
64
71
  </div>
65
- );
72
+ )
66
73
  }
@@ -1,24 +1,24 @@
1
- export { Button } from './Button.js';
2
- export type { ButtonProps } from './Button.js';
3
- export { Badge } from './Badge.js';
4
- export type { BadgeProps } from './Badge.js';
5
- export { Avatar } from './Avatar.js';
6
- export type { AvatarProps } from './Avatar.js';
7
- export { EmptyState } from './EmptyState.js';
8
- export type { EmptyStateProps } from './EmptyState.js';
9
- export { Skeleton } from './Skeleton.js';
10
- export type { SkeletonProps } from './Skeleton.js';
11
- export { useToast, ToastContainer } from './Toast.js';
12
- export type { ToastContainerProps } from './Toast.js';
13
- export { Modal } from './Modal.js';
14
- export type { ModalProps } from './Modal.js';
15
- export { ConfirmDialog } from './ConfirmDialog.js';
16
- export type { ConfirmDialogProps } from './ConfirmDialog.js';
17
- export { DataTable } from './DataTable.js';
18
- export type { DataTableProps } from './DataTable.js';
19
- export { Pagination } from './Pagination.js';
20
- export type { PaginationProps } from './Pagination.js';
21
- export { SearchInput } from './SearchInput.js';
22
- export type { SearchInputProps } from './SearchInput.js';
23
- export { CommandPalette } from './CommandPalette.js';
24
- export type { CommandPaletteProps } from './CommandPalette.js';
1
+ export { Button } from './Button.js'
2
+ export type { ButtonProps } from './Button.js'
3
+ export { Badge } from './Badge.js'
4
+ export type { BadgeProps } from './Badge.js'
5
+ export { Avatar } from './Avatar.js'
6
+ export type { AvatarProps } from './Avatar.js'
7
+ export { EmptyState } from './EmptyState.js'
8
+ export type { EmptyStateProps } from './EmptyState.js'
9
+ export { Skeleton } from './Skeleton.js'
10
+ export type { SkeletonProps } from './Skeleton.js'
11
+ export { useToast, ToastContainer } from './Toast.js'
12
+ export type { ToastContainerProps } from './Toast.js'
13
+ export { Modal } from './Modal.js'
14
+ export type { ModalProps } from './Modal.js'
15
+ export { ConfirmDialog } from './ConfirmDialog.js'
16
+ export type { ConfirmDialogProps } from './ConfirmDialog.js'
17
+ export { DataTable } from './DataTable.js'
18
+ export type { DataTableProps } from './DataTable.js'
19
+ export { Pagination } from './Pagination.js'
20
+ export type { PaginationProps } from './Pagination.js'
21
+ export { SearchInput } from './SearchInput.js'
22
+ export type { SearchInputProps } from './SearchInput.js'
23
+ export { CommandPalette } from './CommandPalette.js'
24
+ export type { CommandPaletteProps } from './CommandPalette.js'