@webiny/app-headless-cms 5.27.0 → 5.28.0-beta.0
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/HeadlessCMS.js +33 -13
- package/HeadlessCMS.js.map +1 -1
- package/admin/components/ContentEntryForm/ContentEntryForm.js +61 -34
- package/admin/components/ContentEntryForm/ContentEntryForm.js.map +1 -1
- package/admin/components/ContentEntryForm/ContentEntryFormPreview.js +41 -18
- package/admin/components/ContentEntryForm/ContentEntryFormPreview.js.map +1 -1
- package/admin/components/ContentEntryForm/Fields.js +22 -9
- package/admin/components/ContentEntryForm/Fields.js.map +1 -1
- package/admin/components/ContentEntryForm/Label.js +23 -9
- package/admin/components/ContentEntryForm/Label.js.map +1 -1
- package/admin/components/ContentEntryForm/RenderFieldElement.js +31 -15
- package/admin/components/ContentEntryForm/RenderFieldElement.js.map +1 -1
- package/admin/components/ContentEntryForm/functions/createValidators.js +23 -8
- package/admin/components/ContentEntryForm/functions/createValidators.js.map +1 -1
- package/admin/components/ContentEntryForm/functions/getValue.js +11 -2
- package/admin/components/ContentEntryForm/functions/getValue.js.map +1 -1
- package/admin/components/ContentEntryForm/functions/setValue.js +16 -4
- package/admin/components/ContentEntryForm/functions/setValue.js.map +1 -1
- package/admin/components/ContentEntryForm/useBind.js +31 -27
- package/admin/components/ContentEntryForm/useBind.js.map +1 -1
- package/admin/components/ContentEntryForm/useContentEntryForm.js +77 -52
- package/admin/components/ContentEntryForm/useContentEntryForm.js.map +1 -1
- package/admin/components/ContentEntryForm/useRenderPlugins.js +14 -5
- package/admin/components/ContentEntryForm/useRenderPlugins.js.map +1 -1
- package/admin/components/ContentModelEditor/Context.js +73 -43
- package/admin/components/ContentModelEditor/Context.js.map +1 -1
- package/admin/components/ContentModelEditor/Editor.js +85 -50
- package/admin/components/ContentModelEditor/Editor.js.map +1 -1
- package/admin/components/ContentModelEditor/FieldsSidebar.js +37 -19
- package/admin/components/ContentModelEditor/FieldsSidebar.js.map +1 -1
- package/admin/components/ContentModelEditor/Header.js +24 -10
- package/admin/components/ContentModelEditor/Header.js.map +1 -1
- package/admin/components/ContentModelEditor/PreviewTab.js +36 -17
- package/admin/components/ContentModelEditor/PreviewTab.js.map +1 -1
- package/admin/components/ContentModelEditor/useContentModelEditor.js +15 -4
- package/admin/components/ContentModelEditor/useContentModelEditor.js.map +1 -1
- package/admin/components/DragPreview.js +27 -12
- package/admin/components/DragPreview.js.map +1 -1
- package/admin/components/Draggable.js +22 -8
- package/admin/components/Draggable.js.map +1 -1
- package/admin/components/DropZone/Center.js +26 -12
- package/admin/components/DropZone/Center.js.map +1 -1
- package/admin/components/DropZone/Horizontal.js +31 -17
- package/admin/components/DropZone/Horizontal.js.map +1 -1
- package/admin/components/DropZone/Vertical.js +29 -15
- package/admin/components/DropZone/Vertical.js.map +1 -1
- package/admin/components/DropZone/index.js +31 -4
- package/admin/components/DropZone/index.js.map +1 -1
- package/admin/components/Droppable.js +20 -6
- package/admin/components/Droppable.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/AppearanceTab.js +50 -27
- package/admin/components/FieldEditor/EditFieldDialog/AppearanceTab.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/GeneralTab.js +55 -36
- package/admin/components/FieldEditor/EditFieldDialog/GeneralTab.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/PredefinedValues.js +60 -21
- package/admin/components/FieldEditor/EditFieldDialog/PredefinedValues.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/ValidatorsTab.js +50 -32
- package/admin/components/FieldEditor/EditFieldDialog/ValidatorsTab.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/functions/getValue.js +13 -3
- package/admin/components/FieldEditor/EditFieldDialog/functions/getValue.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog/functions/setValue.js +16 -6
- package/admin/components/FieldEditor/EditFieldDialog/functions/setValue.js.map +1 -1
- package/admin/components/FieldEditor/EditFieldDialog.js +105 -69
- package/admin/components/FieldEditor/EditFieldDialog.js.map +1 -1
- package/admin/components/FieldEditor/Field.js +86 -51
- package/admin/components/FieldEditor/Field.js.map +1 -1
- package/admin/components/FieldEditor/FieldEditor.js +66 -40
- package/admin/components/FieldEditor/FieldEditor.js.map +1 -1
- package/admin/components/FieldEditor/FieldEditorContext.js +51 -27
- package/admin/components/FieldEditor/FieldEditorContext.js.map +1 -1
- package/admin/components/FieldEditor/Styled.js +24 -8
- package/admin/components/FieldEditor/Styled.js.map +1 -1
- package/admin/components/FieldEditor/index.js +21 -2
- package/admin/components/FieldEditor/index.js.map +1 -1
- package/admin/components/FieldEditor/useFieldEditor.js +13 -4
- package/admin/components/FieldEditor/useFieldEditor.js.map +1 -1
- package/admin/components/FieldEditor/utils/deleteField.js +19 -5
- package/admin/components/FieldEditor/utils/deleteField.js.map +1 -1
- package/admin/components/FieldEditor/utils/getFieldPosition.js +11 -2
- package/admin/components/FieldEditor/utils/getFieldPosition.js.map +1 -1
- package/admin/components/FieldEditor/utils/index.js +39 -4
- package/admin/components/FieldEditor/utils/index.js.map +1 -1
- package/admin/components/FieldEditor/utils/moveField.js +30 -20
- package/admin/components/FieldEditor/utils/moveField.js.map +1 -1
- package/admin/components/FieldEditor/utils/moveRow.js +19 -6
- package/admin/components/FieldEditor/utils/moveRow.js.map +1 -1
- package/admin/constants/statusLabels.js +21 -9
- package/admin/constants/statusLabels.js.map +1 -1
- package/admin/contexts/Cms/NetworkError.js +14 -4
- package/admin/contexts/Cms/NetworkError.js.map +1 -1
- package/admin/contexts/Cms/index.js +29 -11
- package/admin/contexts/Cms/index.js.map +1 -1
- package/admin/elements/ContentGroupMenuElement.js +27 -12
- package/admin/elements/ContentGroupMenuElement.js.map +1 -1
- package/admin/elements/ContentModelMenuElement.js +27 -12
- package/admin/elements/ContentModelMenuElement.js.map +1 -1
- package/admin/elements/NothingToShowElement.js +51 -30
- package/admin/elements/NothingToShowElement.js.map +1 -1
- package/admin/graphql/contentEntries.js +84 -40
- package/admin/graphql/contentEntries.js.map +1 -1
- package/admin/graphql/contentModels.js +20 -6
- package/admin/graphql/contentModels.js.map +1 -1
- package/admin/graphql/createFieldsList.js +19 -6
- package/admin/graphql/createFieldsList.js.map +1 -1
- package/admin/hooks/index.js +68 -6
- package/admin/hooks/index.js.map +1 -1
- package/admin/hooks/useApolloClient.js +13 -3
- package/admin/hooks/useApolloClient.js.map +1 -1
- package/admin/hooks/useCms.js +13 -4
- package/admin/hooks/useCms.js.map +1 -1
- package/admin/hooks/useLazyQuery.js +18 -6
- package/admin/hooks/useLazyQuery.js.map +1 -1
- package/admin/hooks/useMutation.js +18 -6
- package/admin/hooks/useMutation.js.map +1 -1
- package/admin/hooks/usePermission.js +39 -23
- package/admin/hooks/usePermission.js.map +1 -1
- package/admin/hooks/useQuery.js +18 -6
- package/admin/hooks/useQuery.js.map +1 -1
- package/admin/hooks/useQueryLocale.js +21 -7
- package/admin/hooks/useQueryLocale.js.map +1 -1
- package/admin/menus/CmsMenuLoader.js +32 -14
- package/admin/menus/CmsMenuLoader.js.map +1 -1
- package/admin/menus/ContentGroupsMenuItems.js +43 -24
- package/admin/menus/ContentGroupsMenuItems.js.map +1 -1
- package/admin/menus/GlobalSearchPlugins.js +31 -15
- package/admin/menus/GlobalSearchPlugins.js.map +1 -1
- package/admin/menus/NothingToShowElement.js +26 -11
- package/admin/menus/NothingToShowElement.js.map +1 -1
- package/admin/plugins/apiInformation/index.js +17 -5
- package/admin/plugins/apiInformation/index.js.map +1 -1
- package/admin/plugins/definitions/CmsEditorFieldValidatorFileTypePlugin.js +33 -21
- package/admin/plugins/definitions/CmsEditorFieldValidatorFileTypePlugin.js.map +1 -1
- package/admin/plugins/definitions/CmsFieldValidatorFileTypePlugin.js +33 -20
- package/admin/plugins/definitions/CmsFieldValidatorFileTypePlugin.js.map +1 -1
- package/admin/plugins/editor/defaultBar/BackButton.js +28 -11
- package/admin/plugins/editor/defaultBar/BackButton.js.map +1 -1
- package/admin/plugins/editor/defaultBar/CreateContentButton.js +39 -20
- package/admin/plugins/editor/defaultBar/CreateContentButton.js.map +1 -1
- package/admin/plugins/editor/defaultBar/Divider.js +14 -3
- package/admin/plugins/editor/defaultBar/Divider.js.map +1 -1
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettings.js +67 -39
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettings.js.map +1 -1
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettingsButton.js +29 -13
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettingsButton.js.map +1 -1
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettingsStyled.js +30 -10
- package/admin/plugins/editor/defaultBar/FormSettings/FormSettingsStyled.js.map +1 -1
- package/admin/plugins/editor/defaultBar/FormSettings/index.js +15 -1
- package/admin/plugins/editor/defaultBar/FormSettings/index.js.map +1 -1
- package/admin/plugins/editor/defaultBar/Name/Name.js +47 -30
- package/admin/plugins/editor/defaultBar/Name/Name.js.map +1 -1
- package/admin/plugins/editor/defaultBar/Name/NameStyled.js +22 -7
- package/admin/plugins/editor/defaultBar/Name/NameStyled.js.map +1 -1
- package/admin/plugins/editor/defaultBar/Name/index.js +13 -1
- package/admin/plugins/editor/defaultBar/Name/index.js.map +1 -1
- package/admin/plugins/editor/defaultBar/SaveContentModelButton.js +40 -20
- package/admin/plugins/editor/defaultBar/SaveContentModelButton.js.map +1 -1
- package/admin/plugins/editor/defaultBar/index.js +32 -15
- package/admin/plugins/editor/defaultBar/index.js.map +1 -1
- package/admin/plugins/editor/formSettings/components/GeneralSettings.js +33 -19
- package/admin/plugins/editor/formSettings/components/GeneralSettings.js.map +1 -1
- package/admin/plugins/editor/formSettings/components/GroupSelect.js +27 -10
- package/admin/plugins/editor/formSettings/components/GroupSelect.js.map +1 -1
- package/admin/plugins/editor/formSettings/index.js +21 -6
- package/admin/plugins/editor/formSettings/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/Accordion.js +43 -25
- package/admin/plugins/fieldRenderers/Accordion.js.map +1 -1
- package/admin/plugins/fieldRenderers/DynamicSection.js +42 -24
- package/admin/plugins/fieldRenderers/DynamicSection.js.map +1 -1
- package/admin/plugins/fieldRenderers/boolean/booleanSwitch.js +27 -12
- package/admin/plugins/fieldRenderers/boolean/booleanSwitch.js.map +1 -1
- package/admin/plugins/fieldRenderers/boolean/index.js +13 -2
- package/admin/plugins/fieldRenderers/boolean/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/checkboxes.js +30 -15
- package/admin/plugins/fieldRenderers/checkboxes.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/DateOnly.js +34 -15
- package/admin/plugins/fieldRenderers/dateTime/DateOnly.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/DateTimeWithTimezone.js +59 -36
- package/admin/plugins/fieldRenderers/dateTime/DateTimeWithTimezone.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/DateTimeWithoutTimezone.js +50 -30
- package/admin/plugins/fieldRenderers/dateTime/DateTimeWithoutTimezone.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/Input.js +24 -8
- package/admin/plugins/fieldRenderers/dateTime/Input.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/Select.js +18 -5
- package/admin/plugins/fieldRenderers/dateTime/Select.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/Time.js +34 -15
- package/admin/plugins/fieldRenderers/dateTime/Time.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/dateTimeField.js +36 -18
- package/admin/plugins/fieldRenderers/dateTime/dateTimeField.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/dateTimeFields.js +47 -26
- package/admin/plugins/fieldRenderers/dateTime/dateTimeFields.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/index.js +15 -3
- package/admin/plugins/fieldRenderers/dateTime/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/dateTime/utils.js +48 -17
- package/admin/plugins/fieldRenderers/dateTime/utils.js.map +1 -1
- package/admin/plugins/fieldRenderers/file/File.js +34 -16
- package/admin/plugins/fieldRenderers/file/File.js.map +1 -1
- package/admin/plugins/fieldRenderers/file/fileField.js +30 -14
- package/admin/plugins/fieldRenderers/file/fileField.js.map +1 -1
- package/admin/plugins/fieldRenderers/file/fileFields.js +54 -33
- package/admin/plugins/fieldRenderers/file/fileFields.js.map +1 -1
- package/admin/plugins/fieldRenderers/file/index.js +15 -3
- package/admin/plugins/fieldRenderers/file/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/file/utils.js +27 -10
- package/admin/plugins/fieldRenderers/file/utils.js.map +1 -1
- package/admin/plugins/fieldRenderers/longText/index.js +15 -3
- package/admin/plugins/fieldRenderers/longText/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/longText/longText.js +27 -12
- package/admin/plugins/fieldRenderers/longText/longText.js.map +1 -1
- package/admin/plugins/fieldRenderers/longText/longTexts.js +33 -16
- package/admin/plugins/fieldRenderers/longText/longTexts.js.map +1 -1
- package/admin/plugins/fieldRenderers/number/index.js +15 -3
- package/admin/plugins/fieldRenderers/number/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/number/numberInput.js +27 -12
- package/admin/plugins/fieldRenderers/number/numberInput.js.map +1 -1
- package/admin/plugins/fieldRenderers/number/numberInputs.js +33 -16
- package/admin/plugins/fieldRenderers/number/numberInputs.js.map +1 -1
- package/admin/plugins/fieldRenderers/object/StyledComponents.js +17 -5
- package/admin/plugins/fieldRenderers/object/StyledComponents.js.map +1 -1
- package/admin/plugins/fieldRenderers/object/index.js +15 -3
- package/admin/plugins/fieldRenderers/object/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/object/multipleObjects.js +51 -29
- package/admin/plugins/fieldRenderers/object/multipleObjects.js.map +1 -1
- package/admin/plugins/fieldRenderers/object/singleObject.js +35 -17
- package/admin/plugins/fieldRenderers/object/singleObject.js.map +1 -1
- package/admin/plugins/fieldRenderers/radioButtons.js +29 -14
- package/admin/plugins/fieldRenderers/radioButtons.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/ContentEntriesAutocomplete.js +61 -36
- package/admin/plugins/fieldRenderers/ref/components/ContentEntriesAutocomplete.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/ContentEntriesMultiAutoComplete.js +58 -35
- package/admin/plugins/fieldRenderers/ref/components/ContentEntriesMultiAutoComplete.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/EntryStatus.js +37 -18
- package/admin/plugins/fieldRenderers/ref/components/EntryStatus.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/MissingEntryHelpText.js +38 -18
- package/admin/plugins/fieldRenderers/ref/components/MissingEntryHelpText.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/NewRefEntryFormDialog.js +87 -53
- package/admin/plugins/fieldRenderers/ref/components/NewRefEntryFormDialog.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/createEntryUrl.js +15 -3
- package/admin/plugins/fieldRenderers/ref/components/createEntryUrl.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/graphql.js +18 -5
- package/admin/plugins/fieldRenderers/ref/components/graphql.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/helpers.js +23 -5
- package/admin/plugins/fieldRenderers/ref/components/helpers.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/renderItem.js +42 -19
- package/admin/plugins/fieldRenderers/ref/components/renderItem.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/types.js +5 -1
- package/admin/plugins/fieldRenderers/ref/components/types.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/useReference.js +59 -41
- package/admin/plugins/fieldRenderers/ref/components/useReference.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/components/useReferences.js +60 -41
- package/admin/plugins/fieldRenderers/ref/components/useReferences.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/hooks/useNewRefEntry.js +27 -10
- package/admin/plugins/fieldRenderers/ref/hooks/useNewRefEntry.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/hooks/useNewRefEntryDialog.js +30 -10
- package/admin/plugins/fieldRenderers/ref/hooks/useNewRefEntryDialog.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/index.js +15 -3
- package/admin/plugins/fieldRenderers/ref/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/refInput.js +26 -11
- package/admin/plugins/fieldRenderers/ref/refInput.js.map +1 -1
- package/admin/plugins/fieldRenderers/ref/refInputs.js +25 -11
- package/admin/plugins/fieldRenderers/ref/refInputs.js.map +1 -1
- package/admin/plugins/fieldRenderers/richText/index.js +15 -3
- package/admin/plugins/fieldRenderers/richText/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/richText/richTextInput.js +32 -15
- package/admin/plugins/fieldRenderers/richText/richTextInput.js.map +1 -1
- package/admin/plugins/fieldRenderers/richText/richTextInputs.js +43 -22
- package/admin/plugins/fieldRenderers/richText/richTextInputs.js.map +1 -1
- package/admin/plugins/fieldRenderers/select.js +26 -12
- package/admin/plugins/fieldRenderers/select.js.map +1 -1
- package/admin/plugins/fieldRenderers/text/index.js +15 -3
- package/admin/plugins/fieldRenderers/text/index.js.map +1 -1
- package/admin/plugins/fieldRenderers/text/textInput.js +27 -12
- package/admin/plugins/fieldRenderers/text/textInput.js.map +1 -1
- package/admin/plugins/fieldRenderers/text/textInputs.js +33 -16
- package/admin/plugins/fieldRenderers/text/textInputs.js.map +1 -1
- package/admin/plugins/fieldValidators/date/availableValidators.js +11 -2
- package/admin/plugins/fieldValidators/date/availableValidators.js.map +1 -1
- package/admin/plugins/fieldValidators/date/createDateInputField.js +27 -11
- package/admin/plugins/fieldValidators/date/createDateInputField.js.map +1 -1
- package/admin/plugins/fieldValidators/dateGte.js +32 -15
- package/admin/plugins/fieldValidators/dateGte.js.map +1 -1
- package/admin/plugins/fieldValidators/dateLte.js +32 -15
- package/admin/plugins/fieldValidators/dateLte.js.map +1 -1
- package/admin/plugins/fieldValidators/gte.js +23 -9
- package/admin/plugins/fieldValidators/gte.js.map +1 -1
- package/admin/plugins/fieldValidators/in.js +23 -9
- package/admin/plugins/fieldValidators/in.js.map +1 -1
- package/admin/plugins/fieldValidators/lte.js +23 -9
- package/admin/plugins/fieldValidators/lte.js.map +1 -1
- package/admin/plugins/fieldValidators/maxLength.js +23 -9
- package/admin/plugins/fieldValidators/maxLength.js.map +1 -1
- package/admin/plugins/fieldValidators/minLength.js +23 -9
- package/admin/plugins/fieldValidators/minLength.js.map +1 -1
- package/admin/plugins/fieldValidators/pattern.js +40 -22
- package/admin/plugins/fieldValidators/pattern.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/email.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/email.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/lowerCase.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/lowerCase.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/lowerCaseSpace.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/lowerCaseSpace.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/upperCase.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/upperCase.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/upperCaseSpace.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/upperCaseSpace.js.map +1 -1
- package/admin/plugins/fieldValidators/patternPlugins/url.js +8 -1
- package/admin/plugins/fieldValidators/patternPlugins/url.js.map +1 -1
- package/admin/plugins/fieldValidators/required.js +8 -1
- package/admin/plugins/fieldValidators/required.js.map +1 -1
- package/admin/plugins/fieldValidators/unique.js +11 -2
- package/admin/plugins/fieldValidators/unique.js.map +1 -1
- package/admin/plugins/fields/PredefinedValuesDynamicFieldset.d.ts +1 -2
- package/admin/plugins/fields/PredefinedValuesDynamicFieldset.js +72 -46
- package/admin/plugins/fields/PredefinedValuesDynamicFieldset.js.map +1 -1
- package/admin/plugins/fields/boolean.js +34 -18
- package/admin/plugins/fields/boolean.js.map +1 -1
- package/admin/plugins/fields/dateTime.js +60 -44
- package/admin/plugins/fields/dateTime.js.map +1 -1
- package/admin/plugins/fields/file.js +33 -17
- package/admin/plugins/fields/file.js.map +1 -1
- package/admin/plugins/fields/longText.js +33 -17
- package/admin/plugins/fields/longText.js.map +1 -1
- package/admin/plugins/fields/number.js +39 -22
- package/admin/plugins/fields/number.js.map +1 -1
- package/admin/plugins/fields/object/ObjectFields.js +28 -11
- package/admin/plugins/fields/object/ObjectFields.js.map +1 -1
- package/admin/plugins/fields/object.js +30 -14
- package/admin/plugins/fields/object.js.map +1 -1
- package/admin/plugins/fields/ref.js +60 -34
- package/admin/plugins/fields/ref.js.map +1 -1
- package/admin/plugins/fields/richText.js +33 -17
- package/admin/plugins/fields/richText.js.map +1 -1
- package/admin/plugins/fields/text.js +37 -20
- package/admin/plugins/fields/text.js.map +1 -1
- package/admin/plugins/getObjectId.js +8 -1
- package/admin/plugins/getObjectId.js.map +1 -1
- package/admin/plugins/icons.js +25 -10
- package/admin/plugins/icons.js.map +1 -1
- package/admin/plugins/index.d.ts +1 -1
- package/admin/plugins/index.js +32 -12
- package/admin/plugins/index.js.map +1 -1
- package/admin/plugins/install.js +55 -30
- package/admin/plugins/install.js.map +1 -1
- package/admin/plugins/permissionRenderer/CmsPermissions.js +74 -50
- package/admin/plugins/permissionRenderer/CmsPermissions.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/ContentEntryPermission.js +70 -46
- package/admin/plugins/permissionRenderer/components/ContentEntryPermission.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/ContentModelGroupPermission.js +54 -34
- package/admin/plugins/permissionRenderer/components/ContentModelGroupPermission.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/ContentModelList.js +38 -20
- package/admin/plugins/permissionRenderer/components/ContentModelList.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/ContentModelPermission.js +71 -46
- package/admin/plugins/permissionRenderer/components/ContentModelPermission.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/PermissionRendererWrapper.js +27 -12
- package/admin/plugins/permissionRenderer/components/PermissionRendererWrapper.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/PermissionSelector.js +44 -23
- package/admin/plugins/permissionRenderer/components/PermissionSelector.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/StyledComponents.js +14 -3
- package/admin/plugins/permissionRenderer/components/StyledComponents.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/types.js +5 -1
- package/admin/plugins/permissionRenderer/components/types.js.map +1 -1
- package/admin/plugins/permissionRenderer/components/useCmsData.js +43 -22
- package/admin/plugins/permissionRenderer/components/useCmsData.js.map +1 -1
- package/admin/plugins/permissionRenderer/index.js +22 -8
- package/admin/plugins/permissionRenderer/index.js.map +1 -1
- package/admin/plugins/routes.js +66 -37
- package/admin/plugins/routes.js.map +1 -1
- package/admin/plugins/transformers/dateTransformer.js +24 -11
- package/admin/plugins/transformers/dateTransformer.js.map +1 -1
- package/admin/plugins/transformers/index.js +18 -5
- package/admin/plugins/transformers/index.js.map +1 -1
- package/admin/plugins/transformers/numberTransformer.js +11 -2
- package/admin/plugins/transformers/numberTransformer.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/UpgradeItemsInfo.js +19 -7
- package/admin/plugins/upgrades/5.19.0/UpgradeItemsInfo.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/createCmsApolloClient.js +33 -15
- package/admin/plugins/upgrades/5.19.0/createCmsApolloClient.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/createListEntriesQuery.js +23 -9
- package/admin/plugins/upgrades/5.19.0/createListEntriesQuery.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/createListModelsQuery.js +17 -5
- package/admin/plugins/upgrades/5.19.0/createListModelsQuery.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/createRepublishMutation.js +20 -7
- package/admin/plugins/upgrades/5.19.0/createRepublishMutation.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/createUpgradeMutation.js +17 -5
- package/admin/plugins/upgrades/5.19.0/createUpgradeMutation.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/fetchModelEntries.js +27 -13
- package/admin/plugins/upgrades/5.19.0/fetchModelEntries.js.map +1 -1
- package/admin/plugins/upgrades/5.19.0/types.js +5 -1
- package/admin/plugins/upgrades/5.19.0/types.js.map +1 -1
- package/admin/plugins/upgrades/v5.0.0.js +58 -33
- package/admin/plugins/upgrades/v5.0.0.js.map +1 -1
- package/admin/plugins/upgrades/v5.19.0.js +118 -82
- package/admin/plugins/upgrades/v5.19.0.js.map +1 -1
- package/admin/plugins/upgrades/v5.5.0.js +58 -33
- package/admin/plugins/upgrades/v5.5.0.js.map +1 -1
- package/admin/plugins/upgrades/v5.8.0.js +58 -33
- package/admin/plugins/upgrades/v5.8.0.js.map +1 -1
- package/admin/plugins/validators/dateGte.js +23 -9
- package/admin/plugins/validators/dateGte.js.map +1 -1
- package/admin/plugins/validators/dateLte.js +23 -9
- package/admin/plugins/validators/dateLte.js.map +1 -1
- package/admin/plugins/validators/gte.js +20 -7
- package/admin/plugins/validators/gte.js.map +1 -1
- package/admin/plugins/validators/in.js +20 -7
- package/admin/plugins/validators/in.js.map +1 -1
- package/admin/plugins/validators/lte.js +20 -7
- package/admin/plugins/validators/lte.js.map +1 -1
- package/admin/plugins/validators/maxLength.js +20 -7
- package/admin/plugins/validators/maxLength.js.map +1 -1
- package/admin/plugins/validators/minLength.js +20 -7
- package/admin/plugins/validators/minLength.js.map +1 -1
- package/admin/plugins/validators/pattern.js +20 -7
- package/admin/plugins/validators/pattern.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/email.js +8 -1
- package/admin/plugins/validators/patternPlugins/email.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/lowerCase.js +8 -1
- package/admin/plugins/validators/patternPlugins/lowerCase.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/lowerCaseSpace.js +8 -1
- package/admin/plugins/validators/patternPlugins/lowerCaseSpace.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/upperCase.js +8 -1
- package/admin/plugins/validators/patternPlugins/upperCase.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/upperCaseSpace.js +8 -1
- package/admin/plugins/validators/patternPlugins/upperCaseSpace.js.map +1 -1
- package/admin/plugins/validators/patternPlugins/url.js +8 -1
- package/admin/plugins/validators/patternPlugins/url.js.map +1 -1
- package/admin/plugins/validators/required.js +12 -3
- package/admin/plugins/validators/required.js.map +1 -1
- package/admin/plugins/validators/timeGte.js +22 -8
- package/admin/plugins/validators/timeGte.js.map +1 -1
- package/admin/plugins/validators/timeLte.js +22 -8
- package/admin/plugins/validators/timeLte.js.map +1 -1
- package/admin/plugins/validators/unique.js +18 -6
- package/admin/plugins/validators/unique.js.map +1 -1
- package/admin/plugins/welcomeScreenWidget.js +23 -9
- package/admin/plugins/welcomeScreenWidget.js.map +1 -1
- package/admin/views/contentEntries/ContentEntries.js +57 -31
- package/admin/views/contentEntries/ContentEntries.js.map +1 -1
- package/admin/views/contentEntries/ContentEntriesContext.js +43 -21
- package/admin/views/contentEntries/ContentEntriesContext.js.map +1 -1
- package/admin/views/contentEntries/ContentEntriesList.js +102 -75
- package/admin/views/contentEntries/ContentEntriesList.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/ContentEntryContext.js +72 -41
- package/admin/views/contentEntries/ContentEntry/ContentEntryContext.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/RevisionListItem.js +95 -67
- package/admin/views/contentEntries/ContentEntry/RevisionListItem.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/RevisionsList.js +38 -19
- package/admin/views/contentEntries/ContentEntry/RevisionsList.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/cache.js +65 -31
- package/admin/views/contentEntries/ContentEntry/cache.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/Header.js +31 -16
- package/admin/views/contentEntries/ContentEntry/header/Header.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/contentFormOptionsMenu/ContentFormOptionsMenu.js +90 -55
- package/admin/views/contentEntries/ContentEntry/header/contentFormOptionsMenu/ContentFormOptionsMenu.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/index.js +33 -14
- package/admin/views/contentEntries/ContentEntry/header/index.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/requestChanges/RequestChanges.js +47 -26
- package/admin/views/contentEntries/ContentEntry/header/requestChanges/RequestChanges.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/requestReview/RequestReview.js +50 -27
- package/admin/views/contentEntries/ContentEntry/header/requestReview/RequestReview.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/revisionSelector/RevisionSelector.js +47 -26
- package/admin/views/contentEntries/ContentEntry/header/revisionSelector/RevisionSelector.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/saveAndPublishContent/SaveAndPublishContent.js +45 -24
- package/admin/views/contentEntries/ContentEntry/header/saveAndPublishContent/SaveAndPublishContent.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/header/saveContent/SaveContent.js +27 -12
- package/admin/views/contentEntries/ContentEntry/header/saveContent/SaveContent.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/prepareFormData.js +19 -7
- package/admin/views/contentEntries/ContentEntry/prepareFormData.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry/useRevision.js +57 -36
- package/admin/views/contentEntries/ContentEntry/useRevision.js.map +1 -1
- package/admin/views/contentEntries/ContentEntry.js +62 -35
- package/admin/views/contentEntries/ContentEntry.js.map +1 -1
- package/admin/views/contentEntries/experiment/ContentEntriesModule.js +42 -25
- package/admin/views/contentEntries/experiment/ContentEntriesModule.js.map +1 -1
- package/admin/views/contentEntries/experiment/ContentEntriesRenderer.js +29 -9
- package/admin/views/contentEntries/experiment/ContentEntriesRenderer.js.map +1 -1
- package/admin/views/contentEntries/experiment/ContentEntriesViewConfig.js +51 -29
- package/admin/views/contentEntries/experiment/ContentEntriesViewConfig.js.map +1 -1
- package/admin/views/contentEntries/experiment/Property.js +74 -58
- package/admin/views/contentEntries/experiment/Property.js.map +1 -1
- package/admin/views/contentEntries/hooks/useContentEntries.js +13 -4
- package/admin/views/contentEntries/hooks/useContentEntries.js.map +1 -1
- package/admin/views/contentEntries/hooks/useContentEntriesList.js +59 -39
- package/admin/views/contentEntries/hooks/useContentEntriesList.js.map +1 -1
- package/admin/views/contentEntries/hooks/useContentEntry.js +13 -4
- package/admin/views/contentEntries/hooks/useContentEntry.js.map +1 -1
- package/admin/views/contentModelGroups/ContentModelGroups.js +28 -12
- package/admin/views/contentModelGroups/ContentModelGroups.js.map +1 -1
- package/admin/views/contentModelGroups/ContentModelGroupsDataList.js +114 -77
- package/admin/views/contentModelGroups/ContentModelGroupsDataList.js.map +1 -1
- package/admin/views/contentModelGroups/ContentModelGroupsForm.js +117 -78
- package/admin/views/contentModelGroups/ContentModelGroupsForm.js.map +1 -1
- package/admin/views/contentModelGroups/DelayedOnChange.js +49 -48
- package/admin/views/contentModelGroups/DelayedOnChange.js.map +1 -1
- package/admin/views/contentModelGroups/IconPicker.js +56 -33
- package/admin/views/contentModelGroups/IconPicker.js.map +1 -1
- package/admin/views/contentModelGroups/graphql.js +22 -7
- package/admin/views/contentModelGroups/graphql.js.map +1 -1
- package/admin/views/contentModels/CloneContentModelDialog.js +104 -71
- package/admin/views/contentModels/CloneContentModelDialog.js.map +1 -1
- package/admin/views/contentModels/ContentModelEditor.js +30 -14
- package/admin/views/contentModels/ContentModelEditor.js.map +1 -1
- package/admin/views/contentModels/ContentModels.js +49 -30
- package/admin/views/contentModels/ContentModels.js.map +1 -1
- package/admin/views/contentModels/ContentModelsDataList.js +144 -108
- package/admin/views/contentModels/ContentModelsDataList.js.map +1 -1
- package/admin/views/contentModels/NewContentModelDialog.js +107 -70
- package/admin/views/contentModels/NewContentModelDialog.js.map +1 -1
- package/admin/views/contentModels/cache.js +41 -19
- package/admin/views/contentModels/cache.js.map +1 -1
- package/admin/views/contentModels/types.js +5 -1
- package/admin/views/contentModels/types.js.map +1 -1
- package/admin/views/utils.js +16 -4
- package/admin/views/utils.js.map +1 -1
- package/admin/viewsGraphql.js +22 -7
- package/admin/viewsGraphql.js.map +1 -1
- package/index.js +30 -11
- package/index.js.map +1 -1
- package/package.json +22 -22
- package/types.d.ts +3 -3
- package/types.js +5 -1
- package/types.js.map +1 -1
|
@@ -1,35 +1,73 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.default = void 0;
|
|
11
|
+
|
|
12
|
+
var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
|
|
13
|
+
|
|
14
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
|
+
|
|
16
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
17
|
+
|
|
18
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
19
|
+
|
|
20
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
21
|
+
|
|
22
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
23
|
+
|
|
24
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
25
|
+
|
|
26
|
+
var _styled = _interopRequireDefault(require("@emotion/styled"));
|
|
27
|
+
|
|
28
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
29
|
+
|
|
30
|
+
var _get = _interopRequireDefault(require("lodash/get"));
|
|
31
|
+
|
|
32
|
+
var _form = require("@webiny/form");
|
|
33
|
+
|
|
34
|
+
var _Grid = require("@webiny/ui/Grid");
|
|
35
|
+
|
|
36
|
+
var _Input = require("@webiny/ui/Input");
|
|
37
|
+
|
|
38
|
+
var _Button = require("@webiny/ui/Button");
|
|
39
|
+
|
|
40
|
+
var _Progress = require("@webiny/ui/Progress");
|
|
41
|
+
|
|
42
|
+
var _i18n = require("@webiny/app/i18n");
|
|
43
|
+
|
|
44
|
+
var _validation = require("@webiny/validation");
|
|
45
|
+
|
|
46
|
+
var _SimpleForm = require("@webiny/app-admin/components/SimpleForm");
|
|
47
|
+
|
|
48
|
+
var _IconPicker = _interopRequireDefault(require("./IconPicker"));
|
|
49
|
+
|
|
50
|
+
var _reactRouter = require("@webiny/react-router");
|
|
51
|
+
|
|
52
|
+
var _useSnackbar2 = require("@webiny/app-admin/hooks/useSnackbar");
|
|
53
|
+
|
|
54
|
+
var _EmptyView = _interopRequireDefault(require("@webiny/app-admin/components/EmptyView"));
|
|
55
|
+
|
|
56
|
+
var _add18px = require("@webiny/app-admin/assets/icons/add-18px.svg");
|
|
57
|
+
|
|
58
|
+
var _hooks = require("../../hooks");
|
|
59
|
+
|
|
60
|
+
var GQL = _interopRequireWildcard(require("./graphql"));
|
|
61
|
+
|
|
62
|
+
var _usePermission2 = _interopRequireDefault(require("../../hooks/usePermission"));
|
|
63
|
+
|
|
64
|
+
var _Tooltip = require("@webiny/ui/Tooltip");
|
|
6
65
|
|
|
7
66
|
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
|
|
8
67
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
import isEmpty from "lodash/isEmpty";
|
|
13
|
-
import get from "lodash/get";
|
|
14
|
-
import { Form } from "@webiny/form";
|
|
15
|
-
import { Grid, Cell } from "@webiny/ui/Grid";
|
|
16
|
-
import { Input } from "@webiny/ui/Input";
|
|
17
|
-
import { ButtonDefault, ButtonIcon, ButtonPrimary } from "@webiny/ui/Button";
|
|
18
|
-
import { CircularProgress } from "@webiny/ui/Progress";
|
|
19
|
-
import { i18n } from "@webiny/app/i18n";
|
|
20
|
-
import { validation } from "@webiny/validation";
|
|
21
|
-
import { SimpleFormHeader, SimpleForm, SimpleFormFooter, SimpleFormContent } from "@webiny/app-admin/components/SimpleForm";
|
|
22
|
-
import IconPicker from "./IconPicker";
|
|
23
|
-
import { useRouter } from "@webiny/react-router";
|
|
24
|
-
import { useSnackbar } from "@webiny/app-admin/hooks/useSnackbar";
|
|
25
|
-
import EmptyView from "@webiny/app-admin/components/EmptyView";
|
|
26
|
-
import { ReactComponent as AddIcon } from "@webiny/app-admin/assets/icons/add-18px.svg";
|
|
27
|
-
import { useMutation, useQuery } from "../../hooks";
|
|
28
|
-
import * as GQL from "./graphql";
|
|
29
|
-
import usePermission from "../../hooks/usePermission";
|
|
30
|
-
import { Tooltip } from "@webiny/ui/Tooltip";
|
|
31
|
-
var t = i18n.ns("app-headless-cms/admin/content-model-groups/form");
|
|
32
|
-
var ButtonWrapper = /*#__PURE__*/styled("div", {
|
|
68
|
+
var t = _i18n.i18n.ns("app-headless-cms/admin/content-model-groups/form");
|
|
69
|
+
|
|
70
|
+
var ButtonWrapper = /*#__PURE__*/(0, _styled.default)("div", {
|
|
33
71
|
target: "e7xbi20",
|
|
34
72
|
label: "ButtonWrapper"
|
|
35
73
|
})({
|
|
@@ -40,19 +78,19 @@ var ButtonWrapper = /*#__PURE__*/styled("div", {
|
|
|
40
78
|
var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
41
79
|
var canCreate = _ref.canCreate;
|
|
42
80
|
|
|
43
|
-
var _useRouter = useRouter(),
|
|
81
|
+
var _useRouter = (0, _reactRouter.useRouter)(),
|
|
44
82
|
location = _useRouter.location,
|
|
45
83
|
history = _useRouter.history;
|
|
46
84
|
|
|
47
|
-
var _useSnackbar = useSnackbar(),
|
|
85
|
+
var _useSnackbar = (0, _useSnackbar2.useSnackbar)(),
|
|
48
86
|
showSnackbar = _useSnackbar.showSnackbar;
|
|
49
87
|
|
|
50
|
-
var _usePermission =
|
|
88
|
+
var _usePermission = (0, _usePermission2.default)(),
|
|
51
89
|
canEdit = _usePermission.canEdit;
|
|
52
90
|
|
|
53
91
|
var newEntry = new URLSearchParams(location.search).get("new") === "true";
|
|
54
92
|
var id = new URLSearchParams(location.search).get("id");
|
|
55
|
-
var getQuery = useQuery(GQL.GET_CONTENT_MODEL_GROUP, {
|
|
93
|
+
var getQuery = (0, _hooks.useQuery)(GQL.GET_CONTENT_MODEL_GROUP, {
|
|
56
94
|
variables: {
|
|
57
95
|
id: id
|
|
58
96
|
},
|
|
@@ -71,7 +109,7 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
71
109
|
}
|
|
72
110
|
}); // Create a new group and update list cache
|
|
73
111
|
|
|
74
|
-
var _useMutation = useMutation(GQL.CREATE_CONTENT_MODEL_GROUP, {
|
|
112
|
+
var _useMutation = (0, _hooks.useMutation)(GQL.CREATE_CONTENT_MODEL_GROUP, {
|
|
75
113
|
update: function update(cache, _ref2) {
|
|
76
114
|
var data = _ref2.data;
|
|
77
115
|
|
|
@@ -89,28 +127,28 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
89
127
|
}
|
|
90
128
|
|
|
91
129
|
var listContentModelGroups = result.listContentModelGroups;
|
|
92
|
-
cache.writeQuery(
|
|
130
|
+
cache.writeQuery((0, _objectSpread2.default)((0, _objectSpread2.default)({}, gqlParams), {}, {
|
|
93
131
|
data: {
|
|
94
|
-
listContentModelGroups:
|
|
95
|
-
data: [data.contentModelGroup.data].concat(
|
|
132
|
+
listContentModelGroups: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, listContentModelGroups), {}, {
|
|
133
|
+
data: [data.contentModelGroup.data].concat((0, _toConsumableArray2.default)(listContentModelGroups.data))
|
|
96
134
|
})
|
|
97
135
|
}
|
|
98
136
|
}));
|
|
99
137
|
}
|
|
100
138
|
}),
|
|
101
|
-
_useMutation2 =
|
|
139
|
+
_useMutation2 = (0, _slicedToArray2.default)(_useMutation, 2),
|
|
102
140
|
create = _useMutation2[0],
|
|
103
141
|
createMutation = _useMutation2[1];
|
|
104
142
|
|
|
105
|
-
var _useMutation3 = useMutation(GQL.UPDATE_CONTENT_MODEL_GROUP),
|
|
106
|
-
_useMutation4 =
|
|
143
|
+
var _useMutation3 = (0, _hooks.useMutation)(GQL.UPDATE_CONTENT_MODEL_GROUP),
|
|
144
|
+
_useMutation4 = (0, _slicedToArray2.default)(_useMutation3, 2),
|
|
107
145
|
update = _useMutation4[0],
|
|
108
146
|
updateMutation = _useMutation4[1];
|
|
109
147
|
|
|
110
148
|
var loading = [getQuery, createMutation, updateMutation].find(function (item) {
|
|
111
149
|
return item.loading;
|
|
112
150
|
});
|
|
113
|
-
var createOperation = useCallback(function (group) {
|
|
151
|
+
var createOperation = (0, _react.useCallback)(function (group) {
|
|
114
152
|
if (!group.id) {
|
|
115
153
|
return create({
|
|
116
154
|
variables: {
|
|
@@ -134,11 +172,11 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
134
172
|
}
|
|
135
173
|
});
|
|
136
174
|
}, [create, update]);
|
|
137
|
-
var onSubmit = useCallback( /*#__PURE__*/function () {
|
|
138
|
-
var _ref3 =
|
|
175
|
+
var onSubmit = (0, _react.useCallback)( /*#__PURE__*/function () {
|
|
176
|
+
var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(group) {
|
|
139
177
|
var response, _response$data$conten, data, error;
|
|
140
178
|
|
|
141
|
-
return
|
|
179
|
+
return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
|
|
142
180
|
while (1) {
|
|
143
181
|
switch (_context.prev = _context.next) {
|
|
144
182
|
case 0:
|
|
@@ -175,7 +213,7 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
175
213
|
history.push("/cms/content-model-groups?id=".concat(data.id));
|
|
176
214
|
}
|
|
177
215
|
|
|
178
|
-
showSnackbar(t(_templateObject || (_templateObject =
|
|
216
|
+
showSnackbar(t(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["Content model group saved successfully!"]))));
|
|
179
217
|
|
|
180
218
|
case 12:
|
|
181
219
|
case "end":
|
|
@@ -189,26 +227,26 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
189
227
|
return _ref3.apply(this, arguments);
|
|
190
228
|
};
|
|
191
229
|
}(), [id]);
|
|
192
|
-
var data = getQuery.loading ? null :
|
|
193
|
-
var showEmptyView = !newEntry && !loading &&
|
|
230
|
+
var data = getQuery.loading ? null : (0, _get.default)(getQuery, "data.contentModelGroup.data", null);
|
|
231
|
+
var showEmptyView = !newEntry && !loading && (0, _isEmpty.default)(data); // Render "No content selected" view.
|
|
194
232
|
|
|
195
233
|
if (showEmptyView) {
|
|
196
|
-
return /*#__PURE__*/
|
|
197
|
-
title: t(_templateObject2 || (_templateObject2 =
|
|
234
|
+
return /*#__PURE__*/_react.default.createElement(_EmptyView.default, {
|
|
235
|
+
title: t(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["Click on the left side list to display group details {message}"])))({
|
|
198
236
|
message: canCreate ? "or create a..." : ""
|
|
199
237
|
}),
|
|
200
|
-
action: canCreate ? /*#__PURE__*/
|
|
238
|
+
action: canCreate ? /*#__PURE__*/_react.default.createElement(_Button.ButtonDefault, {
|
|
201
239
|
"data-testid": "new-record-button",
|
|
202
240
|
onClick: function onClick() {
|
|
203
241
|
return history.push("/cms/content-model-groups?new=true");
|
|
204
242
|
}
|
|
205
|
-
}, /*#__PURE__*/
|
|
206
|
-
icon: /*#__PURE__*/
|
|
207
|
-
}), " ", t(_templateObject3 || (_templateObject3 =
|
|
243
|
+
}, /*#__PURE__*/_react.default.createElement(_Button.ButtonIcon, {
|
|
244
|
+
icon: /*#__PURE__*/_react.default.createElement(_add18px.ReactComponent, null)
|
|
245
|
+
}), " ", t(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2.default)(["New Group"])))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)
|
|
208
246
|
});
|
|
209
247
|
}
|
|
210
248
|
|
|
211
|
-
return /*#__PURE__*/
|
|
249
|
+
return /*#__PURE__*/_react.default.createElement(_form.Form, {
|
|
212
250
|
onSubmit: onSubmit,
|
|
213
251
|
data: data || {
|
|
214
252
|
icon: "fas/star"
|
|
@@ -217,47 +255,48 @@ var ContentModelGroupsForm = function ContentModelGroupsForm(_ref) {
|
|
|
217
255
|
var data = _ref4.data,
|
|
218
256
|
form = _ref4.form,
|
|
219
257
|
Bind = _ref4.Bind;
|
|
220
|
-
return /*#__PURE__*/
|
|
258
|
+
return /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleForm, {
|
|
221
259
|
"data-testid": "pb-content-model-groups-form"
|
|
222
|
-
}, /*#__PURE__*/
|
|
223
|
-
title: data.name ? data.name : t(_templateObject4 || (_templateObject4 =
|
|
224
|
-
}), loading && /*#__PURE__*/
|
|
260
|
+
}, /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleFormHeader, {
|
|
261
|
+
title: data.name ? data.name : t(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2.default)(["New content model group"])))
|
|
262
|
+
}), loading && /*#__PURE__*/_react.default.createElement(_Progress.CircularProgress, null), /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleFormContent, null, /*#__PURE__*/_react.default.createElement(_Grid.Grid, null, /*#__PURE__*/_react.default.createElement(_Grid.Cell, {
|
|
225
263
|
span: 12
|
|
226
|
-
}, /*#__PURE__*/
|
|
264
|
+
}, /*#__PURE__*/_react.default.createElement(Bind, {
|
|
227
265
|
name: "name",
|
|
228
|
-
validators: validation.create("required,maxLength:100")
|
|
229
|
-
}, /*#__PURE__*/
|
|
230
|
-
label: t(_templateObject5 || (_templateObject5 =
|
|
231
|
-
}))), /*#__PURE__*/
|
|
266
|
+
validators: _validation.validation.create("required,maxLength:100")
|
|
267
|
+
}, /*#__PURE__*/_react.default.createElement(_Input.Input, {
|
|
268
|
+
label: t(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2.default)(["Name"])))
|
|
269
|
+
}))), /*#__PURE__*/_react.default.createElement(_Grid.Cell, {
|
|
232
270
|
span: 12
|
|
233
|
-
}, /*#__PURE__*/
|
|
271
|
+
}, /*#__PURE__*/_react.default.createElement(Bind, {
|
|
234
272
|
name: "icon",
|
|
235
|
-
validators: validation.create("required")
|
|
236
|
-
}, /*#__PURE__*/
|
|
237
|
-
label: t(_templateObject6 || (_templateObject6 =
|
|
238
|
-
description: t(_templateObject7 || (_templateObject7 =
|
|
239
|
-
}))), /*#__PURE__*/
|
|
273
|
+
validators: _validation.validation.create("required")
|
|
274
|
+
}, /*#__PURE__*/_react.default.createElement(_IconPicker.default, {
|
|
275
|
+
label: t(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2.default)(["Group icon"]))),
|
|
276
|
+
description: t(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2.default)(["Icon that will be displayed in the main menu."])))
|
|
277
|
+
}))), /*#__PURE__*/_react.default.createElement(_Grid.Cell, {
|
|
240
278
|
span: 12
|
|
241
|
-
}, /*#__PURE__*/
|
|
279
|
+
}, /*#__PURE__*/_react.default.createElement(Bind, {
|
|
242
280
|
name: "description"
|
|
243
|
-
}, /*#__PURE__*/
|
|
281
|
+
}, /*#__PURE__*/_react.default.createElement(_Input.Input, {
|
|
244
282
|
rows: 5,
|
|
245
|
-
label: t(_templateObject8 || (_templateObject8 =
|
|
246
|
-
}))))), /*#__PURE__*/
|
|
283
|
+
label: t(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2.default)(["Description"])))
|
|
284
|
+
}))))), /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleFormFooter, null, /*#__PURE__*/_react.default.createElement(ButtonWrapper, null, /*#__PURE__*/_react.default.createElement(_Button.ButtonDefault, {
|
|
247
285
|
onClick: function onClick() {
|
|
248
286
|
return history.push("/cms/content-model-groups");
|
|
249
287
|
}
|
|
250
|
-
}, t(_templateObject9 || (_templateObject9 =
|
|
288
|
+
}, t(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2.default)(["Cancel"])))), canEdit(data, "cms.contentModelGroup") && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !data.plugin ? /*#__PURE__*/_react.default.createElement(_Button.ButtonPrimary, {
|
|
251
289
|
onClick: function onClick(ev) {
|
|
252
290
|
form.submit(ev);
|
|
253
291
|
}
|
|
254
|
-
}, t(_templateObject10 || (_templateObject10 =
|
|
292
|
+
}, t(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2.default)(["Save content model group"])))) : /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
|
|
255
293
|
content: "Content model group is registered via a plugin.",
|
|
256
294
|
placement: "bottom"
|
|
257
|
-
}, /*#__PURE__*/
|
|
295
|
+
}, /*#__PURE__*/_react.default.createElement(_Button.ButtonPrimary, {
|
|
258
296
|
disabled: true
|
|
259
|
-
}, t(_templateObject11 || (_templateObject11 =
|
|
297
|
+
}, t(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2.default)(["Save content model group"])))))))));
|
|
260
298
|
});
|
|
261
299
|
};
|
|
262
300
|
|
|
263
|
-
|
|
301
|
+
var _default = ContentModelGroupsForm;
|
|
302
|
+
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["ContentModelGroupsForm.tsx"],"names":["React","useCallback","styled","isEmpty","get","Form","Grid","Cell","Input","ButtonDefault","ButtonIcon","ButtonPrimary","CircularProgress","i18n","validation","SimpleFormHeader","SimpleForm","SimpleFormFooter","SimpleFormContent","IconPicker","useRouter","useSnackbar","EmptyView","ReactComponent","AddIcon","useMutation","useQuery","GQL","usePermission","Tooltip","t","ns","ButtonWrapper","display","justifyContent","ContentModelGroupsForm","canCreate","location","history","showSnackbar","canEdit","newEntry","URLSearchParams","search","id","getQuery","GET_CONTENT_MODEL_GROUP","variables","skip","onCompleted","data","error","contentModelGroup","push","message","CREATE_CONTENT_MODEL_GROUP","update","cache","gqlParams","query","LIST_CONTENT_MODEL_GROUPS","result","readQuery","listContentModelGroups","writeQuery","create","createMutation","UPDATE_CONTENT_MODEL_GROUP","updateMutation","loading","find","item","createOperation","group","name","description","icon","onSubmit","response","showEmptyView","form","Bind","plugin","ev","submit"],"mappings":"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","sourcesContent":["import React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isEmpty from \"lodash/isEmpty\";\nimport get from \"lodash/get\";\nimport { Form, FormRenderPropParams } from \"@webiny/form\";\nimport { Grid, Cell } from \"@webiny/ui/Grid\";\nimport { Input } from \"@webiny/ui/Input\";\nimport { ButtonDefault, ButtonIcon, ButtonPrimary } from \"@webiny/ui/Button\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { validation } from \"@webiny/validation\";\n\nimport {\n SimpleFormHeader,\n SimpleForm,\n SimpleFormFooter,\n SimpleFormContent\n} from \"@webiny/app-admin/components/SimpleForm\";\nimport IconPicker from \"./IconPicker\";\nimport { useRouter } from \"@webiny/react-router\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport EmptyView from \"@webiny/app-admin/components/EmptyView\";\nimport { ReactComponent as AddIcon } from \"@webiny/app-admin/assets/icons/add-18px.svg\";\nimport { useMutation, useQuery } from \"../../hooks\";\nimport * as GQL from \"./graphql\";\nimport usePermission from \"../../hooks/usePermission\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\nimport {\n CmsGroup,\n CreateCmsGroupMutationResponse,\n CreateCmsGroupMutationVariables,\n GetCmsGroupQueryResponse,\n GetCmsGroupQueryVariables,\n ListCmsGroupsQueryResponse,\n UpdateCmsGroupMutationResponse,\n UpdateCmsGroupMutationVariables\n} from \"./graphql\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/content-model-groups/form\");\nconst ButtonWrapper = styled(\"div\")({\n display: \"flex\",\n justifyContent: \"space-between\"\n});\n\ninterface ContentModelGroupsFormProps {\n canCreate: boolean;\n}\nconst ContentModelGroupsForm: React.FC<ContentModelGroupsFormProps> = ({ canCreate }) => {\n const { location, history } = useRouter();\n const { showSnackbar } = useSnackbar();\n const { canEdit } = usePermission();\n\n const newEntry = new URLSearchParams(location.search).get(\"new\") === \"true\";\n const id = new URLSearchParams(location.search).get(\"id\");\n\n const getQuery = useQuery<GetCmsGroupQueryResponse, GetCmsGroupQueryVariables>(\n GQL.GET_CONTENT_MODEL_GROUP,\n {\n variables: {\n id: id as string\n },\n skip: !id,\n onCompleted: data => {\n if (!data) {\n return;\n }\n\n const { error } = data.contentModelGroup;\n if (error) {\n history.push(\"/cms/content-model-group\");\n showSnackbar(error.message);\n }\n }\n }\n );\n\n // Create a new group and update list cache\n const [create, createMutation] = useMutation<\n CreateCmsGroupMutationResponse,\n CreateCmsGroupMutationVariables\n >(GQL.CREATE_CONTENT_MODEL_GROUP, {\n update(cache, { data }) {\n if (!data || data.contentModelGroup.error) {\n return;\n }\n\n const gqlParams = {\n query: GQL.LIST_CONTENT_MODEL_GROUPS\n };\n const result = cache.readQuery<ListCmsGroupsQueryResponse>(gqlParams);\n if (!result || !result.listContentModelGroups) {\n return;\n }\n const { listContentModelGroups } = result;\n cache.writeQuery({\n ...gqlParams,\n data: {\n listContentModelGroups: {\n ...listContentModelGroups,\n data: [data.contentModelGroup.data, ...listContentModelGroups.data]\n }\n }\n });\n }\n });\n const [update, updateMutation] = useMutation<\n UpdateCmsGroupMutationResponse,\n UpdateCmsGroupMutationVariables\n >(GQL.UPDATE_CONTENT_MODEL_GROUP);\n\n const loading = [getQuery, createMutation, updateMutation].find(item => item.loading);\n\n const createOperation = useCallback(\n (group: Partial<CmsGroup>) => {\n if (!group.id) {\n return create({\n variables: {\n data: {\n name: group.name,\n description: group.description,\n icon: group.icon\n }\n }\n });\n }\n return update({\n variables: {\n id: group.id,\n data: {\n name: group.name,\n description: group.description,\n icon: group.icon\n }\n }\n });\n },\n [create, update]\n );\n\n const onSubmit = useCallback(\n async (group: Partial<CmsGroup>): Promise<void> => {\n /**\n * Create or update, depends if group object has id property\n */\n const response = await createOperation(group);\n if (!response.data) {\n showSnackbar(`Missing response data ain Content Model Group Mutation Response.`);\n return;\n }\n\n const { data, error } = response.data.contentModelGroup;\n if (error) {\n showSnackbar(error.message);\n return;\n }\n /**\n * Redirect to a new group\n */\n if (!group.id) {\n history.push(`/cms/content-model-groups?id=${data.id}`);\n }\n showSnackbar(t`Content model group saved successfully!`);\n },\n [id]\n );\n\n const data: CmsGroup = getQuery.loading\n ? null\n : get(getQuery, \"data.contentModelGroup.data\", null);\n\n const showEmptyView = !newEntry && !loading && isEmpty(data);\n // Render \"No content selected\" view.\n if (showEmptyView) {\n return (\n <EmptyView\n title={t`Click on the left side list to display group details {message}`({\n message: canCreate ? \"or create a...\" : \"\"\n })}\n action={\n canCreate ? (\n <ButtonDefault\n data-testid=\"new-record-button\"\n onClick={() => history.push(\"/cms/content-model-groups?new=true\")}\n >\n <ButtonIcon icon={<AddIcon />} /> {t`New Group`}\n </ButtonDefault>\n ) : (\n <></>\n )\n }\n />\n );\n }\n\n return (\n <Form onSubmit={onSubmit} data={data || { icon: \"fas/star\" }}>\n {({ data, form, Bind }: FormRenderPropParams<CmsGroup>) => (\n <SimpleForm data-testid={\"pb-content-model-groups-form\"}>\n <SimpleFormHeader title={data.name ? data.name : t`New content model group`} />\n {loading && <CircularProgress />}\n <SimpleFormContent>\n <Grid>\n <Cell span={12}>\n <Bind\n name=\"name\"\n validators={validation.create(\"required,maxLength:100\")}\n >\n <Input label={t`Name`} />\n </Bind>\n </Cell>\n\n <Cell span={12}>\n <Bind name=\"icon\" validators={validation.create(\"required\")}>\n <IconPicker\n label={t`Group icon`}\n description={t`Icon that will be displayed in the main menu.`}\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"description\">\n <Input rows={5} label={t`Description`} />\n </Bind>\n </Cell>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>\n <ButtonWrapper>\n <ButtonDefault\n onClick={() => history.push(\"/cms/content-model-groups\")}\n >{t`Cancel`}</ButtonDefault>\n\n {canEdit(data, \"cms.contentModelGroup\") && (\n <React.Fragment>\n {!data.plugin ? (\n <ButtonPrimary\n onClick={ev => {\n form.submit(ev);\n }}\n >{t`Save content model group`}</ButtonPrimary>\n ) : (\n <Tooltip\n content={\n \"Content model group is registered via a plugin.\"\n }\n placement={\"bottom\"}\n >\n <ButtonPrimary\n disabled\n >{t`Save content model group`}</ButtonPrimary>\n </Tooltip>\n )}\n </React.Fragment>\n )}\n </ButtonWrapper>\n </SimpleFormFooter>\n </SimpleForm>\n )}\n </Form>\n );\n};\n\nexport default ContentModelGroupsForm;\n"]}
|
|
1
|
+
{"version":3,"names":["t","i18n","ns","ButtonWrapper","styled","display","justifyContent","ContentModelGroupsForm","canCreate","useRouter","location","history","useSnackbar","showSnackbar","usePermission","canEdit","newEntry","URLSearchParams","search","get","id","getQuery","useQuery","GQL","GET_CONTENT_MODEL_GROUP","variables","skip","onCompleted","data","error","contentModelGroup","push","message","useMutation","CREATE_CONTENT_MODEL_GROUP","update","cache","gqlParams","query","LIST_CONTENT_MODEL_GROUPS","result","readQuery","listContentModelGroups","writeQuery","create","createMutation","UPDATE_CONTENT_MODEL_GROUP","updateMutation","loading","find","item","createOperation","useCallback","group","name","description","icon","onSubmit","response","showEmptyView","isEmpty","form","Bind","validation","plugin","ev","submit"],"sources":["ContentModelGroupsForm.tsx"],"sourcesContent":["import React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isEmpty from \"lodash/isEmpty\";\nimport get from \"lodash/get\";\nimport { Form, FormRenderPropParams } from \"@webiny/form\";\nimport { Grid, Cell } from \"@webiny/ui/Grid\";\nimport { Input } from \"@webiny/ui/Input\";\nimport { ButtonDefault, ButtonIcon, ButtonPrimary } from \"@webiny/ui/Button\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { validation } from \"@webiny/validation\";\n\nimport {\n SimpleFormHeader,\n SimpleForm,\n SimpleFormFooter,\n SimpleFormContent\n} from \"@webiny/app-admin/components/SimpleForm\";\nimport IconPicker from \"./IconPicker\";\nimport { useRouter } from \"@webiny/react-router\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport EmptyView from \"@webiny/app-admin/components/EmptyView\";\nimport { ReactComponent as AddIcon } from \"@webiny/app-admin/assets/icons/add-18px.svg\";\nimport { useMutation, useQuery } from \"../../hooks\";\nimport * as GQL from \"./graphql\";\nimport usePermission from \"../../hooks/usePermission\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\nimport {\n CmsGroup,\n CreateCmsGroupMutationResponse,\n CreateCmsGroupMutationVariables,\n GetCmsGroupQueryResponse,\n GetCmsGroupQueryVariables,\n ListCmsGroupsQueryResponse,\n UpdateCmsGroupMutationResponse,\n UpdateCmsGroupMutationVariables\n} from \"./graphql\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/content-model-groups/form\");\nconst ButtonWrapper = styled(\"div\")({\n display: \"flex\",\n justifyContent: \"space-between\"\n});\n\ninterface ContentModelGroupsFormProps {\n canCreate: boolean;\n}\nconst ContentModelGroupsForm: React.FC<ContentModelGroupsFormProps> = ({ canCreate }) => {\n const { location, history } = useRouter();\n const { showSnackbar } = useSnackbar();\n const { canEdit } = usePermission();\n\n const newEntry = new URLSearchParams(location.search).get(\"new\") === \"true\";\n const id = new URLSearchParams(location.search).get(\"id\");\n\n const getQuery = useQuery<GetCmsGroupQueryResponse, GetCmsGroupQueryVariables>(\n GQL.GET_CONTENT_MODEL_GROUP,\n {\n variables: {\n id: id as string\n },\n skip: !id,\n onCompleted: data => {\n if (!data) {\n return;\n }\n\n const { error } = data.contentModelGroup;\n if (error) {\n history.push(\"/cms/content-model-group\");\n showSnackbar(error.message);\n }\n }\n }\n );\n\n // Create a new group and update list cache\n const [create, createMutation] = useMutation<\n CreateCmsGroupMutationResponse,\n CreateCmsGroupMutationVariables\n >(GQL.CREATE_CONTENT_MODEL_GROUP, {\n update(cache, { data }) {\n if (!data || data.contentModelGroup.error) {\n return;\n }\n\n const gqlParams = {\n query: GQL.LIST_CONTENT_MODEL_GROUPS\n };\n const result = cache.readQuery<ListCmsGroupsQueryResponse>(gqlParams);\n if (!result || !result.listContentModelGroups) {\n return;\n }\n const { listContentModelGroups } = result;\n cache.writeQuery({\n ...gqlParams,\n data: {\n listContentModelGroups: {\n ...listContentModelGroups,\n data: [data.contentModelGroup.data, ...listContentModelGroups.data]\n }\n }\n });\n }\n });\n const [update, updateMutation] = useMutation<\n UpdateCmsGroupMutationResponse,\n UpdateCmsGroupMutationVariables\n >(GQL.UPDATE_CONTENT_MODEL_GROUP);\n\n const loading = [getQuery, createMutation, updateMutation].find(item => item.loading);\n\n const createOperation = useCallback(\n (group: Partial<CmsGroup>) => {\n if (!group.id) {\n return create({\n variables: {\n data: {\n name: group.name,\n description: group.description,\n icon: group.icon\n }\n }\n });\n }\n return update({\n variables: {\n id: group.id,\n data: {\n name: group.name,\n description: group.description,\n icon: group.icon\n }\n }\n });\n },\n [create, update]\n );\n\n const onSubmit = useCallback(\n async (group: Partial<CmsGroup>): Promise<void> => {\n /**\n * Create or update, depends if group object has id property\n */\n const response = await createOperation(group);\n if (!response.data) {\n showSnackbar(`Missing response data ain Content Model Group Mutation Response.`);\n return;\n }\n\n const { data, error } = response.data.contentModelGroup;\n if (error) {\n showSnackbar(error.message);\n return;\n }\n /**\n * Redirect to a new group\n */\n if (!group.id) {\n history.push(`/cms/content-model-groups?id=${data.id}`);\n }\n showSnackbar(t`Content model group saved successfully!`);\n },\n [id]\n );\n\n const data: CmsGroup = getQuery.loading\n ? null\n : get(getQuery, \"data.contentModelGroup.data\", null);\n\n const showEmptyView = !newEntry && !loading && isEmpty(data);\n // Render \"No content selected\" view.\n if (showEmptyView) {\n return (\n <EmptyView\n title={t`Click on the left side list to display group details {message}`({\n message: canCreate ? \"or create a...\" : \"\"\n })}\n action={\n canCreate ? (\n <ButtonDefault\n data-testid=\"new-record-button\"\n onClick={() => history.push(\"/cms/content-model-groups?new=true\")}\n >\n <ButtonIcon icon={<AddIcon />} /> {t`New Group`}\n </ButtonDefault>\n ) : (\n <></>\n )\n }\n />\n );\n }\n\n return (\n <Form onSubmit={onSubmit} data={data || { icon: \"fas/star\" }}>\n {({ data, form, Bind }: FormRenderPropParams<CmsGroup>) => (\n <SimpleForm data-testid={\"pb-content-model-groups-form\"}>\n <SimpleFormHeader title={data.name ? data.name : t`New content model group`} />\n {loading && <CircularProgress />}\n <SimpleFormContent>\n <Grid>\n <Cell span={12}>\n <Bind\n name=\"name\"\n validators={validation.create(\"required,maxLength:100\")}\n >\n <Input label={t`Name`} />\n </Bind>\n </Cell>\n\n <Cell span={12}>\n <Bind name=\"icon\" validators={validation.create(\"required\")}>\n <IconPicker\n label={t`Group icon`}\n description={t`Icon that will be displayed in the main menu.`}\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"description\">\n <Input rows={5} label={t`Description`} />\n </Bind>\n </Cell>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>\n <ButtonWrapper>\n <ButtonDefault\n onClick={() => history.push(\"/cms/content-model-groups\")}\n >{t`Cancel`}</ButtonDefault>\n\n {canEdit(data, \"cms.contentModelGroup\") && (\n <React.Fragment>\n {!data.plugin ? (\n <ButtonPrimary\n onClick={ev => {\n form.submit(ev);\n }}\n >{t`Save content model group`}</ButtonPrimary>\n ) : (\n <Tooltip\n content={\n \"Content model group is registered via a plugin.\"\n }\n placement={\"bottom\"}\n >\n <ButtonPrimary\n disabled\n >{t`Save content model group`}</ButtonPrimary>\n </Tooltip>\n )}\n </React.Fragment>\n )}\n </ButtonWrapper>\n </SimpleFormFooter>\n </SimpleForm>\n )}\n </Form>\n );\n};\n\nexport default ContentModelGroupsForm;\n"],"mappings":"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"}
|
|
@@ -1,72 +1,78 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.default = void 0;
|
|
11
|
+
|
|
12
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
13
|
+
|
|
14
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
15
|
+
|
|
16
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
17
|
+
|
|
18
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
19
|
+
|
|
20
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
21
|
+
|
|
22
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
23
|
+
|
|
24
|
+
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
|
|
25
|
+
|
|
26
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
27
|
+
|
|
28
|
+
var React = _interopRequireWildcard(require("react"));
|
|
29
|
+
|
|
30
|
+
var _noop = _interopRequireDefault(require("lodash/noop"));
|
|
31
|
+
|
|
9
32
|
var _excluded = ["children"];
|
|
10
|
-
import * as React from "react";
|
|
11
|
-
import noop from "lodash/noop";
|
|
12
|
-
/**
|
|
13
|
-
* This component is used to wrap Input and Textarea components to optimize form re-render.
|
|
14
|
-
* These 2 are the only components that trigger form model change on each character input.
|
|
15
|
-
* This means, whenever you type a letter an entire form re-renders.
|
|
16
|
-
* On complex forms you will feel and see a significant delay if this component is not used.
|
|
17
|
-
*
|
|
18
|
-
* The logic behind this component is to serve as a middleware between Form and Input/Textarea, and only notify form of a change when
|
|
19
|
-
* a user stops typing for given period of time (400ms by default).
|
|
20
|
-
*/
|
|
21
33
|
|
|
22
34
|
var DelayedOnChange = /*#__PURE__*/function (_React$Component) {
|
|
23
|
-
|
|
35
|
+
(0, _inherits2.default)(DelayedOnChange, _React$Component);
|
|
24
36
|
|
|
25
|
-
var _super =
|
|
37
|
+
var _super = (0, _createSuper2.default)(DelayedOnChange);
|
|
26
38
|
|
|
27
39
|
function DelayedOnChange() {
|
|
28
40
|
var _this;
|
|
29
41
|
|
|
30
|
-
|
|
42
|
+
(0, _classCallCheck2.default)(this, DelayedOnChange);
|
|
31
43
|
|
|
32
44
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
33
45
|
args[_key] = arguments[_key];
|
|
34
46
|
}
|
|
35
47
|
|
|
36
48
|
_this = _super.call.apply(_super, [this].concat(args));
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
_defineProperty(_assertThisInitialized(_this), "state", {
|
|
49
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "delay", null);
|
|
50
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {
|
|
41
51
|
value: ""
|
|
42
52
|
});
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;
|
|
53
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "applyValue", function (value) {
|
|
54
|
+
var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _noop.default;
|
|
46
55
|
_this.delay && clearTimeout(_this.delay);
|
|
47
56
|
_this.delay = null;
|
|
48
57
|
|
|
49
58
|
_this.props.onChange(value, callback);
|
|
50
59
|
});
|
|
51
|
-
|
|
52
|
-
_defineProperty(_assertThisInitialized(_this), "onChange", function (value) {
|
|
60
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onChange", function (value) {
|
|
53
61
|
_this.setState({
|
|
54
62
|
value: value
|
|
55
63
|
}, _this.changed);
|
|
56
64
|
});
|
|
57
|
-
|
|
58
|
-
_defineProperty(_assertThisInitialized(_this), "changed", function () {
|
|
65
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "changed", function () {
|
|
59
66
|
_this.delay && clearTimeout(_this.delay);
|
|
60
67
|
_this.delay = null;
|
|
61
68
|
_this.delay = setTimeout(function () {
|
|
62
69
|
return _this.applyValue(_this.state.value);
|
|
63
70
|
}, _this.props.delay);
|
|
64
71
|
});
|
|
65
|
-
|
|
66
72
|
return _this;
|
|
67
73
|
}
|
|
68
74
|
|
|
69
|
-
|
|
75
|
+
(0, _createClass2.default)(DelayedOnChange, [{
|
|
70
76
|
key: "componentDidMount",
|
|
71
77
|
value: function componentDidMount() {
|
|
72
78
|
this.setState({
|
|
@@ -80,20 +86,16 @@ var DelayedOnChange = /*#__PURE__*/function (_React$Component) {
|
|
|
80
86
|
|
|
81
87
|
var _this$props = this.props,
|
|
82
88
|
children = _this$props.children,
|
|
83
|
-
other =
|
|
84
|
-
|
|
85
|
-
var newProps = _objectSpread(_objectSpread({}, other), {}, {
|
|
89
|
+
other = (0, _objectWithoutProperties2.default)(_this$props, _excluded);
|
|
90
|
+
var newProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, other), {}, {
|
|
86
91
|
value: this.state.value,
|
|
87
92
|
onChange: this.onChange
|
|
88
93
|
});
|
|
89
|
-
|
|
90
94
|
var renderProp = typeof children === "function" ? children : false;
|
|
91
95
|
var child = renderProp ? renderProp(newProps) : /*#__PURE__*/React.cloneElement(children, newProps);
|
|
92
|
-
|
|
93
|
-
var
|
|
94
|
-
|
|
95
|
-
var realOnKeyDown = props.onKeyDown || noop;
|
|
96
|
-
var realOnBlur = props.onBlur || noop; // Need to apply value if input lost focus
|
|
96
|
+
var props = (0, _objectSpread2.default)({}, child.props);
|
|
97
|
+
var realOnKeyDown = props.onKeyDown || _noop.default;
|
|
98
|
+
var realOnBlur = props.onBlur || _noop.default; // Need to apply value if input lost focus
|
|
97
99
|
|
|
98
100
|
props.onBlur = function (ev) {
|
|
99
101
|
ev.persist();
|
|
@@ -123,12 +125,11 @@ var DelayedOnChange = /*#__PURE__*/function (_React$Component) {
|
|
|
123
125
|
return /*#__PURE__*/React.cloneElement(child, props);
|
|
124
126
|
}
|
|
125
127
|
}]);
|
|
126
|
-
|
|
127
128
|
return DelayedOnChange;
|
|
128
129
|
}(React.Component);
|
|
129
130
|
|
|
130
|
-
|
|
131
|
+
(0, _defineProperty2.default)(DelayedOnChange, "defaultProps", {
|
|
131
132
|
delay: 400
|
|
132
133
|
});
|
|
133
|
-
|
|
134
|
-
|
|
134
|
+
var _default = DelayedOnChange;
|
|
135
|
+
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["DelayedOnChange","value","callback","noop","delay","clearTimeout","props","onChange","setState","changed","setTimeout","applyValue","state","children","other","newProps","renderProp","child","React","cloneElement","realOnKeyDown","onKeyDown","realOnBlur","onBlur","ev","persist","target","key","Component"],"sources":["DelayedOnChange.ts"],"sourcesContent":["import * as React from \"react\";\nimport noop from \"lodash/noop\";\n\n/**\n * This component is used to wrap Input and Textarea components to optimize form re-render.\n * These 2 are the only components that trigger form model change on each character input.\n * This means, whenever you type a letter an entire form re-renders.\n * On complex forms you will feel and see a significant delay if this component is not used.\n *\n * The logic behind this component is to serve as a middleware between Form and Input/Textarea, and only notify form of a change when\n * a user stops typing for given period of time (400ms by default).\n */\ninterface OnChangeCbCallable {\n (value: string): void;\n}\ninterface OnChangeCallable {\n (value: string, cb?: OnChangeCbCallable): void;\n}\ninterface ChildrenParams {\n value: string;\n onChange: OnChangeCallable;\n}\ninterface DelayedOnChangeProps {\n delay?: number;\n value?: string;\n onChange: OnChangeCallable;\n onKeyDown?: (ev: React.SyntheticEvent) => void;\n onBlur?: (ev: React.SyntheticEvent) => void;\n children: (params: ChildrenParams) => React.ReactElement;\n}\ninterface DelayedOnChangeState {\n value?: string;\n}\nclass DelayedOnChange extends React.Component<DelayedOnChangeProps, DelayedOnChangeState> {\n static defaultProps: Partial<DelayedOnChangeProps> = {\n delay: 400\n };\n\n private delay: number | null = null;\n\n public override readonly state: DelayedOnChangeState = {\n value: \"\"\n };\n\n public override componentDidMount() {\n this.setState({ value: this.props.value });\n }\n\n private applyValue = (value: any, callback: OnChangeCbCallable = noop): void => {\n this.delay && clearTimeout(this.delay);\n this.delay = null;\n this.props.onChange(value, callback);\n };\n\n private onChange = (value: string): void => {\n this.setState({ value }, this.changed);\n };\n\n private changed = (): void => {\n this.delay && clearTimeout(this.delay);\n this.delay = null;\n this.delay = setTimeout(\n () => this.applyValue(this.state.value),\n this.props.delay\n ) as unknown as number;\n };\n\n public override render(): React.ReactNode {\n const { children, ...other } = this.props;\n const newProps: Omit<DelayedOnChangeProps, \"children\"> = {\n ...other,\n value: this.state.value,\n onChange: this.onChange\n };\n\n const renderProp = typeof children === \"function\" ? children : false;\n const child = renderProp\n ? renderProp(newProps as Required<DelayedOnChangeProps>)\n : React.cloneElement(children as unknown as React.ReactElement, newProps);\n\n const props = { ...child.props };\n const realOnKeyDown = props.onKeyDown || noop;\n const realOnBlur = props.onBlur || noop;\n\n // Need to apply value if input lost focus\n props.onBlur = (ev: React.SyntheticEvent) => {\n ev.persist();\n this.applyValue((ev.target as HTMLInputElement).value, () => realOnBlur(ev));\n };\n\n // Need to listen for TAB key to apply new value immediately, without delay. Otherwise validation will be triggered with old value.\n props.onKeyDown = (ev: React.KeyboardEvent) => {\n ev.persist();\n if (ev.key === \"Tab\") {\n this.applyValue((ev.target as HTMLInputElement).value, () => realOnKeyDown(ev));\n } else if (ev.key === \"Enter\" && props[\"data-on-enter\"]) {\n this.applyValue((ev.target as HTMLInputElement).value, () => realOnKeyDown(ev));\n } else {\n realOnKeyDown(ev);\n }\n };\n\n return React.cloneElement(child, props);\n }\n}\n\nexport default DelayedOnChange;\n"],"mappings":"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"}
|