@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,38 +1,33 @@
1
- import { describe, it, expect } from 'vitest';
2
- import {
3
- scoreRelevance,
4
- sortByRelevance,
5
- sortByColumn,
6
- toggleSort,
7
- } from '../../lib/search.js';
1
+ import { describe, it, expect } from 'vitest'
2
+ import { scoreRelevance, sortByRelevance, sortByColumn, toggleSort } from '../../lib/search.js'
8
3
 
9
4
  describe('scoreRelevance', () => {
10
5
  it('returns 100 for exact match (case-insensitive)', () => {
11
- expect(scoreRelevance('Hello', 'hello')).toBe(100);
12
- expect(scoreRelevance('test', 'test')).toBe(100);
13
- });
6
+ expect(scoreRelevance('Hello', 'hello')).toBe(100)
7
+ expect(scoreRelevance('test', 'test')).toBe(100)
8
+ })
14
9
 
15
10
  it('returns 80 when text starts with the query', () => {
16
- expect(scoreRelevance('hello world', 'hel')).toBe(80);
17
- expect(scoreRelevance('Alpha', 'al')).toBe(80);
18
- });
11
+ expect(scoreRelevance('hello world', 'hel')).toBe(80)
12
+ expect(scoreRelevance('Alpha', 'al')).toBe(80)
13
+ })
19
14
 
20
15
  it('returns 60 when query matches at a word boundary but not at start', () => {
21
- expect(scoreRelevance('say hello', 'hello')).toBe(60);
22
- });
16
+ expect(scoreRelevance('say hello', 'hello')).toBe(60)
17
+ })
23
18
 
24
19
  it('returns 40 when query appears only as a substring without word-boundary match', () => {
25
- expect(scoreRelevance('axxhello', 'hello')).toBe(40);
26
- });
20
+ expect(scoreRelevance('axxhello', 'hello')).toBe(40)
21
+ })
27
22
 
28
23
  it('returns 0 when there is no match', () => {
29
- expect(scoreRelevance('abc def', 'xyz')).toBe(0);
30
- });
24
+ expect(scoreRelevance('abc def', 'xyz')).toBe(0)
25
+ })
31
26
 
32
27
  it('returns 0 for an empty query', () => {
33
- expect(scoreRelevance('anything', '')).toBe(0);
34
- });
35
- });
28
+ expect(scoreRelevance('anything', '')).toBe(0)
29
+ })
30
+ })
36
31
 
37
32
  describe('sortByRelevance', () => {
38
33
  it('sorts items by best field relevance score descending', () => {
@@ -40,99 +35,95 @@ describe('sortByRelevance', () => {
40
35
  { id: 'a', title: 'zzz' },
41
36
  { id: 'b', title: 'hello' },
42
37
  { id: 'c', title: 'say hello' },
43
- ];
44
- const sorted = sortByRelevance(items, 'hello', item => [item.title]);
38
+ ]
39
+ const sorted = sortByRelevance(items, 'hello', (item) => [item.title])
45
40
  // exact match > word-boundary match > no match
46
- expect(sorted.map(i => i.id)).toEqual(['b', 'c', 'a']);
47
- });
41
+ expect(sorted.map((i) => i.id)).toEqual(['b', 'c', 'a'])
42
+ })
48
43
 
49
44
  it('returns the original array reference for an empty query', () => {
50
- const items = [{ id: '1' }, { id: '2' }];
51
- const result = sortByRelevance(items, '', item => [item.id]);
52
- expect(result).toBe(items);
53
- });
45
+ const items = [{ id: '1' }, { id: '2' }]
46
+ const result = sortByRelevance(items, '', (item) => [item.id])
47
+ expect(result).toBe(items)
48
+ })
54
49
 
55
50
  it('returns the original array when query is whitespace-only', () => {
56
- const items = [{ id: '1' }];
57
- expect(sortByRelevance(items, ' ', item => [item.id])).toBe(items);
58
- });
51
+ const items = [{ id: '1' }]
52
+ expect(sortByRelevance(items, ' ', (item) => [item.id])).toBe(items)
53
+ })
59
54
 
