@actuate-media/cms-admin 0.8.0 → 0.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (432) 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/components/Breadcrumbs.d.ts.map +1 -1
  10. package/dist/components/Breadcrumbs.js +2 -4
  11. package/dist/components/Breadcrumbs.js.map +1 -1
  12. package/dist/components/CommandPalette.d.ts.map +1 -1
  13. package/dist/components/CommandPalette.js +7 -3
  14. package/dist/components/CommandPalette.js.map +1 -1
  15. package/dist/components/ContentOverviewChart.d.ts.map +1 -1
  16. package/dist/components/ContentOverviewChart.js.map +1 -1
  17. package/dist/components/ErrorBoundary.d.ts.map +1 -1
  18. package/dist/components/ErrorBoundary.js.map +1 -1
  19. package/dist/components/FocalPointPicker.d.ts.map +1 -1
  20. package/dist/components/FocalPointPicker.js +4 -2
  21. package/dist/components/FocalPointPicker.js.map +1 -1
  22. package/dist/components/FolderTree.d.ts.map +1 -1
  23. package/dist/components/FolderTree.js +18 -10
  24. package/dist/components/FolderTree.js.map +1 -1
  25. package/dist/components/LivePreview.d.ts +1 -1
  26. package/dist/components/LivePreview.d.ts.map +1 -1
  27. package/dist/components/LivePreview.js +6 -2
  28. package/dist/components/LivePreview.js.map +1 -1
  29. package/dist/components/LocaleProvider.d.ts.map +1 -1
  30. package/dist/components/LocaleProvider.js.map +1 -1
  31. package/dist/components/LocaleSwitcher.d.ts.map +1 -1
  32. package/dist/components/LocaleSwitcher.js +1 -1
  33. package/dist/components/LocaleSwitcher.js.map +1 -1
  34. package/dist/components/MediaPickerModal.d.ts.map +1 -1
  35. package/dist/components/MediaPickerModal.js.map +1 -1
  36. package/dist/components/PresenceIndicator.d.ts.map +1 -1
  37. package/dist/components/PresenceIndicator.js +5 -2
  38. package/dist/components/PresenceIndicator.js.map +1 -1
  39. package/dist/components/SEOPanel.d.ts +1 -1
  40. package/dist/components/SEOPanel.d.ts.map +1 -1
  41. package/dist/components/SEOPanel.js +110 -24
  42. package/dist/components/SEOPanel.js.map +1 -1
  43. package/dist/components/SEOPerformance.d.ts.map +1 -1
  44. package/dist/components/SEOPerformance.js +2 -2
  45. package/dist/components/SEOPerformance.js.map +1 -1
  46. package/dist/components/ThemeProvider.d.ts.map +1 -1
  47. package/dist/components/ThemeProvider.js.map +1 -1
  48. package/dist/components/TipTapEditor.d.ts.map +1 -1
  49. package/dist/components/TipTapEditor.js +5 -1
  50. package/dist/components/TipTapEditor.js.map +1 -1
  51. package/dist/components/VersionHistory.d.ts +1 -1
  52. package/dist/components/VersionHistory.d.ts.map +1 -1
  53. package/dist/components/VersionHistory.js +1 -1
  54. package/dist/components/VersionHistory.js.map +1 -1
  55. package/dist/components/ui/Avatar.d.ts.map +1 -1
  56. package/dist/components/ui/Avatar.js.map +1 -1
  57. package/dist/components/ui/Badge.d.ts.map +1 -1
  58. package/dist/components/ui/Badge.js.map +1 -1
  59. package/dist/components/ui/Button.d.ts.map +1 -1
  60. package/dist/components/ui/Button.js.map +1 -1
  61. package/dist/components/ui/CommandPalette.d.ts.map +1 -1
  62. package/dist/components/ui/CommandPalette.js +8 -2
  63. package/dist/components/ui/CommandPalette.js.map +1 -1
  64. package/dist/components/ui/ConfirmDialog.d.ts.map +1 -1
  65. package/dist/components/ui/ConfirmDialog.js.map +1 -1
  66. package/dist/components/ui/DataTable.d.ts.map +1 -1
  67. package/dist/components/ui/DataTable.js +1 -3
  68. package/dist/components/ui/DataTable.js.map +1 -1
  69. package/dist/components/ui/EmptyState.d.ts.map +1 -1
  70. package/dist/components/ui/EmptyState.js +1 -1
  71. package/dist/components/ui/EmptyState.js.map +1 -1
  72. package/dist/components/ui/Modal.d.ts.map +1 -1
  73. package/dist/components/ui/Modal.js.map +1 -1
  74. package/dist/components/ui/Pagination.d.ts +1 -1
  75. package/dist/components/ui/Pagination.d.ts.map +1 -1
  76. package/dist/components/ui/Pagination.js +7 -2
  77. package/dist/components/ui/Pagination.js.map +1 -1
  78. package/dist/components/ui/SearchInput.d.ts.map +1 -1
  79. package/dist/components/ui/SearchInput.js.map +1 -1
  80. package/dist/components/ui/Skeleton.d.ts.map +1 -1
  81. package/dist/components/ui/Skeleton.js.map +1 -1
  82. package/dist/components/ui/Toast.d.ts.map +1 -1
  83. package/dist/components/ui/Toast.js.map +1 -1
  84. package/dist/components/ui/index.d.ts.map +1 -1
  85. package/dist/components/ui/index.js.map +1 -1
  86. package/dist/fields/ArrayField.d.ts.map +1 -1
  87. package/dist/fields/ArrayField.js +1 -1
  88. package/dist/fields/ArrayField.js.map +1 -1
  89. package/dist/fields/BlockBuilderField.d.ts.map +1 -1
  90. package/dist/fields/BlockBuilderField.js +7 -7
  91. package/dist/fields/BlockBuilderField.js.map +1 -1
  92. package/dist/fields/DateField.d.ts.map +1 -1
  93. package/dist/fields/DateField.js +1 -1
  94. package/dist/fields/DateField.js.map +1 -1
  95. package/dist/fields/FieldRenderer.d.ts.map +1 -1
  96. package/dist/fields/FieldRenderer.js.map +1 -1
  97. package/dist/fields/GroupField.d.ts.map +1 -1
  98. package/dist/fields/GroupField.js +1 -1
  99. package/dist/fields/GroupField.js.map +1 -1
  100. package/dist/fields/MediaField.d.ts.map +1 -1
  101. package/dist/fields/MediaField.js +1 -1
  102. package/dist/fields/MediaField.js.map +1 -1
  103. package/dist/fields/NavBuilderField.d.ts.map +1 -1
  104. package/dist/fields/NavBuilderField.js +2 -5
  105. package/dist/fields/NavBuilderField.js.map +1 -1
  106. package/dist/fields/NumberField.d.ts +1 -1
  107. package/dist/fields/NumberField.d.ts.map +1 -1
  108. package/dist/fields/NumberField.js +2 -2
  109. package/dist/fields/NumberField.js.map +1 -1
  110. package/dist/fields/RelationshipField.d.ts.map +1 -1
  111. package/dist/fields/RelationshipField.js +7 -3
  112. package/dist/fields/RelationshipField.js.map +1 -1
  113. package/dist/fields/RichTextField.d.ts +1 -1
  114. package/dist/fields/RichTextField.d.ts.map +1 -1
  115. package/dist/fields/RichTextField.js +2 -2
  116. package/dist/fields/RichTextField.js.map +1 -1
  117. package/dist/fields/SelectField.d.ts.map +1 -1
  118. package/dist/fields/SelectField.js +9 -7
  119. package/dist/fields/SelectField.js.map +1 -1
  120. package/dist/fields/SlugField.d.ts.map +1 -1
  121. package/dist/fields/SlugField.js +1 -1
  122. package/dist/fields/SlugField.js.map +1 -1
  123. package/dist/fields/TextField.d.ts +1 -1
  124. package/dist/fields/TextField.d.ts.map +1 -1
  125. package/dist/fields/TextField.js +2 -2
  126. package/dist/fields/TextField.js.map +1 -1
  127. package/dist/fields/ToggleField.d.ts.map +1 -1
  128. package/dist/fields/ToggleField.js +1 -1
  129. package/dist/fields/ToggleField.js.map +1 -1
  130. package/dist/fields/block-types.d.ts.map +1 -1
  131. package/dist/fields/block-types.js +28 -8
  132. package/dist/fields/block-types.js.map +1 -1
  133. package/dist/fields/index.d.ts.map +1 -1
  134. package/dist/fields/index.js.map +1 -1
  135. package/dist/hooks/useBuilderState.d.ts.map +1 -1
  136. package/dist/hooks/useBuilderState.js.map +1 -1
  137. package/dist/hooks/useContentLock.d.ts.map +1 -1
  138. package/dist/hooks/useContentLock.js.map +1 -1
  139. package/dist/hooks/useDebounce.js.map +1 -1
  140. package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -1
  141. package/dist/hooks/useKeyboardShortcuts.js.map +1 -1
  142. package/dist/index.d.ts +2 -2
  143. package/dist/index.d.ts.map +1 -1
  144. package/dist/index.js.map +1 -1
  145. package/dist/layout/Header.d.ts.map +1 -1
  146. package/dist/layout/Header.js.map +1 -1
  147. package/dist/layout/Layout.d.ts.map +1 -1
  148. package/dist/layout/Layout.js.map +1 -1
  149. package/dist/layout/Sidebar.d.ts +1 -1
  150. package/dist/layout/Sidebar.d.ts.map +1 -1
  151. package/dist/layout/Sidebar.js +5 -8
  152. package/dist/layout/Sidebar.js.map +1 -1
  153. package/dist/lib/api.js.map +1 -1
  154. package/dist/lib/search.d.ts.map +1 -1
  155. package/dist/lib/search.js +3 -5
  156. package/dist/lib/search.js.map +1 -1
  157. package/dist/lib/useApiData.d.ts.map +1 -1
  158. package/dist/lib/useApiData.js.map +1 -1
  159. package/dist/lib/utils.d.ts.map +1 -1
  160. package/dist/lib/utils.js.map +1 -1
  161. package/dist/router/index.d.ts.map +1 -1
  162. package/dist/router/index.js +1 -3
  163. package/dist/router/index.js.map +1 -1
  164. package/dist/views/CollectionList.d.ts.map +1 -1
  165. package/dist/views/CollectionList.js +56 -17
  166. package/dist/views/CollectionList.js.map +1 -1
  167. package/dist/views/Dashboard.d.ts.map +1 -1
  168. package/dist/views/Dashboard.js +26 -13
  169. package/dist/views/Dashboard.js.map +1 -1
  170. package/dist/views/DocumentEdit.d.ts +1 -1
  171. package/dist/views/DocumentEdit.d.ts.map +1 -1
  172. package/dist/views/DocumentEdit.js +33 -15
  173. package/dist/views/DocumentEdit.js.map +1 -1
  174. package/dist/views/ForgotPassword.d.ts.map +1 -1
  175. package/dist/views/ForgotPassword.js.map +1 -1
  176. package/dist/views/FormEditor.d.ts.map +1 -1
  177. package/dist/views/FormEditor.js +8 -2
  178. package/dist/views/FormEditor.js.map +1 -1
  179. package/dist/views/FormSubmissions.d.ts.map +1 -1
  180. package/dist/views/FormSubmissions.js +6 -6
  181. package/dist/views/FormSubmissions.js.map +1 -1
  182. package/dist/views/Forms.d.ts.map +1 -1
  183. package/dist/views/Forms.js.map +1 -1
  184. package/dist/views/Login.d.ts.map +1 -1
  185. package/dist/views/Login.js +5 -2
  186. package/dist/views/Login.js.map +1 -1
  187. package/dist/views/MediaBrowser.d.ts.map +1 -1
  188. package/dist/views/MediaBrowser.js +39 -19
  189. package/dist/views/MediaBrowser.js.map +1 -1
  190. package/dist/views/PageEditor.d.ts.map +1 -1
  191. package/dist/views/PageEditor.js.map +1 -1
  192. package/dist/views/Pages.d.ts.map +1 -1
  193. package/dist/views/Pages.js +20 -10
  194. package/dist/views/Pages.js.map +1 -1
  195. package/dist/views/PostEditor.d.ts.map +1 -1
  196. package/dist/views/PostEditor.js.map +1 -1
  197. package/dist/views/Posts.d.ts.map +1 -1
  198. package/dist/views/Posts.js +13 -7
  199. package/dist/views/Posts.js.map +1 -1
  200. package/dist/views/Redirects.d.ts.map +1 -1
  201. package/dist/views/Redirects.js +17 -5
  202. package/dist/views/Redirects.js.map +1 -1
  203. package/dist/views/ResetPassword.d.ts.map +1 -1
  204. package/dist/views/ResetPassword.js.map +1 -1
  205. package/dist/views/SEO.d.ts.map +1 -1
  206. package/dist/views/SEO.js +39 -16
  207. package/dist/views/SEO.js.map +1 -1
  208. package/dist/views/ScriptTagEditor.d.ts.map +1 -1
  209. package/dist/views/ScriptTagEditor.js +2 -1
  210. package/dist/views/ScriptTagEditor.js.map +1 -1
  211. package/dist/views/ScriptTags.d.ts.map +1 -1
  212. package/dist/views/ScriptTags.js.map +1 -1
  213. package/dist/views/Settings.d.ts.map +1 -1
  214. package/dist/views/Settings.js +38 -11
  215. package/dist/views/Settings.js.map +1 -1
  216. package/dist/views/SetupWizard.d.ts.map +1 -1
  217. package/dist/views/SetupWizard.js.map +1 -1
  218. package/dist/views/Users.d.ts.map +1 -1
  219. package/dist/views/Users.js +5 -3
  220. package/dist/views/Users.js.map +1 -1
  221. package/dist/views/page-builder/AIBlockAssist.d.ts.map +1 -1
  222. package/dist/views/page-builder/AIBlockAssist.js +1 -1
  223. package/dist/views/page-builder/AIBlockAssist.js.map +1 -1
  224. package/dist/views/page-builder/AIGenerateDialog.d.ts.map +1 -1
  225. package/dist/views/page-builder/AIGenerateDialog.js +4 -1
  226. package/dist/views/page-builder/AIGenerateDialog.js.map +1 -1
  227. package/dist/views/page-builder/BlockEditor.d.ts.map +1 -1
  228. package/dist/views/page-builder/BlockEditor.js +1 -1
  229. package/dist/views/page-builder/BlockEditor.js.map +1 -1
  230. package/dist/views/page-builder/BlockPicker.d.ts.map +1 -1
  231. package/dist/views/page-builder/BlockPicker.js.map +1 -1
  232. package/dist/views/page-builder/BottomBar.d.ts.map +1 -1
  233. package/dist/views/page-builder/BottomBar.js.map +1 -1
  234. package/dist/views/page-builder/BuilderToolbar.d.ts.map +1 -1
  235. package/dist/views/page-builder/BuilderToolbar.js.map +1 -1
  236. package/dist/views/page-builder/ContextPanel.d.ts.map +1 -1
  237. package/dist/views/page-builder/ContextPanel.js +4 -1
  238. package/dist/views/page-builder/ContextPanel.js.map +1 -1
  239. package/dist/views/page-builder/DesignScore.d.ts.map +1 -1
  240. package/dist/views/page-builder/DesignScore.js.map +1 -1
  241. package/dist/views/page-builder/NodeSettings.d.ts.map +1 -1
  242. package/dist/views/page-builder/NodeSettings.js +1 -1
  243. package/dist/views/page-builder/NodeSettings.js.map +1 -1
  244. package/dist/views/page-builder/PageBuilder.d.ts +1 -1
  245. package/dist/views/page-builder/PageBuilder.d.ts.map +1 -1
  246. package/dist/views/page-builder/PageBuilder.js +4 -2
  247. package/dist/views/page-builder/PageBuilder.js.map +1 -1
  248. package/dist/views/page-builder/PageSettings.d.ts.map +1 -1
  249. package/dist/views/page-builder/PageSettings.js.map +1 -1
  250. package/dist/views/page-builder/PageTemplates.d.ts.map +1 -1
  251. package/dist/views/page-builder/PageTemplates.js.map +1 -1
  252. package/dist/views/page-builder/SEOPanel.d.ts.map +1 -1
  253. package/dist/views/page-builder/SEOPanel.js +1 -3
  254. package/dist/views/page-builder/SEOPanel.js.map +1 -1
  255. package/dist/views/page-builder/SavedSections.d.ts.map +1 -1
  256. package/dist/views/page-builder/SavedSections.js +3 -7
  257. package/dist/views/page-builder/SavedSections.js.map +1 -1
  258. package/dist/views/page-builder/TemplatePicker.d.ts.map +1 -1
  259. package/dist/views/page-builder/TemplatePicker.js.map +1 -1
  260. package/dist/views/page-builder/block-renderers/CTAPreview.d.ts.map +1 -1
  261. package/dist/views/page-builder/block-renderers/CTAPreview.js +1 -1
  262. package/dist/views/page-builder/block-renderers/CTAPreview.js.map +1 -1
  263. package/dist/views/page-builder/block-renderers/CardsPreview.d.ts.map +1 -1
  264. package/dist/views/page-builder/block-renderers/CardsPreview.js +1 -1
  265. package/dist/views/page-builder/block-renderers/CardsPreview.js.map +1 -1
  266. package/dist/views/page-builder/block-renderers/CodePreview.d.ts.map +1 -1
  267. package/dist/views/page-builder/block-renderers/CodePreview.js +1 -5
  268. package/dist/views/page-builder/block-renderers/CodePreview.js.map +1 -1
  269. package/dist/views/page-builder/block-renderers/FAQPreview.d.ts.map +1 -1
  270. package/dist/views/page-builder/block-renderers/FAQPreview.js +4 -1
  271. package/dist/views/page-builder/block-renderers/FAQPreview.js.map +1 -1
  272. package/dist/views/page-builder/block-renderers/FallbackPreview.d.ts.map +1 -1
  273. package/dist/views/page-builder/block-renderers/FallbackPreview.js.map +1 -1
  274. package/dist/views/page-builder/block-renderers/FormPreview.d.ts.map +1 -1
  275. package/dist/views/page-builder/block-renderers/FormPreview.js +2 -2
  276. package/dist/views/page-builder/block-renderers/FormPreview.js.map +1 -1
  277. package/dist/views/page-builder/block-renderers/GalleryPreview.d.ts.map +1 -1
  278. package/dist/views/page-builder/block-renderers/GalleryPreview.js +1 -3
  279. package/dist/views/page-builder/block-renderers/GalleryPreview.js.map +1 -1
  280. package/dist/views/page-builder/block-renderers/HeroPreview.d.ts.map +1 -1
  281. package/dist/views/page-builder/block-renderers/HeroPreview.js.map +1 -1
  282. package/dist/views/page-builder/block-renderers/ImagePreview.d.ts.map +1 -1
  283. package/dist/views/page-builder/block-renderers/ImagePreview.js.map +1 -1
  284. package/dist/views/page-builder/block-renderers/TextPreview.d.ts.map +1 -1
  285. package/dist/views/page-builder/block-renderers/TextPreview.js +2 -6
  286. package/dist/views/page-builder/block-renderers/TextPreview.js.map +1 -1
  287. package/dist/views/page-builder/block-renderers/VideoPreview.d.ts.map +1 -1
  288. package/dist/views/page-builder/block-renderers/VideoPreview.js +2 -5
  289. package/dist/views/page-builder/block-renderers/VideoPreview.js.map +1 -1
  290. package/dist/views/page-builder/block-renderers/index.d.ts.map +1 -1
  291. package/dist/views/page-builder/block-renderers/index.js.map +1 -1
  292. package/dist/views/page-builder/canvas/BlockRenderer.d.ts.map +1 -1
  293. package/dist/views/page-builder/canvas/BlockRenderer.js +1 -5
  294. package/dist/views/page-builder/canvas/BlockRenderer.js.map +1 -1
  295. package/dist/views/page-builder/canvas/BuilderCanvas.d.ts.map +1 -1
  296. package/dist/views/page-builder/canvas/BuilderCanvas.js.map +1 -1
  297. package/dist/views/page-builder/canvas/ColumnRenderer.d.ts.map +1 -1
  298. package/dist/views/page-builder/canvas/ColumnRenderer.js +1 -5
  299. package/dist/views/page-builder/canvas/ColumnRenderer.js.map +1 -1
  300. package/dist/views/page-builder/canvas/ContainerRenderer.d.ts.map +1 -1
  301. package/dist/views/page-builder/canvas/ContainerRenderer.js +1 -5
  302. package/dist/views/page-builder/canvas/ContainerRenderer.js.map +1 -1
  303. package/dist/views/page-builder/canvas/RowRenderer.d.ts.map +1 -1
  304. package/dist/views/page-builder/canvas/RowRenderer.js +1 -5
  305. package/dist/views/page-builder/canvas/RowRenderer.js.map +1 -1
  306. package/dist/views/page-builder/canvas/SectionRenderer.d.ts.map +1 -1
  307. package/dist/views/page-builder/canvas/SectionRenderer.js +1 -5
  308. package/dist/views/page-builder/canvas/SectionRenderer.js.map +1 -1
  309. package/dist/views/page-builder/canvas/index.d.ts.map +1 -1
  310. package/dist/views/page-builder/canvas/index.js.map +1 -1
  311. package/package.json +2 -2
  312. package/src/AdminRoot.tsx +263 -191
  313. package/src/__tests__/lib/search.test.ts +60 -69
  314. package/src/__tests__/lib/utils.test.ts +12 -12
  315. package/src/__tests__/router/match-route.test.ts +24 -26
  316. package/src/__tests__/router/strip-base.test.ts +15 -15
  317. package/src/components/Breadcrumbs.tsx +27 -24
  318. package/src/components/CommandPalette.tsx +115 -99
  319. package/src/components/ContentOverviewChart.tsx +19 -14
  320. package/src/components/ErrorBoundary.tsx +13 -13
  321. package/src/components/FocalPointPicker.tsx +31 -20
  322. package/src/components/FolderTree.tsx +172 -139
  323. package/src/components/LivePreview.tsx +68 -41
  324. package/src/components/LocaleProvider.tsx +26 -20
  325. package/src/components/LocaleSwitcher.tsx +9 -11
  326. package/src/components/MediaPickerModal.tsx +46 -45
  327. package/src/components/PresenceIndicator.tsx +30 -27
  328. package/src/components/SEOPanel.tsx +378 -228
  329. package/src/components/SEOPerformance.tsx +52 -30
  330. package/src/components/ThemeProvider.tsx +46 -46
  331. package/src/components/TipTapEditor.tsx +60 -64
  332. package/src/components/VersionHistory.tsx +63 -52
  333. package/src/components/ui/Avatar.tsx +8 -8
  334. package/src/components/ui/Badge.tsx +7 -5
  335. package/src/components/ui/Button.tsx +24 -13
  336. package/src/components/ui/CommandPalette.tsx +56 -42
  337. package/src/components/ui/ConfirmDialog.tsx +14 -14
  338. package/src/components/ui/DataTable.tsx +37 -39
  339. package/src/components/ui/EmptyState.tsx +9 -11
  340. package/src/components/ui/Modal.tsx +21 -15
  341. package/src/components/ui/Pagination.tsx +34 -19
  342. package/src/components/ui/SearchInput.tsx +17 -7
  343. package/src/components/ui/Skeleton.tsx +7 -7
  344. package/src/components/ui/Toast.tsx +29 -22
  345. package/src/components/ui/index.ts +24 -24
  346. package/src/fields/ArrayField.tsx +43 -25
  347. package/src/fields/BlockBuilderField.tsx +80 -99
  348. package/src/fields/DateField.tsx +20 -12
  349. package/src/fields/FieldRenderer.tsx +34 -34
  350. package/src/fields/GroupField.tsx +8 -10
  351. package/src/fields/MediaField.tsx +8 -10
  352. package/src/fields/NavBuilderField.tsx +24 -25
  353. package/src/fields/NumberField.tsx +21 -14
  354. package/src/fields/RelationshipField.tsx +105 -91
  355. package/src/fields/RichTextField.tsx +16 -12
  356. package/src/fields/SelectField.tsx +42 -34
  357. package/src/fields/SlugField.tsx +29 -17
  358. package/src/fields/TextField.tsx +24 -16
  359. package/src/fields/ToggleField.tsx +7 -9
  360. package/src/fields/block-types.ts +50 -24
  361. package/src/fields/index.ts +17 -17
  362. package/src/hooks/useBuilderState.ts +260 -221
  363. package/src/hooks/useContentLock.ts +23 -20
  364. package/src/hooks/useDebounce.ts +7 -7
  365. package/src/hooks/useKeyboardShortcuts.ts +16 -16
  366. package/src/index.ts +69 -58
  367. package/src/layout/Header.tsx +21 -20
  368. package/src/layout/Layout.tsx +22 -24
  369. package/src/layout/Sidebar.tsx +107 -72
  370. package/src/lib/api.ts +34 -34
  371. package/src/lib/search.ts +30 -34
  372. package/src/lib/useApiData.ts +65 -62
  373. package/src/lib/utils.ts +3 -3
  374. package/src/router/index.ts +33 -35
  375. package/src/styles/build-input.css +2 -2
  376. package/src/styles/tailwind.css +1 -1
  377. package/src/styles/theme.css +7 -1
  378. package/src/views/CollectionList.tsx +275 -121
  379. package/src/views/Dashboard.tsx +164 -117
  380. package/src/views/DocumentEdit.tsx +298 -253
  381. package/src/views/ForgotPassword.tsx +27 -23
  382. package/src/views/FormEditor.tsx +165 -99
  383. package/src/views/FormSubmissions.tsx +261 -117
  384. package/src/views/Forms.tsx +56 -26
  385. package/src/views/Login.tsx +107 -84
  386. package/src/views/MediaBrowser.tsx +717 -523
  387. package/src/views/PageEditor.tsx +44 -46
  388. package/src/views/Pages.tsx +312 -149
  389. package/src/views/PostEditor.tsx +57 -51
  390. package/src/views/Posts.tsx +206 -74
  391. package/src/views/Redirects.tsx +173 -117
  392. package/src/views/ResetPassword.tsx +43 -32
  393. package/src/views/SEO.tsx +589 -160
  394. package/src/views/ScriptTagEditor.tsx +69 -69
  395. package/src/views/ScriptTags.tsx +54 -42
  396. package/src/views/Settings.tsx +430 -220
  397. package/src/views/SetupWizard.tsx +69 -46
  398. package/src/views/Users.tsx +154 -120
  399. package/src/views/page-builder/AIBlockAssist.tsx +21 -25
  400. package/src/views/page-builder/AIGenerateDialog.tsx +134 -127
  401. package/src/views/page-builder/BlockEditor.tsx +94 -96
  402. package/src/views/page-builder/BlockPicker.tsx +73 -88
  403. package/src/views/page-builder/BottomBar.tsx +15 -11
  404. package/src/views/page-builder/BuilderToolbar.tsx +32 -29
  405. package/src/views/page-builder/ContextPanel.tsx +57 -57
  406. package/src/views/page-builder/DesignScore.tsx +52 -59
  407. package/src/views/page-builder/NodeSettings.tsx +59 -59
  408. package/src/views/page-builder/PageBuilder.tsx +156 -155
  409. package/src/views/page-builder/PageSettings.tsx +16 -15
  410. package/src/views/page-builder/PageTemplates.tsx +23 -17
  411. package/src/views/page-builder/SEOPanel.tsx +90 -111
  412. package/src/views/page-builder/SavedSections.tsx +99 -105
  413. package/src/views/page-builder/TemplatePicker.tsx +44 -48
  414. package/src/views/page-builder/block-renderers/CTAPreview.tsx +11 -13
  415. package/src/views/page-builder/block-renderers/CardsPreview.tsx +13 -15
  416. package/src/views/page-builder/block-renderers/CodePreview.tsx +16 -16
  417. package/src/views/page-builder/block-renderers/FAQPreview.tsx +20 -23
  418. package/src/views/page-builder/block-renderers/FallbackPreview.tsx +5 -5
  419. package/src/views/page-builder/block-renderers/FormPreview.tsx +9 -13
  420. package/src/views/page-builder/block-renderers/GalleryPreview.tsx +22 -28
  421. package/src/views/page-builder/block-renderers/HeroPreview.tsx +17 -30
  422. package/src/views/page-builder/block-renderers/ImagePreview.tsx +12 -12
  423. package/src/views/page-builder/block-renderers/TextPreview.tsx +22 -22
  424. package/src/views/page-builder/block-renderers/VideoPreview.tsx +13 -18
  425. package/src/views/page-builder/block-renderers/index.ts +17 -17
  426. package/src/views/page-builder/canvas/BlockRenderer.tsx +19 -23
  427. package/src/views/page-builder/canvas/BuilderCanvas.tsx +17 -20
  428. package/src/views/page-builder/canvas/ColumnRenderer.tsx +22 -26
  429. package/src/views/page-builder/canvas/ContainerRenderer.tsx +20 -24
  430. package/src/views/page-builder/canvas/RowRenderer.tsx +19 -23
  431. package/src/views/page-builder/canvas/SectionRenderer.tsx +30 -34
  432. package/src/views/page-builder/canvas/index.ts +2 -2
