@webiny/app-headless-cms 5.41.0-dbt.0 → 5.41.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.
Files changed (99) hide show
  1. package/ContentEntryEditorConfig.d.ts +32 -6
  2. package/ContentEntryEditorConfig.js +5 -0
  3. package/ContentEntryEditorConfig.js.map +1 -1
  4. package/ContentEntryListConfig.d.ts +1 -1
  5. package/HeadlessCMS.js +2 -1
  6. package/HeadlessCMS.js.map +1 -1
  7. package/admin/components/ContentEntries/BulkActions/ActionDelete.js +3 -1
  8. package/admin/components/ContentEntries/BulkActions/ActionDelete.js.map +1 -1
  9. package/admin/components/ContentEntries/BulkActions/ActionMove.js +10 -2
  10. package/admin/components/ContentEntries/BulkActions/ActionMove.js.map +1 -1
  11. package/admin/components/ContentEntries/BulkActions/ActionPublish.js +3 -1
  12. package/admin/components/ContentEntries/BulkActions/ActionPublish.js.map +1 -1
  13. package/admin/components/ContentEntries/BulkActions/ActionUnpublish.js +3 -1
  14. package/admin/components/ContentEntries/BulkActions/ActionUnpublish.js.map +1 -1
  15. package/admin/components/ContentEntryForm/ContentEntryForm.d.ts +12 -17
  16. package/admin/components/ContentEntryForm/ContentEntryForm.js +5 -6
  17. package/admin/components/ContentEntryForm/ContentEntryForm.js.map +1 -1
  18. package/admin/components/ContentEntryForm/ContentEntryFormPreview.js +6 -1
  19. package/admin/components/ContentEntryForm/ContentEntryFormPreview.js.map +1 -1
  20. package/admin/components/ContentEntryForm/ContentEntryFormProvider.d.ts +7 -2
  21. package/admin/components/ContentEntryForm/ContentEntryFormProvider.js +8 -42
  22. package/admin/components/ContentEntryForm/ContentEntryFormProvider.js.map +1 -1
  23. package/admin/components/ContentEntryForm/Header/DeleteEntry/DeleteEntry.js +1 -1
  24. package/admin/components/ContentEntryForm/Header/DeleteEntry/DeleteEntry.js.map +1 -1
  25. package/admin/components/ContentEntryForm/Header/RevisionSelector/RevisionSelector.styles.d.ts +7 -7
  26. package/admin/components/ContentEntryForm/SingletonHeader/SaveAction.d.ts +2 -0
  27. package/admin/components/ContentEntryForm/SingletonHeader/SaveAction.js +24 -0
  28. package/admin/components/ContentEntryForm/SingletonHeader/SaveAction.js.map +1 -0
  29. package/admin/components/ContentEntryForm/SingletonHeader/SingletonHeader.d.ts +5 -0
  30. package/admin/components/ContentEntryForm/SingletonHeader/SingletonHeader.js +65 -0
  31. package/admin/components/ContentEntryForm/SingletonHeader/SingletonHeader.js.map +1 -0
  32. package/admin/components/ContentEntryForm/SingletonHeader/index.d.ts +1 -0
  33. package/admin/components/ContentEntryForm/SingletonHeader/index.js +18 -0
  34. package/admin/components/ContentEntryForm/SingletonHeader/index.js.map +1 -0
  35. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision/EntryRevisionDeletedSnackbarMessage.d.ts +8 -0
  36. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision/EntryRevisionDeletedSnackbarMessage.js +18 -0
  37. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision/EntryRevisionDeletedSnackbarMessage.js.map +1 -0
  38. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision.d.ts +2 -0
  39. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision.js +106 -0
  40. package/admin/components/Decorators/ShowConfirmationOnDeleteRevision.js.map +1 -0
  41. package/admin/components/ModelFieldProvider/ModelFieldContext.d.ts +1 -1
  42. package/admin/config/contentEntries/list/Browser/BulkAction.d.ts +6 -1
  43. package/admin/config/contentEntries/list/Browser/BulkAction.js +11 -3
  44. package/admin/config/contentEntries/list/Browser/BulkAction.js.map +1 -1
  45. package/admin/config/contentEntries/list/Browser/index.d.ts +1 -1
  46. package/admin/config/contentEntries/list/ContentEntryListConfig.d.ts +1 -1
  47. package/admin/contexts/Cms/index.d.ts +31 -8
  48. package/admin/contexts/Cms/index.js +146 -46
  49. package/admin/contexts/Cms/index.js.map +1 -1
  50. package/admin/hooks/useModelFieldGraphqlContext.d.ts +1 -1
  51. package/admin/hooks/usePersistEntry.d.ts +12 -0
  52. package/admin/hooks/usePersistEntry.js +48 -0
  53. package/admin/hooks/usePersistEntry.js.map +1 -0
  54. package/admin/lexicalConfig/LexicalEditorConfig.js +6 -10
  55. package/admin/lexicalConfig/LexicalEditorConfig.js.map +1 -1
  56. package/admin/plugins/fieldRenderers/dateTime/DateTimeWithTimezone.js +11 -20
  57. package/admin/plugins/fieldRenderers/dateTime/DateTimeWithTimezone.js.map +1 -1
  58. package/admin/plugins/fieldRenderers/dateTime/DateTimeWithoutTimezone.js +6 -14
  59. package/admin/plugins/fieldRenderers/dateTime/DateTimeWithoutTimezone.js.map +1 -1
  60. package/admin/plugins/fieldRenderers/dateTime/utils.d.ts +2 -0
  61. package/admin/plugins/fieldRenderers/dateTime/utils.js +16 -1
  62. package/admin/plugins/fieldRenderers/dateTime/utils.js.map +1 -1
  63. package/admin/plugins/fieldRenderers/object/FieldSettings.d.ts +1 -1
  64. package/admin/plugins/fieldRenderers/ref/components/NewReferencedEntryDialog.js +32 -12
  65. package/admin/plugins/fieldRenderers/ref/components/NewReferencedEntryDialog.js.map +1 -1
  66. package/admin/plugins/fields/ref.js +7 -1
  67. package/admin/plugins/fields/ref.js.map +1 -1
  68. package/admin/plugins/index.d.ts +3 -3
  69. package/admin/views/contentEntries/ContentEntriesModule.js +2 -1
  70. package/admin/views/contentEntries/ContentEntriesModule.js.map +1 -1
  71. package/admin/views/contentEntries/ContentEntry/ContentEntryContext.d.ts +8 -0
  72. package/admin/views/contentEntries/ContentEntry/ContentEntryContext.js +69 -22
  73. package/admin/views/contentEntries/ContentEntry/ContentEntryContext.js.map +1 -1
  74. package/admin/views/contentEntries/ContentEntry/RevisionsList/PublishEntryRevisionListItem.js +1 -1
  75. package/admin/views/contentEntries/ContentEntry/RevisionsList/PublishEntryRevisionListItem.js.map +1 -1
  76. package/admin/views/contentEntries/ContentEntry/RevisionsList/RevisionListItem.js +6 -6
  77. package/admin/views/contentEntries/ContentEntry/RevisionsList/RevisionListItem.js.map +1 -1
  78. package/admin/views/contentEntries/ContentEntry/RevisionsList/useRevision.js +28 -22
  79. package/admin/views/contentEntries/ContentEntry/RevisionsList/useRevision.js.map +1 -1
  80. package/admin/views/contentEntries/ContentEntry/SingletonContentEntry.d.ts +20 -0
  81. package/admin/views/contentEntries/ContentEntry/SingletonContentEntry.js +66 -0
  82. package/admin/views/contentEntries/ContentEntry/SingletonContentEntry.js.map +1 -0
  83. package/admin/views/contentEntries/ContentEntry/SingletonContentEntryContext.d.ts +20 -0
  84. package/admin/views/contentEntries/ContentEntry/SingletonContentEntryContext.js +75 -0
  85. package/admin/views/contentEntries/ContentEntry/SingletonContentEntryContext.js.map +1 -0
  86. package/admin/views/contentEntries/ContentEntry.js +11 -4
  87. package/admin/views/contentEntries/ContentEntry.js.map +1 -1
  88. package/admin/views/contentEntries/SingletonContentEntryModule.d.ts +2 -0
  89. package/admin/views/contentEntries/SingletonContentEntryModule.js +33 -0
  90. package/admin/views/contentEntries/SingletonContentEntryModule.js.map +1 -0
  91. package/admin/views/contentEntries/hooks/useSingletonContentEntry.d.ts +8 -0
  92. package/admin/views/contentEntries/hooks/useSingletonContentEntry.js +18 -0
  93. package/admin/views/contentEntries/hooks/useSingletonContentEntry.js.map +1 -0
  94. package/admin/views/contentModels/ContentModelsDataList.js +13 -4
  95. package/admin/views/contentModels/ContentModelsDataList.js.map +1 -1
  96. package/admin/views/contentModels/NewContentModelDialog.js +58 -27
  97. package/admin/views/contentModels/NewContentModelDialog.js.map +1 -1
  98. package/allPlugins.d.ts +4 -4
  99. package/package.json +28 -28
