@firecms/core 3.0.0-canary.25 → 3.0.0-canary.251

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 (401) hide show
  1. package/README.md +3 -3
  2. package/dist/app/AppBar.d.ts +12 -0
  3. package/dist/app/Drawer.d.ts +16 -0
  4. package/dist/app/Scaffold.d.ts +34 -0
  5. package/dist/app/index.d.ts +4 -0
  6. package/dist/app/useApp.d.ts +16 -0
  7. package/dist/components/ArrayContainer.d.ts +31 -12
  8. package/dist/components/CircularProgressCenter.d.ts +1 -1
  9. package/dist/components/ClearFilterSortButton.d.ts +5 -0
  10. package/dist/components/{DeleteConfirmationDialog.d.ts → ConfirmationDialog.d.ts} +1 -1
  11. package/dist/components/EntityCollectionTable/EntityCollectionRowActions.d.ts +13 -13
  12. package/dist/components/EntityCollectionTable/EntityCollectionTable.d.ts +2 -2
  13. package/dist/components/EntityCollectionTable/EntityCollectionTableProps.d.ts +22 -6
  14. package/dist/components/EntityCollectionTable/PropertyTableCell.d.ts +1 -0
  15. package/dist/components/EntityCollectionTable/column_utils.d.ts +1 -2
  16. package/dist/components/EntityCollectionTable/fields/TableReferenceField.d.ts +3 -1
  17. package/dist/components/EntityCollectionTable/index.d.ts +1 -1
  18. package/dist/components/EntityCollectionTable/internal/CollectionTableToolbar.d.ts +1 -4
  19. package/dist/components/EntityCollectionTable/internal/EntityTableCell.d.ts +2 -2
  20. package/dist/components/EntityCollectionTable/internal/popup_field/PopupFormField.d.ts +7 -4
  21. package/dist/components/EntityCollectionView/EntityCollectionView.d.ts +20 -2
  22. package/dist/components/EntityCollectionView/EntityCollectionViewStartActions.d.ts +11 -0
  23. package/dist/components/EntityCollectionView/utils.d.ts +3 -0
  24. package/dist/components/EntityJsonPreview.d.ts +3 -0
  25. package/dist/components/EntityPreview.d.ts +8 -5
  26. package/dist/components/ErrorView.d.ts +1 -1
  27. package/dist/components/HomePage/DefaultHomePage.d.ts +2 -15
  28. package/dist/components/HomePage/HomePageDnD.d.ts +76 -0
  29. package/dist/components/HomePage/NavigationCard.d.ts +3 -1
  30. package/dist/components/HomePage/NavigationCardBinding.d.ts +4 -3
  31. package/dist/components/HomePage/NavigationGroup.d.ts +7 -1
  32. package/dist/components/HomePage/RenameGroupDialog.d.ts +9 -0
  33. package/dist/components/PropertyConfigBadge.d.ts +2 -1
  34. package/dist/components/PropertyIdCopyTooltip.d.ts +8 -0
  35. package/dist/components/ReferenceWidget.d.ts +3 -1
  36. package/dist/components/SelectableTable/SelectableTable.d.ts +14 -4
  37. package/dist/components/SelectableTable/filters/ReferenceFilterField.d.ts +2 -1
  38. package/dist/components/UnsavedChangesDialog.d.ts +8 -0
  39. package/dist/components/VirtualTable/VirtualTableProps.d.ts +24 -12
  40. package/dist/components/VirtualTable/types.d.ts +3 -3
  41. package/dist/components/{EntityCollectionTable/internal → common}/default_entity_actions.d.ts +1 -3
  42. package/dist/components/common/index.d.ts +2 -1
  43. package/dist/components/common/table_height.d.ts +5 -0
  44. package/dist/components/common/types.d.ts +4 -6
  45. package/dist/components/common/useColumnsIds.d.ts +3 -1
  46. package/dist/components/common/{useDataSourceEntityCollectionTableController.d.ts → useDataSourceTableController.d.ts} +13 -2
  47. package/dist/components/common/useDebouncedCallback.d.ts +1 -0
  48. package/dist/components/common/useScrollRestoration.d.ts +14 -0
  49. package/dist/components/index.d.ts +5 -2
  50. package/dist/contexts/BreacrumbsContext.d.ts +8 -0
  51. package/dist/core/DefaultAppBar.d.ts +29 -0
  52. package/dist/core/DefaultDrawer.d.ts +19 -0
  53. package/dist/core/DrawerNavigationItem.d.ts +10 -0
  54. package/dist/core/EntityEditView.d.ts +40 -11
  55. package/dist/core/EntityEditViewFormActions.d.ts +2 -0
  56. package/dist/core/FireCMS.d.ts +3 -3
  57. package/dist/core/FireCMSRouter.d.ts +4 -0
  58. package/dist/core/NavigationRoutes.d.ts +2 -3
  59. package/dist/core/SideDialogs.d.ts +4 -2
  60. package/dist/core/field_configs.d.ts +1 -1
  61. package/dist/core/index.d.ts +4 -4
  62. package/dist/form/EntityForm.d.ts +36 -64
  63. package/dist/form/EntityFormActions.d.ts +17 -0
  64. package/dist/form/PropertyFieldBinding.d.ts +1 -1
  65. package/dist/form/components/ErrorFocus.d.ts +1 -1
  66. package/dist/form/components/FieldHelperText.d.ts +3 -3
  67. package/dist/form/components/FormEntry.d.ts +6 -0
  68. package/dist/form/components/FormLayout.d.ts +5 -0
  69. package/dist/form/components/LabelWithIcon.d.ts +1 -1
  70. package/dist/form/components/LabelWithIconAndTooltip.d.ts +15 -0
  71. package/dist/form/components/StorageItemPreview.d.ts +4 -4
  72. package/dist/form/components/index.d.ts +3 -1
  73. package/dist/form/field_bindings/ArrayCustomShapedFieldBinding.d.ts +1 -1
  74. package/dist/form/field_bindings/ArrayOfReferencesFieldBinding.d.ts +1 -1
  75. package/dist/form/field_bindings/BlockFieldBinding.d.ts +1 -1
  76. package/dist/form/field_bindings/KeyValueFieldBinding.d.ts +1 -1
  77. package/dist/form/field_bindings/MapFieldBinding.d.ts +1 -1
  78. package/dist/form/field_bindings/MarkdownEditorFieldBinding.d.ts +11 -0
  79. package/dist/form/field_bindings/{MultiSelectBinding.d.ts → MultiSelectFieldBinding.d.ts} +1 -1
  80. package/dist/form/field_bindings/ReadOnlyFieldBinding.d.ts +1 -1
  81. package/dist/form/field_bindings/ReferenceAsStringFieldBinding.d.ts +9 -0
  82. package/dist/form/field_bindings/ReferenceFieldBinding.d.ts +2 -2
  83. package/dist/form/field_bindings/RepeatFieldBinding.d.ts +1 -1
  84. package/dist/form/field_bindings/SelectFieldBinding.d.ts +1 -1
  85. package/dist/form/field_bindings/StorageUploadFieldBinding.d.ts +5 -13
  86. package/dist/form/field_bindings/SwitchFieldBinding.d.ts +1 -2
  87. package/dist/form/field_bindings/TextFieldBinding.d.ts +1 -1
  88. package/dist/form/index.d.ts +17 -18
  89. package/dist/form/useClearRestoreValue.d.ts +2 -2
  90. package/dist/hooks/data/delete.d.ts +4 -4
  91. package/dist/hooks/data/save.d.ts +4 -5
  92. package/dist/hooks/data/useCollectionFetch.d.ts +1 -1
  93. package/dist/hooks/data/useEntityFetch.d.ts +4 -3
  94. package/dist/hooks/index.d.ts +1 -0
  95. package/dist/hooks/useAuthController.d.ts +1 -1
  96. package/dist/hooks/useBreadcrumbsController.d.ts +26 -0
  97. package/dist/hooks/useBuildNavigationController.d.ts +57 -13
  98. package/dist/hooks/useFireCMSContext.d.ts +1 -1
  99. package/dist/hooks/useModeController.d.ts +1 -2
  100. package/dist/hooks/useProjectLog.d.ts +8 -2
  101. package/dist/hooks/useResolvedNavigationFrom.d.ts +3 -3
  102. package/dist/hooks/useValidateAuthenticator.d.ts +4 -8
  103. package/dist/index.d.ts +1 -0
  104. package/dist/index.es.js +22838 -13874
  105. package/dist/index.es.js.map +1 -1
  106. package/dist/index.umd.js +25639 -588
  107. package/dist/index.umd.js.map +1 -1
  108. package/dist/internal/useBuildDataSource.d.ts +3 -17
  109. package/dist/internal/useBuildSideEntityController.d.ts +3 -3
  110. package/dist/internal/useUnsavedChangesDialog.d.ts +7 -9
  111. package/dist/preview/PropertyPreviewProps.d.ts +6 -1
  112. package/dist/preview/components/EnumValuesChip.d.ts +1 -1
  113. package/dist/preview/components/ReferencePreview.d.ts +3 -2
  114. package/dist/preview/components/StorageThumbnail.d.ts +2 -1
  115. package/dist/preview/components/UrlComponentPreview.d.ts +2 -1
  116. package/dist/preview/util.d.ts +3 -3
  117. package/dist/routes/CustomCMSRoute.d.ts +4 -0
  118. package/dist/routes/FireCMSRoute.d.ts +1 -0
  119. package/dist/routes/HomePageRoute.d.ts +3 -0
  120. package/dist/types/analytics.d.ts +1 -1
  121. package/dist/types/auth.d.ts +8 -10
  122. package/dist/types/collections.d.ts +107 -25
  123. package/dist/types/datasource.d.ts +52 -36
  124. package/dist/types/dialogs_controller.d.ts +7 -3
  125. package/dist/types/entities.d.ts +7 -2
  126. package/dist/types/entity_actions.d.ts +28 -4
  127. package/dist/types/entity_callbacks.d.ts +16 -16
  128. package/dist/types/entity_overrides.d.ts +2 -2
  129. package/dist/types/export_import.d.ts +4 -4
  130. package/dist/types/fields.d.ts +74 -42
  131. package/dist/types/firecms.d.ts +8 -3
  132. package/dist/types/firecms_context.d.ts +1 -1
  133. package/dist/types/index.d.ts +0 -1
  134. package/dist/types/navigation.d.ts +62 -19
  135. package/dist/types/permissions.d.ts +4 -4
  136. package/dist/types/plugins.d.ts +48 -12
  137. package/dist/types/properties.d.ts +80 -24
  138. package/dist/types/property_config.d.ts +1 -3
  139. package/dist/types/side_dialogs_controller.d.ts +10 -0
  140. package/dist/types/side_entity_controller.d.ts +10 -1
  141. package/dist/types/storage.d.ts +75 -0
  142. package/dist/types/user.d.ts +1 -0
  143. package/dist/util/builders.d.ts +3 -3
  144. package/dist/util/callbacks.d.ts +2 -0
  145. package/dist/util/createFormexStub.d.ts +2 -0
  146. package/dist/util/entities.d.ts +3 -3
  147. package/dist/util/entity_actions.d.ts +2 -0
  148. package/dist/util/entity_cache.d.ts +23 -0
  149. package/dist/util/icon_list.d.ts +5 -1
  150. package/dist/util/icon_synonyms.d.ts +1 -98
  151. package/dist/util/icons.d.ts +7 -4
  152. package/dist/util/index.d.ts +3 -0
  153. package/dist/util/navigation_from_path.d.ts +6 -1
  154. package/dist/util/navigation_utils.d.ts +15 -3
  155. package/dist/util/objects.d.ts +2 -1
  156. package/dist/util/permissions.d.ts +4 -4
  157. package/dist/util/plurals.d.ts +0 -2
  158. package/dist/util/property_utils.d.ts +4 -4
  159. package/dist/util/references.d.ts +2 -2
  160. package/dist/util/resolutions.d.ts +41 -17
  161. package/dist/util/storage.d.ts +23 -2
  162. package/dist/util/useStorageUploadController.d.ts +3 -3
  163. package/package.json +64 -48
  164. package/src/app/AppBar.tsx +18 -0
  165. package/src/app/Drawer.tsx +24 -0
  166. package/src/app/Scaffold.tsx +253 -0
  167. package/src/app/index.ts +4 -0
  168. package/src/app/useApp.tsx +32 -0
  169. package/src/components/ArrayContainer.tsx +447 -229
  170. package/src/components/CircularProgressCenter.tsx +2 -2
  171. package/src/components/ClearFilterSortButton.tsx +41 -0
  172. package/src/components/{DeleteConfirmationDialog.tsx → ConfirmationDialog.tsx} +11 -11
  173. package/src/components/DeleteEntityDialog.tsx +13 -20
  174. package/src/components/EntityCollectionTable/EntityCollectionRowActions.tsx +59 -40
  175. package/src/components/EntityCollectionTable/EntityCollectionTable.tsx +38 -31
  176. package/src/components/EntityCollectionTable/EntityCollectionTableProps.tsx +30 -9
  177. package/src/components/EntityCollectionTable/PropertyTableCell.tsx +72 -42
  178. package/src/components/EntityCollectionTable/column_utils.tsx +3 -3
  179. package/src/components/EntityCollectionTable/fields/TableReferenceField.tsx +30 -16
  180. package/src/components/EntityCollectionTable/fields/TableStorageUpload.tsx +19 -17
  181. package/src/components/EntityCollectionTable/index.tsx +1 -1
  182. package/src/components/EntityCollectionTable/internal/CollectionTableToolbar.tsx +32 -37
  183. package/src/components/EntityCollectionTable/internal/EntityTableCell.tsx +49 -36
  184. package/src/components/EntityCollectionTable/internal/EntityTableCellActions.tsx +20 -8
  185. package/src/components/EntityCollectionTable/internal/popup_field/PopupFormField.tsx +135 -105
  186. package/src/components/EntityCollectionTable/internal/popup_field/useDraggable.tsx +9 -9
  187. package/src/components/EntityCollectionView/EntityCollectionView.tsx +231 -117
  188. package/src/components/EntityCollectionView/EntityCollectionViewActions.tsx +4 -2
  189. package/src/components/EntityCollectionView/EntityCollectionViewStartActions.tsx +68 -0
  190. package/src/components/EntityCollectionView/useSelectionController.tsx +20 -7
  191. package/src/components/EntityCollectionView/utils.ts +19 -0
  192. package/src/components/EntityJsonPreview.tsx +66 -0
  193. package/src/components/EntityPreview.tsx +80 -59
  194. package/src/components/EntityView.tsx +13 -10
  195. package/src/components/ErrorView.tsx +4 -4
  196. package/src/components/HomePage/DefaultHomePage.tsx +486 -159
  197. package/src/components/HomePage/FavouritesView.tsx +9 -14
  198. package/src/components/HomePage/HomePageDnD.tsx +613 -0
  199. package/src/components/HomePage/NavigationCard.tsx +48 -39
  200. package/src/components/HomePage/NavigationCardBinding.tsx +17 -16
  201. package/src/components/HomePage/NavigationGroup.tsx +63 -29
  202. package/src/components/HomePage/RenameGroupDialog.tsx +113 -0
  203. package/src/components/HomePage/SmallNavigationCard.tsx +5 -6
  204. package/src/components/NotFoundPage.tsx +2 -2
  205. package/src/components/PropertyConfigBadge.tsx +9 -3
  206. package/src/components/PropertyIdCopyTooltip.tsx +47 -0
  207. package/src/components/ReferenceTable/ReferenceSelectionTable.tsx +21 -13
  208. package/src/components/ReferenceWidget.tsx +21 -11
  209. package/src/components/SearchIconsView.tsx +10 -7
  210. package/src/components/SelectableTable/SelectableTable.tsx +157 -145
  211. package/src/components/SelectableTable/filters/BooleanFilterField.tsx +2 -3
  212. package/src/components/SelectableTable/filters/DateTimeFilterField.tsx +25 -8
  213. package/src/components/SelectableTable/filters/ReferenceFilterField.tsx +36 -12
  214. package/src/components/SelectableTable/filters/StringNumberFilterField.tsx +92 -23
  215. package/src/components/UnsavedChangesDialog.tsx +42 -0
  216. package/src/components/VirtualTable/VirtualTable.tsx +105 -51
  217. package/src/components/VirtualTable/VirtualTableCell.tsx +1 -9
  218. package/src/components/VirtualTable/VirtualTableHeader.tsx +10 -10
  219. package/src/components/VirtualTable/VirtualTableHeaderRow.tsx +2 -2
  220. package/src/components/VirtualTable/VirtualTableProps.tsx +28 -14
  221. package/src/components/VirtualTable/VirtualTableRow.tsx +5 -6
  222. package/src/components/VirtualTable/fields/VirtualTableDateField.tsx +5 -5
  223. package/src/components/VirtualTable/fields/VirtualTableInput.tsx +2 -2
  224. package/src/components/VirtualTable/fields/VirtualTableNumberInput.tsx +2 -1
  225. package/src/components/VirtualTable/fields/VirtualTableSelect.tsx +16 -28
  226. package/src/components/VirtualTable/types.tsx +2 -3
  227. package/src/components/{EntityCollectionTable/internal → common}/default_entity_actions.tsx +44 -40
  228. package/src/components/common/index.ts +2 -1
  229. package/src/components/{VirtualTable/common.tsx → common/table_height.tsx} +5 -2
  230. package/src/components/common/types.tsx +4 -6
  231. package/src/components/common/useColumnsIds.tsx +24 -3
  232. package/src/components/common/useDataSourceTableController.tsx +420 -0
  233. package/src/components/common/useDebouncedCallback.tsx +20 -0
  234. package/src/components/common/useScrollRestoration.tsx +68 -0
  235. package/src/components/common/useTableSearchHelper.ts +53 -12
  236. package/src/components/index.tsx +6 -2
  237. package/src/contexts/BreacrumbsContext.tsx +38 -0
  238. package/src/contexts/DialogsProvider.tsx +5 -4
  239. package/src/contexts/ModeController.tsx +1 -3
  240. package/src/contexts/SnackbarProvider.tsx +2 -0
  241. package/src/core/DefaultAppBar.tsx +219 -0
  242. package/src/core/DefaultDrawer.tsx +185 -0
  243. package/src/core/DrawerNavigationItem.tsx +66 -0
  244. package/src/core/EntityEditView.tsx +408 -478
  245. package/src/core/EntityEditViewFormActions.tsx +199 -0
  246. package/src/core/EntitySidePanel.tsx +85 -21
  247. package/src/core/FireCMS.tsx +72 -58
  248. package/src/core/FireCMSRouter.tsx +17 -0
  249. package/src/core/NavigationRoutes.tsx +28 -38
  250. package/src/core/SideDialogs.tsx +22 -12
  251. package/src/core/field_configs.tsx +26 -13
  252. package/src/core/index.tsx +6 -5
  253. package/src/form/EntityForm.tsx +589 -535
  254. package/src/form/EntityFormActions.tsx +169 -0
  255. package/src/form/PropertyFieldBinding.tsx +88 -45
  256. package/src/form/components/CustomIdField.tsx +9 -3
  257. package/src/form/components/FieldHelperText.tsx +4 -4
  258. package/src/form/components/FormEntry.tsx +22 -0
  259. package/src/form/components/FormLayout.tsx +16 -0
  260. package/src/form/components/LabelWithIcon.tsx +30 -19
  261. package/src/form/components/LabelWithIconAndTooltip.tsx +28 -0
  262. package/src/form/components/StorageItemPreview.tsx +23 -13
  263. package/src/form/components/StorageUploadProgress.tsx +5 -6
  264. package/src/form/components/index.tsx +3 -1
  265. package/src/form/field_bindings/ArrayCustomShapedFieldBinding.tsx +34 -19
  266. package/src/form/field_bindings/ArrayOfReferencesFieldBinding.tsx +50 -36
  267. package/src/form/field_bindings/BlockFieldBinding.tsx +56 -34
  268. package/src/form/field_bindings/DateTimeFieldBinding.tsx +18 -14
  269. package/src/form/field_bindings/KeyValueFieldBinding.tsx +61 -52
  270. package/src/form/field_bindings/MapFieldBinding.tsx +73 -55
  271. package/src/form/field_bindings/MarkdownEditorFieldBinding.tsx +157 -0
  272. package/src/form/field_bindings/{MultiSelectBinding.tsx → MultiSelectFieldBinding.tsx} +26 -21
  273. package/src/form/field_bindings/ReadOnlyFieldBinding.tsx +11 -16
  274. package/src/form/field_bindings/ReferenceAsStringFieldBinding.tsx +135 -0
  275. package/src/form/field_bindings/ReferenceFieldBinding.tsx +42 -31
  276. package/src/form/field_bindings/RepeatFieldBinding.tsx +62 -35
  277. package/src/form/field_bindings/SelectFieldBinding.tsx +24 -15
  278. package/src/form/field_bindings/StorageUploadFieldBinding.tsx +257 -199
  279. package/src/form/field_bindings/SwitchFieldBinding.tsx +29 -24
  280. package/src/form/field_bindings/TextFieldBinding.tsx +28 -24
  281. package/src/form/index.tsx +17 -37
  282. package/src/form/useClearRestoreValue.tsx +2 -2
  283. package/src/form/validation.ts +13 -23
  284. package/src/hooks/data/delete.ts +6 -5
  285. package/src/hooks/data/save.ts +26 -33
  286. package/src/hooks/data/useCollectionFetch.tsx +3 -3
  287. package/src/hooks/data/useDataSource.tsx +11 -3
  288. package/src/hooks/data/useEntityFetch.tsx +10 -6
  289. package/src/hooks/index.tsx +1 -0
  290. package/src/hooks/useAuthController.tsx +1 -1
  291. package/src/hooks/useBreadcrumbsController.tsx +31 -0
  292. package/src/hooks/useBuildLocalConfigurationPersistence.tsx +8 -10
  293. package/src/hooks/useBuildModeController.tsx +22 -29
  294. package/src/hooks/useBuildNavigationController.tsx +440 -119
  295. package/src/hooks/useFireCMSContext.tsx +3 -33
  296. package/src/hooks/useLargeLayout.tsx +0 -35
  297. package/src/hooks/useModeController.tsx +1 -2
  298. package/src/hooks/useProjectLog.tsx +32 -10
  299. package/src/hooks/useResolvedNavigationFrom.tsx +10 -12
  300. package/src/hooks/useValidateAuthenticator.tsx +17 -37
  301. package/src/index.ts +1 -0
  302. package/src/internal/useBuildDataSource.ts +79 -85
  303. package/src/internal/useBuildSideDialogsController.tsx +4 -2
  304. package/src/internal/useBuildSideEntityController.tsx +201 -77
  305. package/src/internal/useUnsavedChangesDialog.tsx +127 -91
  306. package/src/preview/PropertyPreview.tsx +34 -25
  307. package/src/preview/PropertyPreviewProps.tsx +7 -1
  308. package/src/preview/components/BooleanPreview.tsx +2 -2
  309. package/src/preview/components/EmptyValue.tsx +1 -1
  310. package/src/preview/components/EnumValuesChip.tsx +2 -2
  311. package/src/preview/components/ImagePreview.tsx +26 -37
  312. package/src/preview/components/ReferencePreview.tsx +23 -34
  313. package/src/preview/components/StorageThumbnail.tsx +5 -1
  314. package/src/preview/components/UrlComponentPreview.tsx +60 -28
  315. package/src/preview/property_previews/ArrayOfMapsPreview.tsx +6 -6
  316. package/src/preview/property_previews/ArrayOfReferencesPreview.tsx +7 -5
  317. package/src/preview/property_previews/ArrayOfStorageComponentsPreview.tsx +5 -4
  318. package/src/preview/property_previews/ArrayOfStringsPreview.tsx +4 -4
  319. package/src/preview/property_previews/ArrayOneOfPreview.tsx +7 -6
  320. package/src/preview/property_previews/ArrayPropertyPreview.tsx +7 -6
  321. package/src/preview/property_previews/MapPropertyPreview.tsx +12 -11
  322. package/src/preview/property_previews/SkeletonPropertyComponent.tsx +13 -13
  323. package/src/preview/property_previews/StringPropertyPreview.tsx +3 -3
  324. package/src/preview/util.ts +10 -10
  325. package/src/routes/CustomCMSRoute.tsx +21 -0
  326. package/src/routes/FireCMSRoute.tsx +246 -0
  327. package/src/routes/HomePageRoute.tsx +17 -0
  328. package/src/types/analytics.ts +3 -0
  329. package/src/types/auth.tsx +9 -13
  330. package/src/types/collections.ts +129 -30
  331. package/src/types/customization_controller.tsx +0 -1
  332. package/src/types/datasource.ts +61 -43
  333. package/src/types/dialogs_controller.tsx +7 -3
  334. package/src/types/entities.ts +12 -2
  335. package/src/types/entity_actions.tsx +32 -7
  336. package/src/types/entity_callbacks.ts +18 -18
  337. package/src/types/entity_overrides.tsx +2 -2
  338. package/src/types/export_import.ts +4 -4
  339. package/src/types/fields.tsx +85 -46
  340. package/src/types/firecms.tsx +9 -4
  341. package/src/types/firecms_context.tsx +1 -1
  342. package/src/types/index.ts +0 -1
  343. package/src/types/navigation.ts +77 -24
  344. package/src/types/permissions.ts +5 -5
  345. package/src/types/plugins.tsx +57 -14
  346. package/src/types/properties.ts +95 -26
  347. package/src/types/property_config.tsx +1 -2
  348. package/src/types/side_dialogs_controller.tsx +15 -0
  349. package/src/types/side_entity_controller.tsx +11 -1
  350. package/src/types/storage.ts +83 -1
  351. package/src/types/user.ts +2 -0
  352. package/src/util/builders.ts +10 -8
  353. package/src/util/callbacks.ts +119 -0
  354. package/src/util/createFormexStub.tsx +62 -0
  355. package/src/util/entities.ts +9 -6
  356. package/src/util/entity_actions.ts +28 -0
  357. package/src/util/entity_cache.ts +204 -0
  358. package/src/util/enums.ts +1 -1
  359. package/src/util/icon_list.ts +16 -10
  360. package/src/util/icon_synonyms.ts +3 -100
  361. package/src/util/icons.tsx +36 -11
  362. package/src/util/index.ts +3 -0
  363. package/src/util/join_collections.ts +6 -1
  364. package/src/util/make_properties_editable.ts +13 -5
  365. package/src/util/navigation_from_path.ts +18 -7
  366. package/src/util/navigation_utils.ts +141 -25
  367. package/src/util/objects.ts +90 -33
  368. package/src/util/parent_references_from_path.ts +3 -3
  369. package/src/util/permissions.ts +9 -8
  370. package/src/util/plurals.ts +0 -2
  371. package/src/util/property_utils.tsx +17 -6
  372. package/src/util/references.ts +19 -8
  373. package/src/util/resolutions.ts +110 -48
  374. package/src/util/storage.ts +79 -21
  375. package/src/util/strings.ts +2 -2
  376. package/src/util/useStorageUploadController.tsx +91 -28
  377. package/dist/components/EntityCollectionTable/internal/popup_field/ElementResizeListener.d.ts +0 -5
  378. package/dist/components/FireCMSAppBar.d.ts +0 -26
  379. package/dist/components/PropertyIdCopyTooltipContent.d.ts +0 -3
  380. package/dist/components/VirtualTable/common.d.ts +0 -2
  381. package/dist/core/Drawer.d.ts +0 -23
  382. package/dist/core/Scaffold.d.ts +0 -55
  383. package/dist/core/SideEntityView.d.ts +0 -7
  384. package/dist/form/components/FormikArrayContainer.d.ts +0 -18
  385. package/dist/form/field_bindings/MarkdownFieldBinding.d.ts +0 -9
  386. package/dist/internal/useBuildCustomizationController.d.ts +0 -2
  387. package/dist/internal/useLocaleConfig.d.ts +0 -1
  388. package/dist/types/appcheck.d.ts +0 -26
  389. package/src/components/EntityCollectionTable/internal/popup_field/ElementResizeListener.tsx +0 -59
  390. package/src/components/FireCMSAppBar.tsx +0 -165
  391. package/src/components/PropertyIdCopyTooltipContent.tsx +0 -28
  392. package/src/components/common/useDataSourceEntityCollectionTableController.tsx +0 -225
  393. package/src/core/Drawer.tsx +0 -191
  394. package/src/core/Scaffold.tsx +0 -281
  395. package/src/core/SideEntityView.tsx +0 -38
  396. package/src/form/components/FormikArrayContainer.tsx +0 -44
  397. package/src/form/field_bindings/MarkdownFieldBinding.tsx +0 -695
  398. package/src/internal/useBuildCustomizationController.tsx +0 -5
  399. package/src/internal/useLocaleConfig.tsx +0 -18
  400. package/src/types/appcheck.ts +0 -29
  401. /package/src/util/{common.tsx → common.ts} +0 -0