@@ -1,20 +1,20 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import type { ComponentType } from 'react';
4
- import { HeroPreview } from './HeroPreview.js';
5
- import { TextPreview } from './TextPreview.js';
6
- import { ImagePreview } from './ImagePreview.js';
7
- import { CardsPreview } from './CardsPreview.js';
8
- import { CTAPreview } from './CTAPreview.js';
9
- import { VideoPreview } from './VideoPreview.js';
10
- import { GalleryPreview } from './GalleryPreview.js';
11
- import { FAQPreview } from './FAQPreview.js';
12
- import { FormPreview } from './FormPreview.js';
13
- import { CodePreview } from './CodePreview.js';
3
+ import type { ComponentType } from 'react'
4
+ import { HeroPreview } from './HeroPreview.js'
5
+ import { TextPreview } from './TextPreview.js'
6
+ import { ImagePreview } from './ImagePreview.js'
7
+ import { CardsPreview } from './CardsPreview.js'
8
+ import { CTAPreview } from './CTAPreview.js'
9
+ import { VideoPreview } from './VideoPreview.js'
10
+ import { GalleryPreview } from './GalleryPreview.js'
11
+ import { FAQPreview } from './FAQPreview.js'
12
+ import { FormPreview } from './FormPreview.js'
13
+ import { CodePreview } from './CodePreview.js'
14
14
 