60
55
  it('uses the maximum score across multiple search fields', () => {
61
56
  const items = [
62
57
  { id: 'low', a: 'x', b: 'x' },
63
58
  { id: 'high', a: 'x', b: 'exact' },
64
- ];
65
- const sorted = sortByRelevance(items, 'exact', item => [item.a, item.b]);
66
- expect(sorted[0]!.id).toBe('high');
67
- });
68
- });
59
+ ]
60
+ const sorted = sortByRelevance(items, 'exact', (item) => [item.a, item.b])
61
+ expect(sorted[0]!.id).toBe('high')
62
+ })
63
+ })
69
64
 
70
65
  describe('sortByColumn', () => {
71
66
  it('returns the original array when sortConfig is null', () => {
72
- const items = [{ n: 2 }, { n: 1 }];
73
- expect(sortByColumn(items, null, (item, key) => item[key as 'n'])).toBe(items);
74
- });
67
+ const items = [{ n: 2 }, { n: 1 }]
68
+ expect(sortByColumn(items, null, (item, key) => item[key as 'n'])).toBe(items)
69
+ })
75
70
 
76
71
  it('sorts strings ascending', () => {
77
- const items = [{ name: 'b' }, { name: 'a' }, { name: 'c' }];
72
+ const items = [{ name: 'b' }, { name: 'a' }, { name: 'c' }]
78
73
  const sorted = sortByColumn(
79
74
  items,
80
75
  { key: 'name', direction: 'asc' },
81
76
  (item, key) => item[key as 'name'],
82
- );
83
- expect(sorted.map(i => i.name)).toEqual(['a', 'b', 'c']);
84
- });
77
+ )
78
+ expect(sorted.map((i) => i.name)).toEqual(['a', 'b', 'c'])
79
+ })
85
80
 
86
81
  it('sorts strings descending', () => {
87
- const items = [{ name: 'a' }, { name: 'c' }, { name: 'b' }];
82
+ const items = [{ name: 'a' }, { name: 'c' }, { name: 'b' }]
88
83
  const sorted = sortByColumn(
89
84
  items,
90
85
  { key: 'name', direction: 'desc' },
91
86
  (item, key) => item[key as 'name'],
92
- );
93
- expect(sorted.map(i => i.name)).toEqual(['c', 'b', 'a']);
94
- });
87
+ )
88
+ expect(sorted.map((i) => i.name)).toEqual(['c', 'b', 'a'])
89
+ })
95
90
 
96
91
  it('sorts numbers ascending and descending', () => {
97
- const items = [{ v: 3 }, { v: 1 }, { v: 2 }];
98
- const asc = sortByColumn(
99
- items,
100
- { key: 'v', direction: 'asc' },
101
- (item, key) => item[key as 'v'],
102
- );
103
- expect(asc.map(i => i.v)).toEqual([1, 2, 3]);
92
+ const items = [{ v: 3 }, { v: 1 }, { v: 2 }]
93
+ const asc = sortByColumn(items, { key: 'v', direction: 'asc' }, (item, key) => item[key as 'v'])
94
+ expect(asc.map((i) => i.v)).toEqual([1, 2, 3])
104
95
  const desc = sortByColumn(
105
96
  items,
106
97
  { key: 'v', direction: 'desc' },
107
98
  (item, key) => item[key as 'v'],
108
- );
109
- expect(desc.map(i => i.v)).toEqual([3, 2, 1]);
110
- });
111
- });
99
+ )
100
+ expect(desc.map((i) => i.v)).toEqual([3, 2, 1])
101
+ })
102
+ })
112
103
 
113
104
  describe('toggleSort', () => {
114
105
  it('returns ascending sort when current is null', () => {
115
- expect(toggleSort(null, 'title')).toEqual({ key: 'title', direction: 'asc' });
116
- });
106
+ expect(toggleSort(null, 'title')).toEqual({ key: 'title', direction: 'asc' })
107
+ })
117
108
 
118
109
  it('toggles same key from asc to desc', () => {
119
110
  expect(toggleSort({ key: 'title', direction: 'asc' }, 'title')).toEqual({
120
111
  key: 'title',
121
112
  direction: 'desc',
122
- });
123
- });
113
+ })
114
+ })
124
115
 