@@ -1,214 +1,541 @@
1
- import React, { useCallback, useEffect, useState } from "react";
2
-
1
+ import React, { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
+ import Fuse from "fuse.js";
3
+ import { Container, SearchBar } from "@firecms/ui";
3
4
  import { useCustomizationController, useFireCMSContext, useNavigationController } from "../../hooks";
4
- import { CMSAnalyticsEvent, PluginGenericProps, PluginHomePageAdditionalCardsProps } from "../../types";
5
-
5
+ import {
6
+ CMSAnalyticsEvent,
7
+ NavigationEntry,
8
+ NavigationGroupMapping,
9
+ PluginGenericProps,
10
+ PluginHomePageAdditionalCardsProps
11
+ } from "../../types";
6
12
  import { toArray } from "../../util/arrays";
13
+ import { FavouritesView } from "./FavouritesView";
14
+ import { useRestoreScroll } from "../../internal/useRestoreScroll";
7
15
  import { NavigationGroup } from "./NavigationGroup";
16
+ import {
17
+ NavigationGroupDroppable,
18
+ NewGroupDropZone,
19
+ SortableNavigationCard,
20
+ SortableNavigationGroup,
21
+ useHomePageDnd
22
+ } from "./HomePageDnD";
23
+ import { DndContext, DragOverlay, MeasuringStrategy } from "@dnd-kit/core";
8
24
  import { NavigationCardBinding } from "./NavigationCardBinding";
25
+ import { SortableContext, verticalListSortingStrategy } from "@dnd-kit/sortable";
26
+ import { restrictToVerticalAxis, restrictToWindowEdges } from "@dnd-kit/modifiers";
27
+ import { RenameGroupDialog } from "./RenameGroupDialog";
9
28
 
10
- // @ts-ignore
11
- import * as JsSearch from "js-search";
12
-
13
- import { Container, SearchBar } from "@firecms/ui";
14
- import { FavouritesView } from "./FavouritesView";
15
- import { useRestoreScroll } from "../../internal/useRestoreScroll";
29
+ export const DEFAULT_GROUP_NAME = "Views";
30
+ export const ADMIN_GROUP_NAME = "Admin";
16
31
 
17
- const search = new JsSearch.Search("url");
18
- search.addIndex("name");
19
- search.addIndex("description");
20
- search.addIndex("group");
21
- search.addIndex("path");
22
-
23
- /**
24
- * Default entry view for the CMS. This component renders navigation cards
25
- * for each collection defined in the navigation.
26
- * @constructor
27
- * @group Components
28
- */
29
32
  export function DefaultHomePage({
30
33
  additionalActions,
31
34
  additionalChildrenStart,
32
35
  additionalChildrenEnd
33
36
  }: {
34
- /**
35
- * Additional actions to be rendered in the home page, close to the search bar.
36
- */
37
37
  additionalActions?: React.ReactNode;
38
- /**
39
- * Additional children to be rendered in the beginning of the home page.
40
- */
41
38
  additionalChildrenStart?: React.ReactNode;
42
- /**
43
- * Additional children to be rendered at the end of the home page.
44
- */
45
39
  additionalChildrenEnd?: React.ReactNode;
46
40
  }) {
47
-
48
41
  const context = useFireCMSContext();
49
42
  const customizationController = useCustomizationController();
50
43
  const navigationController = useNavigationController();
51
44
 
52
45
  if (!navigationController.topLevelNavigation)
53
- throw Error("Navigation not ready in FireCMSHomePage");
54
-
55
- const {
56
- containerRef,
57
- scroll,
58
- direction
59
- } = useRestoreScroll();
46
+ throw Error("Navigation not ready");
60
47
 
61
48
  const {
62
- navigationEntries,
63
- groups
49
+ allowDragAndDrop,
50
+ navigationEntries: rawNavigationEntries,
51
+ groups: groupOrderFromNavController,
52
+ onNavigationEntriesUpdate
64
53
  } = navigationController.topLevelNavigation;
65
54
 
55
+ const fuse = useRef<Fuse<NavigationEntry> | null>(null);
66
56
  const [filteredUrls, setFilteredUrls] = useState<string[] | null>(null);
57
+ const performingSearch = Boolean(filteredUrls);
67
58
 
68
59
  const filteredNavigationEntries = filteredUrls
69
- ? navigationEntries.filter((entry) => filteredUrls.includes(entry.url))
70
- : navigationEntries;
60
+ ? rawNavigationEntries.filter((e) => filteredUrls.includes(e.url))
61
+ : rawNavigationEntries;
71
62
 
72
63
  useEffect(() => {
73
- search.addDocuments(navigationEntries);
74
- }, [navigationEntries]);
75
-
76
- const updateSearchResults = useCallback(
77
- (value?: string) => {
78
- if (!value || value === "") {
79
- setFilteredUrls(null);
80
- } else {
81
- const searchResult = search.search(value);
82
- setFilteredUrls(searchResult.map((e: any) => e.url));
83
- }
84
- }, []);
85
-
86
- const allGroups: Array<string | undefined> = [...groups];
87
- if (filteredNavigationEntries.filter(e => !e.group).length > 0 || filteredNavigationEntries.length === 0) {
88
- allGroups.push(undefined);
89
- }
64
+ fuse.current = new Fuse(rawNavigationEntries, {
65
+ keys: ["name", "description", "group", "path"]
66
+ });
67
+ }, [rawNavigationEntries]);
68
+
69
+ const updateSearch = useCallback((v?: string) => {
70
+ if (!v?.trim()) return setFilteredUrls(null);
71
+ const r = fuse.current?.search(v.trim());
72
+ setFilteredUrls(r ? r.map((x) => x.item.url) : []);
73
+ }, []);
74
+
75
+ /* ───────────────────────────────────────────────────────────────
76
+ Build groups (all items) + isolate Admin
77
+ ─────────────────────────────────────────────────────────────── */
78
+ const [items, setItems] = useState<
79
+ { name: string; entries: NavigationEntry[] }[]
80
+ >([]);
81
+ const [adminGroupData, setAdminGroupData] = useState<{
82
+ name: string;
83
+ entries: NavigationEntry[];
84
+ } | null>(null);
85
+
86
+ useEffect(() => {
87
+ const src = performingSearch
88
+ ? filteredNavigationEntries
89
+ : rawNavigationEntries;
90
+
91
+ const entriesByGroup: Record<string, NavigationEntry[]> = {};
92
+ src.forEach((e) => {
93
+ const g =
94
+ e.type === "admin"
95
+ ? ADMIN_GROUP_NAME
96
+ : e.group ?? DEFAULT_GROUP_NAME;
97
+ (entriesByGroup[g] ??= []).push(e);
98
+ });
99
+
100
+ let allProcessed: { name: string; entries: NavigationEntry[] }[];
101
+
102
+ if (performingSearch) {
103
+ const ordered = [
104
+ ...new Set(src.map((e) => e.group ?? DEFAULT_GROUP_NAME))
105
+ ];
106
+ allProcessed = ordered
107
+ .map((name) => ({
108
+ name,
109
+ entries: entriesByGroup[name] || []
110
+ }))
111
+ .filter((g) => g.entries.length);
112
+ } else {
113
+ allProcessed = groupOrderFromNavController.map((g) => ({
114
+ name: g,
115
+ entries: entriesByGroup[g] || []
116
+ }));
117
+ Object.keys(entriesByGroup).forEach((g) => {
118
+ if (!groupOrderFromNavController.includes(g))
119
+ allProcessed.push({
120
+ name: g,
121
+ entries: entriesByGroup[g]
122
+ });
123
+ });
124
+ allProcessed = allProcessed.filter(
125
+ (g) =>
126
+ g.entries.length ||
127
+ groupOrderFromNavController.includes(g.name)
128
+ );
129
+ }
130
+
131
+ const admin = allProcessed.find((g) => g.name === ADMIN_GROUP_NAME);
132
+ if (admin) {
133
+ setAdminGroupData(admin);
134
+ setItems(allProcessed.filter((g) => g.name !== ADMIN_GROUP_NAME));
135
+ } else {
136
+ setAdminGroupData(null);
137
+ setItems(allProcessed);
138
+ }
139
+ }, [
140
+ performingSearch,
141
+ filteredNavigationEntries,
142
+ rawNavigationEntries,
143
+ groupOrderFromNavController
144
+ ]);
145
+
146
+ /* ───────────────────────────────────────────────────────────────
147
+ Local update vs. persistence helpers
148
+ ─────────────────────────────────────────────────────────────── */
149
+ const updateItems = (
150
+ updater:
151
+ | { name: string; entries: NavigationEntry[] }[]
152
+ | ((
153
+ prev: { name: string; entries: NavigationEntry[] }[]
154
+ ) => { name: string; entries: NavigationEntry[] }[])
155
+ ) => {
156
+ setItems(updater); // local only
157
+ };
158
+
159
+ const persistNavigationGroups = (
160
+ latest: { name: string; entries: NavigationEntry[] }[]
161
+ ) => {
162
+ const draggable: NavigationGroupMapping[] = latest.map((g) => ({
163
+ name: g.name,
164
+ entries: g.entries.map((e) => e.path)
165
+ }));
166
+
167
+ const all: NavigationGroupMapping[] = adminGroupData
168
+ ? [
169
+ ...draggable,
170
+ {
171
+ name: adminGroupData.name,
172
+ entries: adminGroupData.entries.map((e) => e.path)
173
+ }
174
+ ]
175
+ : draggable;
176
+
177
+ onNavigationEntriesUpdate(all);
178
+ };
90
179
 