15
15
  export interface BlockPreviewProps {
16
- data: Record<string, unknown>;
17
- variant?: string;
16
+ data: Record<string, unknown>
17
+ variant?: string
18
18
  }
19
19
 
20
20
  export const blockRenderers: Record<string, ComponentType<BlockPreviewProps>> = {
@@ -28,7 +28,7 @@ export const blockRenderers: Record<string, ComponentType<BlockPreviewProps>> =
28
28
  faq: FAQPreview,
29
29
  form: FormPreview,
30
30
  code: CodePreview,
31
- };
31
+ }
32
32
 
33
- export { FallbackPreview } from './FallbackPreview.js';
34
- export type { FallbackPreviewProps } from './FallbackPreview.js';
33
+ export { FallbackPreview } from './FallbackPreview.js'
34
+ export type { FallbackPreviewProps } from './FallbackPreview.js'
@@ -1,13 +1,13 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState } from 'react';
4
- import { Box, Type, Image, Layout, Star } from 'lucide-react';
5
- import type { BlockNode } from '@actuate-media/cms-core';
3
+ import { useState } from 'react'
4
+ import { Box, Type, Image, Layout, Star } from 'lucide-react'
5
+ import type { BlockNode } from '@actuate-media/cms-core'
6
6
 
7
7
  export interface BlockRendererProps {
8
- node: BlockNode;
9
- selectedNodeId: string | null;
10
- onSelectNode: (id: string | null) => void;
8
+ node: BlockNode
9
+ selectedNodeId: string | null
10
+ onSelectNode: (id: string | null) => void
11
11
  }