@@ -24,10 +24,14 @@ var _contentModels = require("../../../../graphql/contentModels");
24
24
  var _hooks = require("../../../../hooks");
25
25
  var _Dialog2 = require("./dialog/Dialog");
26
26
  var _navigateFolder = require("@webiny/app-aco/contexts/navigateFolder");
27
+ var _records = require("@webiny/app-aco/contexts/records");
27
28
  var _appAco = require("@webiny/app-aco");
28
29
  var _Elevation = require("@webiny/ui/Elevation");
29
30
  var _SplitView = require("@webiny/app-admin/components/SplitView");
30
31
  var _Progress = require("@webiny/ui/Progress");
32
+ var _usePersistEntry2 = require("../../../../hooks/usePersistEntry");
33
+ var _app = require("@webiny/app-aco/contexts/app");
34
+ var _appAdmin = require("@webiny/app-admin");
31
35
  var _templateObject, _templateObject2, _templateObject3;
32
36
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
33
37
  var t = _i18n.i18n.ns("app-headless-cms/admin/fields/ref");
@@ -42,7 +46,7 @@ var RenderBlock = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV ==
42
46
  } : {
43
47
  name: "vzed0k",
44
48
  styles: "position:relative;background-color:var(--mdc-theme-background);padding:25px;overflow:scroll",
45
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AA2B8B","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                onAfterCreate={entry => onCreate(entry)}\n                                entry={{}}\n                                addEntryToListCache={false}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n    if (!model) {\n        return null;\n    }\n\n    return (\n        <ContentEntriesProvider contentModel={model} key={model.modelId} insideDialog={true}>\n            <FoldersProvider type={`cms:${model.modelId}`}>\n                <NavigateFolderProvider modelId={model.modelId}>\n                    <ContentEntryProviderWithCurrentFolderId\n                        model={model}\n                        onClose={onClose}\n                        onCreate={onCreate}\n                    />\n                </NavigateFolderProvider>\n            </FoldersProvider>\n        </ContentEntriesProvider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
49
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAmC8B","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { SearchRecordsProvider } from \"@webiny/app-aco/contexts/records\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\nimport {\n    AcoAppContext,\n    AcoAppProviderContext,\n    createAppFromModel\n} from \"@webiny/app-aco/contexts/app\";\nimport { DialogsProvider } from \"@webiny/app-admin\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { persistEntry } = usePersistEntry({ addItemToListCache: false });\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                entry={{}}\n                                persistEntry={persistEntry}\n                                onAfterCreate={entry => onCreate(entry)}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n\n    if (!model) {\n        return null;\n    }\n\n    const acoAppContext: AcoAppProviderContext = {\n        app: createAppFromModel({\n            model,\n            id: `cms:${model.modelId}`\n        }),\n        mode: \"cms\",\n        client: apolloClient,\n        model,\n        folderIdPath: \"wbyAco_location.folderId\",\n        folderIdInPath: \"wbyAco_location.folderId_in\",\n        loading: false\n    };\n\n    return (\n        <AcoAppContext.Provider value={acoAppContext}>\n            <FoldersProvider>\n                <SearchRecordsProvider>\n                    <NavigateFolderProvider modelId={model.modelId}>\n                        <DialogsProvider>\n                            <ContentEntriesProvider\n                                contentModel={model}\n                                key={model.modelId}\n                                insideDialog={true}\n                            >\n                                <ContentEntryProviderWithCurrentFolderId\n                                    model={model}\n                                    onClose={onClose}\n                                    onCreate={onCreate}\n                                />\n                            </ContentEntriesProvider>\n                        </DialogsProvider>\n                    </NavigateFolderProvider>\n                </SearchRecordsProvider>\n            </FoldersProvider>\n        </AcoAppContext.Provider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
46
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
51
  });