180
+ /* ───────────────────────────────────────────────────────────────
181
+ Hook for DnD
182
+ ─────────────────────────────────────────────────────────────── */
183
+ const {
184
+ sensors,
185
+ collisionDetection,
186
+ onDragStart,
187
+ onDragOver,
188
+ onDragEnd,
189
+ dropAnimation,
190
+ activeItemForOverlay,
191
+ activeGroupData,
192
+ draggingGroupId,
193
+ containers,
194
+ dndKitActiveNode,
195
+ onDragCancel,
196
+ isDraggingCardOnly,
197
+ dialogOpenForGroup,
198
+ setDialogOpenForGroup,
199
+ handleRenameGroup,
200
+ isHoveringNewGroupDropZone,
201
+ setIsHoveringNewGroupDropZone
202
+ } = useHomePageDnd({
203
+ items,
204
+ setItems: updateItems,
205
+ disabled: !allowDragAndDrop || performingSearch,
206
+ onPersist: persistNavigationGroups, // ——► persistence here
207
+ onGroupMoved: (g) =>
208
+ context.analyticsController?.onAnalyticsEvent?.("home_move_group", {
209
+ name: g
210
+ }),
211
+ onCardMovedBetweenGroups: (card) =>
212
+ context.analyticsController?.onAnalyticsEvent?.("home_move_card", {
213
+ id: card.id
214
+ }),
215
+ onNewGroupDrop: () =>
216
+ context.analyticsController?.onAnalyticsEvent?.(
217
+ "home_drop_new_group"
218
+ )
219
+ });
220
+
221
+ const {
222
+ containerRef,
223
+ direction
224
+ } = useRestoreScroll();
225
+
226
+ const dndDisabled = !allowDragAndDrop || performingSearch;
227
+
228
+ const dndModifiers = useMemo(() => {
229
+ if (dndKitActiveNode?.data.current?.type === "group")
230
+ return [restrictToVerticalAxis, restrictToWindowEdges];
231
+ return [restrictToWindowEdges];
232
+ }, [dndKitActiveNode]);
233
+
234
+ /* ───────────────────────────────────────────────────────────────
235
+ Plugin extras
236
+ ─────────────────────────────────────────────────────────────── */
91
237
  let additionalPluginChildrenStart: React.ReactNode | undefined;