12
12
 
13
13
  const BLOCK_ICONS: Record<string, typeof Box> = {
@@ -15,33 +15,29 @@ const BLOCK_ICONS: Record<string, typeof Box> = {
15
15
  text: Type,
16
16
  image: Image,
17
17
  layout: Layout,
18
- };
18
+ }
19
19
 
20
20
  function getBlockLabel(blockType: string): string {
21
- return blockType.charAt(0).toUpperCase() + blockType.slice(1);
21
+ return blockType.charAt(0).toUpperCase() + blockType.slice(1)
22
22
  }
23
23
 
24
24
  export function BlockRenderer({ node, selectedNodeId, onSelectNode }: BlockRendererProps) {
25
- const [hovered, setHovered] = useState(false);
26
- const isSelected = selectedNodeId === node.id;
27
- const blockType = node.settings.blockType;
28
- const label = getBlockLabel(blockType);
29
- const Icon = BLOCK_ICONS[blockType] ?? Box;
25
+ const [hovered, setHovered] = useState(false)
26
+ const isSelected = selectedNodeId === node.id
27
+ const blockType = node.settings.blockType
28
+ const label = getBlockLabel(blockType)
29
+ const Icon = BLOCK_ICONS[blockType] ?? Box
30
30
 
31
31
  const handleClick = (e: React.MouseEvent) => {
32
- e.stopPropagation();
33
- onSelectNode(node.id);
34
- };
32
+ e.stopPropagation()
33
+ onSelectNode(node.id)
34
+ }
35
35
 
