@firecms/core 3.0.0-canary.26 → 3.0.0-canary.261

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