@webiny/app-dynamic-pages 5.42.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +20 -0
- package/admin/ContentEntryForm/AddPreviewPane.d.ts +2 -0
- package/admin/ContentEntryForm/AddPreviewPane.js +52 -0
- package/admin/ContentEntryForm/AddPreviewPane.js.map +1 -0
- package/admin/ContentEntryForm/PassEntryToDataSource.d.ts +2 -0
- package/admin/ContentEntryForm/PassEntryToDataSource.js +78 -0
- package/admin/ContentEntryForm/PassEntryToDataSource.js.map +1 -0
- package/admin/ContentEntryForm/PreviewPane.d.ts +6 -0
- package/admin/ContentEntryForm/PreviewPane.js +65 -0
- package/admin/ContentEntryForm/PreviewPane.js.map +1 -0
- package/admin/Extensions.d.ts +2 -0
- package/admin/Extensions.js +23 -0
- package/admin/Extensions.js.map +1 -0
- package/admin/PageTemplateDialog/CreateTemplateDialog.d.ts +11 -0
- package/admin/PageTemplateDialog/CreateTemplateDialog.js +203 -0
- package/admin/PageTemplateDialog/CreateTemplateDialog.js.map +1 -0
- package/admin/PageTemplateDialog/PageTemplateDialog.d.ts +2 -0
- package/admin/PageTemplateDialog/PageTemplateDialog.js +55 -0
- package/admin/PageTemplateDialog/PageTemplateDialog.js.map +1 -0
- package/admin/SetupDynamicPages.d.ts +2 -0
- package/admin/SetupDynamicPages.js +23 -0
- package/admin/SetupDynamicPages.js.map +1 -0
- package/admin/elements/Elements.d.ts +2 -0
- package/admin/elements/Elements.js +19 -0
- package/admin/elements/Elements.js.map +1 -0
- package/admin/elements/entriesList.d.ts +2 -0
- package/admin/elements/entriesList.js +42 -0
- package/admin/elements/entriesList.js.map +1 -0
- package/admin/elements/entriesSearch.d.ts +2 -0
- package/admin/elements/entriesSearch.js +41 -0
- package/admin/elements/entriesSearch.js.map +1 -0
- package/admin/elements/eventHandlers/ContentTraverser.d.ts +11 -0
- package/admin/elements/eventHandlers/ContentTraverser.js +35 -0
- package/admin/elements/eventHandlers/ContentTraverser.js.map +1 -0
- package/admin/elements/renderers/DynamicGrid.d.ts +2 -0
- package/admin/elements/renderers/DynamicGrid.js +55 -0
- package/admin/elements/renderers/DynamicGrid.js.map +1 -0
- package/admin/elements/renderers/EntriesList.d.ts +10 -0
- package/admin/elements/renderers/EntriesList.js +30 -0
- package/admin/elements/renderers/EntriesList.js.map +1 -0
- package/admin/elements/renderers/Repeater.d.ts +7 -0
- package/admin/elements/renderers/Repeater.js +29 -0
- package/admin/elements/renderers/Repeater.js.map +1 -0
- package/admin/elements/repeater.d.ts +2 -0
- package/admin/elements/repeater.js +41 -0
- package/admin/elements/repeater.js.map +1 -0
- package/admin/index.d.ts +1 -0
- package/admin/index.js +14 -0
- package/admin/index.js.map +1 -0
- package/admin/pageEditor/DynamicPageEditorConfig.d.ts +2 -0
- package/admin/pageEditor/DynamicPageEditorConfig.js +17 -0
- package/admin/pageEditor/DynamicPageEditorConfig.js.map +1 -0
- package/admin/pageEditor/ElementEventHandlers.d.ts +1 -0
- package/admin/pageEditor/ElementEventHandlers.js +107 -0
- package/admin/pageEditor/ElementEventHandlers.js.map +1 -0
- package/admin/templateEditor/DynamicTemplateEditorConfig.d.ts +2 -0
- package/admin/templateEditor/DynamicTemplateEditorConfig.js +31 -0
- package/admin/templateEditor/DynamicTemplateEditorConfig.js.map +1 -0
- package/admin/templateEditor/ElementEventHandlers.d.ts +1 -0
- package/admin/templateEditor/ElementEventHandlers.js +107 -0
- package/admin/templateEditor/ElementEventHandlers.js.map +1 -0
- package/admin/templateEditor/EntrySelector/EntrySelector.d.ts +2 -0
- package/admin/templateEditor/EntrySelector/EntrySelector.js +38 -0
- package/admin/templateEditor/EntrySelector/EntrySelector.js.map +1 -0
- package/admin/templateEditor/EntrySelector/index.d.ts +1 -0
- package/admin/templateEditor/EntrySelector/index.js +18 -0
- package/admin/templateEditor/EntrySelector/index.js.map +1 -0
- package/dataInjection/AddEntriesListDataSourceContext.d.ts +2 -0
- package/dataInjection/AddEntriesListDataSourceContext.js +33 -0
- package/dataInjection/AddEntriesListDataSourceContext.js.map +1 -0
- package/dataInjection/editor/DisableGridDelete.d.ts +2 -0
- package/dataInjection/editor/DisableGridDelete.js +23 -0
- package/dataInjection/editor/DisableGridDelete.js.map +1 -0
- package/dataInjection/editor/ElementDataSettings.d.ts +2 -0
- package/dataInjection/editor/ElementDataSettings.js +28 -0
- package/dataInjection/editor/ElementDataSettings.js.map +1 -0
- package/dataInjection/editor/HideIfChildOfEntriesList.d.ts +6 -0
- package/dataInjection/editor/HideIfChildOfEntriesList.js +24 -0
- package/dataInjection/editor/HideIfChildOfEntriesList.js.map +1 -0
- package/dataInjection/editor/HideIfEntriesListGridWithDataSource.d.ts +6 -0
- package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js +31 -0
- package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js.map +1 -0
- package/dataInjection/editor/SetupElementDataSettings.d.ts +2 -0
- package/dataInjection/editor/SetupElementDataSettings.js +19 -0
- package/dataInjection/editor/SetupElementDataSettings.js.map +1 -0
- package/dataInjection/renderers/DynamicElementRenderers.d.ts +2 -0
- package/dataInjection/renderers/DynamicElementRenderers.js +27 -0
- package/dataInjection/renderers/DynamicElementRenderers.js.map +1 -0
- package/dataInjection/renderers/DynamicGrid.d.ts +2 -0
- package/dataInjection/renderers/DynamicGrid.js +50 -0
- package/dataInjection/renderers/DynamicGrid.js.map +1 -0
- package/dataInjection/renderers/EntriesList.d.ts +70 -0
- package/dataInjection/renderers/EntriesList.js +51 -0
- package/dataInjection/renderers/EntriesList.js.map +1 -0
- package/dataInjection/renderers/EntriesSearch.d.ts +47 -0
- package/dataInjection/renderers/EntriesSearch.js +38 -0
- package/dataInjection/renderers/EntriesSearch.js.map +1 -0
- package/dataInjection/renderers/Repeater.d.ts +70 -0
- package/dataInjection/renderers/Repeater.js +51 -0
- package/dataInjection/renderers/Repeater.js.map +1 -0
- package/features/index.d.ts +3 -0
- package/features/index.js +40 -0
- package/features/index.js.map +1 -0
- package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.d.ts +4 -0
- package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js +65 -0
- package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js.map +1 -0
- package/features/pageTemplate/hasMainDataSource.d.ts +2 -0
- package/features/pageTemplate/hasMainDataSource.js +13 -0
- package/features/pageTemplate/hasMainDataSource.js.map +1 -0
- package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.d.ts +3 -0
- package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js +20 -0
- package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js.map +1 -0
- package/package.json +56 -0
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
"use strict";
|
|
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;
|
|
26
|
+
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
|
+
var dialogStyles = (0, _emotion.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\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"])));
|
|
28
|
+
var Info = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
29
|
+
target: "e1ualc005"
|
|
30
|
+
} : {
|
|
31
|
+
target: "e1ualc005",
|
|
32
|
+
label: "Info"
|
|
33
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
34
|
+
name: "1ci36am",
|
|
35
|
+
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;}"
|
|
36
|
+
} : {
|
|
37
|
+
name: "1ci36am",
|
|
38
|
+
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"]} */",
|
|
40
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
41
|
+
});
|
|
42
|
+
var ListItemStyled = /*#__PURE__*/(0, _base.default)(_List.ListItem, process.env.NODE_ENV === "production" ? {
|
|
43
|
+
target: "e1ualc004"
|
|
44
|
+
} : {
|
|
45
|
+
target: "e1ualc004",
|
|
46
|
+
label: "ListItemStyled"
|
|
47
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
48
|
+
name: "mv3wdt",
|
|
49
|
+
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;}"
|
|
50
|
+
} : {
|
|
51
|
+
name: "mv3wdt",
|
|
52
|
+
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"]} */",
|
|
54
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
|
+
});
|
|
56
|
+
var ListItemContent = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
57
|
+
target: "e1ualc003"
|
|
58
|
+
} : {
|
|
59
|
+
target: "e1ualc003",
|
|
60
|
+
label: "ListItemContent"
|
|
61
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
62
|
+
name: "1i68tbr",
|
|
63
|
+
styles: "display:grid;padding-left:21px;padding-right:21px"
|
|
64
|
+
} : {
|
|
65
|
+
name: "1i68tbr",
|
|
66
|
+
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"]} */",
|
|
68
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
69
|
+
});
|
|
70
|
+
var Title = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
71
|
+
target: "e1ualc002"
|
|
72
|
+
} : {
|
|
73
|
+
target: "e1ualc002",
|
|
74
|
+
label: "Title"
|
|
75
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
76
|
+
name: "14is9qy",
|
|
77
|
+
styles: "font-size:20px"
|
|
78
|
+
} : {
|
|
79
|
+
name: "14is9qy",
|
|
80
|
+
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"]} */",
|
|
82
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
83
|
+
});
|
|
84
|
+
var Highlight = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
85
|
+
target: "e1ualc001"
|
|
86
|
+
} : {
|
|
87
|
+
target: "e1ualc001",
|
|
88
|
+
label: "Highlight"
|
|
89
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
90
|
+
name: "1re7mf9",
|
|
91
|
+
styles: "color:var(--mdc-theme-primary)"
|
|
92
|
+
} : {
|
|
93
|
+
name: "1re7mf9",
|
|
94
|
+
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"]} */",
|
|
96
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
97
|
+
});
|
|
98
|
+
var DynamicTemplatesInfo = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV === "production" ? {
|
|
99
|
+
target: "e1ualc000"
|
|
100
|
+
} : {
|
|
101
|
+
target: "e1ualc000",
|
|
102
|
+
label: "DynamicTemplatesInfo"
|
|
103
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
104
|
+
name: "17uojnc",
|
|
105
|
+
styles: "padding:24px;font-size:20px;line-height:24px;color:var(--mdc-theme-text-secondary-on-background)"
|
|
106
|
+
} : {
|
|
107
|
+
name: "17uojnc",
|
|
108
|
+
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"]} */",
|
|
110
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
111
|
+
});
|
|
112
|
+
var leftButton = (0, _emotion.css)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n margin-right: auto;\n"])));
|
|
113
|
+
var ModelIcon = function ModelIcon(_ref) {
|
|
114
|
+
var model = _ref.model;
|
|
115
|
+
return /*#__PURE__*/_react.default.createElement(_reactFontawesome.FontAwesomeIcon, {
|
|
116
|
+
style: {
|
|
117
|
+
color: "var(--mdc-theme-text-secondary-on-background)"
|
|
118
|
+
},
|
|
119
|
+
icon: (model.icon || "fas/star").split("/"),
|
|
120
|
+
width: 32,
|
|
121
|
+
size: "2x"
|
|
122
|
+
});
|
|
123
|
+
};
|
|
124
|
+
var HeadlessPageTemplateItem = function HeadlessPageTemplateItem(_ref2) {
|
|
125
|
+
var icon = _ref2.icon,
|
|
126
|
+
name = _ref2.name,
|
|
127
|
+
description = _ref2.description,
|
|
128
|
+
highlight = _ref2.highlight,
|
|
129
|
+
onClick = _ref2.onClick,
|
|
130
|
+
hasNestedFields = _ref2.hasNestedFields;
|
|
131
|
+
return /*#__PURE__*/_react.default.createElement(ListItemStyled, {
|
|
132
|
+
onClick: onClick
|
|
133
|
+
}, /*#__PURE__*/_react.default.createElement(_Icon.Icon, {
|
|
134
|
+
icon: icon
|
|
135
|
+
}), /*#__PURE__*/_react.default.createElement(ListItemContent, null, /*#__PURE__*/_react.default.createElement(Title, null, name), description, /*#__PURE__*/_react.default.createElement(Highlight, null, highlight)), hasNestedFields && /*#__PURE__*/_react.default.createElement(_keyboard_arrow_right.ReactComponent, {
|
|
136
|
+
className: "arrow-right"
|
|
137
|
+
}));
|
|
138
|
+
};
|
|
139
|
+
var CreateTemplateDialog = exports.CreateTemplateDialog = function CreateTemplateDialog(_ref3) {
|
|
140
|
+
var open = _ref3.open,
|
|
141
|
+
onClose = _ref3.onClose,
|
|
142
|
+
onDynamicTemplateSelect = _ref3.onDynamicTemplateSelect,
|
|
143
|
+
onStaticTemplateSelect = _ref3.onStaticTemplateSelect,
|
|
144
|
+
existingDynamicTemplateModelIds = _ref3.existingDynamicTemplateModelIds;
|
|
145
|
+
var _useState = (0, _react.useState)(false),
|
|
146
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
147
|
+
dynamicTemplateSelect = _useState2[0],
|
|
148
|
+
setDynamicTemplateSelect = _useState2[1];
|
|
149
|
+
var _useModels = (0, _appHeadlessCms.useModels)(),
|
|
150
|
+
models = _useModels.models,
|
|
151
|
+
loading = _useModels.loading;
|
|
152
|
+
return /*#__PURE__*/_react.default.createElement(_Dialog.Dialog, {
|
|
153
|
+
open: open,
|
|
154
|
+
className: dialogStyles,
|
|
155
|
+
onClose: onClose
|
|
156
|
+
}, /*#__PURE__*/_react.default.createElement(_Dialog.DialogTitle, null, "What type of a template you wish to create?"), /*#__PURE__*/_react.default.createElement(DynamicTemplatesInfo, null, "Select a Headless Page Template for which you want to create a dynamic page template:"), /*#__PURE__*/_react.default.createElement(_Dialog.DialogContent, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
157
|
+
className: "content-wrapper",
|
|
158
|
+
tabIndex: 0
|
|
159
|
+
}, dynamicTemplateSelect ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, loading && /*#__PURE__*/_react.default.createElement(_Progress.CircularProgress, null), /*#__PURE__*/_react.default.createElement(_List.List, null, models.map(function (model, index) {
|
|
160
|
+
return /*#__PURE__*/_react.default.createElement(HeadlessPageTemplateItem, {
|
|
161
|
+
key: index,
|
|
162
|
+
icon: /*#__PURE__*/_react.default.createElement(ModelIcon, {
|
|
163
|
+
model: model
|
|
164
|
+
}),
|
|
165
|
+
name: model.name,
|
|
166
|
+
description: model.description,
|
|
167
|
+
highlight: existingDynamicTemplateModelIds.some(function (id) {
|
|
168
|
+
return id === model.modelId;
|
|
169
|
+
}) ? "Template already exists, click to edit." : undefined,
|
|
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, {
|
|
176
|
+
width: 36,
|
|
177
|
+
height: 36
|
|
178
|
+
}),
|
|
179
|
+
name: "Static template",
|
|
180
|
+
description: "Used for creating new Page Builder pages.",
|
|
181
|
+
onClick: onStaticTemplateSelect
|
|
182
|
+
}), /*#__PURE__*/_react.default.createElement(HeadlessPageTemplateItem, {
|
|
183
|
+
icon: /*#__PURE__*/_react.default.createElement(_dashboard.ReactComponent, {
|
|
184
|
+
width: 36,
|
|
185
|
+
height: 36
|
|
186
|
+
}),
|
|
187
|
+
name: "Dynamic template",
|
|
188
|
+
description: "Used for auto-generating pages from Headless CMS entries.",
|
|
189
|
+
onClick: function onClick() {
|
|
190
|
+
return setDynamicTemplateSelect(true);
|
|
191
|
+
},
|
|
192
|
+
hasNestedFields: true
|
|
193
|
+
}), /*#__PURE__*/_react.default.createElement(Info, null, /*#__PURE__*/_react.default.createElement(_info.ReactComponent, null), "Click here to learn about different template types.")))), /*#__PURE__*/_react.default.createElement(_Dialog.DialogActions, null, dynamicTemplateSelect && /*#__PURE__*/_react.default.createElement(_Button.ButtonDefault, {
|
|
194
|
+
onClick: function onClick() {
|
|
195
|
+
setDynamicTemplateSelect(false);
|
|
196
|
+
},
|
|
197
|
+
className: leftButton
|
|
198
|
+
}, "< Go back"), /*#__PURE__*/_react.default.createElement(_Dialog.DialogCancel, {
|
|
199
|
+
onClick: onClose
|
|
200
|
+
}, "Cancel")));
|
|
201
|
+
};
|
|
202
|
+
|
|
203
|
+
//# sourceMappingURL=CreateTemplateDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_emotion","_reactFontawesome","_Icon","_Button","_List","_Dialog","_Progress","_appHeadlessCms","_keyboard_arrow_right","_info","_article","_dashboard","_templateObject","_templateObject2","_EMOTION_STRINGIFIED_CSS_ERROR__","dialogStyles","css","_taggedTemplateLiteral2","default","Info","_base","process","env","NODE_ENV","target","label","name","styles","map","toString","ListItemStyled","ListItem","ListItemContent","Title","Highlight","DynamicTemplatesInfo","leftButton","ModelIcon","_ref","model","createElement","FontAwesomeIcon","style","color","icon","split","width","size","HeadlessPageTemplateItem","_ref2","description","highlight","onClick","hasNestedFields","Icon","ReactComponent","className","CreateTemplateDialog","exports","_ref3","open","onClose","onDynamicTemplateSelect","onStaticTemplateSelect","existingDynamicTemplateModelIds","_useState","useState","_useState2","_slicedToArray2","dynamicTemplateSelect","setDynamicTemplateSelect","_useModels","useModels","models","loading","Dialog","DialogTitle","DialogContent","tabIndex","Fragment","CircularProgress","List","index","key","some","id","modelId","undefined","height","DialogActions","ButtonDefault","DialogCancel"],"sources":["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 < Go back\n </ButtonDefault>\n )}\n <DialogCancel onClick={onClose}>Cancel</DialogCancel>\n </DialogActions>\n </Dialog>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.PageTemplateDialog = void 0;
|
|
9
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _appAdmin = require("@webiny/app-admin");
|
|
12
|
+
var _reactRouter = require("@webiny/react-router");
|
|
13
|
+
var _CreatePageTemplateDialog = require("@webiny/app-page-builder/admin/views/PageTemplates/CreatePageTemplateDialog");
|
|
14
|
+
var _CreateTemplateDialog = require("./CreateTemplateDialog");
|
|
15
|
+
var _useCreateDynamicTemplate = require("../../features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate");
|
|
16
|
+
var PageTemplateDialog = exports.PageTemplateDialog = _CreatePageTemplateDialog.CreatePageTemplateDialog.createDecorator(function (Original) {
|
|
17
|
+
return function CreatePageTemplateDialog(props) {
|
|
18
|
+
var _useRouter = (0, _reactRouter.useRouter)(),
|
|
19
|
+
history = _useRouter.history;
|
|
20
|
+
var _useSnackbar = (0, _appAdmin.useSnackbar)(),
|
|
21
|
+
showSnackbar = _useSnackbar.showSnackbar;
|
|
22
|
+
var _useCreateDynamicPage = (0, _useCreateDynamicTemplate.useCreateDynamicPageTemplate)(),
|
|
23
|
+
createDynamicPageTemplate = _useCreateDynamicPage.createDynamicPageTemplate;
|
|
24
|
+
var _useState = (0, _react.useState)(false),
|
|
25
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
26
|
+
showStaticTemplateDialog = _useState2[0],
|
|
27
|
+
setShowStaticTemplateDialog = _useState2[1];
|
|
28
|
+
var createTemplate = (0, _react.useCallback)(async function (model) {
|
|
29
|
+
try {
|
|
30
|
+
var template = await createDynamicPageTemplate(model);
|
|
31
|
+
history.push("/page-builder/template-editor/".concat(template.id));
|
|
32
|
+
} catch (error) {
|
|
33
|
+
showSnackbar(error.message);
|
|
34
|
+
}
|
|
35
|
+
}, []);
|
|
36
|
+
var onClose = (0, _react.useCallback)(function () {
|
|
37
|
+
setShowStaticTemplateDialog(false);
|
|
38
|
+
props.onClose();
|
|
39
|
+
}, [props.onClose]);
|
|
40
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Original, Object.assign({}, props, {
|
|
41
|
+
open: showStaticTemplateDialog,
|
|
42
|
+
onClose: onClose
|
|
43
|
+
})), /*#__PURE__*/_react.default.createElement(_CreateTemplateDialog.CreateTemplateDialog, {
|
|
44
|
+
open: props.open && !showStaticTemplateDialog,
|
|
45
|
+
onClose: props.onClose,
|
|
46
|
+
onDynamicTemplateSelect: createTemplate,
|
|
47
|
+
onStaticTemplateSelect: function onStaticTemplateSelect() {
|
|
48
|
+
return setShowStaticTemplateDialog(true);
|
|
49
|
+
},
|
|
50
|
+
existingDynamicTemplateModelIds: []
|
|
51
|
+
}));
|
|
52
|
+
};
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
//# sourceMappingURL=PageTemplateDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_appAdmin","_reactRouter","_CreatePageTemplateDialog","_CreateTemplateDialog","_useCreateDynamicTemplate","PageTemplateDialog","exports","CreatePageTemplateDialog","createDecorator","Original","props","_useRouter","useRouter","history","_useSnackbar","useSnackbar","showSnackbar","_useCreateDynamicPage","useCreateDynamicPageTemplate","createDynamicPageTemplate","_useState","useState","_useState2","_slicedToArray2","default","showStaticTemplateDialog","setShowStaticTemplateDialog","createTemplate","useCallback","model","template","push","concat","id","error","message","onClose","createElement","Fragment","Object","assign","open","CreateTemplateDialog","onDynamicTemplateSelect","onStaticTemplateSelect","existingDynamicTemplateModelIds"],"sources":["PageTemplateDialog.tsx"],"sourcesContent":["import React, { useState, useCallback } from \"react\";\nimport { useSnackbar } from \"@webiny/app-admin\";\nimport { useRouter } from \"@webiny/react-router\";\nimport { CmsModel } from \"@webiny/app-headless-cms/types\";\nimport { CreatePageTemplateDialog } from \"@webiny/app-page-builder/admin/views/PageTemplates/CreatePageTemplateDialog\";\nimport { CreateTemplateDialog } from \"~/admin/PageTemplateDialog/CreateTemplateDialog\";\nimport { useCreateDynamicPageTemplate } from \"~/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate\";\n\nexport const PageTemplateDialog = CreatePageTemplateDialog.createDecorator(Original => {\n return function CreatePageTemplateDialog(props) {\n const { history } = useRouter();\n const { showSnackbar } = useSnackbar();\n const { createDynamicPageTemplate } = useCreateDynamicPageTemplate();\n const [showStaticTemplateDialog, setShowStaticTemplateDialog] = useState(false);\n\n const createTemplate = useCallback(async (model: CmsModel) => {\n try {\n const template = await createDynamicPageTemplate(model);\n history.push(`/page-builder/template-editor/${template.id}`);\n } catch (error) {\n showSnackbar(error.message);\n }\n }, []);\n\n const onClose = useCallback(() => {\n setShowStaticTemplateDialog(false);\n props.onClose();\n }, [props.onClose]);\n\n return (\n <>\n <Original {...props} open={showStaticTemplateDialog} onClose={onClose} />\n <CreateTemplateDialog\n open={props.open && !showStaticTemplateDialog}\n onClose={props.onClose}\n onDynamicTemplateSelect={createTemplate}\n onStaticTemplateSelect={() => setShowStaticTemplateDialog(true)}\n existingDynamicTemplateModelIds={[]}\n />\n </>\n );\n };\n});\n"],"mappings":";;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,SAAA,GAAAD,OAAA;AACA,IAAAE,YAAA,GAAAF,OAAA;AAEA,IAAAG,yBAAA,GAAAH,OAAA;AACA,IAAAI,qBAAA,GAAAJ,OAAA;AACA,IAAAK,yBAAA,GAAAL,OAAA;AAEO,IAAMM,kBAAkB,GAAAC,OAAA,CAAAD,kBAAA,GAAGE,kDAAwB,CAACC,eAAe,CAAC,UAAAC,QAAQ,EAAI;EACnF,OAAO,SAASF,wBAAwBA,CAACG,KAAK,EAAE;IAC5C,IAAAC,UAAA,GAAoB,IAAAC,sBAAS,EAAC,CAAC;MAAvBC,OAAO,GAAAF,UAAA,CAAPE,OAAO;IACf,IAAAC,YAAA,GAAyB,IAAAC,qBAAW,EAAC,CAAC;MAA9BC,YAAY,GAAAF,YAAA,CAAZE,YAAY;IACpB,IAAAC,qBAAA,GAAsC,IAAAC,sDAA4B,EAAC,CAAC;MAA5DC,yBAAyB,GAAAF,qBAAA,CAAzBE,yBAAyB;IACjC,IAAAC,SAAA,GAAgE,IAAAC,eAAQ,EAAC,KAAK,CAAC;MAAAC,UAAA,OAAAC,eAAA,CAAAC,OAAA,EAAAJ,SAAA;MAAxEK,wBAAwB,GAAAH,UAAA;MAAEI,2BAA2B,GAAAJ,UAAA;IAE5D,IAAMK,cAAc,GAAG,IAAAC,kBAAW,EAAC,gBAAOC,KAAe,EAAK;MAC1D,IAAI;QACA,IAAMC,QAAQ,GAAG,MAAMX,yBAAyB,CAACU,KAAK,CAAC;QACvDhB,OAAO,CAACkB,IAAI,kCAAAC,MAAA,CAAkCF,QAAQ,CAACG,EAAE,CAAE,CAAC;MAChE,CAAC,CAAC,OAAOC,KAAK,EAAE;QACZlB,YAAY,CAACkB,KAAK,CAACC,OAAO,CAAC;MAC/B;IACJ,CAAC,EAAE,EAAE,CAAC;IAEN,IAAMC,OAAO,GAAG,IAAAR,kBAAW,EAAC,YAAM;MAC9BF,2BAA2B,CAAC,KAAK,CAAC;MAClChB,KAAK,CAAC0B,OAAO,CAAC,CAAC;IACnB,CAAC,EAAE,CAAC1B,KAAK,CAAC0B,OAAO,CAAC,CAAC;IAEnB,oBACIvC,MAAA,CAAA2B,OAAA,CAAAa,aAAA,CAAAxC,MAAA,CAAA2B,OAAA,CAAAc,QAAA,qBACIzC,MAAA,CAAA2B,OAAA,CAAAa,aAAA,CAAC5B,QAAQ,EAAA8B,MAAA,CAAAC,MAAA,KAAK9B,KAAK;MAAE+B,IAAI,EAAEhB,wBAAyB;MAACW,OAAO,EAAEA;IAAQ,EAAE,CAAC,eACzEvC,MAAA,CAAA2B,OAAA,CAAAa,aAAA,CAAClC,qBAAA,CAAAuC,oBAAoB;MACjBD,IAAI,EAAE/B,KAAK,CAAC+B,IAAI,IAAI,CAAChB,wBAAyB;MAC9CW,OAAO,EAAE1B,KAAK,CAAC0B,OAAQ;MACvBO,uBAAuB,EAAEhB,cAAe;MACxCiB,sBAAsB,EAAE,SAAxBA,sBAAsBA,CAAA;QAAA,OAAQlB,2BAA2B,CAAC,IAAI,CAAC;MAAA,CAAC;MAChEmB,+BAA+B,EAAE;IAAG,CACvC,CACH,CAAC;EAEX,CAAC;AACL,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.SetupDynamicPages = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _PageTemplateDialog = require("./PageTemplateDialog/PageTemplateDialog");
|
|
10
|
+
var _DynamicTemplateEditorConfig = require("./templateEditor/DynamicTemplateEditorConfig");
|
|
11
|
+
var _AddPreviewPane = require("./ContentEntryForm/AddPreviewPane");
|
|
12
|
+
var _PassEntryToDataSource = require("./ContentEntryForm/PassEntryToDataSource");
|
|
13
|
+
var _Elements = require("./elements/Elements");
|
|
14
|
+
var _DynamicPageEditorConfig = require("./pageEditor/DynamicPageEditorConfig");
|
|
15
|
+
var _DynamicElementRenderers = require("../dataInjection/renderers/DynamicElementRenderers");
|
|
16
|
+
var _appHeadlessCms = require("@webiny/app-headless-cms");
|
|
17
|
+
var _WebsiteDataInjection = require("@webiny/app-page-builder/dataInjection/presets/WebsiteDataInjection");
|
|
18
|
+
var _AddEntriesListDataSourceContext = require("../dataInjection/AddEntriesListDataSourceContext");
|
|
19
|
+
var SetupDynamicPages = exports.SetupDynamicPages = function SetupDynamicPages() {
|
|
20
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Elements.Elements, null), /*#__PURE__*/_react.default.createElement(_PageTemplateDialog.PageTemplateDialog, null), /*#__PURE__*/_react.default.createElement(_DynamicTemplateEditorConfig.DynamicTemplateEditorConfig, null), /*#__PURE__*/_react.default.createElement(_DynamicPageEditorConfig.DynamicPageEditorConfig, null), /*#__PURE__*/_react.default.createElement(_AddPreviewPane.AddPreviewPane, null), /*#__PURE__*/_react.default.createElement(_PassEntryToDataSource.PassEntryToDataSource, null), /*#__PURE__*/_react.default.createElement(_DynamicElementRenderers.DynamicElementRenderers, null), /*#__PURE__*/_react.default.createElement(_appHeadlessCms.ContentEntryEditorConfig, null, /*#__PURE__*/_react.default.createElement(_WebsiteDataInjection.WebsiteDataInjection, null), /*#__PURE__*/_react.default.createElement(_AddEntriesListDataSourceContext.AddEntriesListDataSourceContext, null)));
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
//# sourceMappingURL=SetupDynamicPages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_PageTemplateDialog","_DynamicTemplateEditorConfig","_AddPreviewPane","_PassEntryToDataSource","_Elements","_DynamicPageEditorConfig","_DynamicElementRenderers","_appHeadlessCms","_WebsiteDataInjection","_AddEntriesListDataSourceContext","SetupDynamicPages","exports","default","createElement","Fragment","Elements","PageTemplateDialog","DynamicTemplateEditorConfig","DynamicPageEditorConfig","AddPreviewPane","PassEntryToDataSource","DynamicElementRenderers","ContentEntryEditorConfig","WebsiteDataInjection","AddEntriesListDataSourceContext"],"sources":["SetupDynamicPages.tsx"],"sourcesContent":["import React from \"react\";\nimport { PageTemplateDialog } from \"~/admin/PageTemplateDialog/PageTemplateDialog\";\nimport { DynamicTemplateEditorConfig } from \"~/admin/templateEditor/DynamicTemplateEditorConfig\";\nimport { AddPreviewPane } from \"~/admin/ContentEntryForm/AddPreviewPane\";\nimport { PassEntryToDataSource } from \"~/admin/ContentEntryForm/PassEntryToDataSource\";\nimport { Elements } from \"~/admin/elements/Elements\";\nimport { DynamicPageEditorConfig } from \"~/admin/pageEditor/DynamicPageEditorConfig\";\nimport { DynamicElementRenderers } from \"~/dataInjection/renderers/DynamicElementRenderers\";\nimport { ContentEntryEditorConfig } from \"@webiny/app-headless-cms\";\nimport { WebsiteDataInjection } from \"@webiny/app-page-builder/dataInjection/presets/WebsiteDataInjection\";\nimport { AddEntriesListDataSourceContext } from \"~/dataInjection/AddEntriesListDataSourceContext\";\n\nexport const SetupDynamicPages = () => {\n return (\n <>\n {/* Register editor elements plugins. */}\n <Elements />\n\n {/* Decorate page template dialog. */}\n <PageTemplateDialog />\n\n {/* Configure Template editor. */}\n <DynamicTemplateEditorConfig />\n\n {/* Configure Page editor. */}\n <DynamicPageEditorConfig />\n\n {/* Enable live preview in the CMS entry form. */}\n <AddPreviewPane />\n\n <PassEntryToDataSource />\n\n {/* Register element renderers and decorators. */}\n <DynamicElementRenderers />\n\n {/* Add website-style data binding to page preview. */}\n <ContentEntryEditorConfig>\n <WebsiteDataInjection />\n <AddEntriesListDataSourceContext />\n </ContentEntryEditorConfig>\n </>\n );\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,mBAAA,GAAAD,OAAA;AACA,IAAAE,4BAAA,GAAAF,OAAA;AACA,IAAAG,eAAA,GAAAH,OAAA;AACA,IAAAI,sBAAA,GAAAJ,OAAA;AACA,IAAAK,SAAA,GAAAL,OAAA;AACA,IAAAM,wBAAA,GAAAN,OAAA;AACA,IAAAO,wBAAA,GAAAP,OAAA;AACA,IAAAQ,eAAA,GAAAR,OAAA;AACA,IAAAS,qBAAA,GAAAT,OAAA;AACA,IAAAU,gCAAA,GAAAV,OAAA;AAEO,IAAMW,iBAAiB,GAAAC,OAAA,CAAAD,iBAAA,GAAG,SAApBA,iBAAiBA,CAAA,EAAS;EACnC,oBACIb,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAAAhB,MAAA,CAAAe,OAAA,CAAAE,QAAA,qBAEIjB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACT,SAAA,CAAAW,QAAQ,MAAE,CAAC,eAGZlB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACb,mBAAA,CAAAgB,kBAAkB,MAAE,CAAC,eAGtBnB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACZ,4BAAA,CAAAgB,2BAA2B,MAAE,CAAC,eAG/BpB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACR,wBAAA,CAAAa,uBAAuB,MAAE,CAAC,eAG3BrB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACX,eAAA,CAAAiB,cAAc,MAAE,CAAC,eAElBtB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACV,sBAAA,CAAAiB,qBAAqB,MAAE,CAAC,eAGzBvB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACP,wBAAA,CAAAe,uBAAuB,MAAE,CAAC,eAG3BxB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACN,eAAA,CAAAe,wBAAwB,qBACrBzB,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACL,qBAAA,CAAAe,oBAAoB,MAAE,CAAC,eACxB1B,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACJ,gCAAA,CAAAe,+BAA+B,MAAE,CACZ,CAC5B,CAAC;AAEX,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.Elements = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _plugins = require("@webiny/plugins");
|
|
10
|
+
var _repeater = require("./repeater");
|
|
11
|
+
var _entriesList = require("./entriesList");
|
|
12
|
+
var _DynamicGrid = require("./renderers/DynamicGrid");
|
|
13
|
+
var _entriesSearch = require("./entriesSearch");
|
|
14
|
+
var Elements = exports.Elements = /*#__PURE__*/_react.default.memo(function Elements() {
|
|
15
|
+
_plugins.plugins.register((0, _repeater.createRepeaterElement)(), (0, _entriesList.createEntriesListElement)(), (0, _entriesSearch.createEntriesSearchElement)());
|
|
16
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_DynamicGrid.DynamicGrid, null));
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
//# sourceMappingURL=Elements.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_plugins","_repeater","_entriesList","_DynamicGrid","_entriesSearch","Elements","exports","React","memo","plugins","register","createRepeaterElement","createEntriesListElement","createEntriesSearchElement","default","createElement","Fragment","DynamicGrid"],"sources":["Elements.tsx"],"sourcesContent":["import React from \"react\";\nimport { plugins } from \"@webiny/plugins\";\nimport { createRepeaterElement } from \"~/admin/elements/repeater\";\nimport { createEntriesListElement } from \"~/admin/elements/entriesList\";\nimport { DynamicGrid } from \"./renderers/DynamicGrid\";\nimport { createEntriesSearchElement } from \"~/admin/elements/entriesSearch\";\n\nexport const Elements = React.memo(function Elements() {\n plugins.register(\n createRepeaterElement(),\n createEntriesListElement(),\n createEntriesSearchElement()\n );\n\n return (\n <>\n <DynamicGrid />\n </>\n );\n});\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,YAAA,GAAAH,OAAA;AACA,IAAAI,YAAA,GAAAJ,OAAA;AACA,IAAAK,cAAA,GAAAL,OAAA;AAEO,IAAMM,QAAQ,GAAAC,OAAA,CAAAD,QAAA,gBAAGE,cAAK,CAACC,IAAI,CAAC,SAASH,QAAQA,CAAA,EAAG;EACnDI,gBAAO,CAACC,QAAQ,CACZ,IAAAC,+BAAqB,EAAC,CAAC,EACvB,IAAAC,qCAAwB,EAAC,CAAC,EAC1B,IAAAC,yCAA0B,EAAC,CAC/B,CAAC;EAED,oBACIhB,MAAA,CAAAiB,OAAA,CAAAC,aAAA,CAAAlB,MAAA,CAAAiB,OAAA,CAAAE,QAAA,qBACInB,MAAA,CAAAiB,OAAA,CAAAC,aAAA,CAACZ,YAAA,CAAAc,WAAW,MAAE,CAChB,CAAC;AAEX,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.createEntriesListElement = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _repeat = require("@material-design-icons/svg/round/repeat.svg");
|
|
10
|
+
var _EntriesList = require("./renderers/EntriesList");
|
|
11
|
+
var _helpers = require("@webiny/app-page-builder/editor/helpers");
|
|
12
|
+
var createEntriesListElement = exports.createEntriesListElement = function createEntriesListElement() {
|
|
13
|
+
return {
|
|
14
|
+
name: "pb-editor-page-element-entries-list",
|
|
15
|
+
type: "pb-editor-page-element",
|
|
16
|
+
elementType: "entries-list",
|
|
17
|
+
canReceiveChildren: true,
|
|
18
|
+
toolbar: {
|
|
19
|
+
title: "Entries List",
|
|
20
|
+
group: "pb-editor-element-group-basic",
|
|
21
|
+
preview: function preview() {
|
|
22
|
+
return /*#__PURE__*/_react.default.createElement(_repeat.ReactComponent, null);
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
settings: ["pb-editor-page-element-settings-clone", "pb-editor-page-element-settings-delete"],
|
|
26
|
+
target: ["cell", "block"],
|
|
27
|
+
create: function create() {
|
|
28
|
+
return {
|
|
29
|
+
type: this.elementType,
|
|
30
|
+
elements: [(0, _helpers.createElement)("grid")],
|
|
31
|
+
data: {}
|
|
32
|
+
};
|
|
33
|
+
},
|
|
34
|
+
render: function render(props) {
|
|
35
|
+
return /*#__PURE__*/_react.default.createElement(_EntriesList.AdminEntriesListRenderer, Object.assign({}, props, {
|
|
36
|
+
element: props.element
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
//# sourceMappingURL=entriesList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_repeat","_EntriesList","_helpers","createEntriesListElement","exports","name","type","elementType","canReceiveChildren","toolbar","title","group","preview","default","createElement","ReactComponent","settings","target","create","elements","data","render","props","AdminEntriesListRenderer","Object","assign","element"],"sources":["entriesList.tsx"],"sourcesContent":["import React from \"react\";\nimport { ReactComponent as RepeatIcon } from \"@material-design-icons/svg/round/repeat.svg\";\nimport { PbEditorPageElementPlugin, PbElement } from \"@webiny/app-page-builder/types\";\nimport { AdminEntriesListRenderer } from \"./renderers/EntriesList\";\nimport { createElement } from \"@webiny/app-page-builder/editor/helpers\";\n\nexport const createEntriesListElement = (): PbEditorPageElementPlugin => {\n return {\n name: `pb-editor-page-element-entries-list`,\n type: \"pb-editor-page-element\",\n elementType: \"entries-list\",\n canReceiveChildren: true,\n toolbar: {\n title: \"Entries List\",\n group: \"pb-editor-element-group-basic\",\n preview() {\n return <RepeatIcon />;\n }\n },\n settings: [\n \"pb-editor-page-element-settings-clone\",\n \"pb-editor-page-element-settings-delete\"\n ],\n target: [\"cell\", \"block\"],\n create() {\n return {\n type: this.elementType,\n elements: [createElement(\"grid\")],\n data: {}\n };\n },\n\n render(props) {\n return <AdminEntriesListRenderer {...props} element={props.element as PbElement} />;\n }\n };\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AAEA,IAAAE,YAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAEO,IAAMI,wBAAwB,GAAAC,OAAA,CAAAD,wBAAA,GAAG,SAA3BA,wBAAwBA,CAAA,EAAoC;EACrE,OAAO;IACHE,IAAI,uCAAuC;IAC3CC,IAAI,EAAE,wBAAwB;IAC9BC,WAAW,EAAE,cAAc;IAC3BC,kBAAkB,EAAE,IAAI;IACxBC,OAAO,EAAE;MACLC,KAAK,EAAE,cAAc;MACrBC,KAAK,EAAE,+BAA+B;MACtCC,OAAO,WAAPA,OAAOA,CAAA,EAAG;QACN,oBAAOf,MAAA,CAAAgB,OAAA,CAAAC,aAAA,CAACd,OAAA,CAAAe,cAAU,MAAE,CAAC;MACzB;IACJ,CAAC;IACDC,QAAQ,EAAE,CACN,uCAAuC,EACvC,wCAAwC,CAC3C;IACDC,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;IACzBC,MAAM,WAANA,MAAMA,CAAA,EAAG;MACL,OAAO;QACHZ,IAAI,EAAE,IAAI,CAACC,WAAW;QACtBY,QAAQ,EAAE,CAAC,IAAAL,sBAAa,EAAC,MAAM,CAAC,CAAC;QACjCM,IAAI,EAAE,CAAC;MACX,CAAC;IACL,CAAC;IAEDC,MAAM,WAANA,MAAMA,CAACC,KAAK,EAAE;MACV,oBAAOzB,MAAA,CAAAgB,OAAA,CAAAC,aAAA,CAACb,YAAA,CAAAsB,wBAAwB,EAAAC,MAAA,CAAAC,MAAA,KAAKH,KAAK;QAAEI,OAAO,EAAEJ,KAAK,CAACI;MAAqB,EAAE,CAAC;IACvF;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
|