48
52
  var PaddedLeftPanel = /*#__PURE__*/(0, _base.default)(_SplitView.LeftPanel, process.env.NODE_ENV === "production" ? {
@@ -56,7 +60,7 @@ var PaddedLeftPanel = /*#__PURE__*/(0, _base.default)(_SplitView.LeftPanel, proc
56
60
  } : {
57
61
  name: "1mng3k9",
58
62
  styles: "padding:10px 10px 0",
59
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAkCyC","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                onAfterCreate={entry => onCreate(entry)}\n                                entry={{}}\n                                addEntryToListCache={false}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n    if (!model) {\n        return null;\n    }\n\n    return (\n        <ContentEntriesProvider contentModel={model} key={model.modelId} insideDialog={true}>\n            <FoldersProvider type={`cms:${model.modelId}`}>\n                <NavigateFolderProvider modelId={model.modelId}>\n                    <ContentEntryProviderWithCurrentFolderId\n                        model={model}\n                        onClose={onClose}\n                        onCreate={onCreate}\n                    />\n                </NavigateFolderProvider>\n            </FoldersProvider>\n        </ContentEntriesProvider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AA0CyC","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { SearchRecordsProvider } from \"@webiny/app-aco/contexts/records\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\nimport {\n    AcoAppContext,\n    AcoAppProviderContext,\n    createAppFromModel\n} from \"@webiny/app-aco/contexts/app\";\nimport { DialogsProvider } from \"@webiny/app-admin\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { persistEntry } = usePersistEntry({ addItemToListCache: false });\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                entry={{}}\n                                persistEntry={persistEntry}\n                                onAfterCreate={entry => onCreate(entry)}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n\n    if (!model) {\n        return null;\n    }\n\n    const acoAppContext: AcoAppProviderContext = {\n        app: createAppFromModel({\n            model,\n            id: `cms:${model.modelId}`\n        }),\n        mode: \"cms\",\n        client: apolloClient,\n        model,\n        folderIdPath: \"wbyAco_location.folderId\",\n        folderIdInPath: \"wbyAco_location.folderId_in\",\n        loading: false\n    };\n\n    return (\n        <AcoAppContext.Provider value={acoAppContext}>\n            <FoldersProvider>\n                <SearchRecordsProvider>\n                    <NavigateFolderProvider modelId={model.modelId}>\n                        <DialogsProvider>\n                            <ContentEntriesProvider\n                                contentModel={model}\n                                key={model.modelId}\n                                insideDialog={true}\n                            >\n                                <ContentEntryProviderWithCurrentFolderId\n                                    model={model}\n                                    onClose={onClose}\n                                    onCreate={onCreate}\n                                />\n                            </ContentEntriesProvider>\n                        </DialogsProvider>\n                    </NavigateFolderProvider>\n                </SearchRecordsProvider>\n            </FoldersProvider>\n        </AcoAppContext.Provider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
60
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
61
65
  });
62
66
  var ModalRightPanel = /*#__PURE__*/(0, _base.default)(_SplitView.RightPanel, process.env.NODE_ENV === "production" ? {
@@ -70,7 +74,7 @@ var ModalRightPanel = /*#__PURE__*/(0, _base.default)(_SplitView.RightPanel, pro
70
74
  } : {
71
75
  name: "1iiz6el",
72
76
  styles: ">div{height:auto;}webiny-form-container>div{height:auto;}",
73
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAsC0C","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                onAfterCreate={entry => onCreate(entry)}\n                                entry={{}}\n                                addEntryToListCache={false}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n    if (!model) {\n        return null;\n    }\n\n    return (\n        <ContentEntriesProvider contentModel={model} key={model.modelId} insideDialog={true}>\n            <FoldersProvider type={`cms:${model.modelId}`}>\n                <NavigateFolderProvider modelId={model.modelId}>\n                    <ContentEntryProviderWithCurrentFolderId\n                        model={model}\n                        onClose={onClose}\n                        onCreate={onCreate}\n                    />\n                </NavigateFolderProvider>\n            </FoldersProvider>\n        </ContentEntriesProvider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
77
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AA8C0C","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { SearchRecordsProvider } from \"@webiny/app-aco/contexts/records\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\nimport {\n    AcoAppContext,\n    AcoAppProviderContext,\n    createAppFromModel\n} from \"@webiny/app-aco/contexts/app\";\nimport { DialogsProvider } from \"@webiny/app-admin\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { persistEntry } = usePersistEntry({ addItemToListCache: false });\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                entry={{}}\n                                persistEntry={persistEntry}\n                                onAfterCreate={entry => onCreate(entry)}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n\n    if (!model) {\n        return null;\n    }\n\n    const acoAppContext: AcoAppProviderContext = {\n        app: createAppFromModel({\n            model,\n            id: `cms:${model.modelId}`\n        }),\n        mode: \"cms\",\n        client: apolloClient,\n        model,\n        folderIdPath: \"wbyAco_location.folderId\",\n        folderIdInPath: \"wbyAco_location.folderId_in\",\n        loading: false\n    };\n\n    return (\n        <AcoAppContext.Provider value={acoAppContext}>\n            <FoldersProvider>\n                <SearchRecordsProvider>\n                    <NavigateFolderProvider modelId={model.modelId}>\n                        <DialogsProvider>\n                            <ContentEntriesProvider\n                                contentModel={model}\n                                key={model.modelId}\n                                insideDialog={true}\n                            >\n                                <ContentEntryProviderWithCurrentFolderId\n                                    model={model}\n                                    onClose={onClose}\n                                    onCreate={onCreate}\n                                />\n                            </ContentEntriesProvider>\n                        </DialogsProvider>\n                    </NavigateFolderProvider>\n                </SearchRecordsProvider>\n            </FoldersProvider>\n        </AcoAppContext.Provider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
74
78
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
75
79
  });
76
80
  var ModalFullWidthDialog = /*#__PURE__*/(0, _base.default)(_Dialog2.FullWidthDialog, process.env.NODE_ENV === "production" ? {
@@ -84,7 +88,7 @@ var ModalFullWidthDialog = /*#__PURE__*/(0, _base.default)(_Dialog2.FullWidthDia
84
88
  } : {
85
89
  name: "1ruc94i",
86
90
  styles: ".webiny-ui-dialog__content{height:100%;>div{max-height:inherit;height:inherit;.mdc-layout-grid__inner{height:100%;max-height:inherit;.webiny-split-view__left-panel,.webiny-split-view__right-panel{height:inherit;max-height:inherit;overflow:scroll;}}}}",
87
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAgDoD","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                onAfterCreate={entry => onCreate(entry)}\n                                entry={{}}\n                                addEntryToListCache={false}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n    if (!model) {\n        return null;\n    }\n\n    return (\n        <ContentEntriesProvider contentModel={model} key={model.modelId} insideDialog={true}>\n            <FoldersProvider type={`cms:${model.modelId}`}>\n                <NavigateFolderProvider modelId={model.modelId}>\n                    <ContentEntryProviderWithCurrentFolderId\n                        model={model}\n                        onClose={onClose}\n                        onCreate={onCreate}\n                    />\n                </NavigateFolderProvider>\n            </FoldersProvider>\n        </ContentEntriesProvider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
91
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAwDoD","file":"NewReferencedEntryDialog.tsx","sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n    GET_CONTENT_MODEL,\n    GetCmsModelQueryResponse,\n    GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { SearchRecordsProvider } from \"@webiny/app-aco/contexts/records\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\nimport {\n    AcoAppContext,\n    AcoAppProviderContext,\n    createAppFromModel\n} from \"@webiny/app-aco/contexts/app\";\nimport { DialogsProvider } from \"@webiny/app-admin\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n    position: relative;\n    background-color: var(--mdc-theme-background);\n    padding: 25px;\n    overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n    padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n    > div {\n        height: auto;\n    }\n\n    webiny-form-container > div {\n        height: auto;\n    }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n    .webiny-ui-dialog__content {\n        height: 100%;\n        > div {\n            max-height: inherit;\n            height: inherit;\n            .mdc-layout-grid__inner {\n                height: 100%;\n                max-height: inherit;\n                .webiny-split-view__left-panel,\n                .webiny-split-view__right-panel {\n                    height: inherit;\n                    max-height: inherit;\n                    overflow: scroll;\n                }\n            }\n        }\n    }\n`;\n\ninterface SaveEntry {\n    (): void;\n}\n\ninterface EntryFormProps {\n    onCreate: (entry: CmsContentEntry) => void;\n    setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n    const { contentModel, loading } = useContentEntry();\n    const { persistEntry } = usePersistEntry({ addItemToListCache: false });\n    const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n    return (\n        <ModelProvider model={contentModel}>\n            <SplitView>\n                <PaddedLeftPanel span={3}>\n                    <FolderTree\n                        focusedFolderId={currentFolderId}\n                        onFolderClick={data => navigateToFolder(data.id)}\n                        enableActions={true}\n                        enableCreate={true}\n                    />\n                </PaddedLeftPanel>\n                <ModalRightPanel span={9}>\n                    <RenderBlock>\n                        <Elevation z={2}>\n                            {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n                            <ContentEntryForm\n                                header={false}\n                                entry={{}}\n                                persistEntry={persistEntry}\n                                onAfterCreate={entry => onCreate(entry)}\n                                setSaveEntry={setSaveEntry}\n                            />\n                        </Elevation>\n                    </RenderBlock>\n                </ModalRightPanel>\n            </SplitView>\n        </ModelProvider>\n    );\n};\n\ninterface NewReferencedEntryDialogProps {\n    model: Pick<CmsModel, \"modelId\">;\n    onClose: () => void;\n    onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n    model: baseModel,\n    onClose,\n    onChange\n}: NewReferencedEntryDialogProps) => {\n    const { apolloClient } = useCms();\n    const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n    useEffect(() => {\n        (async () => {\n            const response = await apolloClient.query<\n                GetCmsModelQueryResponse,\n                GetCmsModelQueryVariables\n            >({\n                query: GET_CONTENT_MODEL,\n                variables: {\n                    modelId: baseModel.modelId\n                }\n            });\n            setModel(response.data.getContentModel.data);\n        })();\n    }, [baseModel.modelId]);\n\n    const onCreate = useCallback(\n        (entry: CmsContentEntry) => {\n            if (!model) {\n                onClose();\n                return;\n            }\n            onChange({\n                ...entry,\n                /*\n                 * Format data for AutoComplete.\n                 */\n                published: entry.meta?.status === \"published\",\n                modelId: model.modelId,\n                modelName: model.name\n            });\n            onClose();\n        },\n        [onChange, model]\n    );\n\n    if (!model) {\n        return null;\n    }\n\n    const acoAppContext: AcoAppProviderContext = {\n        app: createAppFromModel({\n            model,\n            id: `cms:${model.modelId}`\n        }),\n        mode: \"cms\",\n        client: apolloClient,\n        model,\n        folderIdPath: \"wbyAco_location.folderId\",\n        folderIdInPath: \"wbyAco_location.folderId_in\",\n        loading: false\n    };\n\n    return (\n        <AcoAppContext.Provider value={acoAppContext}>\n            <FoldersProvider>\n                <SearchRecordsProvider>\n                    <NavigateFolderProvider modelId={model.modelId}>\n                        <DialogsProvider>\n                            <ContentEntriesProvider\n                                contentModel={model}\n                                key={model.modelId}\n                                insideDialog={true}\n                            >\n                                <ContentEntryProviderWithCurrentFolderId\n                                    model={model}\n                                    onClose={onClose}\n                                    onCreate={onCreate}\n                                />\n                            </ContentEntriesProvider>\n                        </DialogsProvider>\n                    </NavigateFolderProvider>\n                </SearchRecordsProvider>\n            </FoldersProvider>\n        </AcoAppContext.Provider>\n    );\n};\n\nconst NavigateFolderProvider = ({\n    modelId,\n    children\n}: {\n    modelId: string;\n    children: React.ReactNode;\n}) => {\n    const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n    const navigateToFolder = useCallback((folderId: string) => {\n        setFolderId(folderId);\n    }, []);\n\n    const navigateToListHome = useCallback(() => {\n        setFolderId(undefined);\n    }, []);\n\n    return (\n        <AbstractNavigateFolderProvider\n            folderId={folderId}\n            createStorageKey={() => `cms:${modelId}:create`}\n            navigateToFolder={navigateToFolder}\n            navigateToLatestFolder={navigateToFolder}\n            navigateToListHome={navigateToListHome}\n        >\n            {children}\n        </AbstractNavigateFolderProvider>\n    );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n    model: CmsModel;\n    onClose: () => void;\n    onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n    model,\n    onClose,\n    onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n    const saveEntryRef = useRef<SaveEntry>();\n    const { currentFolderId } = useNavigateFolder();\n\n    return (\n        <ContentEntryProvider\n            isNewEntry={() => true}\n            getContentId={() => null}\n            currentFolderId={currentFolderId}\n        >\n            <ModalFullWidthDialog open={true} onClose={onClose}>\n                <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n                <DialogContent>\n                    <EntryForm\n                        onCreate={onCreate}\n                        setSaveEntry={cb => (saveEntryRef.current = cb)}\n                    />\n                </DialogContent>\n                <DialogActions>\n                    <DialogCancel>{t`Cancel`}</DialogCancel>\n                    <ButtonPrimary\n                        onClick={() => saveEntryRef.current && saveEntryRef.current()}\n                    >{t`Create Entry`}</ButtonPrimary>\n                </DialogActions>\n            </ModalFullWidthDialog>\n        </ContentEntryProvider>\n    );\n};\n"]} */",
88
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
89
93
  });
90
94
  var EntryForm = function EntryForm(_ref) {
@@ -93,6 +97,10 @@ var EntryForm = function EntryForm(_ref) {
93
97
  var _useContentEntry = (0, _useContentEntry2.useContentEntry)(),
94
98
  contentModel = _useContentEntry.contentModel,
95
99
  loading = _useContentEntry.loading;
100
+ var _usePersistEntry = (0, _usePersistEntry2.usePersistEntry)({
101
+ addItemToListCache: false
102
+ }),
103
+ persistEntry = _usePersistEntry.persistEntry;
96
104
  var _useNavigateFolder = (0, _appAco.useNavigateFolder)(),
97
105
  currentFolderId = _useNavigateFolder.currentFolderId,
98
106
  navigateToFolder = _useNavigateFolder.navigateToFolder;
@@ -115,11 +123,11 @@ var EntryForm = function EntryForm(_ref) {
115
123
  label: "Creating entry..."
116
124
  }) : null, /*#__PURE__*/_react.default.createElement(_ContentEntryForm.ContentEntryForm, {
117
125
  header: false,
126
+ entry: {},
127
+ persistEntry: persistEntry,
118
128
  onAfterCreate: function onAfterCreate(entry) {
119
129
  return onCreate(entry);
120
130
  },
121
- entry: {},
122
- addEntryToListCache: false,
123
131
  setSaveEntry: setSaveEntry
124
132
  }))))));