92
238
  let additionalPluginChildrenEnd: React.ReactNode | undefined;
93
239
  let additionalPluginSections: React.ReactNode | undefined;
240
+
94
241
  if (customizationController.plugins) {
95
- const sectionProps: PluginGenericProps = {
96
- context
97
- };
98
- additionalPluginSections = <>
99
- {customizationController.plugins.filter(plugin => plugin.homePage?.includeSection)
100
- .map((plugin, i) => {
101
- const section = plugin.homePage!.includeSection!(sectionProps)
102
- return (
103
- <NavigationGroup
104
- group={section.title}
105
- key={`plugin_section_${plugin.key}`}>
106
- {section.children}
107
- </NavigationGroup>
108
- );
109
- })}
110
- </>;
111
- additionalPluginChildrenStart = <div className={"flex flex-col gap-2"}>
112
- {customizationController.plugins.filter(plugin => plugin.homePage?.additionalChildrenStart)
113
- .map((plugin, i) => {
114
- return <div key={`plugin_children_start_${i}`}>{plugin.homePage!.additionalChildrenStart}</div>;
115
- })}
116
- </div>;
117
-
118
- additionalPluginChildrenEnd = <div className={"flex flex-col gap-2"}>
119
- {customizationController.plugins.filter(plugin => plugin.homePage?.additionalChildrenEnd)
120
- .map((plugin, i) => {
121
- return <div key={`plugin_children_start_${i}`}>{plugin.homePage!.additionalChildrenEnd}</div>;
122
- })}
123
- </div>;
242
+ const sectionProps: PluginGenericProps = { context };
243
+
244
+ additionalPluginSections = (
245
+ <>
246
+ {customizationController.plugins
247
+ .filter((p) => p.homePage?.includeSection)
248
+ .map((plugin) => {
249
+ const section = plugin.homePage!.includeSection!(
250
+ sectionProps
251
+ );
252
+ return (
253
+ <NavigationGroup
254
+ group={section.title}
255
+ key={`plugin_section_${plugin.key}`}
256
+ >
257
+ {section.children}
258
+ </NavigationGroup>
259
+ );
260
+ })}
261
+ </>
262
+ );
263
+
264
+ additionalPluginChildrenStart = (
265
+ <div className="flex flex-col gap-2">
266
+ {customizationController.plugins
267
+ .filter((p) => p.homePage?.additionalChildrenStart)
268
+ .map((plugin, i) => (
269
+ <div key={`plugin_children_start_${i}`}>
270
+ {plugin.homePage!.additionalChildrenStart}
271
+ </div>
272
+ ))}
273
+ </div>
274
+ );
275
+
276
+ additionalPluginChildrenEnd = (
277
+ <div className="flex flex-col gap-2">
278
+ {customizationController.plugins
279
+ .filter((p) => p.homePage?.additionalChildrenEnd)
280
+ .map((plugin, i) => (
281
+ <div key={`plugin_children_end_${i}`}>
282
+ {plugin.homePage!.additionalChildrenEnd}
283
+ </div>
284
+ ))}
285
+ </div>
286
+ );
124
287
  }
