@webiny/app-headless-cms 5.40.6-beta.2 → 5.40.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/admin/plugins/fieldRenderers/ref/components/NewReferencedEntryDialog.js +25 -10
- package/admin/plugins/fieldRenderers/ref/components/NewReferencedEntryDialog.js.map +1 -1
- package/admin/views/contentModels/NewContentModelDialog.js +3 -9
- package/admin/views/contentModels/NewContentModelDialog.js.map +1 -1
- package/package.json +28 -28
|
@@ -24,11 +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");
|
|
31
32
|
var _usePersistEntry2 = require("../../../../hooks/usePersistEntry");
|
|
33
|
+
var _app = require("@webiny/app-aco/contexts/app");
|
|
34
|
+
var _appAdmin = require("@webiny/app-admin");
|
|
32
35
|
var _templateObject, _templateObject2, _templateObject3;
|
|
33
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)."; }
|
|
34
37
|
var t = _i18n.i18n.ns("app-headless-cms/admin/fields/ref");
|
|
@@ -43,7 +46,7 @@ var RenderBlock = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV ==
|
|
|
43
46
|
} : {
|
|
44
47
|
name: "vzed0k",
|
|
45
48
|
styles: "position:relative;background-color:var(--mdc-theme-background);padding:25px;overflow:scroll",
|
|
46
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AA4B8B","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\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\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    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"]} */",
|
|
47
50
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
48
51
|
});
|
|
49
52
|
var PaddedLeftPanel = /*#__PURE__*/(0, _base.default)(_SplitView.LeftPanel, process.env.NODE_ENV === "production" ? {
|
|
@@ -57,7 +60,7 @@ var PaddedLeftPanel = /*#__PURE__*/(0, _base.default)(_SplitView.LeftPanel, proc
|
|
|
57
60
|
} : {
|
|
58
61
|
name: "1mng3k9",
|
|
59
62
|
styles: "padding:10px 10px 0",
|
|
60
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAmCyC","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\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\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    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"]} */",
|
|
61
64
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
62
65
|
});
|
|
63
66
|
var ModalRightPanel = /*#__PURE__*/(0, _base.default)(_SplitView.RightPanel, process.env.NODE_ENV === "production" ? {
|
|
@@ -71,7 +74,7 @@ var ModalRightPanel = /*#__PURE__*/(0, _base.default)(_SplitView.RightPanel, pro
|
|
|
71
74
|
} : {
|
|
72
75
|
name: "1iiz6el",
|
|
73
76
|
styles: ">div{height:auto;}webiny-form-container>div{height:auto;}",
|
|
74
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAuC0C","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\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\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    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"]} */",
|
|
75
78
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
76
79
|
});
|
|
77
80
|
var ModalFullWidthDialog = /*#__PURE__*/(0, _base.default)(_Dialog2.FullWidthDialog, process.env.NODE_ENV === "production" ? {
|
|
@@ -85,7 +88,7 @@ var ModalFullWidthDialog = /*#__PURE__*/(0, _base.default)(_Dialog2.FullWidthDia
|
|
|
85
88
|
} : {
|
|
86
89
|
name: "1ruc94i",
|
|
87
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;}}}}",
|
|
88
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NewReferencedEntryDialog.tsx"],"names":[],"mappings":"AAiDoD","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\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\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    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"]} */",
|
|
89
92
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
90
93
|
});
|
|
91
94
|
var EntryForm = function EntryForm(_ref) {
|
|
@@ -167,19 +170,31 @@ var NewReferencedEntryDialog = exports.NewReferencedEntryDialog = function NewRe
|
|
|
167
170
|
if (!model) {
|
|
168
171
|
return null;
|
|
169
172
|
}
|
|
170
|
-
|
|
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, {
|
|
171
190
|
contentModel: model,
|
|
172
191
|
key: model.modelId,
|
|
173
192
|
insideDialog: true
|
|
174
|
-
}, /*#__PURE__*/_react.default.createElement(_folders.FoldersProvider, {
|
|
175
|
-
type: "cms:".concat(model.modelId)
|
|
176
|
-
}, /*#__PURE__*/_react.default.createElement(NavigateFolderProvider, {
|
|
177
|
-
modelId: model.modelId
|
|
178
193
|
}, /*#__PURE__*/_react.default.createElement(ContentEntryProviderWithCurrentFolderId, {
|
|
179
194
|
model: model,
|
|
180
195
|
onClose: onClose,
|
|
181
196
|
onCreate: onCreate
|
|
182
|
-
}))));
|
|
197
|
+
})))))));
|
|
183
198
|
};
|
|
184
199
|
var NavigateFolderProvider = function NavigateFolderProvider(_ref3) {
|
|
185
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","_usePersistEntry2","_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","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\";\nimport { usePersistEntry } from \"~/admin/hooks/usePersistEntry\";\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 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":[]}
|
|
@@ -113,7 +113,7 @@ var NewContentModelDialog = function NewContentModelDialog(_ref) {
|
|
|
113
113
|
}
|
|
114
114
|
return contentModelGroups[0]?.value;
|
|
115
115
|
}, [contentModelGroups]);
|
|
116
|
-
var
|
|
116
|
+
var onSubmit = (0, _react.useCallback)(async function (data) {
|
|
117
117
|
setLoading(true);
|
|
118
118
|
/**
|
|
119
119
|
* We need to make sure that tags are always an array.
|
|
@@ -148,10 +148,7 @@ var NewContentModelDialog = function NewContentModelDialog(_ref) {
|
|
|
148
148
|
group: group,
|
|
149
149
|
singleton: false
|
|
150
150
|
},
|
|
151
|
-
onSubmit:
|
|
152
|
-
console.log("submitting", data);
|
|
153
|
-
_onSubmit(data);
|
|
154
|
-
}
|
|
151
|
+
onSubmit: onSubmit
|
|
155
152
|
}, function (_ref3) {
|
|
156
153
|
var Bind = _ref3.Bind,
|
|
157
154
|
submit = _ref3.submit,
|
|
@@ -234,10 +231,7 @@ var NewContentModelDialog = function NewContentModelDialog(_ref) {
|
|
|
234
231
|
label: t(_templateObject16 || (_templateObject16 = (0, _taggedTemplateLiteral2.default)(["Create model with default fields"]))),
|
|
235
232
|
"data-testid": "cms.newcontentmodeldialog.defaultfields"
|
|
236
233
|
}))))), /*#__PURE__*/_react.default.createElement(UID.DialogActions, null, /*#__PURE__*/_react.default.createElement(_Button.ButtonPrimary, {
|
|
237
|
-
onClick:
|
|
238
|
-
console.log("submitting click", data);
|
|
239
|
-
submit(ev);
|
|
240
|
-
}
|
|
234
|
+
onClick: submit
|
|
241
235
|
}, "+ ", t(_templateObject17 || (_templateObject17 = (0, _taggedTemplateLiteral2.default)(["Create Model"]))))));
|
|
242
236
|
}));
|
|
243
237
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRouter","_form","_Input","_Select","_useSnackbar2","_Progress","_validation","_hooks","_i18n","_Button","UID","_Grid","_appHeadlessCmsCommon","_cache","GQL","_Dialog2","_apiNameValidator","_nameValidator","_Checkbox","_IconPicker","_Switch","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_templateObject10","_templateObject11","_templateObject12","_templateObject13","_templateObject14","_templateObject15","_templateObject16","_templateObject17","t","i18n","ns","NewContentModelDialog","_ref","open","onClose","_React$useState","React","useState","_React$useState2","_slicedToArray2","default","loading","setLoading","_useSnackbar","useSnackbar","showSnackbar","_useRouter","useRouter","history","client","useApolloClient","_useMutation","useMutation","CREATE_CONTENT_MODEL","onCompleted","data","_data$createContentMo","createContentModel","model","error","message","push","modelId","update","cache","_ref2","_data$createContentMo2","addModelToListCache","addModelToGroupCache","_useMutation2","listMenuGroupsQuery","useQuery","LIST_MENU_CONTENT_GROUPS_MODELS","skip","groups","useMemo","listContentModelGroups","contentModelGroups","map","item","value","id","label","name","models","reduce","collection","group","apply","_toConsumableArray2","contentModels","nameValidator","useCallback","createNameValidator","apiNameValidator","createApiNameValidator","length","undefined","onSubmit","tags","Array","isArray","singleton","CMS_MODEL_SINGLETON_TAG","pluralApiName","concat","singularApiName","variables","_objectSpread2","createElement","Dialog","Form","console","log","_ref3","Bind","submit","Fragment","CircularProgress","DialogTitle","_taggedTemplateLiteral2","DialogContent","Grid","Cell","span","validators","validation","create","Input","description","defaultValue","Switch","disabled","Select","options","IconPicker","props","Object","assign","rows","maxLength","characterCount","Checkbox","DialogActions","ButtonPrimary","onClick","ev","_default","exports"],"sources":["NewContentModelDialog.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from \"react\";\nimport { useRouter } from \"@webiny/react-router\";\nimport { Form } from \"@webiny/form\";\nimport { Input } from \"@webiny/ui/Input\";\nimport { Select } from \"@webiny/ui/Select\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { validation } from \"@webiny/validation\";\nimport { useApolloClient, useMutation, useQuery } from \"../../hooks\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport * as UID from \"@webiny/ui/Dialog\";\nimport { Cell, Grid } from \"@webiny/ui/Grid\";\nimport { CMS_MODEL_SINGLETON_TAG } from \"@webiny/app-headless-cms-common\";\nimport { addModelToGroupCache, addModelToListCache } from \"./cache\";\nimport * as GQL from \"../../viewsGraphql\";\nimport {\n CreateCmsModelMutationResponse,\n CreateCmsModelMutationVariables,\n ListMenuCmsGroupsQueryResponse\n} from \"../../viewsGraphql\";\nimport { CmsModel } from \"~/types\";\nimport { CmsGroupOption } from \"./types\";\nimport { Dialog } from \"~/admin/components/Dialog\";\nimport { createApiNameValidator } from \"~/admin/views/contentModels/helpers/apiNameValidator\";\nimport { createNameValidator } from \"~/admin/views/contentModels/helpers/nameValidator\";\nimport { Checkbox } from \"@webiny/ui/Checkbox\";\nimport { IconPicker } from \"~/admin/components/IconPicker\";\nimport { Switch } from \"@webiny/ui/Switch\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/views/content-models/new-content-model-dialog\");\n\nexport interface NewContentModelDialogProps {\n open: boolean;\n onClose: UID.DialogOnClose;\n}\n\ninterface CmsModelData {\n name: string;\n description: string;\n group: string;\n singleton?: boolean;\n singularApiName: string;\n pluralApiName: string;\n defaultFields: boolean;\n}\n\nconst NewContentModelDialog = ({ open, onClose }: NewContentModelDialogProps) => {\n const [loading, setLoading] = React.useState(false);\n const { showSnackbar } = useSnackbar();\n const { history } = useRouter();\n const client = useApolloClient();\n\n const [createContentModel] = useMutation<\n CreateCmsModelMutationResponse,\n CreateCmsModelMutationVariables\n >(GQL.CREATE_CONTENT_MODEL, {\n onCompleted(data) {\n setLoading(false);\n\n if (!data) {\n showSnackbar(\"Missing data on Create Content Model Mutation Response.\");\n return;\n }\n\n const { data: model, error } = data.createContentModel;\n\n if (error) {\n setLoading(false);\n showSnackbar(error.message);\n return;\n }\n\n history.push(\"/cms/content-models/\" + model.modelId);\n },\n update(cache, { data }) {\n if (!data) {\n return;\n }\n\n const { data: model, error } = data.createContentModel;\n\n if (error) {\n return;\n }\n\n addModelToListCache(cache, model);\n addModelToGroupCache(cache, model);\n }\n });\n\n const listMenuGroupsQuery = useQuery<ListMenuCmsGroupsQueryResponse>(\n GQL.LIST_MENU_CONTENT_GROUPS_MODELS,\n {\n skip: !open\n }\n );\n\n const groups = useMemo(() => {\n return listMenuGroupsQuery.data?.listContentModelGroups?.data || [];\n }, [listMenuGroupsQuery.data]);\n\n const contentModelGroups = useMemo(() => {\n return groups.map((item): CmsGroupOption => {\n return {\n value: item.id,\n label: item.name\n };\n });\n }, [groups]);\n\n const models = useMemo(() => {\n return groups.reduce<CmsModel[]>((collection, group) => {\n collection.push(...group.contentModels);\n return collection;\n }, []);\n }, [groups]);\n\n const nameValidator = useCallback(createNameValidator({ models }), [models]);\n\n const apiNameValidator = useCallback(createApiNameValidator({ client, models }), [\n client,\n models\n ]);\n\n const group = useMemo<string | undefined>(() => {\n if (!contentModelGroups.length) {\n return undefined;\n }\n return contentModelGroups[0]?.value;\n }, [contentModelGroups]);\n\n const onSubmit = useCallback(\n async (data: CmsModelData) => {\n setLoading(true);\n /**\n * We need to make sure that tags are always an array.\n * At the moment there is no tags on the CmsModelData type.\n * If it is added at some point, the @ts-expect-error should be removed - it will cause TS error.\n */\n // @ts-expect-error\n const tags: string[] = Array.isArray(data.tags) ? data.tags : [];\n /**\n * If a model is a singleton, we add a special tag to it.\n * + we need to put the pluralApiName to something that is not used.\n */\n if (data.singleton) {\n tags.push(CMS_MODEL_SINGLETON_TAG);\n data.pluralApiName = `${data.singularApiName}Unused`;\n }\n delete data.singleton;\n await createContentModel({\n variables: {\n data: {\n ...data,\n tags\n }\n }\n });\n },\n [loading, createContentModel]\n );\n\n return (\n <Dialog open={open} onClose={onClose} data-testid=\"cms-new-content-model-modal\">\n {open && (\n <Form<CmsModelData>\n data={{ group, singleton: false }}\n onSubmit={data => {\n console.log(\"submitting\", data);\n onSubmit(data);\n }}\n >\n {({ Bind, submit, data }) => {\n return (\n <>\n {loading && (\n <CircularProgress label={\"Creating content model...\"} />\n )}\n <UID.DialogTitle>{t`New Content Model`}</UID.DialogTitle>\n <UID.DialogContent>\n <Grid>\n <Cell span={12}>\n <Bind\n name={\"name\"}\n validators={[\n validation.create(\"required,maxLength:100\"),\n nameValidator\n ]}\n >\n <Input\n label={t`Name`}\n description={t`The name of the content model. Use the singular form, e.g. Author Category, not Author Categories.`}\n data-testid=\"cms.newcontentmodeldialog.name\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"singularApiName\"}\n validators={[\n validation.create(\"required,maxLength:100\"),\n apiNameValidator\n ]}\n >\n <Input\n label={t`Singular API Name`}\n description={t`The API name of the content model. For example: AuthorCategory.`}\n data-testid=\"cms.newcontentmodeldialog.singularApiName\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name={\"singleton\"} defaultValue={false}>\n <Switch\n description={t`Create a model that can hold only one entry. Cannot be changed later.`}\n label={t`Single entry model`}\n data-testid=\"cms.newcontentmodeldialog.singleton\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"pluralApiName\"}\n validators={\n data.singleton\n ? []\n : [\n validation.create(\n \"required,maxLength:100\"\n ),\n apiNameValidator\n ]\n }\n >\n <Input\n disabled={data.singleton}\n label={t`Plural API Name`}\n description={t`The plural API name of the content model. For example: AuthorCategories.`}\n data-testid=\"cms.newcontentmodeldialog.pluralApiName\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"group\"}\n validators={validation.create(\"required\")}\n >\n <Select\n description={t`Choose a content model group`}\n label={t`Content model group`}\n options={contentModelGroups}\n data-testid=\"cms.newcontentmodeldialog.selectgroup\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"icon\">\n <IconPicker\n label={t`Icon`}\n description={t`Choose an icon to represent the model.`}\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"description\">\n {props => (\n <Input\n {...props}\n rows={4}\n maxLength={200}\n characterCount\n label={t`Description`}\n data-testid=\"cms.newcontentmodeldialog.description\"\n />\n )}\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name={\"defaultFields\"} defaultValue={true}>\n <Checkbox\n description={t`Create model with default title (text), description (long text) and image (file) fields`}\n label={t`Create model with default fields`}\n data-testid=\"cms.newcontentmodeldialog.defaultfields\"\n />\n </Bind>\n </Cell>\n </Grid>\n </UID.DialogContent>\n <UID.DialogActions>\n <ButtonPrimary\n onClick={ev => {\n console.log(\"submitting click\", data);\n submit(ev);\n }}\n >\n + {t`Create Model`}\n </ButtonPrimary>\n </UID.DialogActions>\n </>\n );\n }}\n </Form>\n )}\n </Dialog>\n );\n};\n\nexport default NewContentModelDialog;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRouter","_form","_Input","_Select","_useSnackbar2","_Progress","_validation","_hooks","_i18n","_Button","UID","_Grid","_appHeadlessCmsCommon","_cache","GQL","_Dialog2","_apiNameValidator","_nameValidator","_Checkbox","_IconPicker","_Switch","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_templateObject10","_templateObject11","_templateObject12","_templateObject13","_templateObject14","_templateObject15","_templateObject16","_templateObject17","t","i18n","ns","NewContentModelDialog","_ref","open","onClose","_React$useState","React","useState","_React$useState2","_slicedToArray2","default","loading","setLoading","_useSnackbar","useSnackbar","showSnackbar","_useRouter","useRouter","history","client","useApolloClient","_useMutation","useMutation","CREATE_CONTENT_MODEL","onCompleted","data","_data$createContentMo","createContentModel","model","error","message","push","modelId","update","cache","_ref2","_data$createContentMo2","addModelToListCache","addModelToGroupCache","_useMutation2","listMenuGroupsQuery","useQuery","LIST_MENU_CONTENT_GROUPS_MODELS","skip","groups","useMemo","listContentModelGroups","contentModelGroups","map","item","value","id","label","name","models","reduce","collection","group","apply","_toConsumableArray2","contentModels","nameValidator","useCallback","createNameValidator","apiNameValidator","createApiNameValidator","length","undefined","onSubmit","tags","Array","isArray","singleton","CMS_MODEL_SINGLETON_TAG","pluralApiName","concat","singularApiName","variables","_objectSpread2","createElement","Dialog","Form","_ref3","Bind","submit","Fragment","CircularProgress","DialogTitle","_taggedTemplateLiteral2","DialogContent","Grid","Cell","span","validators","validation","create","Input","description","defaultValue","Switch","disabled","Select","options","IconPicker","props","Object","assign","rows","maxLength","characterCount","Checkbox","DialogActions","ButtonPrimary","onClick","_default","exports"],"sources":["NewContentModelDialog.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from \"react\";\nimport { useRouter } from \"@webiny/react-router\";\nimport { Form } from \"@webiny/form\";\nimport { Input } from \"@webiny/ui/Input\";\nimport { Select } from \"@webiny/ui/Select\";\nimport { useSnackbar } from \"@webiny/app-admin/hooks/useSnackbar\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { validation } from \"@webiny/validation\";\nimport { useApolloClient, useMutation, useQuery } from \"../../hooks\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport { ButtonPrimary } from \"@webiny/ui/Button\";\nimport * as UID from \"@webiny/ui/Dialog\";\nimport { Cell, Grid } from \"@webiny/ui/Grid\";\nimport { CMS_MODEL_SINGLETON_TAG } from \"@webiny/app-headless-cms-common\";\nimport { addModelToGroupCache, addModelToListCache } from \"./cache\";\nimport * as GQL from \"../../viewsGraphql\";\nimport {\n CreateCmsModelMutationResponse,\n CreateCmsModelMutationVariables,\n ListMenuCmsGroupsQueryResponse\n} from \"../../viewsGraphql\";\nimport { CmsModel } from \"~/types\";\nimport { CmsGroupOption } from \"./types\";\nimport { Dialog } from \"~/admin/components/Dialog\";\nimport { createApiNameValidator } from \"~/admin/views/contentModels/helpers/apiNameValidator\";\nimport { createNameValidator } from \"~/admin/views/contentModels/helpers/nameValidator\";\nimport { Checkbox } from \"@webiny/ui/Checkbox\";\nimport { IconPicker } from \"~/admin/components/IconPicker\";\nimport { Switch } from \"@webiny/ui/Switch\";\n\nconst t = i18n.ns(\"app-headless-cms/admin/views/content-models/new-content-model-dialog\");\n\nexport interface NewContentModelDialogProps {\n open: boolean;\n onClose: UID.DialogOnClose;\n}\n\ninterface CmsModelData {\n name: string;\n description: string;\n group: string;\n singleton?: boolean;\n singularApiName: string;\n pluralApiName: string;\n defaultFields: boolean;\n}\n\nconst NewContentModelDialog = ({ open, onClose }: NewContentModelDialogProps) => {\n const [loading, setLoading] = React.useState(false);\n const { showSnackbar } = useSnackbar();\n const { history } = useRouter();\n const client = useApolloClient();\n\n const [createContentModel] = useMutation<\n CreateCmsModelMutationResponse,\n CreateCmsModelMutationVariables\n >(GQL.CREATE_CONTENT_MODEL, {\n onCompleted(data) {\n setLoading(false);\n\n if (!data) {\n showSnackbar(\"Missing data on Create Content Model Mutation Response.\");\n return;\n }\n\n const { data: model, error } = data.createContentModel;\n\n if (error) {\n setLoading(false);\n showSnackbar(error.message);\n return;\n }\n\n history.push(\"/cms/content-models/\" + model.modelId);\n },\n update(cache, { data }) {\n if (!data) {\n return;\n }\n\n const { data: model, error } = data.createContentModel;\n\n if (error) {\n return;\n }\n\n addModelToListCache(cache, model);\n addModelToGroupCache(cache, model);\n }\n });\n\n const listMenuGroupsQuery = useQuery<ListMenuCmsGroupsQueryResponse>(\n GQL.LIST_MENU_CONTENT_GROUPS_MODELS,\n {\n skip: !open\n }\n );\n\n const groups = useMemo(() => {\n return listMenuGroupsQuery.data?.listContentModelGroups?.data || [];\n }, [listMenuGroupsQuery.data]);\n\n const contentModelGroups = useMemo(() => {\n return groups.map((item): CmsGroupOption => {\n return {\n value: item.id,\n label: item.name\n };\n });\n }, [groups]);\n\n const models = useMemo(() => {\n return groups.reduce<CmsModel[]>((collection, group) => {\n collection.push(...group.contentModels);\n return collection;\n }, []);\n }, [groups]);\n\n const nameValidator = useCallback(createNameValidator({ models }), [models]);\n\n const apiNameValidator = useCallback(createApiNameValidator({ client, models }), [\n client,\n models\n ]);\n\n const group = useMemo<string | undefined>(() => {\n if (!contentModelGroups.length) {\n return undefined;\n }\n return contentModelGroups[0]?.value;\n }, [contentModelGroups]);\n\n const onSubmit = useCallback(\n async (data: CmsModelData) => {\n setLoading(true);\n /**\n * We need to make sure that tags are always an array.\n * At the moment there is no tags on the CmsModelData type.\n * If it is added at some point, the @ts-expect-error should be removed - it will cause TS error.\n */\n // @ts-expect-error\n const tags: string[] = Array.isArray(data.tags) ? data.tags : [];\n /**\n * If a model is a singleton, we add a special tag to it.\n * + we need to put the pluralApiName to something that is not used.\n */\n if (data.singleton) {\n tags.push(CMS_MODEL_SINGLETON_TAG);\n data.pluralApiName = `${data.singularApiName}Unused`;\n }\n delete data.singleton;\n await createContentModel({\n variables: {\n data: {\n ...data,\n tags\n }\n }\n });\n },\n [loading, createContentModel]\n );\n\n return (\n <Dialog open={open} onClose={onClose} data-testid=\"cms-new-content-model-modal\">\n {open && (\n <Form<CmsModelData> data={{ group, singleton: false }} onSubmit={onSubmit}>\n {({ Bind, submit, data }) => {\n return (\n <>\n {loading && (\n <CircularProgress label={\"Creating content model...\"} />\n )}\n <UID.DialogTitle>{t`New Content Model`}</UID.DialogTitle>\n <UID.DialogContent>\n <Grid>\n <Cell span={12}>\n <Bind\n name={\"name\"}\n validators={[\n validation.create(\"required,maxLength:100\"),\n nameValidator\n ]}\n >\n <Input\n label={t`Name`}\n description={t`The name of the content model. Use the singular form, e.g. Author Category, not Author Categories.`}\n data-testid=\"cms.newcontentmodeldialog.name\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"singularApiName\"}\n validators={[\n validation.create(\"required,maxLength:100\"),\n apiNameValidator\n ]}\n >\n <Input\n label={t`Singular API Name`}\n description={t`The API name of the content model. For example: AuthorCategory.`}\n data-testid=\"cms.newcontentmodeldialog.singularApiName\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name={\"singleton\"} defaultValue={false}>\n <Switch\n description={t`Create a model that can hold only one entry. Cannot be changed later.`}\n label={t`Single entry model`}\n data-testid=\"cms.newcontentmodeldialog.singleton\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"pluralApiName\"}\n validators={\n data.singleton\n ? []\n : [\n validation.create(\n \"required,maxLength:100\"\n ),\n apiNameValidator\n ]\n }\n >\n <Input\n disabled={data.singleton}\n label={t`Plural API Name`}\n description={t`The plural API name of the content model. For example: AuthorCategories.`}\n data-testid=\"cms.newcontentmodeldialog.pluralApiName\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind\n name={\"group\"}\n validators={validation.create(\"required\")}\n >\n <Select\n description={t`Choose a content model group`}\n label={t`Content model group`}\n options={contentModelGroups}\n data-testid=\"cms.newcontentmodeldialog.selectgroup\"\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"icon\">\n <IconPicker\n label={t`Icon`}\n description={t`Choose an icon to represent the model.`}\n />\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name=\"description\">\n {props => (\n <Input\n {...props}\n rows={4}\n maxLength={200}\n characterCount\n label={t`Description`}\n data-testid=\"cms.newcontentmodeldialog.description\"\n />\n )}\n </Bind>\n </Cell>\n <Cell span={12}>\n <Bind name={\"defaultFields\"} defaultValue={true}>\n <Checkbox\n description={t`Create model with default title (text), description (long text) and image (file) fields`}\n label={t`Create model with default fields`}\n data-testid=\"cms.newcontentmodeldialog.defaultfields\"\n />\n </Bind>\n </Cell>\n </Grid>\n </UID.DialogContent>\n <UID.DialogActions>\n <ButtonPrimary onClick={submit}>\n + {t`Create Model`}\n </ButtonPrimary>\n </UID.DialogActions>\n </>\n );\n }}\n </Form>\n )}\n </Dialog>\n );\n};\n\nexport default NewContentModelDialog;\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/app-headless-cms",
|
|
3
|
-
"version": "5.40.6
|
|
3
|
+
"version": "5.40.6",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -28,30 +28,30 @@
|
|
|
28
28
|
"@material-design-icons/svg": "0.14.13",
|
|
29
29
|
"@svgr/webpack": "6.5.1",
|
|
30
30
|
"@types/react": "18.2.79",
|
|
31
|
-
"@webiny/app": "5.40.6
|
|
32
|
-
"@webiny/app-aco": "5.40.6
|
|
33
|
-
"@webiny/app-admin": "5.40.6
|
|
34
|
-
"@webiny/app-graphql-playground": "5.40.6
|
|
35
|
-
"@webiny/app-headless-cms-common": "5.40.6
|
|
36
|
-
"@webiny/app-i18n": "5.40.6
|
|
37
|
-
"@webiny/app-plugin-admin-welcome-screen": "5.40.6
|
|
38
|
-
"@webiny/app-security": "5.40.6
|
|
39
|
-
"@webiny/app-tenancy": "5.40.6
|
|
40
|
-
"@webiny/app-trash-bin": "5.40.6
|
|
41
|
-
"@webiny/error": "5.40.6
|
|
42
|
-
"@webiny/feature-flags": "5.40.6
|
|
43
|
-
"@webiny/form": "5.40.6
|
|
44
|
-
"@webiny/lexical-editor": "5.40.6
|
|
45
|
-
"@webiny/lexical-nodes": "5.40.6
|
|
46
|
-
"@webiny/lexical-theme": "5.40.6
|
|
47
|
-
"@webiny/plugins": "5.40.6
|
|
48
|
-
"@webiny/react-composition": "5.40.6
|
|
49
|
-
"@webiny/react-properties": "5.40.6
|
|
50
|
-
"@webiny/react-router": "5.40.6
|
|
51
|
-
"@webiny/theme": "5.40.6
|
|
52
|
-
"@webiny/ui": "5.40.6
|
|
53
|
-
"@webiny/utils": "5.40.6
|
|
54
|
-
"@webiny/validation": "5.40.6
|
|
31
|
+
"@webiny/app": "5.40.6",
|
|
32
|
+
"@webiny/app-aco": "5.40.6",
|
|
33
|
+
"@webiny/app-admin": "5.40.6",
|
|
34
|
+
"@webiny/app-graphql-playground": "5.40.6",
|
|
35
|
+
"@webiny/app-headless-cms-common": "5.40.6",
|
|
36
|
+
"@webiny/app-i18n": "5.40.6",
|
|
37
|
+
"@webiny/app-plugin-admin-welcome-screen": "5.40.6",
|
|
38
|
+
"@webiny/app-security": "5.40.6",
|
|
39
|
+
"@webiny/app-tenancy": "5.40.6",
|
|
40
|
+
"@webiny/app-trash-bin": "5.40.6",
|
|
41
|
+
"@webiny/error": "5.40.6",
|
|
42
|
+
"@webiny/feature-flags": "5.40.6",
|
|
43
|
+
"@webiny/form": "5.40.6",
|
|
44
|
+
"@webiny/lexical-editor": "5.40.6",
|
|
45
|
+
"@webiny/lexical-nodes": "5.40.6",
|
|
46
|
+
"@webiny/lexical-theme": "5.40.6",
|
|
47
|
+
"@webiny/plugins": "5.40.6",
|
|
48
|
+
"@webiny/react-composition": "5.40.6",
|
|
49
|
+
"@webiny/react-properties": "5.40.6",
|
|
50
|
+
"@webiny/react-router": "5.40.6",
|
|
51
|
+
"@webiny/theme": "5.40.6",
|
|
52
|
+
"@webiny/ui": "5.40.6",
|
|
53
|
+
"@webiny/utils": "5.40.6",
|
|
54
|
+
"@webiny/validation": "5.40.6",
|
|
55
55
|
"apollo-cache": "1.3.5",
|
|
56
56
|
"apollo-client": "2.6.10",
|
|
57
57
|
"apollo-link": "1.2.14",
|
|
@@ -85,8 +85,8 @@
|
|
|
85
85
|
"@babel/preset-react": "7.24.1",
|
|
86
86
|
"@babel/preset-typescript": "7.24.1",
|
|
87
87
|
"@emotion/babel-plugin": "11.11.0",
|
|
88
|
-
"@webiny/cli": "5.40.6
|
|
89
|
-
"@webiny/project-utils": "5.40.6
|
|
88
|
+
"@webiny/cli": "5.40.6",
|
|
89
|
+
"@webiny/project-utils": "5.40.6",
|
|
90
90
|
"babel-plugin-module-resolver": "5.0.0",
|
|
91
91
|
"rimraf": "5.0.5",
|
|
92
92
|
"ttypescript": "1.5.15",
|
|
@@ -115,5 +115,5 @@
|
|
|
115
115
|
]
|
|
116
116
|
}
|
|
117
117
|
},
|
|
118
|
-
"gitHead": "
|
|
118
|
+
"gitHead": "f9da84b373e62f9f269599c4301e5e4418a98d51"
|
|
119
119
|
}
|