125
133
  };
@@ -162,19 +170,31 @@ var NewReferencedEntryDialog = exports.NewReferencedEntryDialog = function NewRe
162
170
  if (!model) {
163
171
  return null;
164
172
  }
165
- return /*#__PURE__*/_react.default.createElement(_ContentEntriesContext.ContentEntriesProvider, {
173
+ var acoAppContext = {
174
+ app: (0, _app.createAppFromModel)({
175
+ model: model,
176
+ id: "cms:".concat(model.modelId)
177
+ }),
178
+ mode: "cms",
179
+ client: apolloClient,
180
+ model: model,
181
+ folderIdPath: "wbyAco_location.folderId",
182
+ folderIdInPath: "wbyAco_location.folderId_in",
183
+ loading: false
184
+ };
185
+ return /*#__PURE__*/_react.default.createElement(_app.AcoAppContext.Provider, {
186
+ value: acoAppContext
187
+ }, /*#__PURE__*/_react.default.createElement(_folders.FoldersProvider, null, /*#__PURE__*/_react.default.createElement(_records.SearchRecordsProvider, null, /*#__PURE__*/_react.default.createElement(NavigateFolderProvider, {
188
+ modelId: model.modelId
189
+ }, /*#__PURE__*/_react.default.createElement(_appAdmin.DialogsProvider, null, /*#__PURE__*/_react.default.createElement(_ContentEntriesContext.ContentEntriesProvider, {
166
190
  contentModel: model,
167
191
  key: model.modelId,
168
192
  insideDialog: true
169
- }, /*#__PURE__*/_react.default.createElement(_folders.FoldersProvider, {
170
- type: "cms:".concat(model.modelId)
171
- }, /*#__PURE__*/_react.default.createElement(NavigateFolderProvider, {
172
- modelId: model.modelId
173
193
  }, /*#__PURE__*/_react.default.createElement(ContentEntryProviderWithCurrentFolderId, {
174
194
  model: model,
175
195
  onClose: onClose,
176
196
  onCreate: onCreate
177
- }))));
197
+ })))))));
178
198
  };