125
288
 
289
+ /* ───────────────────────────────────────────────────────────────
290
+ Render
291
+ ─────────────────────────────────────────────────────────────── */
126
292
  return (
127
- <div id="home_page"
128
- ref={containerRef}
129
- className="py-2 overflow-auto h-full w-full">
130
- <Container maxWidth={"6xl"}>
293
+ <div ref={containerRef} className="py-2 overflow-auto h-full w-full">
294
+ <Container maxWidth="6xl">
295
+ {/* search & actions */}
131
296
  <div
132
297
  className="w-full sticky py-4 transition-all duration-400 ease-in-out top-0 z-10 flex flex-row gap-4"
133
- style={{ top: direction === "down" ? -84 : 0 }}>
134
- <SearchBar onTextSearch={updateSearchResults}
135
- placeholder={"Search collections"}
136
- large={false}
137
- innerClassName={"w-full"}
138
- className={"w-full flex-grow"}/>
298
+ style={{ top: direction === "down" ? -84 : 0 }}
299
+ >
300
+ <SearchBar
301
+ onTextSearch={updateSearch}
302
+ placeholder="Search collections"
303
+ autoFocus
304
+ innerClassName="w-full"
305
+ className="w-full flex-grow"
306
+ />
139
307
  {additionalActions}
140
308
  </div>
141
309
 
142
- <FavouritesView hidden={Boolean(filteredUrls)}/>
310
+ <FavouritesView hidden={performingSearch}/>
143
311
 
144
312
  {additionalChildrenStart}
145
-
146
313
  {additionalPluginChildrenStart}
147
314
 
148
- {allGroups.map((group, index) => {
149
-
150
- const AdditionalCards: React.ComponentType<PluginHomePageAdditionalCardsProps>[] = [];
151
- const actionProps: PluginHomePageAdditionalCardsProps = {
152
- group,
153
- context
154
- };
155
-
156
- if (customizationController.plugins) {
157
- customizationController.plugins.forEach(plugin => {
158
- if (plugin.homePage?.AdditionalCards) {
159
- AdditionalCards.push(...toArray(plugin.homePage?.AdditionalCards));
160
- }
161
- });
162
- }
163
-
164
- const thisGroupCollections = filteredNavigationEntries
165
- .filter((entry) => entry.group === group || (!entry.group && group === undefined));
166
- if (thisGroupCollections.length === 0 && AdditionalCards.length === 0)
167
- return null;
168
- return (
169
- <NavigationGroup
170
- group={group}
171
- key={`plugin_section_${group}`}>
172
-
173
- <div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
174
- {thisGroupCollections.map((entry) => (
175
- <div key={`nav_${entry.group}_${entry.name}`} className="col-span-1">
176
- <NavigationCardBinding
177
- {...entry}
178
- onClick={() => {
179
- let event: CMSAnalyticsEvent;
180
- if (entry.type === "collection") {
181
- event = "home_navigate_to_collection";
182
- } else if (entry.type === "view") {
183
- event = "home_navigate_to_view";
184
- } else if (entry.type === "admin") {
185
- event = "home_navigate_to_admin_view";
186
- } else {
187
- event = "unmapped_event";
188
- }
189
- context.analyticsController?.onAnalyticsEvent?.(event, { path: entry.path });
190
- }}
191
- />
192
- </div>
193
- ))}
194
- {AdditionalCards &&
195
- AdditionalCards.map((AdditionalCard, i) => (
196
- <div key={`nav_${group}_add_${i}`}>
197
- <AdditionalCard {...actionProps} />
198
- </div>
199
- ))}
315
+ {/* ─────── DND context ─────── */}
316
+ <DndContext
317
+ sensors={sensors}
318
+ collisionDetection={collisionDetection}
319
+ measuring={{
320
+ droppable: {
321
+ strategy: MeasuringStrategy.Always,
322
+ frequency: 500
323
+ }
324
+ }}
325
+ onDragStart={onDragStart}
326
+ onDragOver={onDragOver}
327
+ onDragEnd={onDragEnd}
328
+ onDragCancel={onDragCancel}
329
+ modifiers={dndModifiers}
330
+ >
331
+ <SortableContext
332
+ key={JSON.stringify(containers)}
333
+ items={containers}
334
+ strategy={verticalListSortingStrategy}
335
+ >
336
+ {items.map((groupData) => {
337
+ const groupKey = groupData.name;
338
+ const entriesInGroup = groupData.entries;
339
+
340
+ const AdditionalCards: React.ComponentType<PluginHomePageAdditionalCardsProps>[] =
341
+ [];
342
+ customizationController.plugins?.forEach((p) => {
343
+ if (p.homePage?.AdditionalCards)
344
+ AdditionalCards.push(
345
+ ...toArray(p.homePage.AdditionalCards)
346
+ );
347
+ });
348
+
349
+ const actionProps: PluginHomePageAdditionalCardsProps = {
350
+ group:
351
+ groupKey === DEFAULT_GROUP_NAME
352
+ ? undefined
353
+ : groupKey,
354
+ context
355
+ };
356
+
357
+ if (
358
+ entriesInGroup.length === 0 &&
359
+ (AdditionalCards.length === 0 || performingSearch) &&
360
+ !groupOrderFromNavController.includes(groupKey)
361
+ )
362
+ return null;
363
+
364
+ return (
365
+ <SortableNavigationGroup
366
+ key={groupKey}
367
+ groupName={groupKey}
368
+ disabled={dndDisabled}
369
+ >
370
+ <NavigationGroup
371
+ group={
372
+ groupKey === DEFAULT_GROUP_NAME
373
+ ? undefined
374
+ : groupKey
375
+ }
376
+ minimised={
377
+ draggingGroupId === groupKey &&
378
+ !isDraggingCardOnly
379
+ }
380
+ isPotentialCardDropTarget={
381
+ isDraggingCardOnly
382
+ }
383
+ dndDisabled={dndDisabled}
384
+ onEditGroup={() => {
385
+ if (dndDisabled) return;
386
+ setDialogOpenForGroup(groupKey);
387
+ }}
388
+ >
389
+ <NavigationGroupDroppable
390
+ id={groupKey}
391
+ itemIds={entriesInGroup.map(
392
+ (e) => e.url
393
+ )}
394
+ isPotentialCardDropTarget={
395
+ isDraggingCardOnly
396
+ }
397
+ >
398
+ <div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 ">
399
+ {entriesInGroup.map(
400
+ (entry) => (
401
+ <SortableNavigationCard
402
+ key={entry.url}
403
+ entry={entry}
404
+ onClick={() => {
405
+ let event: CMSAnalyticsEvent =
406
+ "unmapped_event";
407
+ if (
408
+ entry.type ===
409
+ "collection"
410
+ )
411
+ event =
412
+ "home_navigate_to_collection";
413
+ else if (
414
+ entry.type ===
415
+ "view"
416
+ )
417
+ event =
418
+ "home_navigate_to_view";
419
+ else if (
420
+ entry.type ===
421
+ "admin"
422
+ )
423
+ event =
424
+ "home_navigate_to_admin_view";
425
+
426
+ context.analyticsController?.onAnalyticsEvent?.(
427
+ event,
428
+ {
429
+ path: entry.path
430
+ }
431
+ );
432
+ }}
433
+ />
434
+ )
435
+ )}
436
+ {!performingSearch &&
437
+ groupKey.toLowerCase() !==
438
+ ADMIN_GROUP_NAME.toLowerCase() &&
439
+ AdditionalCards.map(
440
+ (C, i) => (
441
+ <C
442
+ key={`extra_${groupKey}_${i}`}
443
+ {...actionProps}
444
+ />
445
+ )
446
+ )}
447
+ </div>
448
+ </NavigationGroupDroppable>
449
+ </NavigationGroup>
450
+ </SortableNavigationGroup>
451
+ );
452
+ })}
453
+ </SortableContext>
454
+
455
+ <NewGroupDropZone
456
+ disabled={dndDisabled}
457
+ setIsHovering={setIsHoveringNewGroupDropZone}
458
+ />
459
+
460
+ <DragOverlay adjustScale={false} dropAnimation={dropAnimation}>
461
+ {activeGroupData &&
462
+ draggingGroupId === activeGroupData.name ? (
463
+ <div
464
+ className="rounded-lg bg-transparent"
465
+ style={{
466
+ padding: 0,
467
+ margin: 0
468
+ }}
469
+ >
470
+ <NavigationGroup
471
+ group={
472
+ activeGroupData.name ===
473
+ DEFAULT_GROUP_NAME
474
+ ? undefined
475
+ : activeGroupData.name
476
+ }
477
+ isPreview={false}
478
+ minimised
479
+ />
200
480
  </div>
201
- </NavigationGroup>
202
- );
203
- })}
481
+ ) : activeItemForOverlay ? (
482
+ <NavigationCardBinding
483
+ {...activeItemForOverlay}
484
+ shrink={isHoveringNewGroupDropZone}
485
+ />
486
+ ) : null}
487
+ </DragOverlay>
488
+ </DndContext>
204
489
 
205
- {additionalPluginSections}
490
+ {!performingSearch && adminGroupData && (
491
+ <NavigationGroup group={adminGroupData.name}>
492
+ <div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 ">
493
+ {adminGroupData.entries.map((entry) => (
494
+ <NavigationCardBinding
495
+ key={entry.url}
496
+ {...entry}
497
+ onClick={() => {
498
+ let event: CMSAnalyticsEvent =
499
+ "unmapped_event";
500
+ if (entry.type === "collection")
501
+ event =
502
+ "home_navigate_to_collection";
503
+ else if (entry.type === "view")
504
+ event = "home_navigate_to_view";
505
+ else if (entry.type === "admin")
506
+ event =
507
+ "home_navigate_to_admin_view";
206
508
 
207
- {additionalPluginChildrenEnd}
509
+ context.analyticsController?.onAnalyticsEvent?.(
510
+ event,
511
+ { path: entry.path }
512
+ );
513
+ }}
514
+ />
515
+ ))}
516
+ </div>
517
+ </NavigationGroup>
518
+ )}
208
519
 
520
+ {additionalPluginSections}
521
+ {additionalPluginChildrenEnd}
209
522
  {additionalChildrenEnd}
210
-
211
523
  </Container>
524
+
525
+ {dialogOpenForGroup && (
526
+ <RenameGroupDialog
527
+ open
528
+ initialName={dialogOpenForGroup}
529
+ existingGroupNames={items
530
+ .map((g) => g.name)
531
+ .filter((n) => n !== dialogOpenForGroup)}
532
+ onClose={() => setDialogOpenForGroup(null)}
533
+ onRename={(newName) => {
534
+ handleRenameGroup(dialogOpenForGroup, newName);
535
+ setDialogOpenForGroup(null);
536
+ }}
537
+ />
538
+ )}
212
539
  </div>
213
540
  );
214
541
  }