@firecms/core 3.0.0-canary.29 → 3.0.0-canary.292
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.
- package/README.md +3 -3
- package/dist/app/AppBar.d.ts +12 -0
- package/dist/app/Drawer.d.ts +16 -0
- package/dist/app/Scaffold.d.ts +34 -0
- package/dist/app/index.d.ts +4 -0
- package/dist/app/useApp.d.ts +16 -0
- package/dist/components/ArrayContainer.d.ts +31 -12
- package/dist/components/CircularProgressCenter.d.ts +1 -1
- package/dist/components/ClearFilterSortButton.d.ts +5 -0
- package/dist/components/{DeleteConfirmationDialog.d.ts → ConfirmationDialog.d.ts} +1 -1
- package/dist/components/EntityCollectionTable/EntityCollectionRowActions.d.ts +14 -13
- package/dist/components/EntityCollectionTable/EntityCollectionTable.d.ts +2 -2
- package/dist/components/EntityCollectionTable/EntityCollectionTableProps.d.ts +22 -6
- package/dist/components/EntityCollectionTable/PropertyTableCell.d.ts +1 -0
- package/dist/components/EntityCollectionTable/column_utils.d.ts +1 -2
- package/dist/components/EntityCollectionTable/fields/TableReferenceField.d.ts +3 -1
- package/dist/components/EntityCollectionTable/index.d.ts +1 -1
- package/dist/components/EntityCollectionTable/internal/CollectionTableToolbar.d.ts +1 -4
- package/dist/components/EntityCollectionTable/internal/EntityTableCell.d.ts +2 -2
- package/dist/components/EntityCollectionTable/internal/popup_field/PopupFormField.d.ts +7 -4
- package/dist/components/EntityCollectionView/EntityCollectionView.d.ts +20 -2
- package/dist/components/EntityCollectionView/EntityCollectionViewStartActions.d.ts +11 -0
- package/dist/components/EntityCollectionView/utils.d.ts +3 -0
- package/dist/components/EntityJsonPreview.d.ts +3 -0
- package/dist/components/EntityPreview.d.ts +10 -7
- package/dist/components/ErrorView.d.ts +1 -1
- package/dist/components/HomePage/DefaultHomePage.d.ts +2 -15
- package/dist/components/HomePage/HomePageDnD.d.ts +77 -0
- package/dist/components/HomePage/NavigationCard.d.ts +3 -1
- package/dist/components/HomePage/NavigationCardBinding.d.ts +4 -3
- package/dist/components/HomePage/NavigationGroup.d.ts +8 -1
- package/dist/components/HomePage/RenameGroupDialog.d.ts +9 -0
- package/dist/components/PropertyCollectionView.d.ts +23 -0
- package/dist/components/PropertyConfigBadge.d.ts +2 -1
- package/dist/components/PropertyIdCopyTooltip.d.ts +8 -0
- package/dist/components/ReferenceWidget.d.ts +3 -1
- package/dist/components/SelectableTable/SelectableTable.d.ts +14 -4
- package/dist/components/SelectableTable/filters/ReferenceFilterField.d.ts +2 -1
- package/dist/components/UnsavedChangesDialog.d.ts +8 -0
- package/dist/components/UserDisplay.d.ts +7 -0
- package/dist/components/VirtualTable/VirtualTableProps.d.ts +24 -12
- package/dist/components/VirtualTable/fields/VirtualTableUserSelect.d.ts +12 -0
- package/dist/components/VirtualTable/types.d.ts +3 -3
- package/dist/components/{EntityCollectionTable/internal → common}/default_entity_actions.d.ts +1 -3
- package/dist/components/common/index.d.ts +2 -1
- package/dist/components/common/table_height.d.ts +5 -0
- package/dist/components/common/types.d.ts +4 -6
- package/dist/components/common/useColumnsIds.d.ts +3 -1
- package/dist/components/common/{useDataSourceEntityCollectionTableController.d.ts → useDataSourceTableController.d.ts} +13 -2
- package/dist/components/common/useDebouncedCallback.d.ts +1 -0
- package/dist/components/common/useScrollRestoration.d.ts +14 -0
- package/dist/components/index.d.ts +5 -2
- package/dist/contexts/BreacrumbsContext.d.ts +8 -0
- package/dist/contexts/InternalUserManagementContext.d.ts +3 -0
- package/dist/core/DefaultAppBar.d.ts +29 -0
- package/dist/core/DefaultDrawer.d.ts +19 -0
- package/dist/core/DrawerNavigationItem.d.ts +10 -0
- package/dist/core/EntityEditView.d.ts +49 -11
- package/dist/core/EntityEditViewFormActions.d.ts +2 -0
- package/dist/core/FireCMS.d.ts +2 -3
- package/dist/core/FireCMSRouter.d.ts +4 -0
- package/dist/core/NavigationRoutes.d.ts +2 -3
- package/dist/core/SideDialogs.d.ts +4 -2
- package/dist/core/field_configs.d.ts +1 -1
- package/dist/core/index.d.ts +4 -4
- package/dist/form/EntityForm.d.ts +40 -64
- package/dist/form/EntityFormActions.d.ts +21 -0
- package/dist/form/PropertyFieldBinding.d.ts +1 -1
- package/dist/form/components/ErrorFocus.d.ts +1 -1
- package/dist/form/components/FieldHelperText.d.ts +3 -3
- package/dist/form/components/FormEntry.d.ts +6 -0
- package/dist/form/components/FormLayout.d.ts +5 -0
- package/dist/form/components/LabelWithIcon.d.ts +1 -1
- package/dist/form/components/LabelWithIconAndTooltip.d.ts +15 -0
- package/dist/form/components/LocalChangesMenu.d.ts +11 -0
- package/dist/form/components/StorageItemPreview.d.ts +4 -4
- package/dist/form/components/index.d.ts +3 -1
- package/dist/form/field_bindings/ArrayCustomShapedFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/ArrayOfReferencesFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/BlockFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/KeyValueFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/MapFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/MarkdownEditorFieldBinding.d.ts +11 -0
- package/dist/form/field_bindings/{MultiSelectBinding.d.ts → MultiSelectFieldBinding.d.ts} +1 -1
- package/dist/form/field_bindings/ReadOnlyFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/ReferenceAsStringFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/ReferenceFieldBinding.d.ts +2 -2
- package/dist/form/field_bindings/RepeatFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/SelectFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/StorageUploadFieldBinding.d.ts +5 -13
- package/dist/form/field_bindings/SwitchFieldBinding.d.ts +1 -2
- package/dist/form/field_bindings/TextFieldBinding.d.ts +1 -1
- package/dist/form/field_bindings/UserSelectFieldBinding.d.ts +12 -0
- package/dist/form/index.d.ts +18 -18
- package/dist/form/useClearRestoreValue.d.ts +2 -2
- package/dist/hooks/data/delete.d.ts +4 -4
- package/dist/hooks/data/save.d.ts +4 -5
- package/dist/hooks/data/useCollectionFetch.d.ts +1 -1
- package/dist/hooks/data/useEntityFetch.d.ts +4 -3
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/useAuthController.d.ts +1 -1
- package/dist/hooks/useBreadcrumbsController.d.ts +26 -0
- package/dist/hooks/useBuildNavigationController.d.ts +57 -13
- package/dist/hooks/useCollapsedGroups.d.ts +9 -0
- package/dist/hooks/useFireCMSContext.d.ts +1 -1
- package/dist/hooks/useInternalUserManagementController.d.ts +12 -0
- package/dist/hooks/useModeController.d.ts +1 -2
- package/dist/hooks/useProjectLog.d.ts +8 -2
- package/dist/hooks/useResolvedNavigationFrom.d.ts +3 -3
- package/dist/hooks/useValidateAuthenticator.d.ts +4 -8
- package/dist/index.d.ts +1 -0
- package/dist/index.es.js +24546 -13965
- package/dist/index.es.js.map +1 -1
- package/dist/index.umd.js +27256 -588
- package/dist/index.umd.js.map +1 -1
- package/dist/internal/useBuildDataSource.d.ts +3 -17
- package/dist/internal/useBuildSideEntityController.d.ts +3 -3
- package/dist/internal/useUnsavedChangesDialog.d.ts +7 -9
- package/dist/preview/PropertyPreviewProps.d.ts +6 -1
- package/dist/preview/components/EnumValuesChip.d.ts +1 -1
- package/dist/preview/components/ReferencePreview.d.ts +4 -3
- package/dist/preview/components/StorageThumbnail.d.ts +2 -1
- package/dist/preview/components/UrlComponentPreview.d.ts +2 -1
- package/dist/preview/components/UserPreview.d.ts +8 -0
- package/dist/preview/index.d.ts +1 -0
- package/dist/preview/util.d.ts +3 -3
- package/dist/routes/CustomCMSRoute.d.ts +4 -0
- package/dist/routes/FireCMSRoute.d.ts +1 -0
- package/dist/routes/HomePageRoute.d.ts +3 -0
- package/dist/types/analytics.d.ts +1 -1
- package/dist/types/auth.d.ts +8 -10
- package/dist/types/collections.d.ts +123 -25
- package/dist/types/customization_controller.d.ts +8 -0
- package/dist/types/datasource.d.ts +52 -36
- package/dist/types/dialogs_controller.d.ts +7 -3
- package/dist/types/entities.d.ts +12 -3
- package/dist/types/entity_actions.d.ts +72 -8
- package/dist/types/entity_callbacks.d.ts +16 -16
- package/dist/types/entity_overrides.d.ts +2 -2
- package/dist/types/export_import.d.ts +4 -4
- package/dist/types/fields.d.ts +79 -39
- package/dist/types/firecms.d.ts +31 -3
- package/dist/types/firecms_context.d.ts +17 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/internal_user_management.d.ts +20 -0
- package/dist/types/navigation.d.ts +62 -19
- package/dist/types/permissions.d.ts +4 -4
- package/dist/types/plugins.d.ts +58 -13
- package/dist/types/properties.d.ts +122 -31
- package/dist/types/property_config.d.ts +1 -3
- package/dist/types/roles.d.ts +3 -0
- package/dist/types/side_dialogs_controller.d.ts +10 -0
- package/dist/types/side_entity_controller.d.ts +14 -1
- package/dist/types/storage.d.ts +75 -0
- package/dist/types/user.d.ts +2 -1
- package/dist/util/builders.d.ts +3 -3
- package/dist/util/callbacks.d.ts +2 -0
- package/dist/util/collections.d.ts +1 -0
- package/dist/util/createFormexStub.d.ts +2 -0
- package/dist/util/entities.d.ts +3 -3
- package/dist/util/entity_actions.d.ts +2 -0
- package/dist/util/entity_cache.d.ts +28 -0
- package/dist/util/icon_list.d.ts +5 -1
- package/dist/util/icon_synonyms.d.ts +1 -98
- package/dist/util/icons.d.ts +7 -4
- package/dist/util/index.d.ts +3 -0
- package/dist/util/make_properties_editable.d.ts +1 -2
- package/dist/util/navigation_from_path.d.ts +10 -1
- package/dist/util/navigation_utils.d.ts +15 -3
- package/dist/util/objects.d.ts +3 -1
- package/dist/util/permissions.d.ts +4 -4
- package/dist/util/plurals.d.ts +0 -2
- package/dist/util/property_utils.d.ts +4 -4
- package/dist/util/references.d.ts +2 -2
- package/dist/util/resolutions.d.ts +42 -17
- package/dist/util/storage.d.ts +23 -2
- package/dist/util/useStorageUploadController.d.ts +4 -3
- package/package.json +70 -53
- package/src/app/AppBar.tsx +18 -0
- package/src/app/Drawer.tsx +24 -0
- package/src/app/Scaffold.tsx +253 -0
- package/src/app/index.ts +4 -0
- package/src/app/useApp.tsx +32 -0
- package/src/components/ArrayContainer.tsx +447 -229
- package/src/components/CircularProgressCenter.tsx +2 -2
- package/src/components/ClearFilterSortButton.tsx +41 -0
- package/src/components/{DeleteConfirmationDialog.tsx → ConfirmationDialog.tsx} +12 -11
- package/src/components/DeleteEntityDialog.tsx +13 -20
- package/src/components/EntityCollectionTable/EntityCollectionRowActions.tsx +87 -62
- package/src/components/EntityCollectionTable/EntityCollectionTable.tsx +38 -31
- package/src/components/EntityCollectionTable/EntityCollectionTableProps.tsx +30 -9
- package/src/components/EntityCollectionTable/PropertyTableCell.tsx +84 -42
- package/src/components/EntityCollectionTable/column_utils.tsx +3 -3
- package/src/components/EntityCollectionTable/fields/TableReferenceField.tsx +30 -16
- package/src/components/EntityCollectionTable/fields/TableStorageUpload.tsx +19 -17
- package/src/components/EntityCollectionTable/index.tsx +1 -1
- package/src/components/EntityCollectionTable/internal/CollectionTableToolbar.tsx +34 -39
- package/src/components/EntityCollectionTable/internal/EntityTableCell.tsx +49 -36
- package/src/components/EntityCollectionTable/internal/EntityTableCellActions.tsx +20 -8
- package/src/components/EntityCollectionTable/internal/popup_field/PopupFormField.tsx +135 -105
- package/src/components/EntityCollectionTable/internal/popup_field/useDraggable.tsx +9 -9
- package/src/components/EntityCollectionView/EntityCollectionView.tsx +241 -119
- package/src/components/EntityCollectionView/EntityCollectionViewActions.tsx +7 -4
- package/src/components/EntityCollectionView/EntityCollectionViewStartActions.tsx +68 -0
- package/src/components/EntityCollectionView/useSelectionController.tsx +20 -7
- package/src/components/EntityCollectionView/utils.ts +19 -0
- package/src/components/EntityJsonPreview.tsx +66 -0
- package/src/components/EntityPreview.tsx +83 -62
- package/src/components/EntityView.tsx +34 -42
- package/src/components/ErrorView.tsx +4 -4
- package/src/components/FireCMSLogo.tsx +7 -51
- package/src/components/HomePage/DefaultHomePage.tsx +516 -158
- package/src/components/HomePage/FavouritesView.tsx +9 -14
- package/src/components/HomePage/HomePageDnD.tsx +702 -0
- package/src/components/HomePage/NavigationCard.tsx +48 -39
- package/src/components/HomePage/NavigationCardBinding.tsx +17 -16
- package/src/components/HomePage/NavigationGroup.tsx +144 -30
- package/src/components/HomePage/RenameGroupDialog.tsx +123 -0
- package/src/components/HomePage/SmallNavigationCard.tsx +5 -6
- package/src/components/NotFoundPage.tsx +2 -2
- package/src/components/PropertyCollectionView.tsx +329 -0
- package/src/components/PropertyConfigBadge.tsx +10 -4
- package/src/components/PropertyIdCopyTooltip.tsx +47 -0
- package/src/components/ReferenceTable/ReferenceSelectionTable.tsx +23 -13
- package/src/components/ReferenceWidget.tsx +21 -11
- package/src/components/SearchIconsView.tsx +10 -7
- package/src/components/SelectableTable/SelectableTable.tsx +157 -157
- package/src/components/SelectableTable/filters/BooleanFilterField.tsx +2 -3
- package/src/components/SelectableTable/filters/DateTimeFilterField.tsx +27 -9
- package/src/components/SelectableTable/filters/ReferenceFilterField.tsx +36 -12
- package/src/components/SelectableTable/filters/StringNumberFilterField.tsx +92 -24
- package/src/components/UnsavedChangesDialog.tsx +46 -0
- package/src/components/UserDisplay.tsx +55 -0
- package/src/components/VirtualTable/VirtualTable.tsx +105 -51
- package/src/components/VirtualTable/VirtualTableCell.tsx +1 -9
- package/src/components/VirtualTable/VirtualTableHeader.tsx +10 -10
- package/src/components/VirtualTable/VirtualTableHeaderRow.tsx +2 -2
- package/src/components/VirtualTable/VirtualTableProps.tsx +28 -14
- package/src/components/VirtualTable/VirtualTableRow.tsx +5 -6
- package/src/components/VirtualTable/fields/VirtualTableDateField.tsx +5 -5
- package/src/components/VirtualTable/fields/VirtualTableInput.tsx +2 -2
- package/src/components/VirtualTable/fields/VirtualTableNumberInput.tsx +2 -1
- package/src/components/VirtualTable/fields/VirtualTableSelect.tsx +16 -28
- package/src/components/VirtualTable/fields/VirtualTableUserSelect.tsx +99 -0
- package/src/components/VirtualTable/types.tsx +2 -3
- package/src/components/{EntityCollectionTable/internal → common}/default_entity_actions.tsx +64 -44
- package/src/components/common/index.ts +2 -1
- package/src/components/{VirtualTable/common.tsx → common/table_height.tsx} +5 -2
- package/src/components/common/types.tsx +4 -6
- package/src/components/common/useColumnsIds.tsx +16 -2
- package/src/components/common/useDataSourceTableController.tsx +420 -0
- package/src/components/common/useDebouncedCallback.tsx +20 -0
- package/src/components/common/useScrollRestoration.tsx +68 -0
- package/src/components/common/useTableSearchHelper.ts +53 -12
- package/src/components/index.tsx +6 -2
- package/src/contexts/BreacrumbsContext.tsx +38 -0
- package/src/contexts/DialogsProvider.tsx +5 -4
- package/src/contexts/InternalUserManagementContext.tsx +4 -0
- package/src/contexts/ModeController.tsx +1 -3
- package/src/contexts/SnackbarProvider.tsx +2 -0
- package/src/core/DefaultAppBar.tsx +219 -0
- package/src/core/DefaultDrawer.tsx +185 -0
- package/src/core/DrawerNavigationItem.tsx +66 -0
- package/src/core/EntityEditView.tsx +447 -469
- package/src/core/EntityEditViewFormActions.tsx +344 -0
- package/src/core/EntitySidePanel.tsx +96 -23
- package/src/core/FireCMS.tsx +85 -60
- package/src/core/FireCMSRouter.tsx +17 -0
- package/src/core/NavigationRoutes.tsx +28 -38
- package/src/core/SideDialogs.tsx +22 -12
- package/src/core/field_configs.tsx +41 -14
- package/src/core/index.tsx +6 -5
- package/src/form/EntityForm.tsx +740 -523
- package/src/form/EntityFormActions.tsx +226 -0
- package/src/form/PropertyFieldBinding.tsx +88 -41
- package/src/form/components/CustomIdField.tsx +9 -3
- package/src/form/components/ErrorFocus.tsx +22 -29
- package/src/form/components/FieldHelperText.tsx +4 -4
- package/src/form/components/FormEntry.tsx +22 -0
- package/src/form/components/FormLayout.tsx +16 -0
- package/src/form/components/LabelWithIcon.tsx +30 -19
- package/src/form/components/LabelWithIconAndTooltip.tsx +28 -0
- package/src/form/components/LocalChangesMenu.tsx +144 -0
- package/src/form/components/StorageItemPreview.tsx +23 -13
- package/src/form/components/StorageUploadProgress.tsx +5 -6
- package/src/form/components/index.tsx +3 -1
- package/src/form/field_bindings/ArrayCustomShapedFieldBinding.tsx +34 -19
- package/src/form/field_bindings/ArrayOfReferencesFieldBinding.tsx +50 -36
- package/src/form/field_bindings/BlockFieldBinding.tsx +56 -33
- package/src/form/field_bindings/DateTimeFieldBinding.tsx +18 -14
- package/src/form/field_bindings/KeyValueFieldBinding.tsx +61 -52
- package/src/form/field_bindings/MapFieldBinding.tsx +73 -55
- package/src/form/field_bindings/MarkdownEditorFieldBinding.tsx +159 -0
- package/src/form/field_bindings/{MultiSelectBinding.tsx → MultiSelectFieldBinding.tsx} +26 -21
- package/src/form/field_bindings/ReadOnlyFieldBinding.tsx +11 -16
- package/src/form/field_bindings/ReferenceAsStringFieldBinding.tsx +135 -0
- package/src/form/field_bindings/ReferenceFieldBinding.tsx +42 -31
- package/src/form/field_bindings/RepeatFieldBinding.tsx +62 -35
- package/src/form/field_bindings/SelectFieldBinding.tsx +24 -15
- package/src/form/field_bindings/StorageUploadFieldBinding.tsx +257 -199
- package/src/form/field_bindings/SwitchFieldBinding.tsx +29 -24
- package/src/form/field_bindings/TextFieldBinding.tsx +28 -24
- package/src/form/field_bindings/UserSelectFieldBinding.tsx +94 -0
- package/src/form/index.tsx +21 -37
- package/src/form/useClearRestoreValue.tsx +2 -2
- package/src/form/validation.ts +13 -23
- package/src/hooks/data/delete.ts +6 -5
- package/src/hooks/data/save.ts +26 -33
- package/src/hooks/data/useCollectionFetch.tsx +3 -3
- package/src/hooks/data/useDataSource.tsx +11 -3
- package/src/hooks/data/useEntityFetch.tsx +10 -6
- package/src/hooks/index.tsx +4 -0
- package/src/hooks/useAuthController.tsx +1 -1
- package/src/hooks/useBreadcrumbsController.tsx +31 -0
- package/src/hooks/useBrowserTitleAndIcon.tsx +1 -1
- package/src/hooks/useBuildLocalConfigurationPersistence.tsx +8 -10
- package/src/hooks/useBuildModeController.tsx +22 -29
- package/src/hooks/useBuildNavigationController.tsx +515 -121
- package/src/hooks/useCollapsedGroups.ts +64 -0
- package/src/hooks/useFireCMSContext.tsx +9 -35
- package/src/hooks/useInternalUserManagementController.tsx +16 -0
- package/src/hooks/useLargeLayout.tsx +0 -35
- package/src/hooks/useModeController.tsx +1 -2
- package/src/hooks/useProjectLog.tsx +32 -10
- package/src/hooks/useResolvedNavigationFrom.tsx +10 -12
- package/src/hooks/useValidateAuthenticator.tsx +17 -37
- package/src/index.ts +1 -0
- package/src/internal/useBuildDataSource.ts +79 -85
- package/src/internal/useBuildSideDialogsController.tsx +4 -2
- package/src/internal/useBuildSideEntityController.tsx +204 -77
- package/src/internal/useUnsavedChangesDialog.tsx +127 -91
- package/src/preview/PropertyPreview.tsx +42 -25
- package/src/preview/PropertyPreviewProps.tsx +7 -1
- package/src/preview/components/BooleanPreview.tsx +2 -2
- package/src/preview/components/EmptyValue.tsx +1 -1
- package/src/preview/components/EnumValuesChip.tsx +2 -2
- package/src/preview/components/ImagePreview.tsx +26 -37
- package/src/preview/components/ReferencePreview.tsx +30 -38
- package/src/preview/components/StorageThumbnail.tsx +5 -1
- package/src/preview/components/UrlComponentPreview.tsx +60 -28
- package/src/preview/components/UserPreview.tsx +27 -0
- package/src/preview/index.ts +1 -0
- package/src/preview/property_previews/ArrayOfMapsPreview.tsx +6 -6
- package/src/preview/property_previews/ArrayOfReferencesPreview.tsx +7 -5
- package/src/preview/property_previews/ArrayOfStorageComponentsPreview.tsx +5 -4
- package/src/preview/property_previews/ArrayOfStringsPreview.tsx +4 -4
- package/src/preview/property_previews/ArrayOneOfPreview.tsx +7 -6
- package/src/preview/property_previews/ArrayPropertyPreview.tsx +8 -7
- package/src/preview/property_previews/MapPropertyPreview.tsx +14 -13
- package/src/preview/property_previews/NumberPropertyPreview.tsx +2 -2
- package/src/preview/property_previews/SkeletonPropertyComponent.tsx +13 -13
- package/src/preview/property_previews/StringPropertyPreview.tsx +3 -3
- package/src/preview/util.ts +10 -10
- package/src/routes/CustomCMSRoute.tsx +21 -0
- package/src/routes/FireCMSRoute.tsx +246 -0
- package/src/routes/HomePageRoute.tsx +17 -0
- package/src/types/analytics.ts +3 -0
- package/src/types/auth.tsx +9 -13
- package/src/types/collections.ts +146 -30
- package/src/types/customization_controller.tsx +9 -1
- package/src/types/datasource.ts +61 -43
- package/src/types/dialogs_controller.tsx +7 -3
- package/src/types/entities.ts +19 -3
- package/src/types/entity_actions.tsx +86 -10
- package/src/types/entity_callbacks.ts +18 -18
- package/src/types/entity_overrides.tsx +2 -2
- package/src/types/export_import.ts +4 -4
- package/src/types/fields.tsx +91 -42
- package/src/types/firecms.tsx +34 -4
- package/src/types/firecms_context.tsx +18 -1
- package/src/types/index.ts +1 -1
- package/src/types/internal_user_management.ts +24 -0
- package/src/types/navigation.ts +77 -24
- package/src/types/permissions.ts +5 -5
- package/src/types/plugins.tsx +69 -15
- package/src/types/properties.ts +141 -33
- package/src/types/property_config.tsx +2 -2
- package/src/types/roles.ts +3 -0
- package/src/types/side_dialogs_controller.tsx +15 -0
- package/src/types/side_entity_controller.tsx +16 -1
- package/src/types/storage.ts +83 -1
- package/src/types/user.ts +3 -1
- package/src/util/builders.ts +10 -8
- package/src/util/callbacks.ts +119 -0
- package/src/util/collections.ts +8 -0
- package/src/util/createFormexStub.tsx +66 -0
- package/src/util/entities.ts +11 -8
- package/src/util/entity_actions.ts +28 -0
- package/src/util/entity_cache.ts +223 -0
- package/src/util/enums.ts +1 -1
- package/src/util/icon_list.ts +16 -10
- package/src/util/icon_synonyms.ts +3 -100
- package/src/util/icons.tsx +36 -11
- package/src/util/index.ts +3 -0
- package/src/util/join_collections.ts +11 -4
- package/src/util/make_properties_editable.ts +5 -19
- package/src/util/navigation_from_path.ts +33 -12
- package/src/util/navigation_utils.ts +141 -25
- package/src/util/objects.ts +128 -33
- package/src/util/parent_references_from_path.ts +3 -3
- package/src/util/permissions.ts +9 -8
- package/src/util/plurals.ts +0 -2
- package/src/util/property_utils.tsx +17 -6
- package/src/util/references.ts +19 -8
- package/src/util/resolutions.ts +122 -48
- package/src/util/storage.ts +79 -21
- package/src/util/strings.ts +2 -2
- package/src/util/useStorageUploadController.tsx +162 -62
- package/dist/components/EntityCollectionTable/internal/popup_field/ElementResizeListener.d.ts +0 -5
- package/dist/components/FireCMSAppBar.d.ts +0 -26
- package/dist/components/PropertyIdCopyTooltipContent.d.ts +0 -3
- package/dist/components/VirtualTable/common.d.ts +0 -2
- package/dist/core/Drawer.d.ts +0 -23
- package/dist/core/Scaffold.d.ts +0 -55
- package/dist/core/SideEntityView.d.ts +0 -7
- package/dist/form/components/FormikArrayContainer.d.ts +0 -18
- package/dist/form/field_bindings/MarkdownFieldBinding.d.ts +0 -9
- package/dist/internal/useBuildCustomizationController.d.ts +0 -2
- package/dist/internal/useLocaleConfig.d.ts +0 -1
- package/dist/types/appcheck.d.ts +0 -26
- package/src/components/EntityCollectionTable/internal/popup_field/ElementResizeListener.tsx +0 -59
- package/src/components/FireCMSAppBar.tsx +0 -165
- package/src/components/PropertyIdCopyTooltipContent.tsx +0 -28
- package/src/components/common/useDataSourceEntityCollectionTableController.tsx +0 -225
- package/src/core/Drawer.tsx +0 -191
- package/src/core/Scaffold.tsx +0 -281
- package/src/core/SideEntityView.tsx +0 -38
- package/src/form/components/FormikArrayContainer.tsx +0 -44
- package/src/form/field_bindings/MarkdownFieldBinding.tsx +0 -695
- package/src/internal/useBuildCustomizationController.tsx +0 -5
- package/src/internal/useLocaleConfig.tsx +0 -18
- package/src/types/appcheck.ts +0 -29
- /package/src/util/{common.tsx → common.ts} +0 -0
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {
|
|
3
|
+
Entity,
|
|
4
|
+
EntityAction,
|
|
5
|
+
FireCMSContext,
|
|
6
|
+
FormContext,
|
|
7
|
+
ResolvedEntityCollection,
|
|
8
|
+
SideEntityController
|
|
9
|
+
} from "../types";
|
|
10
|
+
import {
|
|
11
|
+
Button,
|
|
12
|
+
cls,
|
|
13
|
+
defaultBorderMixin,
|
|
14
|
+
DialogActions,
|
|
15
|
+
ErrorIcon,
|
|
16
|
+
IconButton,
|
|
17
|
+
LoadingButton,
|
|
18
|
+
Typography
|
|
19
|
+
} from "@firecms/ui";
|
|
20
|
+
import { FormexController } from "@firecms/formex";
|
|
21
|
+
import { useFireCMSContext, useSideEntityController } from "../hooks";
|
|
22
|
+
|
|
23
|
+
export interface EntityFormActionsProps {
|
|
24
|
+
fullPath: string;
|
|
25
|
+
fullIdPath?: string;
|
|
26
|
+
collection: ResolvedEntityCollection;
|
|
27
|
+
path: string;
|
|
28
|
+
entity?: Entity;
|
|
29
|
+
layout: "bottom" | "side";
|
|
30
|
+
savingError?: Error;
|
|
31
|
+
formex: FormexController<any>;
|
|
32
|
+
disabled: boolean;
|
|
33
|
+
status: "new" | "existing" | "copy";
|
|
34
|
+
pluginActions: React.ReactNode[];
|
|
35
|
+
openEntityMode: "side_panel" | "full_screen";
|
|
36
|
+
showDefaultActions?: boolean;
|
|
37
|
+
navigateBack: () => void;
|
|
38
|
+
formContext: FormContext
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function EntityFormActions({
|
|
42
|
+
fullPath,
|
|
43
|
+
fullIdPath,
|
|
44
|
+
collection,
|
|
45
|
+
entity,
|
|
46
|
+
layout,
|
|
47
|
+
savingError,
|
|
48
|
+
formex,
|
|
49
|
+
disabled,
|
|
50
|
+
status,
|
|
51
|
+
pluginActions,
|
|
52
|
+
openEntityMode,
|
|
53
|
+
navigateBack,
|
|
54
|
+
formContext
|
|
55
|
+
}: EntityFormActionsProps) {
|
|
56
|
+
|
|
57
|
+
const context = useFireCMSContext();
|
|
58
|
+
const sideEntityController = useSideEntityController();
|
|
59
|
+
|
|
60
|
+
return layout === "bottom"
|
|
61
|
+
? buildBottomActions({
|
|
62
|
+
fullPath,
|
|
63
|
+
fullIdPath,
|
|
64
|
+
savingError,
|
|
65
|
+
entity,
|
|
66
|
+
collection,
|
|
67
|
+
context,
|
|
68
|
+
sideEntityController,
|
|
69
|
+
disabled,
|
|
70
|
+
status,
|
|
71
|
+
pluginActions,
|
|
72
|
+
openEntityMode,
|
|
73
|
+
navigateBack,
|
|
74
|
+
formContext,
|
|
75
|
+
formex
|
|
76
|
+
})
|
|
77
|
+
: buildSideActions({
|
|
78
|
+
fullPath,
|
|
79
|
+
fullIdPath,
|
|
80
|
+
savingError,
|
|
81
|
+
entity,
|
|
82
|
+
collection,
|
|
83
|
+
context,
|
|
84
|
+
sideEntityController,
|
|
85
|
+
disabled,
|
|
86
|
+
status,
|
|
87
|
+
pluginActions,
|
|
88
|
+
openEntityMode,
|
|
89
|
+
navigateBack,
|
|
90
|
+
formContext,
|
|
91
|
+
formex
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
type ActionsViewProps<M extends object> = {
|
|
96
|
+
fullPath: string,
|
|
97
|
+
fullIdPath?: string,
|
|
98
|
+
savingError: Error | undefined,
|
|
99
|
+
entity: Entity<M> | undefined,
|
|
100
|
+
formActions?: EntityAction[],
|
|
101
|
+
collection: ResolvedEntityCollection,
|
|
102
|
+
context: FireCMSContext,
|
|
103
|
+
sideEntityController: SideEntityController,
|
|
104
|
+
disabled: boolean,
|
|
105
|
+
status: "new" | "existing" | "copy",
|
|
106
|
+
pluginActions?: React.ReactNode[],
|
|
107
|
+
openEntityMode: "side_panel" | "full_screen";
|
|
108
|
+
navigateBack: () => void;
|
|
109
|
+
formContext: FormContext,
|
|
110
|
+
formex: FormexController<any>;
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
function buildBottomActions<M extends object>({
|
|
114
|
+
savingError,
|
|
115
|
+
entity,
|
|
116
|
+
fullPath,
|
|
117
|
+
fullIdPath,
|
|
118
|
+
formActions,
|
|
119
|
+
collection,
|
|
120
|
+
context,
|
|
121
|
+
sideEntityController,
|
|
122
|
+
disabled,
|
|
123
|
+
status,
|
|
124
|
+
pluginActions,
|
|
125
|
+
openEntityMode,
|
|
126
|
+
navigateBack,
|
|
127
|
+
formContext,
|
|
128
|
+
formex
|
|
129
|
+
}: ActionsViewProps<M>) {
|
|
130
|
+
|
|
131
|
+
const hasErrors = Object.keys(formex.errors).length > 0 && formex.submitCount > 0;
|
|
132
|
+
|
|
133
|
+
return <DialogActions position={"absolute"}>
|
|
134
|
+
{savingError &&
|
|
135
|
+
<div className="text-right">
|
|
136
|
+
<Typography color={"error"}>{savingError.message}</Typography>
|
|
137
|
+
</div>
|
|
138
|
+
}
|
|
139
|
+
{entity && (formActions ?? []).length > 0 && <div className="flex-grow flex overflow-auto no-scrollbar">
|
|
140
|
+
{(formActions ?? []).map(action => (
|
|
141
|
+
<IconButton
|
|
142
|
+
key={action.name}
|
|
143
|
+
color="primary"
|
|
144
|
+
onClick={(event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {
|
|
145
|
+
event.stopPropagation();
|
|
146
|
+
if (entity)
|
|
147
|
+
action.onClick({
|
|
148
|
+
view: "form",
|
|
149
|
+
entity,
|
|
150
|
+
fullPath: fullPath ?? collection.path,
|
|
151
|
+
fullIdPath: fullIdPath ?? collection.id,
|
|
152
|
+
collection: collection,
|
|
153
|
+
context,
|
|
154
|
+
sideEntityController,
|
|
155
|
+
openEntityMode: openEntityMode,
|
|
156
|
+
navigateBack,
|
|
157
|
+
formContext
|
|
158
|
+
});
|
|
159
|
+
}}>
|
|
160
|
+
{action.icon}
|
|
161
|
+
</IconButton>
|
|
162
|
+
))}
|
|
163
|
+
</div>}
|
|
164
|
+
{pluginActions}
|
|
165
|
+
<Button variant="text" disabled={disabled || formex.isSubmitting}
|
|
166
|
+
color={"primary"}
|
|
167
|
+
type="reset">
|
|
168
|
+
{status === "existing" ? "Discard" : "Clear"}
|
|
169
|
+
</Button>
|
|
170
|
+
<Button variant={"filled"}
|
|
171
|
+
color="primary"
|
|
172
|
+
type="submit"
|
|
173
|
+
disabled={disabled || formex.isSubmitting}
|
|
174
|
+
startIcon={hasErrors ? <ErrorIcon/> : undefined}>
|
|
175
|
+
{status === "existing" && "Save"}
|
|
176
|
+
{status === "copy" && "Create copy"}
|
|
177
|
+
{status === "new" && "Create"}
|
|
178
|
+
</Button>
|
|
179
|
+
|
|
180
|
+
</DialogActions>;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
function buildSideActions<M extends object>({
|
|
184
|
+
savingError,
|
|
185
|
+
entity,
|
|
186
|
+
formActions,
|
|
187
|
+
fullPath,
|
|
188
|
+
fullIdPath,
|
|
189
|
+
openEntityMode,
|
|
190
|
+
collection,
|
|
191
|
+
context,
|
|
192
|
+
sideEntityController,
|
|
193
|
+
disabled,
|
|
194
|
+
status,
|
|
195
|
+
pluginActions,
|
|
196
|
+
formex
|
|
197
|
+
}: ActionsViewProps<M>) {
|
|
198
|
+
|
|
199
|
+
const hasErrors = Object.keys(formex.errors).length > 0 && formex.submitCount > 0;
|
|
200
|
+
|
|
201
|
+
return <div
|
|
202
|
+
className={cls("overflow-auto h-full flex flex-col gap-2 w-80 2xl:w-96 px-4 py-16 sticky top-0 border-l", defaultBorderMixin)}>
|
|
203
|
+
<LoadingButton fullWidth={true}
|
|
204
|
+
variant="filled"
|
|
205
|
+
color="primary"
|
|
206
|
+
type="submit"
|
|
207
|
+
size={"large"}
|
|
208
|
+
startIcon={hasErrors ? <ErrorIcon/> : undefined}
|
|
209
|
+
disabled={disabled || formex.isSubmitting}>
|
|
210
|
+
{status === "existing" && "Save"}
|
|
211
|
+
{status === "copy" && "Create copy"}
|
|
212
|
+
{status === "new" && "Create"}
|
|
213
|
+
</LoadingButton>
|
|
214
|
+
<Button fullWidth={true} variant="text" disabled={disabled || formex.isSubmitting} type="reset">
|
|
215
|
+
{status === "existing" ? "Discard" : "Clear"}
|
|
216
|
+
</Button>
|
|
217
|
+
|
|
218
|
+
{pluginActions}
|
|
219
|
+
|
|
220
|
+
{savingError &&
|
|
221
|
+
<div className="text-right">
|
|
222
|
+
<Typography color={"error"}>{savingError.message}</Typography>
|
|
223
|
+
</div>
|
|
224
|
+
}
|
|
225
|
+
</div>;
|
|
226
|
+
}
|
|
@@ -5,19 +5,19 @@ import { Field, FieldProps as FormexFieldProps, getIn } from "@firecms/formex";
|
|
|
5
5
|
|
|
6
6
|
import {
|
|
7
7
|
CMSType,
|
|
8
|
-
EntityCollection,
|
|
9
8
|
FieldProps,
|
|
10
9
|
FireCMSPlugin,
|
|
11
10
|
PluginFieldBuilderParams,
|
|
12
11
|
Property,
|
|
13
12
|
PropertyFieldBindingProps,
|
|
14
13
|
PropertyOrBuilder,
|
|
14
|
+
ResolvedEntityCollection,
|
|
15
15
|
ResolvedProperty
|
|
16
16
|
} from "../types";
|
|
17
17
|
import { ReadOnlyFieldBinding } from "./field_bindings/ReadOnlyFieldBinding";
|
|
18
18
|
|
|
19
19
|
import { isHidden, isPropertyBuilder, isReadOnly, resolveProperty } from "../util";
|
|
20
|
-
import { useCustomizationController } from "../hooks";
|
|
20
|
+
import { useAuthController, useCustomizationController } from "../hooks";
|
|
21
21
|
import { Typography } from "@firecms/ui";
|
|
22
22
|
import { getFieldConfig, getFieldId } from "../core";
|
|
23
23
|
import { ErrorBoundary } from "../components";
|
|
@@ -51,6 +51,13 @@ export const PropertyFieldBinding = React.memo(PropertyFieldBindingInternal, (a:
|
|
|
51
51
|
if (a.propertyKey !== b.propertyKey) {
|
|
52
52
|
return false;
|
|
53
53
|
}
|
|
54
|
+
if (a.index !== b.index) {
|
|
55
|
+
return false;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
if (a.size !== b.size) {
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
54
61
|
const aIsBuilder = isPropertyBuilder(a.property) || a.property.fromBuilder;
|
|
55
62
|
const bIsBuilder = isPropertyBuilder(b.property) || b.property.fromBuilder;
|
|
56
63
|
|
|
@@ -67,24 +74,29 @@ export const PropertyFieldBinding = React.memo(PropertyFieldBindingInternal, (a:
|
|
|
67
74
|
return false;
|
|
68
75
|
}) as typeof PropertyFieldBindingInternal;
|
|
69
76
|
|
|
70
|
-
function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Record<string, any> =
|
|
77
|
+
function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Record<string, any> = any>
|
|
71
78
|
({
|
|
72
79
|
propertyKey,
|
|
73
80
|
property,
|
|
74
81
|
context,
|
|
75
82
|
includeDescription,
|
|
76
83
|
underlyingValueHasChanged,
|
|
77
|
-
disabled,
|
|
78
|
-
tableMode,
|
|
84
|
+
disabled: disabledProp,
|
|
79
85
|
partOfArray,
|
|
80
86
|
partOfBlock,
|
|
87
|
+
minimalistView,
|
|
81
88
|
autoFocus,
|
|
89
|
+
index,
|
|
90
|
+
size,
|
|
91
|
+
onPropertyChange,
|
|
82
92
|
}: PropertyFieldBindingProps<T, M>): ReactElement<PropertyFieldBindingProps<T, M>> {
|
|
83
93
|
|
|
94
|
+
const authController = useAuthController();
|
|
84
95
|
const customizationController = useCustomizationController();
|
|
85
96
|
|
|
86
97
|
return (
|
|
87
98
|
<Field
|
|
99
|
+
key={propertyKey}
|
|
88
100
|
name={propertyKey}
|
|
89
101
|
>
|
|
90
102
|
{(fieldProps) => {
|
|
@@ -92,14 +104,17 @@ function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Rec
|
|
|
92
104
|
let Component: ComponentType<FieldProps<T>> | undefined;
|
|
93
105
|
const resolvedProperty: ResolvedProperty<T> | null = resolveProperty({
|
|
94
106
|
propertyKey,
|
|
95
|
-
propertyValue: fieldProps.field.value,
|
|
96
107
|
propertyOrBuilder: property,
|
|
97
108
|
values: fieldProps.form.values,
|
|
98
109
|
path: context.path,
|
|
99
110
|
entityId: context.entityId,
|
|
100
|
-
|
|
111
|
+
propertyConfigs: customizationController.propertyConfigs,
|
|
112
|
+
index,
|
|
113
|
+
authController
|
|
101
114
|
});
|
|
102
115
|
|
|
116
|
+
const disabled = disabledProp || isReadOnly(resolvedProperty) || Boolean(resolvedProperty?.disabled) || context.disabled;
|
|
117
|
+
|
|
103
118
|
if (resolvedProperty === null || isHidden(resolvedProperty)) {
|
|
104
119
|
return <></>;
|
|
105
120
|
} else if (isReadOnly(resolvedProperty)) {
|
|
@@ -111,16 +126,24 @@ function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Rec
|
|
|
111
126
|
} else {
|
|
112
127
|
const propertyConfig = getFieldConfig(resolvedProperty, customizationController.propertyConfigs);
|
|
113
128
|
if (!propertyConfig) {
|
|
114
|
-
console.log("INTERNAL: Could not find field config for property", {
|
|
129
|
+
console.log("INTERNAL: Could not find field config for property", {
|
|
130
|
+
propertyKey,
|
|
131
|
+
property,
|
|
132
|
+
resolvedProperty,
|
|
133
|
+
fields: customizationController.propertyConfigs,
|
|
134
|
+
propertyConfig
|
|
135
|
+
});
|
|
115
136
|
throw new Error(`INTERNAL: Could not find field config for property ${propertyKey}`);
|
|
116
137
|
}
|
|
117
138
|
const configProperty = resolveProperty({
|
|
139
|
+
propertyKey,
|
|
118
140
|
propertyOrBuilder: propertyConfig.property,
|
|
119
|
-
propertyValue: fieldProps.field.value,
|
|
120
141
|
values: fieldProps.form.values,
|
|
121
142
|
path: context.path,
|
|
122
143
|
entityId: context.entityId,
|
|
123
|
-
|
|
144
|
+
propertyConfigs: customizationController.propertyConfigs,
|
|
145
|
+
index,
|
|
146
|
+
authController
|
|
124
147
|
});
|
|
125
148
|
Component = configProperty.Field as ComponentType<FieldProps<T>>;
|
|
126
149
|
}
|
|
@@ -128,7 +151,9 @@ function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Rec
|
|
|
128
151
|
console.warn(`No field component found for property ${propertyKey}`);
|
|
129
152
|
console.warn("Property:", property);
|
|
130
153
|
return (
|
|
131
|
-
<div
|
|
154
|
+
<div className={"w-full"}>
|
|
155
|
+
{`Currently the field ${resolvedProperty.dataType} is not supported`}
|
|
156
|
+
</div>
|
|
132
157
|
);
|
|
133
158
|
}
|
|
134
159
|
|
|
@@ -139,23 +164,25 @@ function PropertyFieldBindingInternal<T extends CMSType = CMSType, M extends Rec
|
|
|
139
164
|
underlyingValueHasChanged,
|
|
140
165
|
context,
|
|
141
166
|
disabled,
|
|
142
|
-
tableMode,
|
|
143
167
|
partOfArray,
|
|
144
168
|
partOfBlock,
|
|
145
|
-
|
|
169
|
+
minimalistView,
|
|
170
|
+
autoFocus,
|
|
171
|
+
size,
|
|
172
|
+
onPropertyChange
|
|
146
173
|
};
|
|
147
174
|
|
|
148
175
|
return <FieldInternal
|
|
149
176
|
Component={Component as ComponentType<FieldProps>}
|
|
150
177
|
componentProps={componentProps}
|
|
151
|
-
|
|
178
|
+
formexFieldProps={fieldProps}/>;
|
|
152
179
|
}}
|
|
153
180
|
</Field>
|
|
154
181
|
);
|
|
155
182
|
|
|
156
183
|
}
|
|
157
184
|
|
|
158
|
-
type ResolvedPropertyFieldBindingProps<T extends CMSType = CMSType, M extends Record<string, any> =
|
|
185
|
+
type ResolvedPropertyFieldBindingProps<T extends CMSType = CMSType, M extends Record<string, any> = any> =
|
|
159
186
|
Omit<PropertyFieldBindingProps<T, M>, "property">
|
|
160
187
|
& {
|
|
161
188
|
property: ResolvedProperty<T>
|
|
@@ -169,52 +196,59 @@ function FieldInternal<T extends CMSType, CustomProps, M extends Record<string,
|
|
|
169
196
|
property,
|
|
170
197
|
includeDescription,
|
|
171
198
|
underlyingValueHasChanged,
|
|
172
|
-
tableMode,
|
|
173
199
|
partOfArray,
|
|
174
200
|
partOfBlock,
|
|
201
|
+
minimalistView,
|
|
175
202
|
autoFocus,
|
|
176
203
|
context,
|
|
177
|
-
disabled
|
|
204
|
+
disabled,
|
|
205
|
+
size,
|
|
206
|
+
onPropertyChange
|
|
178
207
|
},
|
|
179
|
-
|
|
208
|
+
formexFieldProps
|
|
180
209
|
}:
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
210
|
+
{
|
|
211
|
+
Component: ComponentType<FieldProps<T, any, M>>,
|
|
212
|
+
componentProps: ResolvedPropertyFieldBindingProps<T, M>,
|
|
213
|
+
formexFieldProps: FormexFieldProps<T, any>
|
|
214
|
+
}) {
|
|
186
215
|
|
|
187
216
|
const { plugins } = useCustomizationController();
|
|
188
217
|
|
|
189
218
|
const customFieldProps: any = property.customProps;
|
|
190
|
-
const value =
|
|
191
|
-
|
|
192
|
-
const
|
|
193
|
-
const touched = getIn(fieldProps.form.touched, propertyKey);
|
|
219
|
+
const value = formexFieldProps.field.value;
|
|
220
|
+
const error = getIn(formexFieldProps.form.errors, propertyKey);
|
|
221
|
+
const touched = getIn(formexFieldProps.form.touched, propertyKey);
|
|
194
222
|
|
|
195
223
|
const showError: boolean = error &&
|
|
196
|
-
(
|
|
224
|
+
(formexFieldProps.form.submitCount > 0 || property.validation?.unique) &&
|
|
197
225
|
(!Array.isArray(error) || !!error.filter((e: any) => !!e).length);
|
|
198
226
|
|
|
199
|
-
const WrappedComponent: ComponentType<FieldProps<T, any, M>> | null = useWrappedComponent(
|
|
227
|
+
const WrappedComponent: ComponentType<FieldProps<T, any, M>> | null = useWrappedComponent({
|
|
228
|
+
path: context.path,
|
|
229
|
+
collection: context.collection,
|
|
230
|
+
propertyKey: propertyKey,
|
|
231
|
+
property: property,
|
|
232
|
+
Component: Component,
|
|
233
|
+
plugins: plugins
|
|
234
|
+
});
|
|
200
235
|
const UsedComponent: ComponentType<FieldProps<T>> = WrappedComponent ?? Component;
|
|
201
236
|
|
|
202
|
-
const isSubmitting =
|
|
237
|
+
const isSubmitting = formexFieldProps.form.isSubmitting;
|
|
203
238
|
|
|
204
239
|
const setValue = useCallback((value: T | null, shouldValidate?: boolean) => {
|
|
205
|
-
|
|
206
|
-
|
|
240
|
+
formexFieldProps.form.setFieldTouched(propertyKey, true, false);
|
|
241
|
+
formexFieldProps.form.setFieldValue(propertyKey, value, shouldValidate);
|
|
207
242
|
}, []);
|
|
208
243
|
|
|
209
244
|
const setFieldValue = useCallback((otherPropertyKey: string, value: CMSType | null, shouldValidate?: boolean) => {
|
|
210
|
-
|
|
211
|
-
|
|
245
|
+
formexFieldProps.form.setFieldTouched(propertyKey, true, false);
|
|
246
|
+
formexFieldProps.form.setFieldValue(otherPropertyKey, value, shouldValidate);
|
|
212
247
|
}, []);
|
|
213
248
|
|
|
214
249
|
const cmsFieldProps: FieldProps<T, CustomProps, M> = {
|
|
215
250
|
propertyKey,
|
|
216
251
|
value: value as T,
|
|
217
|
-
// initialValue,
|
|
218
252
|
setValue,
|
|
219
253
|
setFieldValue,
|
|
220
254
|
error,
|
|
@@ -225,12 +259,14 @@ function FieldInternal<T extends CMSType, CustomProps, M extends Record<string,
|
|
|
225
259
|
property: property as ResolvedProperty<T>,
|
|
226
260
|
disabled: disabled ?? false,
|
|
227
261
|
underlyingValueHasChanged: underlyingValueHasChanged ?? false,
|
|
228
|
-
tableMode: tableMode ?? false,
|
|
229
262
|
partOfArray: partOfArray ?? false,
|
|
230
263
|
partOfBlock: partOfBlock ?? false,
|
|
264
|
+
minimalistView: minimalistView ?? false,
|
|
231
265
|
autoFocus: autoFocus ?? false,
|
|
232
266
|
customProps: customFieldProps,
|
|
233
|
-
context
|
|
267
|
+
context,
|
|
268
|
+
size,
|
|
269
|
+
onPropertyChange
|
|
234
270
|
};
|
|
235
271
|
|
|
236
272
|
return (
|
|
@@ -266,13 +302,24 @@ const shouldPropertyReRender = (property: PropertyOrBuilder | ResolvedProperty,
|
|
|
266
302
|
}
|
|
267
303
|
}
|
|
268
304
|
|
|
269
|
-
|
|
270
|
-
path
|
|
271
|
-
collection
|
|
305
|
+
interface UseWrappedComponentParams<T extends CMSType = CMSType, M extends Record<string, any> = any> {
|
|
306
|
+
path?: string,
|
|
307
|
+
collection?: ResolvedEntityCollection<M>,
|
|
272
308
|
propertyKey: string,
|
|
273
309
|
property: ResolvedProperty<T>,
|
|
274
310
|
Component: ComponentType<FieldProps<T, any, M>>,
|
|
275
311
|
plugins?: FireCMSPlugin[]
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
function useWrappedComponent<T extends CMSType = CMSType, M extends Record<string, any> = any>(
|
|
315
|
+
{
|
|
316
|
+
path,
|
|
317
|
+
collection,
|
|
318
|
+
propertyKey,
|
|
319
|
+
property,
|
|
320
|
+
Component,
|
|
321
|
+
plugins
|
|
322
|
+
}: UseWrappedComponentParams<T, M>
|
|
276
323
|
): ComponentType<FieldProps<T, any, M>> | null {
|
|
277
324
|
|
|
278
325
|
const wrapperRef = useRef<ComponentType<FieldProps<T, any, M>> | null>((() => {
|
|
@@ -288,7 +335,7 @@ function useWrappedComponent<T extends CMSType = CMSType, M extends Record<strin
|
|
|
288
335
|
Field: Component,
|
|
289
336
|
plugin,
|
|
290
337
|
path,
|
|
291
|
-
collection
|
|
338
|
+
collection,
|
|
292
339
|
};
|
|
293
340
|
const enabled = plugin.form?.fieldBuilderEnabled?.(params);
|
|
294
341
|
if (enabled === undefined || enabled)
|
|
@@ -68,7 +68,8 @@ export function CustomIdField<M extends Record<string, any>>({
|
|
|
68
68
|
? (
|
|
69
69
|
<>
|
|
70
70
|
|
|
71
|
-
<Tooltip title={"Copy"}
|
|
71
|
+
<Tooltip title={"Copy"}
|
|
72
|
+
asChild={true}>
|
|
72
73
|
<IconButton onClick={(e) => copy(entity.id)}
|
|
73
74
|
aria-label="copy-id">
|
|
74
75
|
<ContentCopyIcon size={"small"}/>
|
|
@@ -76,7 +77,8 @@ export function CustomIdField<M extends Record<string, any>>({
|
|
|
76
77
|
</Tooltip>
|
|
77
78
|
|
|
78
79
|
{customizationController?.entityLinkBuilder &&
|
|
79
|
-
<Tooltip title={"Open in the console"}
|
|
80
|
+
<Tooltip title={"Open in the console"}
|
|
81
|
+
asChild={true}>
|
|
80
82
|
<IconButton component={"a"}
|
|
81
83
|
href={customizationController.entityLinkBuilder({ entity })}
|
|
82
84
|
rel="noopener noreferrer"
|
|
@@ -98,8 +100,12 @@ export function CustomIdField<M extends Record<string, any>>({
|
|
|
98
100
|
|
|
99
101
|
{enumValues &&
|
|
100
102
|
<Select
|
|
103
|
+
size={"large"}
|
|
101
104
|
error={error}
|
|
102
|
-
|
|
105
|
+
fullWidth={true}
|
|
106
|
+
onValueChange={(v) => {
|
|
107
|
+
onChange(v as string);
|
|
108
|
+
}}
|
|
103
109
|
{...fieldProps}
|
|
104
110
|
renderValue={(option) => {
|
|
105
111
|
const enumConfig = enumValues.find(e => e.id === option);
|
|
@@ -1,51 +1,44 @@
|
|
|
1
|
-
import React, { useEffect } from "react";
|
|
1
|
+
import React, { useEffect, useRef } from "react";
|
|
2
2
|
import { useFormex } from "@firecms/formex";
|
|
3
3
|
|
|
4
4
|
export const ErrorFocus = ({ containerRef }:
|
|
5
5
|
{
|
|
6
6
|
containerRef?: React.RefObject<HTMLDivElement>
|
|
7
7
|
}) => {
|
|
8
|
-
const {
|
|
8
|
+
const {
|
|
9
|
+
isValidating,
|
|
10
|
+
errors,
|
|
11
|
+
version
|
|
12
|
+
} = useFormex();
|
|
13
|
+
|
|
14
|
+
const prevVersion = useRef(version);
|
|
9
15
|
|
|
10
16
|
useEffect(() => {
|
|
17
|
+
|
|
18
|
+
if (version === prevVersion.current) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
|
|
11
22
|
const keys = Object.keys(errors);
|
|
12
23
|
|
|
13
|
-
// Whenever there are errors and the form
|
|
14
|
-
if (keys.length > 0
|
|
24
|
+
// Whenever there are errors and the form has been submitted and is not validating
|
|
25
|
+
if (!isValidating && keys.length > 0) {
|
|
15
26
|
const errorElement = containerRef?.current?.querySelector<HTMLDivElement>(
|
|
16
27
|
`#form_field_${keys[0]}`
|
|
17
28
|
);
|
|
18
29
|
|
|
19
|
-
if (errorElement
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
top: scrollableParent.scrollTop + top - 196,
|
|
25
|
-
behavior: "smooth"
|
|
26
|
-
});
|
|
27
|
-
}
|
|
30
|
+
if (errorElement) {
|
|
31
|
+
errorElement.scrollIntoView({
|
|
32
|
+
behavior: "smooth",
|
|
33
|
+
block: "center"
|
|
34
|
+
});
|
|
28
35
|
const input = errorElement.querySelector("input");
|
|
29
36
|
if (input) input.focus();
|
|
30
37
|
}
|
|
38
|
+
prevVersion.current = version;
|
|
31
39
|
}
|
|
32
|
-
}, [
|
|
40
|
+
}, [isValidating, errors, containerRef, version]);
|
|
33
41
|
|
|
34
42
|
// This component does not render anything by itself.
|
|
35
43
|
return null;
|
|
36
44
|
};
|
|
37
|
-
|
|
38
|
-
const isScrollable = (ele: HTMLElement | null) => {
|
|
39
|
-
const hasScrollableContent = ele && ele.scrollHeight > ele.clientHeight;
|
|
40
|
-
|
|
41
|
-
const overflowYStyle = ele ? window.getComputedStyle(ele).overflowY : null;
|
|
42
|
-
const isOverflowHidden = overflowYStyle && overflowYStyle.indexOf("hidden") !== -1;
|
|
43
|
-
|
|
44
|
-
return hasScrollableContent && !isOverflowHidden;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
const getScrollableParent = (ele: HTMLElement | null): HTMLElement | null => {
|
|
48
|
-
return (!ele || ele === document.body)
|
|
49
|
-
? document.body
|
|
50
|
-
: (isScrollable(ele) ? ele : getScrollableParent(ele.parentNode as HTMLElement));
|
|
51
|
-
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ResolvedProperty } from "../../types";
|
|
1
|
+
import { Property, ResolvedProperty } from "../../types";
|
|
2
2
|
import { IconButton, InfoIcon, Tooltip, Typography } from "@firecms/ui";
|
|
3
3
|
|
|
4
4
|
/**
|
|
@@ -13,8 +13,8 @@ export function FieldHelperText({
|
|
|
13
13
|
disabled
|
|
14
14
|
}: {
|
|
15
15
|
error?: string,
|
|
16
|
-
showError
|
|
17
|
-
property: ResolvedProperty,
|
|
16
|
+
showError?: boolean,
|
|
17
|
+
property: ResolvedProperty | Property,
|
|
18
18
|
includeDescription?: boolean,
|
|
19
19
|
disabled?: boolean,
|
|
20
20
|
}
|
|
@@ -44,7 +44,7 @@ export function FieldHelperText({
|
|
|
44
44
|
{property.longDescription &&
|
|
45
45
|
<Tooltip title={property.longDescription}
|
|
46
46
|
side="bottom"
|
|
47
|
-
|
|
47
|
+
asChild={true}>
|
|
48
48
|
<IconButton
|
|
49
49
|
size={"small"}
|
|
50
50
|
className="self-start">
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ErrorBoundary } from "../../components";
|
|
3
|
+
|
|
4
|
+
export function FormEntry({
|
|
5
|
+
propertyKey,
|
|
6
|
+
widthPercentage = 100,
|
|
7
|
+
children
|
|
8
|
+
}: {
|
|
9
|
+
propertyKey: string;
|
|
10
|
+
widthPercentage?: number;
|
|
11
|
+
children: React.ReactNode;
|
|
12
|
+
}) {
|
|
13
|
+
return (
|
|
14
|
+
<div id={`form_field_${propertyKey}`}
|
|
15
|
+
className={"relative"}
|
|
16
|
+
style={{ width: widthPercentage === 100 ? "100%" : `calc(${widthPercentage}% - 8px)` }}>
|
|
17
|
+
<ErrorBoundary>
|
|
18
|
+
{children}
|
|
19
|
+
</ErrorBoundary>
|
|
20
|
+
</div>
|
|
21
|
+
);
|
|
22
|
+
}
|