36
36
  return (
37
37
  <div
38
38
  data-node-id={node.id}
39
39
  className={`relative min-h-[48px] transition-shadow ${
40
- isSelected
41
- ? 'ring-2 ring-primary ring-offset-2'
42
- : hovered
43
- ? 'ring-1 ring-primary/50'
44
- : ''
40
+ isSelected ? 'ring-2 ring-primary ring-offset-2' : hovered ? 'ring-1 ring-primary/50' : ''
45
41
  }`}
46
42
  onClick={handleClick}
47
43
  onMouseEnter={() => setHovered(true)}
@@ -58,5 +54,5 @@ export function BlockRenderer({ node, selectedNodeId, onSelectNode }: BlockRende
58
54
  <span className="text-sm text-muted-foreground">{label}</span>
59
55
  </div>
60
56
  </div>
61
- );
57
+ )
62
58
  }
@@ -1,22 +1,22 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { LayoutGrid } from 'lucide-react';
4
- import type { PageNode } from '@actuate-media/cms-core';
5
- import { SectionRenderer } from './SectionRenderer.js';
3
+ import { LayoutGrid } from 'lucide-react'
4
+ import type { PageNode } from '@actuate-media/cms-core'
5
+ import { SectionRenderer } from './SectionRenderer.js'
6
6
 