125
116
  it('toggles same key from desc to asc', () => {
126
117
  expect(toggleSort({ key: 'title', direction: 'desc' }, 'title')).toEqual({
127
118
  key: 'title',
128
119
  direction: 'asc',
129
- });
130
- });
120
+ })
121
+ })
131
122
 
132
123
  it('starts ascending when switching to a different key', () => {
133
124
  expect(toggleSort({ key: 'foo', direction: 'desc' }, 'bar')).toEqual({
134
125
  key: 'bar',
135
126
  direction: 'asc',
136
- });
137
- });
138
- });
127
+ })
128
+ })
129
+ })
@@ -1,19 +1,19 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { cn } from '../../lib/utils.js';
1
+ import { describe, it, expect } from 'vitest'
2
+ import { cn } from '../../lib/utils.js'
3
3
 
4
4
  describe('cn', () => {
5
5
  it('merges multiple class names into a single string', () => {
6
- expect(cn('foo', 'bar')).toBe('foo bar');
7
- expect(cn('a', 'b', 'c')).toBe('a b c');
8
- });
6
+ expect(cn('foo', 'bar')).toBe('foo bar')
7
+ expect(cn('a', 'b', 'c')).toBe('a b c')
8
+ })
9
9
 
10
10
  it('omits falsy conditional classes', () => {
11
- expect(cn('base', false && 'hidden', 'visible')).toBe('base visible');
12
- expect(cn('x', undefined, null, 0, 'y')).toBe('x y');
13
- });
11
+ expect(cn('base', false && 'hidden', 'visible')).toBe('base visible')
12
+ expect(cn('x', undefined, null, 0, 'y')).toBe('x y')
13
+ })
14
14
 
15
15
  it('resolves conflicting Tailwind utilities in favor of the last one', () => {
16
- expect(cn('p-4', 'p-2')).toBe('p-2');
17
- expect(cn('text-sm', 'text-lg')).toBe('text-lg');
18
- });
19
- });
16
+ expect(cn('p-4', 'p-2')).toBe('p-2')
17
+ expect(cn('text-sm', 'text-lg')).toBe('text-lg')
18
+ })
19
+ })
@@ -1,47 +1,45 @@
1
- import { describe, it, expect } from 'vitest';
1
+ import { describe, it, expect } from 'vitest'
2
2
 
3
3
  function matchRoute(currentPath: string, pattern: string): Record<string, string> | null {
4
- const patternParts = pattern.split('/').filter(Boolean);
5
- const pathParts = currentPath.split('/').filter(Boolean);
6
- if (pattern === '/' && pathParts.length === 0) return {};
7
- if (patternParts.length !== pathParts.length) return null;
8
- const params: Record<string, string> = {};
4
+ const patternParts = pattern.split('/').filter(Boolean)
5
+ const pathParts = currentPath.split('/').filter(Boolean)
6
+ if (pattern === '/' && pathParts.length === 0) return {}
7
+ if (patternParts.length !== pathParts.length) return null
8
+ const params: Record<string, string> = {}
9
9
  for (let i = 0; i < patternParts.length; i++) {
10
- const patternPart = patternParts[i]!;
11
- const pathPart = pathParts[i]!;
10
+ const patternPart = patternParts[i]!
11
+ const pathPart = pathParts[i]!
12
12
  if (patternPart.startsWith(':')) {
13
- params[patternPart.slice(1)] = pathPart;
13
+ params[patternPart.slice(1)] = pathPart
14
14
  } else if (patternPart !== pathPart) {
15
- return null;
15
+ return null
16
16
  }
17
17
  }
18
- return params;
18
+ return params
19
19
  }
20
20
 
21
21
  describe('matchRoute', () => {
22
22
  it('matches the root pattern against an empty path', () => {
23
- expect(matchRoute('/', '/')).toEqual({});
24
- });
23
+ expect(matchRoute('/', '/')).toEqual({})
24
+ })
25
25
 
