@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.
Files changed (114) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +20 -0
  3. package/admin/ContentEntryForm/AddPreviewPane.d.ts +2 -0
  4. package/admin/ContentEntryForm/AddPreviewPane.js +52 -0
  5. package/admin/ContentEntryForm/AddPreviewPane.js.map +1 -0
  6. package/admin/ContentEntryForm/PassEntryToDataSource.d.ts +2 -0
  7. package/admin/ContentEntryForm/PassEntryToDataSource.js +78 -0
  8. package/admin/ContentEntryForm/PassEntryToDataSource.js.map +1 -0
  9. package/admin/ContentEntryForm/PreviewPane.d.ts +6 -0
  10. package/admin/ContentEntryForm/PreviewPane.js +65 -0
  11. package/admin/ContentEntryForm/PreviewPane.js.map +1 -0
  12. package/admin/Extensions.d.ts +2 -0
  13. package/admin/Extensions.js +23 -0
  14. package/admin/Extensions.js.map +1 -0
  15. package/admin/PageTemplateDialog/CreateTemplateDialog.d.ts +11 -0
  16. package/admin/PageTemplateDialog/CreateTemplateDialog.js +203 -0
  17. package/admin/PageTemplateDialog/CreateTemplateDialog.js.map +1 -0
  18. package/admin/PageTemplateDialog/PageTemplateDialog.d.ts +2 -0
  19. package/admin/PageTemplateDialog/PageTemplateDialog.js +55 -0
  20. package/admin/PageTemplateDialog/PageTemplateDialog.js.map +1 -0
  21. package/admin/SetupDynamicPages.d.ts +2 -0
  22. package/admin/SetupDynamicPages.js +23 -0
  23. package/admin/SetupDynamicPages.js.map +1 -0
  24. package/admin/elements/Elements.d.ts +2 -0
  25. package/admin/elements/Elements.js +19 -0
  26. package/admin/elements/Elements.js.map +1 -0
  27. package/admin/elements/entriesList.d.ts +2 -0
  28. package/admin/elements/entriesList.js +42 -0
  29. package/admin/elements/entriesList.js.map +1 -0
  30. package/admin/elements/entriesSearch.d.ts +2 -0
  31. package/admin/elements/entriesSearch.js +41 -0
  32. package/admin/elements/entriesSearch.js.map +1 -0
  33. package/admin/elements/eventHandlers/ContentTraverser.d.ts +11 -0
  34. package/admin/elements/eventHandlers/ContentTraverser.js +35 -0
  35. package/admin/elements/eventHandlers/ContentTraverser.js.map +1 -0
  36. package/admin/elements/renderers/DynamicGrid.d.ts +2 -0
  37. package/admin/elements/renderers/DynamicGrid.js +55 -0
  38. package/admin/elements/renderers/DynamicGrid.js.map +1 -0
  39. package/admin/elements/renderers/EntriesList.d.ts +10 -0
  40. package/admin/elements/renderers/EntriesList.js +30 -0
  41. package/admin/elements/renderers/EntriesList.js.map +1 -0
  42. package/admin/elements/renderers/Repeater.d.ts +7 -0
  43. package/admin/elements/renderers/Repeater.js +29 -0
  44. package/admin/elements/renderers/Repeater.js.map +1 -0
  45. package/admin/elements/repeater.d.ts +2 -0
  46. package/admin/elements/repeater.js +41 -0
  47. package/admin/elements/repeater.js.map +1 -0
  48. package/admin/index.d.ts +1 -0
  49. package/admin/index.js +14 -0
  50. package/admin/index.js.map +1 -0
  51. package/admin/pageEditor/DynamicPageEditorConfig.d.ts +2 -0
  52. package/admin/pageEditor/DynamicPageEditorConfig.js +17 -0
  53. package/admin/pageEditor/DynamicPageEditorConfig.js.map +1 -0
  54. package/admin/pageEditor/ElementEventHandlers.d.ts +1 -0
  55. package/admin/pageEditor/ElementEventHandlers.js +107 -0
  56. package/admin/pageEditor/ElementEventHandlers.js.map +1 -0
  57. package/admin/templateEditor/DynamicTemplateEditorConfig.d.ts +2 -0
  58. package/admin/templateEditor/DynamicTemplateEditorConfig.js +31 -0
  59. package/admin/templateEditor/DynamicTemplateEditorConfig.js.map +1 -0
  60. package/admin/templateEditor/ElementEventHandlers.d.ts +1 -0
  61. package/admin/templateEditor/ElementEventHandlers.js +107 -0
  62. package/admin/templateEditor/ElementEventHandlers.js.map +1 -0
  63. package/admin/templateEditor/EntrySelector/EntrySelector.d.ts +2 -0
  64. package/admin/templateEditor/EntrySelector/EntrySelector.js +38 -0
  65. package/admin/templateEditor/EntrySelector/EntrySelector.js.map +1 -0
  66. package/admin/templateEditor/EntrySelector/index.d.ts +1 -0
  67. package/admin/templateEditor/EntrySelector/index.js +18 -0
  68. package/admin/templateEditor/EntrySelector/index.js.map +1 -0
  69. package/dataInjection/AddEntriesListDataSourceContext.d.ts +2 -0
  70. package/dataInjection/AddEntriesListDataSourceContext.js +33 -0
  71. package/dataInjection/AddEntriesListDataSourceContext.js.map +1 -0
  72. package/dataInjection/editor/DisableGridDelete.d.ts +2 -0
  73. package/dataInjection/editor/DisableGridDelete.js +23 -0
  74. package/dataInjection/editor/DisableGridDelete.js.map +1 -0
  75. package/dataInjection/editor/ElementDataSettings.d.ts +2 -0
  76. package/dataInjection/editor/ElementDataSettings.js +28 -0
  77. package/dataInjection/editor/ElementDataSettings.js.map +1 -0
  78. package/dataInjection/editor/HideIfChildOfEntriesList.d.ts +6 -0
  79. package/dataInjection/editor/HideIfChildOfEntriesList.js +24 -0
  80. package/dataInjection/editor/HideIfChildOfEntriesList.js.map +1 -0
  81. package/dataInjection/editor/HideIfEntriesListGridWithDataSource.d.ts +6 -0
  82. package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js +31 -0
  83. package/dataInjection/editor/HideIfEntriesListGridWithDataSource.js.map +1 -0
  84. package/dataInjection/editor/SetupElementDataSettings.d.ts +2 -0
  85. package/dataInjection/editor/SetupElementDataSettings.js +19 -0
  86. package/dataInjection/editor/SetupElementDataSettings.js.map +1 -0
  87. package/dataInjection/renderers/DynamicElementRenderers.d.ts +2 -0
  88. package/dataInjection/renderers/DynamicElementRenderers.js +27 -0
  89. package/dataInjection/renderers/DynamicElementRenderers.js.map +1 -0
  90. package/dataInjection/renderers/DynamicGrid.d.ts +2 -0
  91. package/dataInjection/renderers/DynamicGrid.js +50 -0
  92. package/dataInjection/renderers/DynamicGrid.js.map +1 -0
  93. package/dataInjection/renderers/EntriesList.d.ts +70 -0
  94. package/dataInjection/renderers/EntriesList.js +51 -0
  95. package/dataInjection/renderers/EntriesList.js.map +1 -0
  96. package/dataInjection/renderers/EntriesSearch.d.ts +47 -0
  97. package/dataInjection/renderers/EntriesSearch.js +38 -0
  98. package/dataInjection/renderers/EntriesSearch.js.map +1 -0
  99. package/dataInjection/renderers/Repeater.d.ts +70 -0
  100. package/dataInjection/renderers/Repeater.js +51 -0
  101. package/dataInjection/renderers/Repeater.js.map +1 -0
  102. package/features/index.d.ts +3 -0
  103. package/features/index.js +40 -0
  104. package/features/index.js.map +1 -0
  105. package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.d.ts +4 -0
  106. package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js +65 -0
  107. package/features/pageTemplate/createDynamicTemplate/useCreateDynamicTemplate.js.map +1 -0
  108. package/features/pageTemplate/hasMainDataSource.d.ts +2 -0
  109. package/features/pageTemplate/hasMainDataSource.js +13 -0
  110. package/features/pageTemplate/hasMainDataSource.js.map +1 -0
  111. package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.d.ts +3 -0
  112. package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js +20 -0
  113. package/features/pageTemplate/listDynamicTemplates/useListDynamicTemplates.js.map +1 -0
  114. 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 &lt; 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,2 @@
1
+ import React from "react";
2
+ export declare const PageTemplateDialog: (props: unknown) => React.JSX.Element;
@@ -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,2 @@
1
+ import React from "react";
2
+ export declare const SetupDynamicPages: () => React.JSX.Element;
@@ -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,2 @@
1
+ import React from "react";
2
+ export declare const Elements: React.NamedExoticComponent<object>;
@@ -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,2 @@
1
+ import { PbEditorPageElementPlugin } from "@webiny/app-page-builder/types";
2
+ export declare const createEntriesListElement: () => PbEditorPageElementPlugin;
@@ -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":[]}
@@ -0,0 +1,2 @@
1
+ import { PbEditorPageElementPlugin } from "@webiny/app-page-builder/types";
2
+ export declare const createEntriesSearchElement: () => PbEditorPageElementPlugin;