7
7
  export interface BuilderCanvasProps {
8
- tree: PageNode;
9
- selectedNodeId: string | null;
10
- showGridOverlay: boolean;
11
- deviceMode: 'desktop' | 'tablet' | 'mobile';
12
- onSelectNode: (id: string | null) => void;
8
+ tree: PageNode
9
+ selectedNodeId: string | null
10
+ showGridOverlay: boolean
11
+ deviceMode: 'desktop' | 'tablet' | 'mobile'
12
+ onSelectNode: (id: string | null) => void
13
13
  }
14
14
 
15
15
  const DEVICE_CLASSES: Record<BuilderCanvasProps['deviceMode'], string> = {
16
16
  desktop: 'w-full',
17
17
  tablet: 'max-w-[768px] mx-auto',
18
18
  mobile: 'max-w-[375px] mx-auto',
19
- };
19
+ }
20
20
 
21
21
  export function BuilderCanvas({
22
22
  tree,
@@ -27,15 +27,12 @@ export function BuilderCanvas({
27
27
  }: BuilderCanvasProps) {
28
28
  const handleCanvasClick = (e: React.MouseEvent) => {
29
29
  if (e.target === e.currentTarget) {
30
- onSelectNode(null);
30
+ onSelectNode(null)
31
31
  }
32
- };
32
+ }
33
33
 
34
34
  return (
35
- <div
36
- className="relative flex-1 overflow-auto bg-muted p-6"
37
- onClick={handleCanvasClick}
38
- >
35
+ <div className="relative flex-1 overflow-auto bg-muted p-6" onClick={handleCanvasClick}>
39
36
  {showGridOverlay && <GridOverlay deviceMode={deviceMode} />}
40
37
 
41
38
  <div
@@ -51,9 +48,9 @@ export function BuilderCanvas({
51
48
  selectedNodeId={selectedNodeId}
52
49
  onSelectNode={onSelectNode}
53
50
  />
54
- );
51
+ )
55
52
  }
56
- return null;
53
+ return null
57
54
  })}
58
55
 
59
56
  {tree.children.length === 0 && (
@@ -67,7 +64,7 @@ export function BuilderCanvas({
67
64
  )}
68
65
  </div>
69
66
  </div>
70
- );
67
+ )
71
68
  }
72
69
 
73
70
  function GridOverlay({ deviceMode }: { deviceMode: BuilderCanvasProps['deviceMode'] }) {
@@ -86,5 +83,5 @@ function GridOverlay({ deviceMode }: { deviceMode: BuilderCanvasProps['deviceMod
86
83
  ))}
87
84
  </div>
88
85
  </div>
89
- );
86
+ )
90
87
  }
@@ -1,36 +1,32 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState } from 'react';
4
- import type { ColumnNode } from '@actuate-media/cms-core';
5
- import { BlockRenderer } from './BlockRenderer.js';
6
- import { ContainerRenderer } from './ContainerRenderer.js';
3
+ import { useState } from 'react'
4
+ import type { ColumnNode } from '@actuate-media/cms-core'
5
+ import { BlockRenderer } from './BlockRenderer.js'
6
+ import { ContainerRenderer } from './ContainerRenderer.js'
7
7
 
8
8
  export interface ColumnRendererProps {
9
- node: ColumnNode;
10
- selectedNodeId: string | null;
11
- onSelectNode: (id: string | null) => void;
9
+ node: ColumnNode
10
+ selectedNodeId: string | null
11
+ onSelectNode: (id: string | null) => void
12
12
  }
13
13
 
14
14
  export function ColumnRenderer({ node, selectedNodeId, onSelectNode }: ColumnRendererProps) {
15
- const [hovered, setHovered] = useState(false);
16
- const isSelected = selectedNodeId === node.id;
17
- const width = node.settings.width;
18
- const isEmpty = node.children.length === 0;
15
+ const [hovered, setHovered] = useState(false)
16
+ const isSelected = selectedNodeId === node.id
17
+ const width = node.settings.width
18
+ const isEmpty = node.children.length === 0
19
19
 
20
20
  const handleClick = (e: React.MouseEvent) => {
21
- e.stopPropagation();
22
- onSelectNode(node.id);
23
- };
21
+ e.stopPropagation()
22
+ onSelectNode(node.id)
23
+ }
24
24
 
