@webiny/app-dynamic-pages 5.43.2 → 6.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/admin/ContentEntryForm/AddPreviewPane.js +24 -29
- package/admin/ContentEntryForm/AddPreviewPane.js.map +1 -1
- package/admin/ContentEntryForm/PassEntryToDataSource.js +39 -59
- package/admin/ContentEntryForm/PassEntryToDataSource.js.map +1 -1
- package/admin/ContentEntryForm/PreviewPane.js +21 -30
- package/admin/ContentEntryForm/PreviewPane.js.map +1 -1
- package/admin/Extensions.js +9 -18
- package/admin/Extensions.js.map +1 -1
- package/admin/PageTemplateDialog/CreateTemplateDialog.js +89 -92
- package/admin/PageTemplateDialog/CreateTemplateDialog.js.map +1 -1
- package/admin/PageTemplateDialog/PageTemplateDialog.js +24 -35
- package/admin/PageTemplateDialog/PageTemplateDialog.js.map +1 -1
- package/admin/SetupDynamicPages.js +13 -20
- package/admin/SetupDynamicPages.js.map +1 -1
- package/admin/elements/Elements.js +9 -16
- package/admin/elements/Elements.js.map +1 -1
- package/admin/elements/entriesList.js +12 -19
- package/admin/elements/entriesList.js.map +1 -1
- package/admin/elements/entriesSearch.js +10 -17
- package/admin/elements/entriesSearch.js.map +1 -1
- package/admin/elements/eventHandlers/ContentTraverser.js +7 -32
- package/admin/elements/eventHandlers/ContentTraverser.js.map +1 -1
- package/admin/elements/renderers/DynamicGrid.js +26 -32
- package/admin/elements/renderers/DynamicGrid.js.map +1 -1
- package/admin/elements/renderers/EntriesList.js +11 -19
- package/admin/elements/renderers/EntriesList.js.map +1 -1
- package/admin/elements/renderers/Repeater.js +11 -19
- package/admin/elements/renderers/Repeater.js.map +1 -1
- package/admin/elements/repeater.js +10 -17
- package/admin/elements/repeater.js.map +1 -1
- package/admin/index.js +1 -12
- package/admin/index.js.map +1 -1
- package/admin/pageEditor/DynamicPageEditorConfig.js +7 -14
- package/admin/pageEditor/DynamicPageEditorConfig.js.map +1 -1
- package/admin/pageEditor/ElementEventHandlers.js +52 -59
- package/admin/pageEditor/ElementEventHandlers.js.map +1 -1
- package/admin/templateEditor/DynamicTemplateEditorConfig.js +22 -25
- package/admin/templateEditor/DynamicTemplateEditorConfig.js.map +1 -1
- package/admin/templateEditor/ElementEventHandlers.js +52 -59
- package/admin/templateEditor/ElementEventHandlers.js.map +1 -1
- package/admin/templateEditor/EntrySelector/EntrySelector.js +16 -27
- package/admin/templateEditor/EntrySelector/EntrySelector.js.map +1 -1
- package/admin/templateEditor/EntrySelector/index.js +1 -16
- package/admin/templateEditor/EntrySelector/index.js.map +1 -1
- package/dataInjection/AddEntriesListDataSourceContext.js +14 -20
- package/dataInjection/AddEntriesListDataSourceContext.js.map +1 -1
- package/dataInjection/editor/DisableGridDelete.js +10 -15
- package/dataInjection/editor/DisableGridDelete.js.map +1 -1
- package/dataInjection/editor/ElementDataSettings.js +13 -20
- package/dataInjection/editor/ElementDataSettings.js.map +1 -1
- package/dataInjection/editor/HideIfChildOfEntriesList.js +10 -18
- package/dataInjection/editor/HideIfChildOfEntriesList.js.map +1 -1
- package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js +16 -25
- package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js.map +1 -1
- package/dataInjection/editor/SetupElementDataSettings.js +9 -14
- package/dataInjection/editor/SetupElementDataSettings.js.map +1 -1
- package/dataInjection/renderers/DynamicElementRenderers.js +14 -21
- package/dataInjection/renderers/DynamicElementRenderers.js.map +1 -1
- package/dataInjection/renderers/DynamicGrid.js +24 -30
- package/dataInjection/renderers/DynamicGrid.js.map +1 -1
- package/dataInjection/renderers/EntriesList.js +20 -26
- package/dataInjection/renderers/EntriesList.js.map +1 -1
- package/dataInjection/renderers/EntriesSearch.js +9 -21
- package/dataInjection/renderers/EntriesSearch.js.map +1 -1
- package/dataInjection/renderers/Repeater.js +20 -26
- package/dataInjection/renderers/Repeater.js.map +1 -1
- package/features/index.js +3 -38
- package/features/index.js.map +1 -1
- package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js +18 -25
- package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js.map +1 -1
- package/features/pageTemplate/hasMainDataSource.js +2 -10
- package/features/pageTemplate/hasMainDataSource.js.map +1 -1
- package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js +8 -15
- package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js.map +1 -1
- package/package.json +12 -13
|
@@ -1,31 +1,33 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports.CreateTemplateDialog = void 0;
|
|
9
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
-
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
12
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
-
var _emotion = require("emotion");
|
|
14
|
-
var _reactFontawesome = require("@fortawesome/react-fontawesome");
|
|
15
|
-
var _Icon = require("@webiny/ui/Icon");
|
|
16
|
-
var _Button = require("@webiny/ui/Button");
|
|
17
|
-
var _List = require("@webiny/ui/List");
|
|
18
|
-
var _Dialog = require("@webiny/ui/Dialog");
|
|
19
|
-
var _Progress = require("@webiny/ui/Progress");
|
|
20
|
-
var _appHeadlessCms = require("@webiny/app-headless-cms");
|
|
21
|
-
var _keyboard_arrow_right = require("@material-design-icons/svg/round/keyboard_arrow_right.svg");
|
|
22
|
-
var _info = require("@material-design-icons/svg/outlined/info.svg");
|
|
23
|
-
var _article = require("@material-design-icons/svg/outlined/article.svg");
|
|
24
|
-
var _dashboard = require("@material-design-icons/svg/outlined/dashboard.svg");
|
|
25
|
-
var _templateObject, _templateObject2;
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
26
2
|
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)."; }
|
|
27
|
-
|
|
28
|
-
|
|
3
|
+
import React, { useState } from "react";
|
|
4
|
+
import { css } from "emotion";
|
|
5
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
6
|
+
import { Icon } from "@webiny/ui/Icon";
|
|
7
|
+
import { ButtonDefault } from "@webiny/ui/Button";
|
|
8
|
+
import { List, ListItem } from "@webiny/ui/List";
|
|
9
|
+
import { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from "@webiny/ui/Dialog";
|
|
10
|
+
import { CircularProgress } from "@webiny/ui/Progress";
|
|
11
|
+
import { useModels } from "@webiny/app-headless-cms";
|
|
12
|
+
import { ReactComponent as ArrowRightIcon } from "@webiny/icons/keyboard_arrow_right.svg";
|
|
13
|
+
import { ReactComponent as InfoIcon } from "@webiny/icons/info.svg";
|
|
14
|
+
import { ReactComponent as ArticleIcon } from "@webiny/icons/article.svg";
|
|
15
|
+
import { ReactComponent as DatabaseIcon } from "@webiny/icons/dashboard.svg";
|
|
16
|
+
const dialogStyles = css`
|
|
17
|
+
.mdc-dialog__surface {
|
|
18
|
+
width: 600px;
|
|
19
|
+
min-width: 600px;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.mdc-dialog__content {
|
|
23
|
+
padding-top: 0 !important;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.content-wrapper:focus-visible {
|
|
27
|
+
outline: none;
|
|
28
|
+
}
|
|
29
|
+
`;
|
|
30
|
+
const Info = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
29
31
|
target: "e1ualc005"
|
|
30
32
|
} : {
|
|
31
33
|
target: "e1ualc005",
|
|
@@ -36,10 +38,10 @@ var Info = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "prod
|
|
|
36
38
|
} : {
|
|
37
39
|
name: "1ci36am",
|
|
38
40
|
styles: "display:flex;align-items:center;padding:12px;margin-top:12px;background:var(--mdc-theme-background);color:var(--mdc-theme-text-secondary-on-background);fill:var(--mdc-theme-text-secondary-on-background);cursor:pointer;& svg{margin-right:12px;}",
|
|
39
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAkCuB","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
41
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAkCuB","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
40
42
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
41
43
|
});
|
|
42
|
-
|
|
44
|
+
const ListItemStyled = /*#__PURE__*/_styled(ListItem, process.env.NODE_ENV === "production" ? {
|
|
43
45
|
target: "e1ualc004"
|
|
44
46
|
} : {
|
|
45
47
|
target: "e1ualc004",
|
|
@@ -50,10 +52,10 @@ var ListItemStyled = /*#__PURE__*/(0, _base.default)(_List.ListItem, process.env
|
|
|
50
52
|
} : {
|
|
51
53
|
name: "mv3wdt",
|
|
52
54
|
styles: "padding-top:8px;padding-bottom:8px;height:auto;min-height:64px;color:var(--mdc-theme-text-secondary-on-background);fill:var(--mdc-theme-text-secondary-on-background);& svg{flex-shrink:0;}.arrow-right{margin-left:auto;}",
|
|
53
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAiDuC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
55
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAiDuC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
54
56
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
57
|
});
|
|
56
|
-
|
|
58
|
+
const ListItemContent = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
57
59
|
target: "e1ualc003"
|
|
58
60
|
} : {
|
|
59
61
|
target: "e1ualc003",
|
|
@@ -64,10 +66,10 @@ var ListItemContent = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_EN
|
|
|
64
66
|
} : {
|
|
65
67
|
name: "1i68tbr",
|
|
66
68
|
styles: "display:grid;padding-left:21px;padding-right:21px",
|
|
67
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAkEkC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
69
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAkEkC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
68
70
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
69
71
|
});
|
|
70
|
-
|
|
72
|
+
const Title = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
71
73
|
target: "e1ualc002"
|
|
72
74
|
} : {
|
|
73
75
|
target: "e1ualc002",
|
|
@@ -78,10 +80,10 @@ var Title = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "pro
|
|
|
78
80
|
} : {
|
|
79
81
|
name: "14is9qy",
|
|
80
82
|
styles: "font-size:20px",
|
|
81
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAwEwB","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
83
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAwEwB","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
82
84
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
83
85
|
});
|
|
84
|
-
|
|
86
|
+
const Highlight = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
85
87
|
target: "e1ualc001"
|
|
86
88
|
} : {
|
|
87
89
|
target: "e1ualc001",
|
|
@@ -92,10 +94,10 @@ var Highlight = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV ===
|
|
|
92
94
|
} : {
|
|
93
95
|
name: "1re7mf9",
|
|
94
96
|
styles: "color:var(--mdc-theme-primary)",
|
|
95
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AA4E4B","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
97
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AA4E4B","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
96
98
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
97
99
|
});
|
|
98
|
-
|
|
100
|
+
const DynamicTemplatesInfo = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
99
101
|
target: "e1ualc000"
|
|
100
102
|
} : {
|
|
101
103
|
target: "e1ualc000",
|
|
@@ -106,13 +108,16 @@ var DynamicTemplatesInfo = /*#__PURE__*/(0, _base.default)("div", process.env.NO
|
|
|
106
108
|
} : {
|
|
107
109
|
name: "17uojnc",
|
|
108
110
|
styles: "padding:24px;font-size:20px;line-height:24px;color:var(--mdc-theme-text-secondary-on-background)",
|
|
109
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAgFuC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@material-design-icons/svg/round/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@material-design-icons/svg/outlined/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@material-design-icons/svg/outlined/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@material-design-icons/svg/outlined/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
111
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CreateTemplateDialog.tsx"],"names":[],"mappings":"AAgFuC","file":"CreateTemplateDialog.tsx","sourcesContent":["import React, { useState } from \"react\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\n\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { ButtonDefault } from \"@webiny/ui/Button\";\nimport { List, ListItem } from \"@webiny/ui/List\";\nimport { Dialog, DialogTitle, DialogContent, DialogActions, DialogCancel } from \"@webiny/ui/Dialog\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { useModels } from \"@webiny/app-headless-cms\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\n\nimport { ReactComponent as ArrowRightIcon } from \"@webiny/icons/keyboard_arrow_right.svg\";\nimport { ReactComponent as InfoIcon } from \"@webiny/icons/info.svg\";\nimport { ReactComponent as ArticleIcon } from \"@webiny/icons/article.svg\";\nimport { ReactComponent as DatabaseIcon } from \"@webiny/icons/dashboard.svg\";\n\nconst dialogStyles = css`\n    .mdc-dialog__surface {\n        width: 600px;\n        min-width: 600px;\n    }\n\n    .mdc-dialog__content {\n        padding-top: 0 !important;\n    }\n\n    .content-wrapper:focus-visible {\n        outline: none;\n    }\n`;\n\nconst Info = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 12px;\n    margin-top: 12px;\n    background: var(--mdc-theme-background);\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n    cursor: pointer;\n\n    & svg {\n        margin-right: 12px;\n    }\n`;\n\nconst ListItemStyled = styled(ListItem)`\n    padding-top: 8px;\n    padding-bottom: 8px;\n    height: auto;\n    min-height: 64px;\n    color: var(--mdc-theme-text-secondary-on-background);\n    fill: var(--mdc-theme-text-secondary-on-background);\n\n    & svg {\n        flex-shrink: 0;\n    }\n\n    .arrow-right {\n        margin-left: auto;\n    }\n`;\n\nconst ListItemContent = styled.div`\n    display: grid;\n    padding-left: 21px;\n    padding-right: 21px;\n`;\n\nconst Title = styled.div`\n    font-size: 20px;\n`;\n\nconst Highlight = styled.div`\n    color: var(--mdc-theme-primary);\n`;\n\nconst DynamicTemplatesInfo = styled.div`\n    padding: 24px;\n    font-size: 20px;\n    line-height: 24px;\n    color: var(--mdc-theme-text-secondary-on-background);\n`;\n\nconst leftButton = css`\n    margin-right: auto;\n`;\n\ninterface ModelIconProps {\n    model: CmsModel;\n}\nconst ModelIcon: React.FC<ModelIconProps> = ({ model }) => {\n    return (\n        <FontAwesomeIcon\n            style={{ color: \"var(--mdc-theme-text-secondary-on-background)\" }}\n            icon={(model.icon || \"fas/star\").split(\"/\") as IconProp}\n            width={32}\n            size={\"2x\"}\n        />\n    );\n};\n\ntype HeadlessPageTemplateItemProps = {\n    icon: React.ReactElement<any>;\n    name: string;\n    description?: string;\n    highlight?: string;\n    onClick: () => void;\n    hasNestedFields?: boolean;\n};\n\nconst HeadlessPageTemplateItem: React.FC<HeadlessPageTemplateItemProps> = ({\n    icon,\n    name,\n    description,\n    highlight,\n    onClick,\n    hasNestedFields\n}) => {\n    return (\n        <ListItemStyled onClick={onClick}>\n            <Icon icon={icon} />\n            <ListItemContent>\n                <Title>{name}</Title>\n                {description}\n                <Highlight>{highlight}</Highlight>\n            </ListItemContent>\n            {hasNestedFields && <ArrowRightIcon className=\"arrow-right\" />}\n        </ListItemStyled>\n    );\n};\n\ntype CreateTemplateDialogProps = {\n    open: boolean;\n    onClose: () => void;\n    onDynamicTemplateSelect: (model: CmsModel) => void;\n    onStaticTemplateSelect: () => void;\n    existingDynamicTemplateModelIds: string[];\n};\n\nexport const CreateTemplateDialog: React.FC<CreateTemplateDialogProps> = ({\n    open,\n    onClose,\n    onDynamicTemplateSelect,\n    onStaticTemplateSelect,\n    existingDynamicTemplateModelIds\n}) => {\n    const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);\n    const { models, loading } = useModels();\n\n    return (\n        <Dialog open={open} className={dialogStyles} onClose={onClose}>\n            <DialogTitle>What type of a template you wish to create?</DialogTitle>\n            <DynamicTemplatesInfo>\n                Select a Headless Page Template for which you want to create a dynamic page\n                template:\n            </DynamicTemplatesInfo>\n            <DialogContent>\n                <div className=\"content-wrapper\" tabIndex={0}>\n                    {dynamicTemplateSelect ? (\n                        <>\n                            {loading && <CircularProgress />}\n                            <List>\n                                {models.map((model, index) => (\n                                    <HeadlessPageTemplateItem\n                                        key={index}\n                                        icon={<ModelIcon model={model} />}\n                                        name={model.name}\n                                        description={model.description}\n                                        highlight={\n                                            existingDynamicTemplateModelIds.some(\n                                                id => id === model.modelId\n                                            )\n                                                ? \"Template already exists, click to edit.\"\n                                                : undefined\n                                        }\n                                        onClick={() => onDynamicTemplateSelect(model)}\n                                    />\n                                ))}\n                            </List>\n                        </>\n                    ) : (\n                        <>\n                            <HeadlessPageTemplateItem\n                                icon={<ArticleIcon width={36} height={36} />}\n                                name={\"Static template\"}\n                                description={\"Used for creating new Page Builder pages.\"}\n                                onClick={onStaticTemplateSelect}\n                            />\n                            <HeadlessPageTemplateItem\n                                icon={<DatabaseIcon width={36} height={36} />}\n                                name={\"Dynamic template\"}\n                                description={\n                                    \"Used for auto-generating pages  from Headless CMS entries.\"\n                                }\n                                onClick={() => setDynamicTemplateSelect(true)}\n                                hasNestedFields\n                            />\n                            <Info>\n                                <InfoIcon />\n                                Click here to learn about different template types.\n                            </Info>\n                        </>\n                    )}\n                </div>\n            </DialogContent>\n            <DialogActions>\n                {dynamicTemplateSelect && (\n                    <ButtonDefault\n                        onClick={() => {\n                            setDynamicTemplateSelect(false);\n                        }}\n                        className={leftButton}\n                    >\n                        &lt; Go back\n                    </ButtonDefault>\n                )}\n                <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n            </DialogActions>\n        </Dialog>\n    );\n};\n"]} */",
|
|
110
112
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
111
113
|
});
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
const leftButton = css`
|
|
115
|
+
margin-right: auto;
|
|
116
|
+
`;
|
|
117
|
+
const ModelIcon = ({
|
|
118
|
+
model
|
|
119
|
+
}) => {
|
|
120
|
+
return /*#__PURE__*/React.createElement(FontAwesomeIcon, {
|
|
116
121
|
style: {
|
|
117
122
|
color: "var(--mdc-theme-text-secondary-on-background)"
|
|
118
123
|
},
|
|
@@ -121,81 +126,73 @@ var ModelIcon = function ModelIcon(_ref) {
|
|
|
121
126
|
size: "2x"
|
|
122
127
|
});
|
|
123
128
|
};
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
129
|
+
const HeadlessPageTemplateItem = ({
|
|
130
|
+
icon,
|
|
131
|
+
name,
|
|
132
|
+
description,
|
|
133
|
+
highlight,
|
|
134
|
+
onClick,
|
|
135
|
+
hasNestedFields
|
|
136
|
+
}) => {
|
|
137
|
+
return /*#__PURE__*/React.createElement(ListItemStyled, {
|
|
132
138
|
onClick: onClick
|
|
133
|
-
}, /*#__PURE__*/
|
|
139
|
+
}, /*#__PURE__*/React.createElement(Icon, {
|
|
134
140
|
icon: icon
|
|
135
|
-
}), /*#__PURE__*/
|
|
141
|
+
}), /*#__PURE__*/React.createElement(ListItemContent, null, /*#__PURE__*/React.createElement(Title, null, name), description, /*#__PURE__*/React.createElement(Highlight, null, highlight)), hasNestedFields && /*#__PURE__*/React.createElement(ArrowRightIcon, {
|
|
136
142
|
className: "arrow-right"
|
|
137
143
|
}));
|
|
138
144
|
};
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
return /*#__PURE__*/_react.default.createElement(_Dialog.Dialog, {
|
|
145
|
+
export const CreateTemplateDialog = ({
|
|
146
|
+
open,
|
|
147
|
+
onClose,
|
|
148
|
+
onDynamicTemplateSelect,
|
|
149
|
+
onStaticTemplateSelect,
|
|
150
|
+
existingDynamicTemplateModelIds
|
|
151
|
+
}) => {
|
|
152
|
+
const [dynamicTemplateSelect, setDynamicTemplateSelect] = useState(false);
|
|
153
|
+
const {
|
|
154
|
+
models,
|
|
155
|
+
loading
|
|
156
|
+
} = useModels();
|
|
157
|
+
return /*#__PURE__*/React.createElement(Dialog, {
|
|
153
158
|
open: open,
|
|
154
159
|
className: dialogStyles,
|
|
155
160
|
onClose: onClose
|
|
156
|
-
}, /*#__PURE__*/
|
|
161
|
+
}, /*#__PURE__*/React.createElement(DialogTitle, null, "What type of a template you wish to create?"), /*#__PURE__*/React.createElement(DynamicTemplatesInfo, null, "Select a Headless Page Template for which you want to create a dynamic page template:"), /*#__PURE__*/React.createElement(DialogContent, null, /*#__PURE__*/React.createElement("div", {
|
|
157
162
|
className: "content-wrapper",
|
|
158
163
|
tabIndex: 0
|
|
159
|
-
}, dynamicTemplateSelect ? /*#__PURE__*/
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
onClick: function onClick() {
|
|
171
|
-
return onDynamicTemplateSelect(model);
|
|
172
|
-
}
|
|
173
|
-
});
|
|
174
|
-
}))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(HeadlessPageTemplateItem, {
|
|
175
|
-
icon: /*#__PURE__*/_react.default.createElement(_article.ReactComponent, {
|
|
164
|
+
}, dynamicTemplateSelect ? /*#__PURE__*/React.createElement(React.Fragment, null, loading && /*#__PURE__*/React.createElement(CircularProgress, null), /*#__PURE__*/React.createElement(List, null, models.map((model, index) => /*#__PURE__*/React.createElement(HeadlessPageTemplateItem, {
|
|
165
|
+
key: index,
|
|
166
|
+
icon: /*#__PURE__*/React.createElement(ModelIcon, {
|
|
167
|
+
model: model
|
|
168
|
+
}),
|
|
169
|
+
name: model.name,
|
|
170
|
+
description: model.description,
|
|
171
|
+
highlight: existingDynamicTemplateModelIds.some(id => id === model.modelId) ? "Template already exists, click to edit." : undefined,
|
|
172
|
+
onClick: () => onDynamicTemplateSelect(model)
|
|
173
|
+
})))) : /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(HeadlessPageTemplateItem, {
|
|
174
|
+
icon: /*#__PURE__*/React.createElement(ArticleIcon, {
|
|
176
175
|
width: 36,
|
|
177
176
|
height: 36
|
|
178
177
|
}),
|
|
179
178
|
name: "Static template",
|
|
180
179
|
description: "Used for creating new Page Builder pages.",
|
|
181
180
|
onClick: onStaticTemplateSelect
|
|
182
|
-
}), /*#__PURE__*/
|
|
183
|
-
icon: /*#__PURE__*/
|
|
181
|
+
}), /*#__PURE__*/React.createElement(HeadlessPageTemplateItem, {
|
|
182
|
+
icon: /*#__PURE__*/React.createElement(DatabaseIcon, {
|
|
184
183
|
width: 36,
|
|
185
184
|
height: 36
|
|
186
185
|
}),
|
|
187
186
|
name: "Dynamic template",
|
|
188
187
|
description: "Used for auto-generating pages from Headless CMS entries.",
|
|
189
|
-
onClick:
|
|
190
|
-
return setDynamicTemplateSelect(true);
|
|
191
|
-
},
|
|
188
|
+
onClick: () => setDynamicTemplateSelect(true),
|
|
192
189
|
hasNestedFields: true
|
|
193
|
-
}), /*#__PURE__*/
|
|
194
|
-
onClick:
|
|
190
|
+
}), /*#__PURE__*/React.createElement(Info, null, /*#__PURE__*/React.createElement(InfoIcon, null), "Click here to learn about different template types.")))), /*#__PURE__*/React.createElement(DialogActions, null, dynamicTemplateSelect && /*#__PURE__*/React.createElement(ButtonDefault, {
|
|
191
|
+
onClick: () => {
|
|
195
192
|
setDynamicTemplateSelect(false);
|
|
196
193
|
},
|
|
197
194
|
className: leftButton
|
|
198
|
-
}, "< Go back"), /*#__PURE__*/
|
|
195
|
+
}, "< Go back"), /*#__PURE__*/React.createElement(DialogCancel, {
|
|
199
196
|
onClick: onClose
|
|
200
197
|
}, "Cancel")));
|
|
201
198
|
};
|