26
26
  it('matches static multi-segment paths', () => {
27
- expect(matchRoute('/collections/posts', '/collections/posts')).toEqual({});
28
- });
27
+ expect(matchRoute('/collections/posts', '/collections/posts')).toEqual({})
28
+ })
29
29
 
30
30
  it('extracts named parameters from dynamic segments', () => {
31
31
  expect(matchRoute('/collections/posts/abc-123', '/collections/posts/:id')).toEqual({
32
32
  id: 'abc-123',
33
- });
34
- expect(
35
- matchRoute('/users/u1/settings', '/users/:userId/settings'),
36
- ).toEqual({ userId: 'u1' });
37
- });
33
+ })
34
+ expect(matchRoute('/users/u1/settings', '/users/:userId/settings')).toEqual({ userId: 'u1' })
35
+ })
38
36
 
39
37
  it('returns null when a static segment does not match', () => {
40
- expect(matchRoute('/collections/pages', '/collections/posts')).toBeNull();
41
- });
38
+ expect(matchRoute('/collections/pages', '/collections/posts')).toBeNull()
39
+ })
42
40
 
43
41
  it('returns null when segment counts differ', () => {
44
- expect(matchRoute('/a', '/a/b')).toBeNull();
45
- expect(matchRoute('/a/b', '/a')).toBeNull();
46
- });
47
- });
42
+ expect(matchRoute('/a', '/a/b')).toBeNull()
43
+ expect(matchRoute('/a/b', '/a')).toBeNull()
44
+ })
45
+ })
@@ -1,30 +1,30 @@
1
- import { describe, it, expect } from 'vitest';
1
+ import { describe, it, expect } from 'vitest'
2
2
 
3
3
  // Copy of the internal stripBase function for testing
4
4
  function stripBase(pathname: string, basePath: string): string {
5
5
  if (pathname.startsWith(basePath)) {
6
- const rest = pathname.slice(basePath.length);
7
- return rest === '' || rest === '/' ? '/' : rest.startsWith('/') ? rest : `/${rest}`;
6
+ const rest = pathname.slice(basePath.length)
7
+ return rest === '' || rest === '/' ? '/' : rest.startsWith('/') ? rest : `/${rest}`
8
8
  }
9
- return '/';
9
+ return '/'
10
10
  }
11
11
 
12
12
  describe('stripBase', () => {
13
13
  it('strips the base path and returns the remainder with a leading slash', () => {
14
- expect(stripBase('/admin/dashboard', '/admin')).toBe('/dashboard');
15
- expect(stripBase('/admin/collections/posts', '/admin')).toBe('/collections/posts');
16
- });
14
+ expect(stripBase('/admin/dashboard', '/admin')).toBe('/dashboard')
15
+ expect(stripBase('/admin/collections/posts', '/admin')).toBe('/collections/posts')
16
+ })
17
17
 
18
18
  it('returns root when the pathname is exactly the base or base plus trailing slash', () => {
19
- expect(stripBase('/admin', '/admin')).toBe('/');
20
- expect(stripBase('/admin/', '/admin')).toBe('/');
21
- });
19
+ expect(stripBase('/admin', '/admin')).toBe('/')
20
+ expect(stripBase('/admin/', '/admin')).toBe('/')
21
+ })
22
22
 
23
23
  it('returns root when the pathname does not start with the base path', () => {
24
- expect(stripBase('/public/page', '/admin')).toBe('/');
25
- });
24
+ expect(stripBase('/public/page', '/admin')).toBe('/')
25
+ })
26
26
 
27
27
  it('normalizes remainder that lacks a leading slash', () => {
28
- expect(stripBase('/adminfoo', '/admin')).toBe('/foo');
29
- });
30
- });
28
+ expect(stripBase('/adminfoo', '/admin')).toBe('/foo')
29
+ })
30
+ })
@@ -1,6 +1,6 @@
1
- 'use client';
1
+ 'use client'
2
2
 
3
- import { ChevronRight, Home } from 'lucide-react';
3
+ import { ChevronRight, Home } from 'lucide-react'
4
4
 