25
25
  return (
26
26
  <div
27
27
  data-node-id={node.id}
28
28
  className={`relative transition-shadow ${
29
- isSelected
30
- ? 'ring-2 ring-primary ring-offset-2'
31
- : hovered
32
- ? 'ring-1 ring-primary/50'
33
- : ''
29
+ isSelected ? 'ring-2 ring-primary ring-offset-2' : hovered ? 'ring-1 ring-primary/50' : ''
34
30
  }`}
35
31
  style={{
36
32
  gridColumn: `span ${width}`,
@@ -39,8 +35,8 @@ export function ColumnRenderer({ node, selectedNodeId, onSelectNode }: ColumnRen
39
35
  }}
40
36
  onClick={handleClick}
41
37
  onMouseEnter={(e) => {
42
- e.stopPropagation();
43
- setHovered(true);
38
+ e.stopPropagation()
39
+ setHovered(true)
44
40
  }}
45
41
  onMouseLeave={() => setHovered(false)}
46
42
  >
@@ -65,7 +61,7 @@ export function ColumnRenderer({ node, selectedNodeId, onSelectNode }: ColumnRen
65
61
  selectedNodeId={selectedNodeId}
66
62
  onSelectNode={onSelectNode}
67
63
  />
68
- );
64
+ )
69
65
  }
70
66
  if (child.type === 'container') {
71
67
  return (
@@ -75,12 +71,12 @@ export function ColumnRenderer({ node, selectedNodeId, onSelectNode }: ColumnRen
75
71
  selectedNodeId={selectedNodeId}
76
72
  onSelectNode={onSelectNode}
77
73
  />
78
- );
74
+ )
79
75
  }
80
- return null;
76
+ return null
81
77
  })}
82
78
  </div>
83
79
  )}
84
80
  </div>
85
- );
81
+ )
86
82
  }
@@ -1,42 +1,38 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState } from 'react';
4
- import type { ContainerNode } from '@actuate-media/cms-core';
5
- import { RowRenderer } from './RowRenderer.js';
3
+ import { useState } from 'react'
4
+ import type { ContainerNode } from '@actuate-media/cms-core'
5
+ import { RowRenderer } from './RowRenderer.js'
6
6
 
7
7
  export interface ContainerRendererProps {
8
- node: ContainerNode;
9
- selectedNodeId: string | null;
10
- onSelectNode: (id: string | null) => void;
8
+ node: ContainerNode
9
+ selectedNodeId: string | null
10
+ onSelectNode: (id: string | null) => void
11
11
  }
12
12
 
13
13
  export function ContainerRenderer({ node, selectedNodeId, onSelectNode }: ContainerRendererProps) {
14
- const [hovered, setHovered] = useState(false);
15
- const isSelected = selectedNodeId === node.id;
16
- const maxWidth = node.settings.maxWidth ?? '1200px';
17
- const alignment = node.settings.alignment ?? 'center';
18
- const padding = node.settings.padding;
14
+ const [hovered, setHovered] = useState(false)
15
+ const isSelected = selectedNodeId === node.id
16
+ const maxWidth = node.settings.maxWidth ?? '1200px'
17
+ const alignment = node.settings.alignment ?? 'center'
18
+ const padding = node.settings.padding
19
19
 
20
20
  const marginMap: Record<string, string> = {
21
21
  left: '0 auto 0 0',
22
22
  center: '0 auto',
23
23
  right: '0 0 0 auto',
24
- };
24
+ }
25
25
 
26
26
  const handleClick = (e: React.MouseEvent) => {
27
- e.stopPropagation();
28
- onSelectNode(node.id);
29
- };
27
+ e.stopPropagation()
28
+ onSelectNode(node.id)
29
+ }
30
30
 
31
31
  return (
32
32
  <div
33
33
  data-node-id={node.id}
34
34
  className={`relative transition-shadow ${
35
- isSelected
36
- ? 'ring-2 ring-primary ring-offset-2'
37
- : hovered
38
- ? 'ring-1 ring-primary/50'
39
- : ''
35
+ isSelected ? 'ring-2 ring-primary ring-offset-2' : hovered ? 'ring-1 ring-primary/50' : ''
40
36
  }`}
41
37
  style={{
42
38
  maxWidth,
@@ -45,8 +41,8 @@ export function ContainerRenderer({ node, selectedNodeId, onSelectNode }: Contai
45
41
  }}
46
42
  onClick={handleClick}
47
43
  onMouseEnter={(e) => {
48
- e.stopPropagation();
49
- setHovered(true);
44
+ e.stopPropagation()
45
+ setHovered(true)
50
46
  }}
51
47
  onMouseLeave={() => setHovered(false)}
52
48
  >
@@ -67,5 +63,5 @@ export function ContainerRenderer({ node, selectedNodeId, onSelectNode }: Contai
67
63
  ))}
68
64
  </div>
69
65
  </div>
70
- );
66
+ )
71
67
  }
@@ -1,47 +1,43 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState } from 'react';
4
- import type { RowNode } from '@actuate-media/cms-core';
5
- import { ColumnRenderer } from './ColumnRenderer.js';
3
+ import { useState } from 'react'
4
+ import type { RowNode } from '@actuate-media/cms-core'
5
+ import { ColumnRenderer } from './ColumnRenderer.js'
6
6
 
7
7
  export interface RowRendererProps {
8
- node: RowNode;
9
- selectedNodeId: string | null;
10
- onSelectNode: (id: string | null) => void;
8
+ node: RowNode
9
+ selectedNodeId: string | null
10
+ onSelectNode: (id: string | null) => void
11
11
  }
12
12
 
13
13
  export function RowRenderer({ node, selectedNodeId, onSelectNode }: RowRendererProps) {
14
- const [hovered, setHovered] = useState(false);
15
- const isSelected = selectedNodeId === node.id;
16
- const gap = node.settings.gap ?? '16px';
17
- const verticalAlign = node.settings.verticalAlign ?? 'stretch';
14
+ const [hovered, setHovered] = useState(false)
15
+ const isSelected = selectedNodeId === node.id
16
+ const gap = node.settings.gap ?? '16px'
17
+ const verticalAlign = node.settings.verticalAlign ?? 'stretch'
18
18
 
19
19
  const alignMap: Record<string, string> = {
20
20
  top: 'start',
21
21
  center: 'center',
22
22
  bottom: 'end',
23
23
  stretch: 'stretch',
24
- };
24
+ }
25
25
 