179
199
  var NavigateFolderProvider = function NavigateFolderProvider(_ref3) {
180
200
  var modelId = _ref3.modelId,
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireWildcard","require","_ContentEntryContext","_folders","_Dialog","_ContentEntriesContext","_i18n","_useContentEntry2","_ModelProvider","_ContentEntryForm","_Button","_contentModels","_hooks","_Dialog2","_navigateFolder","_appAco","_Elevation","_SplitView","_Progress","_templateObject","_templateObject2","_templateObject3","_EMOTION_STRINGIFIED_CSS_ERROR__","t","i18n","ns","RenderBlock","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","PaddedLeftPanel","LeftPanel","ModalRightPanel","RightPanel","ModalFullWidthDialog","FullWidthDialog","EntryForm","_ref","onCreate","setSaveEntry","_useContentEntry","useContentEntry","contentModel","loading","_useNavigateFolder","useNavigateFolder","currentFolderId","navigateToFolder","createElement","ModelProvider","model","SplitView","span","FolderTree","focusedFolderId","onFolderClick","data","id","enableActions","enableCreate","Elevation","z","CircularProgress","ContentEntryForm","header","onAfterCreate","entry","addEntryToListCache","NewReferencedEntryDialog","exports","_ref2","baseModel","onClose","onChange","_useCms","useCms","apolloClient","_useState","useState","undefined","_useState2","_slicedToArray2","setModel","useEffect","response","query","GET_CONTENT_MODEL","variables","modelId","getContentModel","useCallback","_objectSpread2","published","meta","status","modelName","ContentEntriesProvider","key","insideDialog","FoldersProvider","type","concat","NavigateFolderProvider","ContentEntryProviderWithCurrentFolderId","_ref3","children","_useState3","_useState4","folderId","setFolderId","navigateToListHome","createStorageKey","navigateToLatestFolder","_ref4","saveEntryRef","useRef","_useNavigateFolder2","ContentEntryProvider","isNewEntry","getContentId","open","DialogTitle","_taggedTemplateLiteral2","DialogContent","cb","current","DialogActions","DialogCancel","ButtonPrimary","onClick"],"sources":["NewReferencedEntryDialog.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n GET_CONTENT_MODEL,\n GetCmsModelQueryResponse,\n GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n position: relative;\n background-color: var(--mdc-theme-background);\n padding: 25px;\n overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n > div {\n height: auto;\n }\n\n webiny-form-container > div {\n height: auto;\n }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n .webiny-ui-dialog__content {\n height: 100%;\n > div {\n max-height: inherit;\n height: inherit;\n .mdc-layout-grid__inner {\n height: 100%;\n max-height: inherit;\n .webiny-split-view__left-panel,\n .webiny-split-view__right-panel {\n height: inherit;\n max-height: inherit;\n overflow: scroll;\n }\n }\n }\n }\n`;\n\ninterface SaveEntry {\n (): void;\n}\n\ninterface EntryFormProps {\n onCreate: (entry: CmsContentEntry) => void;\n setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n const { contentModel, loading } = useContentEntry();\n const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n return (\n <ModelProvider model={contentModel}>\n <SplitView>\n <PaddedLeftPanel span={3}>\n <FolderTree\n focusedFolderId={currentFolderId}\n onFolderClick={data => navigateToFolder(data.id)}\n enableActions={true}\n enableCreate={true}\n />\n </PaddedLeftPanel>\n <ModalRightPanel span={9}>\n <RenderBlock>\n <Elevation z={2}>\n {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n <ContentEntryForm\n header={false}\n onAfterCreate={entry => onCreate(entry)}\n entry={{}}\n addEntryToListCache={false}\n setSaveEntry={setSaveEntry}\n />\n </Elevation>\n </RenderBlock>\n </ModalRightPanel>\n </SplitView>\n </ModelProvider>\n );\n};\n\ninterface NewReferencedEntryDialogProps {\n model: Pick<CmsModel, \"modelId\">;\n onClose: () => void;\n onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n model: baseModel,\n onClose,\n onChange\n}: NewReferencedEntryDialogProps) => {\n const { apolloClient } = useCms();\n const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n useEffect(() => {\n (async () => {\n const response = await apolloClient.query<\n GetCmsModelQueryResponse,\n GetCmsModelQueryVariables\n >({\n query: GET_CONTENT_MODEL,\n variables: {\n modelId: baseModel.modelId\n }\n });\n setModel(response.data.getContentModel.data);\n })();\n }, [baseModel.modelId]);\n\n const onCreate = useCallback(\n (entry: CmsContentEntry) => {\n if (!model) {\n onClose();\n return;\n }\n onChange({\n ...entry,\n /*\n * Format data for AutoComplete.\n */\n published: entry.meta?.status === \"published\",\n modelId: model.modelId,\n modelName: model.name\n });\n onClose();\n },\n [onChange, model]\n );\n if (!model) {\n return null;\n }\n\n return (\n <ContentEntriesProvider contentModel={model} key={model.modelId} insideDialog={true}>\n <FoldersProvider type={`cms:${model.modelId}`}>\n <NavigateFolderProvider modelId={model.modelId}>\n <ContentEntryProviderWithCurrentFolderId\n model={model}\n onClose={onClose}\n onCreate={onCreate}\n />\n </NavigateFolderProvider>\n </FoldersProvider>\n </ContentEntriesProvider>\n );\n};\n\nconst NavigateFolderProvider = ({\n modelId,\n children\n}: {\n modelId: string;\n children: React.ReactNode;\n}) => {\n const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n const navigateToFolder = useCallback((folderId: string) => {\n setFolderId(folderId);\n }, []);\n\n const navigateToListHome = useCallback(() => {\n setFolderId(undefined);\n }, []);\n\n return (\n <AbstractNavigateFolderProvider\n folderId={folderId}\n createStorageKey={() => `cms:${modelId}:create`}\n navigateToFolder={navigateToFolder}\n navigateToLatestFolder={navigateToFolder}\n navigateToListHome={navigateToListHome}\n >\n {children}\n </AbstractNavigateFolderProvider>\n );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n model: CmsModel;\n onClose: () => void;\n onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n model,\n onClose,\n onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n const saveEntryRef = useRef<SaveEntry>();\n const { currentFolderId } = useNavigateFolder();\n\n return (\n <ContentEntryProvider\n isNewEntry={() => true}\n getContentId={() => null}\n currentFolderId={currentFolderId}\n >\n <ModalFullWidthDialog open={true} onClose={onClose}>\n <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n <DialogContent>\n <EntryForm\n onCreate={onCreate}\n setSaveEntry={cb => (saveEntryRef.current = cb)}\n />\n </DialogContent>\n <DialogActions>\n <DialogCancel>{t`Cancel`}</DialogCancel>\n <ButtonPrimary\n onClick={() => saveEntryRef.current && saveEntryRef.current()}\n >{t`Create Entry`}</ButtonPrimary>\n </DialogActions>\n </ModalFullWidthDialog>\n </ContentEntryProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireWildcard","require","_ContentEntryContext","_folders","_Dialog","_ContentEntriesContext","_i18n","_useContentEntry2","_ModelProvider","_ContentEntryForm","_Button","_contentModels","_hooks","_Dialog2","_navigateFolder","_records","_appAco","_Elevation","_SplitView","_Progress","_usePersistEntry2","_app","_appAdmin","_templateObject","_templateObject2","_templateObject3","_EMOTION_STRINGIFIED_CSS_ERROR__","t","i18n","ns","RenderBlock","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","PaddedLeftPanel","LeftPanel","ModalRightPanel","RightPanel","ModalFullWidthDialog","FullWidthDialog","EntryForm","_ref","onCreate","setSaveEntry","_useContentEntry","useContentEntry","contentModel","loading","_usePersistEntry","usePersistEntry","addItemToListCache","persistEntry","_useNavigateFolder","useNavigateFolder","currentFolderId","navigateToFolder","createElement","ModelProvider","model","SplitView","span","FolderTree","focusedFolderId","onFolderClick","data","id","enableActions","enableCreate","Elevation","z","CircularProgress","ContentEntryForm","header","entry","onAfterCreate","NewReferencedEntryDialog","exports","_ref2","baseModel","onClose","onChange","_useCms","useCms","apolloClient","_useState","useState","undefined","_useState2","_slicedToArray2","setModel","useEffect","response","query","GET_CONTENT_MODEL","variables","modelId","getContentModel","useCallback","_objectSpread2","published","meta","status","modelName","acoAppContext","app","createAppFromModel","concat","mode","client","folderIdPath","folderIdInPath","AcoAppContext","Provider","value","FoldersProvider","SearchRecordsProvider","NavigateFolderProvider","DialogsProvider","ContentEntriesProvider","key","insideDialog","ContentEntryProviderWithCurrentFolderId","_ref3","children","_useState3","_useState4","folderId","setFolderId","navigateToListHome","createStorageKey","navigateToLatestFolder","_ref4","saveEntryRef","useRef","_useNavigateFolder2","ContentEntryProvider","isNewEntry","getContentId","open","DialogTitle","_taggedTemplateLiteral2","DialogContent","cb","current","DialogActions","DialogCancel","ButtonPrimary","onClick"],"sources":["NewReferencedEntryDialog.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { ContentEntryProvider } from \"~/admin/views/contentEntries/ContentEntry/ContentEntryContext\";\nimport { FoldersProvider } from \"@webiny/app-aco/contexts/folders\";\nimport { DialogActions, DialogCancel, DialogContent, DialogTitle } from \"@webiny/ui/Dialog\";\nimport { ContentEntriesProvider } from \"~/admin/views/contentEntries/ContentEntriesContext\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { CmsContentEntry, CmsModel } from \"~/types\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks/useContentEntry\";\nimport { ModelProvider } from \"~/admin/components/ModelProvider\";\nimport { ContentEntryForm } from \"~/admin/components/ContentEntryForm/ContentEntryForm\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport {\n GET_CONTENT_MODEL,\n GetCmsModelQueryResponse,\n GetCmsModelQueryVariables\n} from \"~/admin/graphql/contentModels\";\nimport { useCms } from \"~/admin/hooks\";\nimport { FullWidthDialog } from \"./dialog/Dialog\";\nimport { NavigateFolderProvider as AbstractNavigateFolderProvider } from \"@webiny/app-aco/contexts/navigateFolder\";\nimport { SearchRecordsProvider } from \"@webiny/app-aco/contexts/records\";\nimport { FolderTree, useNavigateFolder } from \"@webiny/app-aco\";\nimport styled from \"@emotion/styled\";\nimport { Elevation } from \"@webiny/ui/Elevation\";\nimport { SplitView, LeftPanel, RightPanel } from \"@webiny/app-admin/components/SplitView\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\nimport {\n AcoAppContext,\n AcoAppProviderContext,\n createAppFromModel\n} from \"@webiny/app-aco/contexts/app\";\nimport { DialogsProvider } from \"@webiny/app-admin\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields/ref\");\n\nconst RenderBlock = styled.div`\n position: relative;\n background-color: var(--mdc-theme-background);\n padding: 25px;\n overflow: scroll;\n`;\n\nconst PaddedLeftPanel = styled(LeftPanel)`\n padding: 10px 10px 0;\n`;\n\nconst ModalRightPanel = styled(RightPanel)`\n > div {\n height: auto;\n }\n\n webiny-form-container > div {\n height: auto;\n }\n`;\n\nconst ModalFullWidthDialog = styled(FullWidthDialog)`\n .webiny-ui-dialog__content {\n height: 100%;\n > div {\n max-height: inherit;\n height: inherit;\n .mdc-layout-grid__inner {\n height: 100%;\n max-height: inherit;\n .webiny-split-view__left-panel,\n .webiny-split-view__right-panel {\n height: inherit;\n max-height: inherit;\n overflow: scroll;\n }\n }\n }\n }\n`;\n\ninterface SaveEntry {\n (): void;\n}\n\ninterface EntryFormProps {\n onCreate: (entry: CmsContentEntry) => void;\n setSaveEntry: (cb: SaveEntry) => void;\n}\n\nconst EntryForm = ({ onCreate, setSaveEntry }: EntryFormProps) => {\n const { contentModel, loading } = useContentEntry();\n const { persistEntry } = usePersistEntry({ addItemToListCache: false });\n const { currentFolderId, navigateToFolder } = useNavigateFolder();\n\n return (\n <ModelProvider model={contentModel}>\n <SplitView>\n <PaddedLeftPanel span={3}>\n <FolderTree\n focusedFolderId={currentFolderId}\n onFolderClick={data => navigateToFolder(data.id)}\n enableActions={true}\n enableCreate={true}\n />\n </PaddedLeftPanel>\n <ModalRightPanel span={9}>\n <RenderBlock>\n <Elevation z={2}>\n {loading ? <CircularProgress label={\"Creating entry...\"} /> : null}\n <ContentEntryForm\n header={false}\n entry={{}}\n persistEntry={persistEntry}\n onAfterCreate={entry => onCreate(entry)}\n setSaveEntry={setSaveEntry}\n />\n </Elevation>\n </RenderBlock>\n </ModalRightPanel>\n </SplitView>\n </ModelProvider>\n );\n};\n\ninterface NewReferencedEntryDialogProps {\n model: Pick<CmsModel, \"modelId\">;\n onClose: () => void;\n onChange: (entry: any) => void;\n}\n\nexport const NewReferencedEntryDialog = ({\n model: baseModel,\n onClose,\n onChange\n}: NewReferencedEntryDialogProps) => {\n const { apolloClient } = useCms();\n const [model, setModel] = useState<CmsModel | undefined>(undefined);\n\n useEffect(() => {\n (async () => {\n const response = await apolloClient.query<\n GetCmsModelQueryResponse,\n GetCmsModelQueryVariables\n >({\n query: GET_CONTENT_MODEL,\n variables: {\n modelId: baseModel.modelId\n }\n });\n setModel(response.data.getContentModel.data);\n })();\n }, [baseModel.modelId]);\n\n const onCreate = useCallback(\n (entry: CmsContentEntry) => {\n if (!model) {\n onClose();\n return;\n }\n onChange({\n ...entry,\n /*\n * Format data for AutoComplete.\n */\n published: entry.meta?.status === \"published\",\n modelId: model.modelId,\n modelName: model.name\n });\n onClose();\n },\n [onChange, model]\n );\n\n if (!model) {\n return null;\n }\n\n const acoAppContext: AcoAppProviderContext = {\n app: createAppFromModel({\n model,\n id: `cms:${model.modelId}`\n }),\n mode: \"cms\",\n client: apolloClient,\n model,\n folderIdPath: \"wbyAco_location.folderId\",\n folderIdInPath: \"wbyAco_location.folderId_in\",\n loading: false\n };\n\n return (\n <AcoAppContext.Provider value={acoAppContext}>\n <FoldersProvider>\n <SearchRecordsProvider>\n <NavigateFolderProvider modelId={model.modelId}>\n <DialogsProvider>\n <ContentEntriesProvider\n contentModel={model}\n key={model.modelId}\n insideDialog={true}\n >\n <ContentEntryProviderWithCurrentFolderId\n model={model}\n onClose={onClose}\n onCreate={onCreate}\n />\n </ContentEntriesProvider>\n </DialogsProvider>\n </NavigateFolderProvider>\n </SearchRecordsProvider>\n </FoldersProvider>\n </AcoAppContext.Provider>\n );\n};\n\nconst NavigateFolderProvider = ({\n modelId,\n children\n}: {\n modelId: string;\n children: React.ReactNode;\n}) => {\n const [folderId, setFolderId] = useState<string | undefined>(undefined);\n\n const navigateToFolder = useCallback((folderId: string) => {\n setFolderId(folderId);\n }, []);\n\n const navigateToListHome = useCallback(() => {\n setFolderId(undefined);\n }, []);\n\n return (\n <AbstractNavigateFolderProvider\n folderId={folderId}\n createStorageKey={() => `cms:${modelId}:create`}\n navigateToFolder={navigateToFolder}\n navigateToLatestFolder={navigateToFolder}\n navigateToListHome={navigateToListHome}\n >\n {children}\n </AbstractNavigateFolderProvider>\n );\n};\n\ninterface ContentEntryProviderWithCurrentFolderIdProps {\n model: CmsModel;\n onClose: () => void;\n onCreate: (entry: CmsContentEntry) => void;\n}\n\nconst ContentEntryProviderWithCurrentFolderId = ({\n model,\n onClose,\n onCreate\n}: ContentEntryProviderWithCurrentFolderIdProps) => {\n const saveEntryRef = useRef<SaveEntry>();\n const { currentFolderId } = useNavigateFolder();\n\n return (\n <ContentEntryProvider\n isNewEntry={() => true}\n getContentId={() => null}\n currentFolderId={currentFolderId}\n >\n <ModalFullWidthDialog open={true} onClose={onClose}>\n <DialogTitle>{t`New {modelName} Entry`({ modelName: model.name })}</DialogTitle>\n <DialogContent>\n <EntryForm\n onCreate={onCreate}\n setSaveEntry={cb => (saveEntryRef.current = cb)}\n />\n </DialogContent>\n <DialogActions>\n <DialogCancel>{t`Cancel`}</DialogCancel>\n <ButtonPrimary\n onClick={() => saveEntryRef.current && saveEntryRef.current()}\n >{t`Create Entry`}</ButtonPrimary>\n </DialogActions>\n </ModalFullWidthDialog>\n </ContentEntryProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -19,6 +19,7 @@ var _i18n = require("@webiny/app/i18n");
19
19
  var _form = require("@webiny/form");
20
20
  var _hooks = require("../../hooks");
21
21
  var _renderInfo = require("./ref/renderInfo");
22
+ var _appHeadlessCmsCommon = require("@webiny/app-headless-cms-common");
22
23
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
23
24
  var t = _i18n.i18n.ns("app-headless-cms/admin/fields");
24
25
  var RefFieldSettings = function RefFieldSettings() {
@@ -45,7 +46,12 @@ var RefFieldSettings = function RefFieldSettings() {
45
46
  // Format options for the Autocomplete component.
46
47
  var options = (0, _react.useMemo)(function () {
47
48
  var models = (0, _get.default)(data, "listContentModels.data", []);
48
- return models.map(function (model) {
49
+ return models
50
+ /**
51
+ * Remove singleton models from the list of options.
52
+ */.filter(function (model) {
53
+ return !model.tags?.includes(_appHeadlessCmsCommon.CMS_MODEL_SINGLETON_TAG);
54
+ }).map(function (model) {
49
55
  return {
50
56
  id: model.modelId,
51
57
  name: model.name
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireWildcard","require","_get","_interopRequireDefault","_viewsGraphql","_validation","_Grid","_AutoComplete","_useSnackbar2","_roundLink24px","_i18n","_form","_hooks","_renderInfo","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","t","i18n","ns","RefFieldSettings","_useModel","useModel","model","_useForm","useForm","formData","data","lockedFields","fieldId","isFieldLocked","some","lockedField","_useQuery","useQuery","LIST_CONTENT_MODELS","loading","error","_useSnackbar","useSnackbar","showSnackbar","message","options","useMemo","models","get","map","id","modelId","name","atLeastOneItem","useCallback","value","validation","validate","err","ValidationError","default","createElement","Grid","Cell","span","Bind","validators","bind","formattedValueForAutoComplete","filter","option","_ref","MultiAutoComplete","Object","assign","onChange","values","label","_taggedTemplateLiteral2","description","disabled","plugin","type","field","listValidators","icon","ReactComponent","allowMultipleValues","allowPredefinedValues","multipleValuesLabel","createField","settings","renderer","renderSettings","graphql","queryField","renderInfo","_default","exports"],"sources":["ref.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from \"react\";\nimport get from \"lodash/get\";\nimport { LIST_CONTENT_MODELS, ListCmsModelsQueryResponse } from \"../../viewsGraphql\";\nimport { validation, ValidationError } from \"@webiny/validation\";\nimport { Cell, Grid } from \"@webiny/ui/Grid\";\nimport { MultiAutoComplete } from \"@webiny/ui/AutoComplete\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport { CmsModelFieldTypePlugin, CmsModel } from \"~/types\";\nimport { ReactComponent as RefIcon } from \"./icons/round-link-24px.svg\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { Bind, BindComponentRenderProp, useForm } from \"@webiny/form\";\nimport { useQuery, useModel } from \"~/admin/hooks\";\nimport { renderInfo } from \"./ref/renderInfo\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields\");\n\nconst RefFieldSettings = () => {\n const { model } = useModel();\n const { data: formData } = useForm();\n const lockedFields = model.lockedFields || [];\n const fieldId = (formData || {}).fieldId || null;\n const isFieldLocked = lockedFields.some(\n lockedField => fieldId && lockedField.fieldId === fieldId\n );\n\n const { data, loading, error } = useQuery<ListCmsModelsQueryResponse>(LIST_CONTENT_MODELS);\n const { showSnackbar } = useSnackbar();\n\n if (error) {\n showSnackbar(error.message);\n return null;\n }\n\n // Format options for the Autocomplete component.\n const options = useMemo(() => {\n const models = get(data, \"listContentModels.data\", []) as CmsModel[];\n return models.map(model => {\n return { id: model.modelId, name: model.name };\n });\n }, [data]);\n\n const atLeastOneItem = useCallback(async (value: Pick<CmsModel, \"modelId\">) => {\n try {\n await validation.validate(value, \"required,minLength:1\");\n } catch (err) {\n throw new ValidationError(`Please select at least 1 item`);\n }\n }, []);\n\n return (\n <Grid>\n <Cell span={12}>\n <Bind name={\"settings.models\"} validators={atLeastOneItem}>\n {(bind: BindComponentRenderProp<CmsModel[]>) => {\n // Format value prop for MultiAutoComplete component.\n const formattedValueForAutoComplete = options.filter(option =>\n bind.value.some(({ modelId }) => option.id === modelId)\n );\n\n return (\n <MultiAutoComplete\n {...bind}\n value={formattedValueForAutoComplete}\n onChange={(values: CmsModel[]) => {\n bind.onChange(values.map(value => ({ modelId: value.id })));\n }}\n label={loading ? t`Loading models...` : t`Content models`}\n description={t`Cannot be changed later`}\n options={options}\n disabled={isFieldLocked || loading}\n />\n );\n }}\n </Bind>\n </Cell>\n </Grid>\n );\n};\n\nconst plugin: CmsModelFieldTypePlugin = {\n type: \"cms-editor-field-type\",\n name: \"cms-editor-field-type-ref\",\n field: {\n type: \"ref\",\n validators: [\"required\"],\n listValidators: [\"minLength\", \"maxLength\"],\n label: t`Reference`,\n description: t`Reference existing content entries. For example, a book can reference one or more authors.`,\n icon: <RefIcon />,\n allowMultipleValues: true,\n allowPredefinedValues: false,\n multipleValuesLabel: t`Use as a list of references`,\n createField() {\n return {\n type: this.type,\n settings: {\n models: []\n },\n validation: [],\n renderer: {\n name: \"\"\n }\n };\n },\n renderSettings() {\n return <RefFieldSettings />;\n },\n graphql: {\n queryField: /* GraphQL */ `\n {\n modelId\n id\n }\n `\n },\n renderInfo\n }\n};\n\nexport default plugin;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireWildcard","require","_get","_interopRequireDefault","_viewsGraphql","_validation","_Grid","_AutoComplete","_useSnackbar2","_roundLink24px","_i18n","_form","_hooks","_renderInfo","_appHeadlessCmsCommon","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","t","i18n","ns","RefFieldSettings","_useModel","useModel","model","_useForm","useForm","formData","data","lockedFields","fieldId","isFieldLocked","some","lockedField","_useQuery","useQuery","LIST_CONTENT_MODELS","loading","error","_useSnackbar","useSnackbar","showSnackbar","message","options","useMemo","models","get","filter","tags","includes","CMS_MODEL_SINGLETON_TAG","map","id","modelId","name","atLeastOneItem","useCallback","value","validation","validate","err","ValidationError","default","createElement","Grid","Cell","span","Bind","validators","bind","formattedValueForAutoComplete","option","_ref","MultiAutoComplete","Object","assign","onChange","values","label","_taggedTemplateLiteral2","description","disabled","plugin","type","field","listValidators","icon","ReactComponent","allowMultipleValues","allowPredefinedValues","multipleValuesLabel","createField","settings","renderer","renderSettings","graphql","queryField","renderInfo","_default","exports"],"sources":["ref.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from \"react\";\nimport get from \"lodash/get\";\nimport { LIST_CONTENT_MODELS, ListCmsModelsQueryResponse } from \"../../viewsGraphql\";\nimport { validation, ValidationError } from \"@webiny/validation\";\nimport { Cell, Grid } from \"@webiny/ui/Grid\";\nimport { MultiAutoComplete } from \"@webiny/ui/AutoComplete\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport { CmsModel, CmsModelFieldTypePlugin } from \"~/types\";\nimport { ReactComponent as RefIcon } from \"./icons/round-link-24px.svg\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { Bind, BindComponentRenderProp, useForm } from \"@webiny/form\";\nimport { useModel, useQuery } from \"~/admin/hooks\";\nimport { renderInfo } from \"./ref/renderInfo\";\nimport { CMS_MODEL_SINGLETON_TAG } from \"@webiny/app-headless-cms-common\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/fields\");\n\nconst RefFieldSettings = () => {\n const { model } = useModel();\n const { data: formData } = useForm();\n const lockedFields = model.lockedFields || [];\n const fieldId = (formData || {}).fieldId || null;\n const isFieldLocked = lockedFields.some(\n lockedField => fieldId && lockedField.fieldId === fieldId\n );\n\n const { data, loading, error } = useQuery<ListCmsModelsQueryResponse>(LIST_CONTENT_MODELS);\n const { showSnackbar } = useSnackbar();\n\n if (error) {\n showSnackbar(error.message);\n return null;\n }\n\n // Format options for the Autocomplete component.\n const options = useMemo(() => {\n const models = get(data, \"listContentModels.data\", []) as CmsModel[];\n return (\n models\n /**\n * Remove singleton models from the list of options.\n */\n .filter(model => {\n return !model.tags?.includes(CMS_MODEL_SINGLETON_TAG);\n })\n .map(model => {\n return { id: model.modelId, name: model.name };\n })\n );\n }, [data]);\n\n const atLeastOneItem = useCallback(async (value: Pick<CmsModel, \"modelId\">) => {\n try {\n await validation.validate(value, \"required,minLength:1\");\n } catch (err) {\n throw new ValidationError(`Please select at least 1 item`);\n }\n }, []);\n\n return (\n <Grid>\n <Cell span={12}>\n <Bind name={\"settings.models\"} validators={atLeastOneItem}>\n {(bind: BindComponentRenderProp<CmsModel[]>) => {\n // Format value prop for MultiAutoComplete component.\n const formattedValueForAutoComplete = options.filter(option =>\n bind.value.some(({ modelId }) => option.id === modelId)\n );\n\n return (\n <MultiAutoComplete\n {...bind}\n value={formattedValueForAutoComplete}\n onChange={(values: CmsModel[]) => {\n bind.onChange(values.map(value => ({ modelId: value.id })));\n }}\n label={loading ? t`Loading models...` : t`Content models`}\n description={t`Cannot be changed later`}\n options={options}\n disabled={isFieldLocked || loading}\n />\n );\n }}\n </Bind>\n </Cell>\n </Grid>\n );\n};\n\nconst plugin: CmsModelFieldTypePlugin = {\n type: \"cms-editor-field-type\",\n name: \"cms-editor-field-type-ref\",\n field: {\n type: \"ref\",\n validators: [\"required\"],\n listValidators: [\"minLength\", \"maxLength\"],\n label: t`Reference`,\n description: t`Reference existing content entries. For example, a book can reference one or more authors.`,\n icon: <RefIcon />,\n allowMultipleValues: true,\n allowPredefinedValues: false,\n multipleValuesLabel: t`Use as a list of references`,\n createField() {\n return {\n type: this.type,\n settings: {\n models: []\n },\n validation: [],\n renderer: {\n name: \"\"\n }\n };\n },\n renderSettings() {\n return <RefFieldSettings />;\n },\n graphql: {\n queryField: /* GraphQL */ `\n {\n modelId\n id\n }\n `\n },\n renderInfo\n }\n};\n\nexport default plugin;\n"],"mappings":"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","ignoreList":[]}
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- declare const _default: () => (import("@webiny/app-headless-cms-common/types").CmsEditorFormSettingsPlugin | import("@webiny/app-headless-cms-common/types").CmsIconsPlugin | import("@webiny/app-admin/types").AdminInstallationPlugin | import("@webiny/app-admin/types").AdminAppPermissionRendererPlugin | import("@webiny/app/types").RoutePlugin[] | import("@webiny/app-headless-cms-common/types").CmsFieldValueTransformer<{
2
+ declare const _default: () => (import("@webiny/app-headless-cms-common/types").CmsIconsPlugin | import("@webiny/app/types").RoutePlugin[] | import("@webiny/app-admin/types").AdminInstallationPlugin | import("@webiny/app-headless-cms-common/types").CmsFieldValueTransformer<{
3
3
  id: string;
4
4
  type: string;
5
5
  fieldId: string;
@@ -7,7 +7,7 @@ declare const _default: () => (import("@webiny/app-headless-cms-common/types").C
7
7
  label: string;
8
8
  helpText?: string | undefined;
9
9
  placeholderText?: string | undefined;
10
- validation?: (import("@webiny/validation/types").Validator | import("@webiny/app-headless-cms-common/types").CmsModelFieldValidator)[] | undefined;
10
+ validation?: (import("@webiny/app-headless-cms-common/types").CmsModelFieldValidator | import("@webiny/validation/types").Validator)[] | undefined;
11
11
  listValidation?: import("@webiny/app-headless-cms-common/types").CmsModelFieldValidator[] | undefined;
12
12
  multipleValues?: boolean | undefined;
13
13
  predefinedValues?: import("@webiny/app-headless-cms-common/types").CmsEditorFieldPredefinedValues | undefined;
@@ -17,7 +17,7 @@ declare const _default: () => (import("@webiny/app-headless-cms-common/types").C
17
17
  settings?: Record<string, any> | undefined;
18
18
  } | ((props: import("@webiny/app-headless-cms-common/types").CmsModelFieldRendererProps) => import("react").ReactNode);
19
19
  tags?: string[] | undefined;
20
- }>[] | import("@webiny/app").ApolloCacheObjectIdPlugin<import("@webiny/app").ApolloCacheObject> | {
20
+ }>[] | import("@webiny/app-headless-cms-common/types").CmsEditorFormSettingsPlugin | import("@webiny/app-admin/types").AdminAppPermissionRendererPlugin | import("@webiny/app").ApolloCacheObjectIdPlugin<import("@webiny/app").ApolloCacheObject> | {
21
21
  name: string;
22
22
  type: string;
23
23
  render(): import("react").JSX.Element;
@@ -17,6 +17,7 @@ var _RefFieldRenderer = require("../../components/ContentEntries/Filters/RefFiel
17
17
  var _ShowConfirmationOnDelete = require("../../components/Decorators/ShowConfirmationOnDelete");
18
18
  var _ShowConfirmationOnPublish = require("../../components/Decorators/ShowConfirmationOnPublish");
19
19
  var _ShowConfirmationOnUnpublish = require("../../components/Decorators/ShowConfirmationOnUnpublish");
20
+ var _ShowConfirmationOnDeleteRevision = require("../../components/Decorators/ShowConfirmationOnDeleteRevision");
20
21
  var Browser = _contentEntries.ContentEntryListConfig.Browser;
21
22
  var Actions = _contentEntries.ContentEntryEditorConfig.Actions;
22
23
  var ContentEntriesModule = exports.ContentEntriesModule = function ContentEntriesModule() {
@@ -98,7 +99,7 @@ var ContentEntriesModule = exports.ContentEntriesModule = function ContentEntrie
98
99
  name: "ref",
99
100
  element: /*#__PURE__*/_react.default.createElement(_RefFieldRenderer.Ref, null),
100
101
  type: Browser.AdvancedSearch.FieldRenderer.FieldType.REF
101
- })), /*#__PURE__*/_react.default.createElement(_contentEntries.ContentEntryEditorConfig, null, /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnPublish.ShowConfirmationOnPublish, null), /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnUnpublish.ShowConfirmationOnUnpublish, null), /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnDelete.ShowConfirmationOnDelete, null), /*#__PURE__*/_react.default.createElement(Actions.ButtonAction, {
102
+ })), /*#__PURE__*/_react.default.createElement(_contentEntries.ContentEntryEditorConfig, null, /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnPublish.ShowConfirmationOnPublish, null), /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnUnpublish.ShowConfirmationOnUnpublish, null), /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnDelete.ShowConfirmationOnDelete, null), /*#__PURE__*/_react.default.createElement(_ShowConfirmationOnDeleteRevision.ShowConfirmationOnDeleteRevision, null), /*#__PURE__*/_react.default.createElement(Actions.ButtonAction, {
102
103
  name: "save",
103
104
  element: /*#__PURE__*/_react.default.createElement(_Header.SaveContentButton, null)
104
105
  }), /*#__PURE__*/_react.default.createElement(Actions.ButtonAction, {