5
5
  const LABEL_MAP: Record<string, string> = {
6
6
  posts: 'Posts',
@@ -18,48 +18,51 @@ const LABEL_MAP: Record<string, string> = {
18
18
  submissions: 'Submissions',
19
19
  new: 'New',
20
20
  edit: 'Edit',
21
- };
21
+ }
22
22
 
23
23
  function labelFor(segment: string): string {
24
- return LABEL_MAP[segment] ?? segment.replace(/[-_]/g, ' ').replace(/\b\w/g, c => c.toUpperCase());
24
+ return (
25
+ LABEL_MAP[segment] ?? segment.replace(/[-_]/g, ' ').replace(/\b\w/g, (c) => c.toUpperCase())
26
+ )
25
27
  }
26
28
 
27
29
  function isId(segment: string): boolean {
28
- return /^\d+$/.test(segment) || /^[0-9a-f]{8,}$/i.test(segment);
30
+ return /^\d+$/.test(segment) || /^[0-9a-f]{8,}$/i.test(segment)
29
31
  }
30
32
 
31
33
  export interface BreadcrumbsProps {
32
- currentPath: string;
33
- onNavigate: (path: string) => void;
34
+ currentPath: string
35
+ onNavigate: (path: string) => void
34
36
  }
35
37
 
36
38
  export function Breadcrumbs({ currentPath, onNavigate }: BreadcrumbsProps) {
37
- const segments = currentPath.split('/').filter(Boolean);
39
+ const segments = currentPath.split('/').filter(Boolean)
38
40
 
39
- if (segments.length === 0) return null;
41
+ if (segments.length === 0) return null
40
42
 
41
- const crumbs: { label: string; path: string }[] = [];
42
- let accumulated = '';
43
+ const crumbs: { label: string; path: string }[] = []
44
+ let accumulated = ''
43
45
 
44
46
  for (let i = 0; i < segments.length; i++) {
45
- const seg = segments[i]!;
46
- accumulated += `/${seg}`;
47
+ const seg = segments[i]!
48
+ accumulated += `/${seg}`
47
49
 
48
- let label: string;
50
+ let label: string
49
51
  if (isId(seg)) {
50
- const parentLabel = i > 0 ? labelFor(segments[i - 1]!) : '';
51
- label = parentLabel
52
- ? `Edit ${parentLabel.replace(/s$/, '')}`
53
- : `#${seg}`;
52
+ const parentLabel = i > 0 ? labelFor(segments[i - 1]!) : ''
53
+ label = parentLabel ? `Edit ${parentLabel.replace(/s$/, '')}` : `#${seg}`
54
54
  } else {
55
- label = labelFor(seg);
55
+ label = labelFor(seg)
56
56
  }
57
57
 
58
- crumbs.push({ label, path: accumulated });
58
+ crumbs.push({ label, path: accumulated })
59
59
  }
60
60
 
61
61
  return (
62
- <nav aria-label="Breadcrumb" className="flex items-center gap-1 text-sm py-2.5 px-4 bg-white border-b border-gray-200 overflow-x-auto">
62
+ <nav
63
+ aria-label="Breadcrumb"
64
+ className="flex items-center gap-1 text-sm py-2.5 px-4 bg-white border-b border-gray-200 overflow-x-auto"
65
+ >
63
66
  <button
64
67
  type="button"
65
68
  onClick={() => onNavigate('/')}
@@ -70,7 +73,7 @@ export function Breadcrumbs({ currentPath, onNavigate }: BreadcrumbsProps) {
70
73
  </button>
71
74
 
72
75
  {crumbs.map((crumb, i) => {
73
- const isLast = i === crumbs.length - 1;
76
+ const isLast = i === crumbs.length - 1
74
77
  return (
75
78
  <span key={crumb.path} className="flex items-center gap-1 shrink-0">
76
79
  <ChevronRight className="w-3.5 h-3.5 text-gray-400" />
@@ -86,8 +89,8 @@ export function Breadcrumbs({ currentPath, onNavigate }: BreadcrumbsProps) {
86
89
  </button>
87
90
  )}
88
91
  </span>
89
- );
92
+ )
90
93
  })}
91
94
  </nav>
92
- );
95
+ )
93
96
  }