26
26
  const handleClick = (e: React.MouseEvent) => {
27
- e.stopPropagation();
28
- onSelectNode(node.id);
29
- };
27
+ e.stopPropagation()
28
+ onSelectNode(node.id)
29
+ }
30
30
 
31
31
  return (
32
32
  <div
33
33
  data-node-id={node.id}
34
34
  className={`relative transition-shadow ${
35
- isSelected
36
- ? 'ring-2 ring-primary ring-offset-2'
37
- : hovered
38
- ? 'ring-1 ring-primary/50'
39
- : ''
35
+ isSelected ? 'ring-2 ring-primary ring-offset-2' : hovered ? 'ring-1 ring-primary/50' : ''
40
36
  }`}
41
37
  onClick={handleClick}
42
38
  onMouseEnter={(e) => {
43
- e.stopPropagation();
44
- setHovered(true);
39
+ e.stopPropagation()
40
+ setHovered(true)
45
41
  }}
46
42
  onMouseLeave={() => setHovered(false)}
47
43
  >
@@ -68,5 +64,5 @@ export function RowRenderer({ node, selectedNodeId, onSelectNode }: RowRendererP
68
64
  ))}
69
65
  </div>
70
66
  </div>
71
- );
67
+ )
72
68
  }
@@ -1,65 +1,61 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { useState } from 'react';
4
- import type { SectionNode } from '@actuate-media/cms-core';
5
- import { ContainerRenderer } from './ContainerRenderer.js';
6
- import { RowRenderer } from './RowRenderer.js';
3
+ import { useState } from 'react'
4
+ import type { SectionNode } from '@actuate-media/cms-core'
5
+ import { ContainerRenderer } from './ContainerRenderer.js'
6
+ import { RowRenderer } from './RowRenderer.js'
7
7
 
8
8
  export interface SectionRendererProps {
9
- node: SectionNode;
10
- selectedNodeId: string | null;
11
- onSelectNode: (id: string | null) => void;
9
+ node: SectionNode
10
+ selectedNodeId: string | null
11
+ onSelectNode: (id: string | null) => void
12
12
  }
13
13
 
14
14
  export function SectionRenderer({ node, selectedNodeId, onSelectNode }: SectionRendererProps) {
15
- const [hovered, setHovered] = useState(false);
16
- const isSelected = selectedNodeId === node.id;
15
+ const [hovered, setHovered] = useState(false)
16
+ const isSelected = selectedNodeId === node.id
17
17
 
18
18
  const handleClick = (e: React.MouseEvent) => {
19
- e.stopPropagation();
20
- onSelectNode(node.id);
21
- };
19
+ e.stopPropagation()
20
+ onSelectNode(node.id)
21
+ }
22
22
 
23
- const backgroundStyle: React.CSSProperties = {};
23
+ const backgroundStyle: React.CSSProperties = {}
24
24
  if (node.settings.background) {
25
- backgroundStyle.backgroundColor = node.settings.background;
25
+ backgroundStyle.backgroundColor = node.settings.background
26
26
  }
27
27
  if (node.settings.backgroundImage) {
28
- backgroundStyle.backgroundImage = `url(${node.settings.backgroundImage})`;
29
- backgroundStyle.backgroundSize = 'cover';
30
- backgroundStyle.backgroundPosition = 'center';
28
+ backgroundStyle.backgroundImage = `url(${node.settings.backgroundImage})`
29
+ backgroundStyle.backgroundSize = 'cover'
30
+ backgroundStyle.backgroundPosition = 'center'
31
31
  }
32
32
  if (node.settings.backgroundGradient) {
33
- backgroundStyle.backgroundImage = node.settings.backgroundGradient;
33
+ backgroundStyle.backgroundImage = node.settings.backgroundGradient
34
34
  }
35
35
  if (node.settings.paddingTop) {
36
- backgroundStyle.paddingTop = node.settings.paddingTop;
36
+ backgroundStyle.paddingTop = node.settings.paddingTop
37
37
  }
38
38
  if (node.settings.paddingBottom) {
39
- backgroundStyle.paddingBottom = node.settings.paddingBottom;
39
+ backgroundStyle.paddingBottom = node.settings.paddingBottom
40
40
  }
41
41
  if (node.settings.marginTop) {
42
- backgroundStyle.marginTop = node.settings.marginTop;
42
+ backgroundStyle.marginTop = node.settings.marginTop
43
43
  }
44
44
  if (node.settings.marginBottom) {
45
- backgroundStyle.marginBottom = node.settings.marginBottom;
45
+ backgroundStyle.marginBottom = node.settings.marginBottom
46
46
  }
47
47
 
48
48
  return (
49
49
  <div
50
50
  data-node-id={node.id}
51
51
  className={`relative w-full transition-shadow ${
52
- isSelected
53
- ? 'ring-2 ring-primary ring-offset-2'
54
- : hovered
55
- ? 'ring-1 ring-primary/50'
56
- : ''
52
+ isSelected ? 'ring-2 ring-primary ring-offset-2' : hovered ? 'ring-1 ring-primary/50' : ''
57
53
  }`}
58
54
  style={backgroundStyle}
59
55
  onClick={handleClick}
60
56
  onMouseEnter={(e) => {
61
- e.stopPropagation();
62
- setHovered(true);
57
+ e.stopPropagation()
58
+ setHovered(true)
63
59
  }}
64
60
  onMouseLeave={() => setHovered(false)}
65
61
  >
@@ -78,7 +74,7 @@ export function SectionRenderer({ node, selectedNodeId, onSelectNode }: SectionR
78
74
  selectedNodeId={selectedNodeId}
79
75
  onSelectNode={onSelectNode}
80
76
  />
81
- );
77
+ )
82
78
  }
83
79
  if (child.type === 'row') {
84
80
  return (
@@ -88,10 +84,10 @@ export function SectionRenderer({ node, selectedNodeId, onSelectNode }: SectionR
88
84
  selectedNodeId={selectedNodeId}
89
85
  onSelectNode={onSelectNode}
90
86
  />
91
- );
87
+ )
92
88
  }
93
- return null;
89
+ return null
94
90
  })}
95
91
  </div>
96
- );
92
+ )
97
93
  }
@@ -1,2 +1,2 @@
1
- export { BuilderCanvas } from './BuilderCanvas.js';
2
- export type { BuilderCanvasProps } from './BuilderCanvas.js';
1
+ export { BuilderCanvas } from './BuilderCanvas.js'
2
+ export type { BuilderCanvasProps } from './BuilderCanvas.js'