@webiny/app-headless-cms 5.42.3-beta.2 → 5.42.3-beta.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ContentEntryEditorConfig.d.ts +21 -0
- package/ContentEntryEditorConfig.js +4 -5
- package/ContentEntryEditorConfig.js.map +1 -1
- package/ContentEntryListConfig.d.ts +6 -1
- package/admin/components/LexicalCmsEditor/LexicalCmsEditor.js +1 -4
- package/admin/components/LexicalCmsEditor/LexicalCmsEditor.js.map +1 -1
- package/admin/config/contentEntries/list/Browser/AdvancedSearch/FieldRenderer.js +1 -4
- package/admin/config/contentEntries/list/Browser/AdvancedSearch/FieldRenderer.js.map +1 -1
- package/admin/config/contentEntries/list/Browser/EntryAction.js +2 -4
- package/admin/config/contentEntries/list/Browser/EntryAction.js.map +1 -1
- package/admin/config/contentEntries/list/Browser/FolderAction.js +1 -4
- package/admin/config/contentEntries/list/Browser/FolderAction.js.map +1 -1
- package/admin/config/contentEntries/list/Browser/Table/Column.js +2 -4
- package/admin/config/contentEntries/list/Browser/Table/Column.js.map +1 -1
- package/admin/config/contentEntries/list/ContentEntryListConfig.d.ts +48 -43
- package/admin/config/contentEntries/list/ContentEntryListConfig.js +11 -2
- package/admin/config/contentEntries/list/ContentEntryListConfig.js.map +1 -1
- package/admin/plugins/fieldRenderers/dynamicZone/MultiValueDynamicZone.d.ts +1 -0
- package/admin/plugins/fieldRenderers/dynamicZone/MultiValueDynamicZone.js +7 -3
- package/admin/plugins/fieldRenderers/dynamicZone/MultiValueDynamicZone.js.map +1 -1
- package/admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone.d.ts +35 -1
- package/admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone.js +26 -9
- package/admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone.js.map +1 -1
- package/admin/plugins/fieldRenderers/dynamicZone/dynamicZoneRenderer.d.ts +1 -0
- package/admin/plugins/fieldRenderers/dynamicZone/dynamicZoneRenderer.js +2 -1
- package/admin/plugins/fieldRenderers/dynamicZone/dynamicZoneRenderer.js.map +1 -1
- package/package.json +27 -27
|
@@ -278,6 +278,27 @@ export declare const ContentEntryEditorConfig: (({ priority, children }: import(
|
|
|
278
278
|
displayName: string;
|
|
279
279
|
}>) => (props: unknown) => import("react").JSX.Element;
|
|
280
280
|
};
|
|
281
|
+
SingleValue: {
|
|
282
|
+
ItemContainer: ((props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element) & {
|
|
283
|
+
original: (props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element;
|
|
284
|
+
originalName: string;
|
|
285
|
+
displayName: string;
|
|
286
|
+
} & {
|
|
287
|
+
original: ((props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element) & {
|
|
288
|
+
original: (props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element;
|
|
289
|
+
originalName: string;
|
|
290
|
+
displayName: string;
|
|
291
|
+
};
|
|
292
|
+
originalName: string;
|
|
293
|
+
displayName: string;
|
|
294
|
+
} & {
|
|
295
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<((props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element) & {
|
|
296
|
+
original: (props: import("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone").SingleValueItemContainerProps) => import("react").JSX.Element;
|
|
297
|
+
originalName: string;
|
|
298
|
+
displayName: string;
|
|
299
|
+
}>) => (props: unknown) => import("react").JSX.Element;
|
|
300
|
+
};
|
|
301
|
+
};
|
|
281
302
|
MultiValue: {
|
|
282
303
|
Container: (({ children }: import("./admin/plugins/fieldRenderers/dynamicZone/MultiValueDynamicZone").MultiValueContainerProps) => import("react").JSX.Element) & {
|
|
283
304
|
original: ({ children }: import("./admin/plugins/fieldRenderers/dynamicZone/MultiValueDynamicZone").MultiValueContainerProps) => import("react").JSX.Element;
|
|
@@ -18,6 +18,7 @@ var _contentEntries = require("./admin/config/contentEntries");
|
|
|
18
18
|
var _SingletonContentEntry = require("./admin/views/contentEntries/ContentEntry/SingletonContentEntry");
|
|
19
19
|
var _useSingletonContentEntry = require("./admin/views/contentEntries/hooks/useSingletonContentEntry");
|
|
20
20
|
var _FullScreenContentEntryHeaderLeft = require("./admin/views/contentEntries/ContentEntry/FullScreenContentEntry/FullScreenContentEntryHeaderLeft");
|
|
21
|
+
var _SingleValueDynamicZone = require("./admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone");
|
|
21
22
|
var ContentEntryEditorConfig = exports.ContentEntryEditorConfig = Object.assign(_contentEntries.ContentEntryEditorConfig, {
|
|
22
23
|
ContentEntry: Object.assign(_ContentEntry.ContentEntry, {
|
|
23
24
|
useContentEntry: _hooks.useContentEntry,
|
|
@@ -45,11 +46,9 @@ var ContentEntryEditorConfig = exports.ContentEntryEditorConfig = Object.assign(
|
|
|
45
46
|
useTemplate: DzField.useTemplate
|
|
46
47
|
},
|
|
47
48
|
Container: DzField.DynamicZoneContainer,
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
// Item: null
|
|
52
|
-
// },
|
|
49
|
+
SingleValue: {
|
|
50
|
+
ItemContainer: _SingleValueDynamicZone.SingleValueItemContainer
|
|
51
|
+
},
|
|
53
52
|
MultiValue: {
|
|
54
53
|
Container: DzField.MultiValueContainer,
|
|
55
54
|
ItemContainer: DzField.MultiValueItemContainer,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DzField","_interopRequireWildcard","require","_object","_ContentEntryForm","_Header","_ContentEntryFormPreview","_useContentEntryForm","_DefaultLayout","_hooks","_ContentEntry","_contentEntries","_SingletonContentEntry","_useSingletonContentEntry","_FullScreenContentEntryHeaderLeft","ContentEntryEditorConfig","exports","Object","assign","BaseContentEntryEditorConfig","ContentEntry","useContentEntry","DefaultLayout","ContentEntryForm","BaseContentEntryForm","useContentEntryForm","Header","ContentEntryFormHeader","Title","ContentEntryFormTitle","Meta","ContentEntryFormMeta","ContentEntryFormPreview","SingletonContentEntry","useSingletonContentEntry","FieldRenderers","MultiValue","ItemContainer","ObjectField","MultiValueItemContainer","DynamicZone","Template","useTemplate","Container","DynamicZoneContainer","MultiValueContainer","Item","MultiValueItem","TemplateGallery"],"sources":["ContentEntryEditorConfig.ts"],"sourcesContent":["import * as DzField from \"~/admin/plugins/fieldRenderers/dynamicZone\";\nimport { Components as ObjectField } from \"~/admin/plugins/fieldRenderers/object\";\nimport { ContentEntryForm as BaseContentEntryForm } from \"./admin/components/ContentEntryForm/ContentEntryForm\";\nimport { Header as ContentEntryFormHeader } from \"./admin/components/ContentEntryForm/Header\";\nimport { ContentEntryFormPreview } from \"./admin/components/ContentEntryForm/ContentEntryFormPreview\";\nimport { useContentEntryForm } from \"./admin/components/ContentEntryForm/useContentEntryForm\";\nimport { DefaultLayout } from \"~/admin/components/ContentEntryForm/DefaultLayout\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks\";\nimport { ContentEntry } from \"~/admin/views/contentEntries/ContentEntry\";\nimport { ContentEntryEditorConfig as BaseContentEntryEditorConfig } from \"./admin/config/contentEntries\";\nimport { SingletonContentEntry } from \"~/admin/views/contentEntries/ContentEntry/SingletonContentEntry\";\nimport { useSingletonContentEntry } from \"~/admin/views/contentEntries/hooks/useSingletonContentEntry\";\nimport {\n ContentEntryFormMeta,\n ContentEntryFormTitle\n} from \"~/admin/views/contentEntries/ContentEntry/FullScreenContentEntry/FullScreenContentEntryHeaderLeft\";\n\nexport const ContentEntryEditorConfig = Object.assign(BaseContentEntryEditorConfig, {\n ContentEntry: Object.assign(ContentEntry, {\n useContentEntry,\n DefaultLayout,\n ContentEntryForm: Object.assign(BaseContentEntryForm, {\n useContentEntryForm,\n Header: Object.assign(ContentEntryFormHeader, {\n Title: ContentEntryFormTitle,\n Meta: ContentEntryFormMeta\n })\n }),\n ContentEntryFormPreview\n }),\n SingletonContentEntry: Object.assign(SingletonContentEntry, {\n useSingletonContentEntry\n }),\n FieldRenderers: {\n Object: {\n MultiValue: {\n ItemContainer: ObjectField.MultiValueItemContainer\n }\n },\n DynamicZone: {\n Template: {\n useTemplate: DzField.useTemplate\n },\n Container: DzField.DynamicZoneContainer,\n
|
|
1
|
+
{"version":3,"names":["DzField","_interopRequireWildcard","require","_object","_ContentEntryForm","_Header","_ContentEntryFormPreview","_useContentEntryForm","_DefaultLayout","_hooks","_ContentEntry","_contentEntries","_SingletonContentEntry","_useSingletonContentEntry","_FullScreenContentEntryHeaderLeft","_SingleValueDynamicZone","ContentEntryEditorConfig","exports","Object","assign","BaseContentEntryEditorConfig","ContentEntry","useContentEntry","DefaultLayout","ContentEntryForm","BaseContentEntryForm","useContentEntryForm","Header","ContentEntryFormHeader","Title","ContentEntryFormTitle","Meta","ContentEntryFormMeta","ContentEntryFormPreview","SingletonContentEntry","useSingletonContentEntry","FieldRenderers","MultiValue","ItemContainer","ObjectField","MultiValueItemContainer","DynamicZone","Template","useTemplate","Container","DynamicZoneContainer","SingleValue","SingleValueItemContainer","MultiValueContainer","Item","MultiValueItem","TemplateGallery"],"sources":["ContentEntryEditorConfig.ts"],"sourcesContent":["import * as DzField from \"~/admin/plugins/fieldRenderers/dynamicZone\";\nimport { Components as ObjectField } from \"~/admin/plugins/fieldRenderers/object\";\nimport { ContentEntryForm as BaseContentEntryForm } from \"./admin/components/ContentEntryForm/ContentEntryForm\";\nimport { Header as ContentEntryFormHeader } from \"./admin/components/ContentEntryForm/Header\";\nimport { ContentEntryFormPreview } from \"./admin/components/ContentEntryForm/ContentEntryFormPreview\";\nimport { useContentEntryForm } from \"./admin/components/ContentEntryForm/useContentEntryForm\";\nimport { DefaultLayout } from \"~/admin/components/ContentEntryForm/DefaultLayout\";\nimport { useContentEntry } from \"~/admin/views/contentEntries/hooks\";\nimport { ContentEntry } from \"~/admin/views/contentEntries/ContentEntry\";\nimport { ContentEntryEditorConfig as BaseContentEntryEditorConfig } from \"./admin/config/contentEntries\";\nimport { SingletonContentEntry } from \"~/admin/views/contentEntries/ContentEntry/SingletonContentEntry\";\nimport { useSingletonContentEntry } from \"~/admin/views/contentEntries/hooks/useSingletonContentEntry\";\nimport {\n ContentEntryFormMeta,\n ContentEntryFormTitle\n} from \"~/admin/views/contentEntries/ContentEntry/FullScreenContentEntry/FullScreenContentEntryHeaderLeft\";\nimport { SingleValueItemContainer } from \"~/admin/plugins/fieldRenderers/dynamicZone/SingleValueDynamicZone\";\n\nexport const ContentEntryEditorConfig = Object.assign(BaseContentEntryEditorConfig, {\n ContentEntry: Object.assign(ContentEntry, {\n useContentEntry,\n DefaultLayout,\n ContentEntryForm: Object.assign(BaseContentEntryForm, {\n useContentEntryForm,\n Header: Object.assign(ContentEntryFormHeader, {\n Title: ContentEntryFormTitle,\n Meta: ContentEntryFormMeta\n })\n }),\n ContentEntryFormPreview\n }),\n SingletonContentEntry: Object.assign(SingletonContentEntry, {\n useSingletonContentEntry\n }),\n FieldRenderers: {\n Object: {\n MultiValue: {\n ItemContainer: ObjectField.MultiValueItemContainer\n }\n },\n DynamicZone: {\n Template: {\n useTemplate: DzField.useTemplate\n },\n Container: DzField.DynamicZoneContainer,\n SingleValue: {\n ItemContainer: SingleValueItemContainer\n },\n MultiValue: {\n Container: DzField.MultiValueContainer,\n ItemContainer: DzField.MultiValueItemContainer,\n Item: DzField.MultiValueItem\n },\n TemplateGallery: DzField.TemplateGallery\n }\n }\n});\n"],"mappings":";;;;;;;AAAA,IAAAA,OAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,iBAAA,GAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,wBAAA,GAAAJ,OAAA;AACA,IAAAK,oBAAA,GAAAL,OAAA;AACA,IAAAM,cAAA,GAAAN,OAAA;AACA,IAAAO,MAAA,GAAAP,OAAA;AACA,IAAAQ,aAAA,GAAAR,OAAA;AACA,IAAAS,eAAA,GAAAT,OAAA;AACA,IAAAU,sBAAA,GAAAV,OAAA;AACA,IAAAW,yBAAA,GAAAX,OAAA;AACA,IAAAY,iCAAA,GAAAZ,OAAA;AAIA,IAAAa,uBAAA,GAAAb,OAAA;AAEO,IAAMc,wBAAwB,GAAAC,OAAA,CAAAD,wBAAA,GAAGE,MAAM,CAACC,MAAM,CAACC,wCAA4B,EAAE;EAChFC,YAAY,EAAEH,MAAM,CAACC,MAAM,CAACE,0BAAY,EAAE;IACtCC,eAAe,EAAfA,sBAAe;IACfC,aAAa,EAAbA,4BAAa;IACbC,gBAAgB,EAAEN,MAAM,CAACC,MAAM,CAACM,kCAAoB,EAAE;MAClDC,mBAAmB,EAAnBA,wCAAmB;MACnBC,MAAM,EAAET,MAAM,CAACC,MAAM,CAACS,cAAsB,EAAE;QAC1CC,KAAK,EAAEC,uDAAqB;QAC5BC,IAAI,EAAEC;MACV,CAAC;IACL,CAAC,CAAC;IACFC,uBAAuB,EAAvBA;EACJ,CAAC,CAAC;EACFC,qBAAqB,EAAEhB,MAAM,CAACC,MAAM,CAACe,4CAAqB,EAAE;IACxDC,wBAAwB,EAAxBA;EACJ,CAAC,CAAC;EACFC,cAAc,EAAE;IACZlB,MAAM,EAAE;MACJmB,UAAU,EAAE;QACRC,aAAa,EAAEC,kBAAW,CAACC;MAC/B;IACJ,CAAC;IACDC,WAAW,EAAE;MACTC,QAAQ,EAAE;QACNC,WAAW,EAAE3C,OAAO,CAAC2C;MACzB,CAAC;MACDC,SAAS,EAAE5C,OAAO,CAAC6C,oBAAoB;MACvCC,WAAW,EAAE;QACTR,aAAa,EAAES;MACnB,CAAC;MACDV,UAAU,EAAE;QACRO,SAAS,EAAE5C,OAAO,CAACgD,mBAAmB;QACtCV,aAAa,EAAEtC,OAAO,CAACwC,uBAAuB;QAC9CS,IAAI,EAAEjD,OAAO,CAACkD;MAClB,CAAC;MACDC,eAAe,EAAEnD,OAAO,CAACmD;IAC7B;EACJ;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
export declare const ContentEntryListConfig:
|
|
2
|
+
export declare const ContentEntryListConfig: {
|
|
3
|
+
({ children }: {
|
|
4
|
+
children: import("react").ReactNode;
|
|
5
|
+
}): import("react").JSX.Element;
|
|
6
|
+
displayName: string;
|
|
7
|
+
} & {
|
|
3
8
|
Browser: {
|
|
4
9
|
AdvancedSearch: {
|
|
5
10
|
FieldRenderer: (({ modelIds, ...props }: import("./admin/config/contentEntries/list/Browser/AdvancedSearch/FieldRenderer").FieldRendererProps) => import("react").JSX.Element | null) & {
|
|
@@ -7,7 +7,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
exports.LexicalCmsEditor = void 0;
|
|
8
8
|
var _react = _interopRequireWildcard(require("react"));
|
|
9
9
|
var _lexicalEditor = require("@webiny/lexical-editor");
|
|
10
|
-
var _reactComposition = require("@webiny/react-composition");
|
|
11
10
|
var _LexicalEditor = require("@webiny/app-admin/components/LexicalEditor");
|
|
12
11
|
var placeholderStyles = {
|
|
13
12
|
position: "absolute",
|
|
@@ -26,9 +25,7 @@ var styles = {
|
|
|
26
25
|
minHeight: 200,
|
|
27
26
|
maxHeight: 350
|
|
28
27
|
};
|
|
29
|
-
var toolbar = /*#__PURE__*/_react.default.createElement(
|
|
30
|
-
name: "cms"
|
|
31
|
-
}, /*#__PURE__*/_react.default.createElement(_lexicalEditor.StaticToolbar, null));
|
|
28
|
+
var toolbar = /*#__PURE__*/_react.default.createElement(_lexicalEditor.StaticToolbar, null);
|
|
32
29
|
var LexicalCmsEditor = exports.LexicalCmsEditor = function LexicalCmsEditor(props) {
|
|
33
30
|
var onChange = (0, _react.useCallback)(function (jsonString) {
|
|
34
31
|
if (props?.onChange) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_lexicalEditor","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_lexicalEditor","_LexicalEditor","placeholderStyles","position","top","left","contentEditableStyles","minHeight","display","padding","styles","backgroundColor","border","maxHeight","toolbar","default","createElement","StaticToolbar","LexicalCmsEditor","exports","props","onChange","useCallback","jsonString","JSON","parse","LexicalEditor","Object","assign","focus","value","stringify","staticToolbar","tag","placeholder"],"sources":["LexicalCmsEditor.tsx"],"sourcesContent":["import React, { useCallback } from \"react\";\nimport { StaticToolbar } from \"@webiny/lexical-editor\";\nimport { RichTextEditorProps } from \"@webiny/lexical-editor/types\";\nimport { LexicalEditor } from \"@webiny/app-admin/components/LexicalEditor\";\n\nconst placeholderStyles: React.CSSProperties = { position: \"absolute\", top: 40, left: 25 };\n\nconst contentEditableStyles: React.CSSProperties = {\n minHeight: 200,\n display: \"block\",\n padding: 10\n};\n\nconst styles: React.CSSProperties = {\n backgroundColor: \"#fff\",\n border: \"1px solid #e1e1e1\",\n padding: \"10px 14px\",\n minHeight: 200,\n maxHeight: 350\n};\n\nconst toolbar = <StaticToolbar />;\n\nexport const LexicalCmsEditor = (props: Omit<RichTextEditorProps, \"theme\">) => {\n const onChange = useCallback(\n (jsonString: string) => {\n if (props?.onChange) {\n props?.onChange(JSON.parse(jsonString));\n }\n },\n [props?.onChange]\n );\n\n return (\n <LexicalEditor\n {...props}\n focus={true}\n value={props.value ? JSON.stringify(props.value) : props.value}\n onChange={onChange}\n staticToolbar={toolbar}\n tag={\"p\"}\n placeholder={props?.placeholder || \"Enter your text here...\"}\n placeholderStyles={placeholderStyles}\n contentEditableStyles={contentEditableStyles}\n styles={styles}\n />\n );\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,cAAA,GAAAD,OAAA;AAEA,IAAAE,cAAA,GAAAF,OAAA;AAEA,IAAMG,iBAAsC,GAAG;EAAEC,QAAQ,EAAE,UAAU;EAAEC,GAAG,EAAE,EAAE;EAAEC,IAAI,EAAE;AAAG,CAAC;AAE1F,IAAMC,qBAA0C,GAAG;EAC/CC,SAAS,EAAE,GAAG;EACdC,OAAO,EAAE,OAAO;EAChBC,OAAO,EAAE;AACb,CAAC;AAED,IAAMC,MAA2B,GAAG;EAChCC,eAAe,EAAE,MAAM;EACvBC,MAAM,EAAE,mBAAmB;EAC3BH,OAAO,EAAE,WAAW;EACpBF,SAAS,EAAE,GAAG;EACdM,SAAS,EAAE;AACf,CAAC;AAED,IAAMC,OAAO,gBAAGjB,MAAA,CAAAkB,OAAA,CAAAC,aAAA,CAAChB,cAAA,CAAAiB,aAAa,MAAE,CAAC;AAE1B,IAAMC,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,GAAG,SAAnBA,gBAAgBA,CAAIE,KAAyC,EAAK;EAC3E,IAAMC,QAAQ,GAAG,IAAAC,kBAAW,EACxB,UAACC,UAAkB,EAAK;IACpB,IAAIH,KAAK,EAAEC,QAAQ,EAAE;MACjBD,KAAK,EAAEC,QAAQ,CAACG,IAAI,CAACC,KAAK,CAACF,UAAU,CAAC,CAAC;IAC3C;EACJ,CAAC,EACD,CAACH,KAAK,EAAEC,QAAQ,CACpB,CAAC;EAED,oBACIxB,MAAA,CAAAkB,OAAA,CAAAC,aAAA,CAACf,cAAA,CAAAyB,aAAa,EAAAC,MAAA,CAAAC,MAAA,KACNR,KAAK;IACTS,KAAK,EAAE,IAAK;IACZC,KAAK,EAAEV,KAAK,CAACU,KAAK,GAAGN,IAAI,CAACO,SAAS,CAACX,KAAK,CAACU,KAAK,CAAC,GAAGV,KAAK,CAACU,KAAM;IAC/DT,QAAQ,EAAEA,QAAS;IACnBW,aAAa,EAAElB,OAAQ;IACvBmB,GAAG,EAAE,GAAI;IACTC,WAAW,EAAEd,KAAK,EAAEc,WAAW,IAAI,yBAA0B;IAC7DhC,iBAAiB,EAAEA,iBAAkB;IACrCI,qBAAqB,EAAEA,qBAAsB;IAC7CI,MAAM,EAAEA;EAAO,EAClB,CAAC;AAEV,CAAC","ignoreList":[]}
|
|
@@ -13,7 +13,6 @@ Object.defineProperty(exports, "FieldRendererConfig", {
|
|
|
13
13
|
});
|
|
14
14
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
15
15
|
var _react = _interopRequireDefault(require("react"));
|
|
16
|
-
var _reactComposition = require("@webiny/react-composition");
|
|
17
16
|
var _appAco = require("@webiny/app-aco");
|
|
18
17
|
var _ModelProvider = require("../../../../../components/ModelProvider");
|
|
19
18
|
var _excluded = ["modelIds"];
|
|
@@ -27,9 +26,7 @@ var BaseFieldRenderer = function BaseFieldRenderer(_ref) {
|
|
|
27
26
|
if (modelIds.length > 0 && !modelIds.includes(model.modelId)) {
|
|
28
27
|
return null;
|
|
29
28
|
}
|
|
30
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
31
|
-
name: "cms"
|
|
32
|
-
}, /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(AdvancedSearch.FieldRenderer, props)));
|
|
29
|
+
return /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(AdvancedSearch.FieldRenderer, props));
|
|
33
30
|
};
|
|
34
31
|
var FieldRenderer = exports.FieldRenderer = Object.assign(BaseFieldRenderer, {
|
|
35
32
|
useInputField: AdvancedSearch.FieldRenderer.useInputField,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_appAco","_ModelProvider","_excluded","AdvancedSearch","AcoConfig","BaseFieldRenderer","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","_useModel","useModel","model","length","includes","modelId","createElement","FieldRenderer","exports","Object","assign","useInputField","FieldType"],"sources":["FieldRenderer.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n AcoConfig,\n AdvancedSearchFieldRendererConfig as FieldRendererConfig\n} from \"@webiny/app-aco\";\nimport { useModel } from \"~/admin/components/ModelProvider\";\n\nconst { AdvancedSearch } = AcoConfig;\n\nexport { FieldRendererConfig };\n\nexport interface FieldRendererProps\n extends React.ComponentProps<typeof AcoConfig.AdvancedSearch.FieldRenderer> {\n modelIds?: string[];\n}\n\nconst BaseFieldRenderer = ({ modelIds = [], ...props }: FieldRendererProps) => {\n const { model } = useModel();\n\n if (modelIds.length > 0 && !modelIds.includes(model.modelId)) {\n return null;\n }\n\n return (\n <AcoConfig>\n <AdvancedSearch.FieldRenderer {...props} />\n </AcoConfig>\n );\n};\n\nexport const FieldRenderer = Object.assign(BaseFieldRenderer, {\n useInputField: AdvancedSearch.FieldRenderer.useInputField,\n FieldType: AdvancedSearch.FieldRenderer.FieldType\n});\n"],"mappings":";;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AAIA,IAAAE,cAAA,GAAAF,OAAA;AAA4D,IAAAG,SAAA;AAE5D,IAAQC,cAAc,GAAKC,iBAAS,CAA5BD,cAAc;AAStB,IAAME,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAAC,IAAA,EAAwD;EAAA,IAAAC,aAAA,GAAAD,IAAA,CAAlDE,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,EAAE,GAAAA,aAAA;IAAKE,KAAK,OAAAC,yBAAA,CAAAC,OAAA,EAAAL,IAAA,EAAAJ,SAAA;EAChD,IAAAU,SAAA,GAAkB,IAAAC,uBAAQ,EAAC,CAAC;IAApBC,KAAK,GAAAF,SAAA,CAALE,KAAK;EAEb,IAAIN,QAAQ,CAACO,MAAM,GAAG,CAAC,IAAI,CAACP,QAAQ,CAACQ,QAAQ,CAACF,KAAK,CAACG,OAAO,CAAC,EAAE;IAC1D,OAAO,IAAI;EACf;EAEA,oBACIpB,MAAA,CAAAc,OAAA,CAAAO,aAAA,CAAClB,OAAA,CAAAI,SAAS,qBACNP,MAAA,CAAAc,OAAA,CAAAO,aAAA,CAACf,cAAc,CAACgB,aAAa,EAAKV,KAAQ,CACnC,CAAC;AAEpB,CAAC;AAEM,IAAMU,aAAa,GAAAC,OAAA,CAAAD,aAAA,GAAGE,MAAM,CAACC,MAAM,CAACjB,iBAAiB,EAAE;EAC1DkB,aAAa,EAAEpB,cAAc,CAACgB,aAAa,CAACI,aAAa;EACzDC,SAAS,EAAErB,cAAc,CAACgB,aAAa,CAACK;AAC5C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -22,11 +22,9 @@ var BaseEntryAction = (0, _reactComposition.makeDecoratable)("EntryAction", func
|
|
|
22
22
|
var _ref$modelIds = _ref.modelIds,
|
|
23
23
|
modelIds = _ref$modelIds === void 0 ? [] : _ref$modelIds,
|
|
24
24
|
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
25
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
26
|
-
name: "cms"
|
|
27
|
-
}, /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(_IsApplicableToCurrentModel.IsApplicableToCurrentModel, {
|
|
25
|
+
return /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(_IsApplicableToCurrentModel.IsApplicableToCurrentModel, {
|
|
28
26
|
modelIds: modelIds
|
|
29
|
-
}, /*#__PURE__*/_react.default.createElement(Record.Action, props)))
|
|
27
|
+
}, /*#__PURE__*/_react.default.createElement(Record.Action, props)));
|
|
30
28
|
});
|
|
31
29
|
var EntryAction = exports.EntryAction = Object.assign(BaseEntryAction, {
|
|
32
30
|
OptionsMenuItem: Record.Action.OptionsMenuItem,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_reactComposition","_appAco","_IsApplicableToCurrentModel","_excluded","Record","AcoConfig","BaseEntryAction","makeDecoratable","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","createElement","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_reactComposition","_appAco","_IsApplicableToCurrentModel","_excluded","Record","AcoConfig","BaseEntryAction","makeDecoratable","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","createElement","IsApplicableToCurrentModel","Action","EntryAction","exports","Object","assign","OptionsMenuItem","OptionsMenuLink"],"sources":["EntryAction.tsx"],"sourcesContent":["import React from \"react\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { AcoConfig, RecordActionConfig } from \"@webiny/app-aco\";\nimport { IsApplicableToCurrentModel } from \"~/admin/config/IsApplicableToCurrentModel\";\n\nconst { Record } = AcoConfig;\n\nexport { RecordActionConfig as EntryActionConfig };\n\nexport interface EntryActionProps extends React.ComponentProps<typeof AcoConfig.Record.Action> {\n modelIds?: string[];\n}\n\nconst BaseEntryAction = makeDecoratable(\n \"EntryAction\",\n ({ modelIds = [], ...props }: EntryActionProps) => {\n return (\n <AcoConfig>\n <IsApplicableToCurrentModel modelIds={modelIds}>\n <Record.Action {...props} />\n </IsApplicableToCurrentModel>\n </AcoConfig>\n );\n }\n);\n\nexport const EntryAction = Object.assign(BaseEntryAction, {\n OptionsMenuItem: Record.Action.OptionsMenuItem,\n OptionsMenuLink: Record.Action.OptionsMenuLink\n});\n"],"mappings":";;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,2BAAA,GAAAH,OAAA;AAAuF,IAAAI,SAAA;AAEvF,IAAQC,MAAM,GAAKC,iBAAS,CAApBD,MAAM;AAQd,IAAME,eAAe,GAAG,IAAAC,iCAAe,EACnC,aAAa,EACb,UAAAC,IAAA,EAAmD;EAAA,IAAAC,aAAA,GAAAD,IAAA,CAAhDE,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,EAAE,GAAAA,aAAA;IAAKE,KAAK,OAAAC,yBAAA,CAAAC,OAAA,EAAAL,IAAA,EAAAL,SAAA;EACtB,oBACIN,MAAA,CAAAgB,OAAA,CAAAC,aAAA,CAACb,OAAA,CAAAI,SAAS,qBACNR,MAAA,CAAAgB,OAAA,CAAAC,aAAA,CAACZ,2BAAA,CAAAa,0BAA0B;IAACL,QAAQ,EAAEA;EAAS,gBAC3Cb,MAAA,CAAAgB,OAAA,CAAAC,aAAA,CAACV,MAAM,CAACY,MAAM,EAAKL,KAAQ,CACH,CACrB,CAAC;AAEpB,CACJ,CAAC;AAEM,IAAMM,WAAW,GAAAC,OAAA,CAAAD,WAAA,GAAGE,MAAM,CAACC,MAAM,CAACd,eAAe,EAAE;EACtDe,eAAe,EAAEjB,MAAM,CAACY,MAAM,CAACK,eAAe;EAC9CC,eAAe,EAAElB,MAAM,CAACY,MAAM,CAACM;AACnC,CAAC,CAAC","ignoreList":[]}
|
|
@@ -13,7 +13,6 @@ Object.defineProperty(exports, "FolderActionConfig", {
|
|
|
13
13
|
});
|
|
14
14
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
15
15
|
var _react = _interopRequireDefault(require("react"));
|
|
16
|
-
var _reactComposition = require("@webiny/react-composition");
|
|
17
16
|
var _appAco = require("@webiny/app-aco");
|
|
18
17
|
var _hooks = require("../../../../hooks");
|
|
19
18
|
var _excluded = ["modelIds"];
|
|
@@ -27,9 +26,7 @@ var BaseFolderAction = function BaseFolderAction(_ref) {
|
|
|
27
26
|
if (modelIds.length > 0 && !modelIds.includes(model.modelId)) {
|
|
28
27
|
return null;
|
|
29
28
|
}
|
|
30
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
31
|
-
name: "cms"
|
|
32
|
-
}, /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(Folder.Action, props)));
|
|
29
|
+
return /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(Folder.Action, props));
|
|
33
30
|
};
|
|
34
31
|
var FolderAction = exports.FolderAction = Object.assign(BaseFolderAction, {
|
|
35
32
|
OptionsMenuItem: Folder.Action.OptionsMenuItem
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_appAco","_hooks","_excluded","Folder","AcoConfig","BaseFolderAction","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","_useModel","useModel","model","length","includes","modelId","createElement","Action","FolderAction","exports","Object","assign","OptionsMenuItem"],"sources":["FolderAction.tsx"],"sourcesContent":["import React from \"react\";\nimport { AcoConfig, FolderActionConfig } from \"@webiny/app-aco\";\nimport { useModel } from \"~/admin/hooks\";\n\nconst { Folder } = AcoConfig;\n\nexport { FolderActionConfig };\n\nexport interface FolderActionProps extends React.ComponentProps<typeof AcoConfig.Folder.Action> {\n modelIds?: string[];\n}\n\nconst BaseFolderAction = ({ modelIds = [], ...props }: FolderActionProps) => {\n const { model } = useModel();\n\n if (modelIds.length > 0 && !modelIds.includes(model.modelId)) {\n return null;\n }\n\n return (\n <AcoConfig>\n <Folder.Action {...props} />\n </AcoConfig>\n );\n};\n\nexport const FolderAction = Object.assign(BaseFolderAction, {\n OptionsMenuItem: Folder.Action.OptionsMenuItem\n});\n"],"mappings":";;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,MAAA,GAAAF,OAAA;AAAyC,IAAAG,SAAA;AAEzC,IAAQC,MAAM,GAAKC,iBAAS,CAApBD,MAAM;AAQd,IAAME,gBAAgB,GAAG,SAAnBA,gBAAgBA,CAAAC,IAAA,EAAuD;EAAA,IAAAC,aAAA,GAAAD,IAAA,CAAjDE,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,EAAE,GAAAA,aAAA;IAAKE,KAAK,OAAAC,yBAAA,CAAAC,OAAA,EAAAL,IAAA,EAAAJ,SAAA;EAC/C,IAAAU,SAAA,GAAkB,IAAAC,eAAQ,EAAC,CAAC;IAApBC,KAAK,GAAAF,SAAA,CAALE,KAAK;EAEb,IAAIN,QAAQ,CAACO,MAAM,GAAG,CAAC,IAAI,CAACP,QAAQ,CAACQ,QAAQ,CAACF,KAAK,CAACG,OAAO,CAAC,EAAE;IAC1D,OAAO,IAAI;EACf;EAEA,oBACIpB,MAAA,CAAAc,OAAA,CAAAO,aAAA,CAAClB,OAAA,CAAAI,SAAS,qBACNP,MAAA,CAAAc,OAAA,CAAAO,aAAA,CAACf,MAAM,CAACgB,MAAM,EAAKV,KAAQ,CACpB,CAAC;AAEpB,CAAC;AAEM,IAAMW,YAAY,GAAAC,OAAA,CAAAD,YAAA,GAAGE,MAAM,CAACC,MAAM,CAAClB,gBAAgB,EAAE;EACxDmB,eAAe,EAAErB,MAAM,CAACgB,MAAM,CAACK;AACnC,CAAC,CAAC","ignoreList":[]}
|
|
@@ -22,11 +22,9 @@ var BaseColumnComponent = function BaseColumnComponent(_ref) {
|
|
|
22
22
|
var _ref$modelIds = _ref.modelIds,
|
|
23
23
|
modelIds = _ref$modelIds === void 0 ? [] : _ref$modelIds,
|
|
24
24
|
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
25
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
26
|
-
name: "cms"
|
|
27
|
-
}, /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(_IsApplicableToCurrentModel.IsApplicableToCurrentModel, {
|
|
25
|
+
return /*#__PURE__*/_react.default.createElement(_appAco.AcoConfig, null, /*#__PURE__*/_react.default.createElement(_IsApplicableToCurrentModel.IsApplicableToCurrentModel, {
|
|
28
26
|
modelIds: modelIds
|
|
29
|
-
}, /*#__PURE__*/_react.default.createElement(Table.Column, props)))
|
|
27
|
+
}, /*#__PURE__*/_react.default.createElement(Table.Column, props)));
|
|
30
28
|
};
|
|
31
29
|
var BaseColumn = (0, _reactComposition.makeDecoratable)("Column", BaseColumnComponent);
|
|
32
30
|
var Column = exports.Column = Object.assign(BaseColumn, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_reactComposition","_appAco","_IsApplicableToCurrentModel","_excluded","Table","AcoConfig","BaseColumnComponent","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","createElement","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_reactComposition","_appAco","_IsApplicableToCurrentModel","_excluded","Table","AcoConfig","BaseColumnComponent","_ref","_ref$modelIds","modelIds","props","_objectWithoutProperties2","default","createElement","IsApplicableToCurrentModel","Column","BaseColumn","makeDecoratable","exports","Object","assign","useTableRow","createUseTableRow","isFolderRow"],"sources":["Column.tsx"],"sourcesContent":["import React from \"react\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { AcoConfig, TableColumnConfig as ColumnConfig } from \"@webiny/app-aco\";\nimport { TableItem } from \"~/types\";\nimport { IsApplicableToCurrentModel } from \"~/admin/config/IsApplicableToCurrentModel\";\n\nconst { Table } = AcoConfig;\n\nexport { ColumnConfig };\n\nexport interface ColumnProps extends React.ComponentProps<typeof AcoConfig.Table.Column> {\n modelIds?: string[];\n}\n\nconst BaseColumnComponent = ({ modelIds = [], ...props }: ColumnProps) => {\n return (\n <AcoConfig>\n <IsApplicableToCurrentModel modelIds={modelIds}>\n <Table.Column {...props} />\n </IsApplicableToCurrentModel>\n </AcoConfig>\n );\n};\n\nconst BaseColumn = makeDecoratable(\"Column\", BaseColumnComponent);\n\nexport const Column = Object.assign(BaseColumn, {\n useTableRow: Table.Column.createUseTableRow<TableItem>(),\n isFolderRow: Table.Column.isFolderRow\n});\n"],"mappings":";;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AAEA,IAAAG,2BAAA,GAAAH,OAAA;AAAuF,IAAAI,SAAA;AAEvF,IAAQC,KAAK,GAAKC,iBAAS,CAAnBD,KAAK;AAQb,IAAME,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAAAC,IAAA,EAAiD;EAAA,IAAAC,aAAA,GAAAD,IAAA,CAA3CE,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,EAAE,GAAAA,aAAA;IAAKE,KAAK,OAAAC,yBAAA,CAAAC,OAAA,EAAAL,IAAA,EAAAJ,SAAA;EAClD,oBACIN,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACZ,OAAA,CAAAI,SAAS,qBACNR,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACX,2BAAA,CAAAY,0BAA0B;IAACL,QAAQ,EAAEA;EAAS,gBAC3CZ,MAAA,CAAAe,OAAA,CAAAC,aAAA,CAACT,KAAK,CAACW,MAAM,EAAKL,KAAQ,CACF,CACrB,CAAC;AAEpB,CAAC;AAED,IAAMM,UAAU,GAAG,IAAAC,iCAAe,EAAC,QAAQ,EAAEX,mBAAmB,CAAC;AAE1D,IAAMS,MAAM,GAAAG,OAAA,CAAAH,MAAA,GAAGI,MAAM,CAACC,MAAM,CAACJ,UAAU,EAAE;EAC5CK,WAAW,EAAEjB,KAAK,CAACW,MAAM,CAACO,iBAAiB,CAAY,CAAC;EACxDC,WAAW,EAAEnB,KAAK,CAACW,MAAM,CAACQ;AAC9B,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,30 +1,35 @@
|
|
|
1
|
-
|
|
2
|
-
export declare const ContentEntryListConfig:
|
|
1
|
+
import React from "react";
|
|
2
|
+
export declare const ContentEntryListConfig: {
|
|
3
|
+
({ children }: {
|
|
4
|
+
children: React.ReactNode;
|
|
5
|
+
}): React.JSX.Element;
|
|
6
|
+
displayName: string;
|
|
7
|
+
} & {
|
|
3
8
|
Browser: {
|
|
4
9
|
AdvancedSearch: {
|
|
5
|
-
FieldRenderer: (({ modelIds, ...props }: import("./Browser/AdvancedSearch/FieldRenderer").FieldRendererProps) =>
|
|
10
|
+
FieldRenderer: (({ modelIds, ...props }: import("./Browser/AdvancedSearch/FieldRenderer").FieldRendererProps) => React.JSX.Element | null) & {
|
|
6
11
|
useInputField: () => import("@webiny/app-aco").InputFieldContext;
|
|
7
12
|
FieldType: typeof import("@webiny/app-aco/components/AdvancedSearch/domain").FieldType;
|
|
8
13
|
};
|
|
9
14
|
};
|
|
10
|
-
BulkAction: (({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
11
|
-
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
15
|
+
BulkAction: (({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null) & {
|
|
16
|
+
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null;
|
|
12
17
|
originalName: string;
|
|
13
18
|
displayName: string;
|
|
14
19
|
} & {
|
|
15
|
-
original: (({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
16
|
-
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
20
|
+
original: (({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null) & {
|
|
21
|
+
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null;
|
|
17
22
|
originalName: string;
|
|
18
23
|
displayName: string;
|
|
19
24
|
};
|
|
20
25
|
originalName: string;
|
|
21
26
|
displayName: string;
|
|
22
27
|
} & {
|
|
23
|
-
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
24
|
-
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) =>
|
|
28
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null) & {
|
|
29
|
+
original: ({ name, after, before, remove, modelIds, element }: import("./Browser/BulkAction").BulkActionProps) => React.JSX.Element | null;
|
|
25
30
|
originalName: string;
|
|
26
31
|
displayName: string;
|
|
27
|
-
}>) => (props: unknown) =>
|
|
32
|
+
}>) => (props: unknown) => React.JSX.Element;
|
|
28
33
|
} & {
|
|
29
34
|
useButtons: () => import("@webiny/app-admin/components/Buttons/useButtons").ButtonsProviderContext;
|
|
30
35
|
useWorker: () => {
|
|
@@ -38,92 +43,92 @@ export declare const ContentEntryListConfig: (({ priority, children }: import("@
|
|
|
38
43
|
};
|
|
39
44
|
useDialog: () => import("@webiny/app-admin").UseDialogWithReportResponse;
|
|
40
45
|
};
|
|
41
|
-
EntryAction: (({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
42
|
-
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
46
|
+
EntryAction: (({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element) & {
|
|
47
|
+
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element;
|
|
43
48
|
originalName: string;
|
|
44
49
|
displayName: string;
|
|
45
50
|
} & {
|
|
46
|
-
original: (({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
47
|
-
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
51
|
+
original: (({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element) & {
|
|
52
|
+
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element;
|
|
48
53
|
originalName: string;
|
|
49
54
|
displayName: string;
|
|
50
55
|
};
|
|
51
56
|
originalName: string;
|
|
52
57
|
displayName: string;
|
|
53
58
|
} & {
|
|
54
|
-
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
55
|
-
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) =>
|
|
59
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element) & {
|
|
60
|
+
original: ({ modelIds, ...props }: import("./Browser/EntryAction").EntryActionProps) => React.JSX.Element;
|
|
56
61
|
originalName: string;
|
|
57
62
|
displayName: string;
|
|
58
|
-
}>) => (props: unknown) =>
|
|
63
|
+
}>) => (props: unknown) => React.JSX.Element;
|
|
59
64
|
} & {
|
|
60
|
-
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) =>
|
|
61
|
-
OptionsMenuLink: (props: import("@webiny/app-admin").OptionsMenuLinkProps) =>
|
|
65
|
+
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) => React.JSX.Element;
|
|
66
|
+
OptionsMenuLink: (props: import("@webiny/app-admin").OptionsMenuLinkProps) => React.JSX.Element;
|
|
62
67
|
};
|
|
63
|
-
Filter: (({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
64
|
-
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
68
|
+
Filter: (({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null) & {
|
|
69
|
+
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null;
|
|
65
70
|
originalName: string;
|
|
66
71
|
displayName: string;
|
|
67
72
|
} & {
|
|
68
|
-
original: (({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
69
|
-
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
73
|
+
original: (({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null) & {
|
|
74
|
+
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null;
|
|
70
75
|
originalName: string;
|
|
71
76
|
displayName: string;
|
|
72
77
|
};
|
|
73
78
|
originalName: string;
|
|
74
79
|
displayName: string;
|
|
75
80
|
} & {
|
|
76
|
-
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
77
|
-
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
81
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null) & {
|
|
82
|
+
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null;
|
|
78
83
|
originalName: string;
|
|
79
84
|
displayName: string;
|
|
80
|
-
}>) => (props: unknown) =>
|
|
85
|
+
}>) => (props: unknown) => React.JSX.Element;
|
|
81
86
|
} & {
|
|
82
|
-
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
83
|
-
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) =>
|
|
87
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null) & {
|
|
88
|
+
original: ({ name, element, modelIds, after, before, remove }: import("./Browser/Filter").FilterProps) => React.JSX.Element | null;
|
|
84
89
|
originalName: string;
|
|
85
90
|
displayName: string;
|
|
86
|
-
}>) => (props: import("./Browser/Filter").CreateDecoratorParams) =>
|
|
91
|
+
}>) => (props: import("./Browser/Filter").CreateDecoratorParams) => React.JSX.Element;
|
|
87
92
|
};
|
|
88
|
-
FiltersToWhere: ({ converter, modelIds }: import("./Browser/FiltersToWhere").FiltersToWhereProps) =>
|
|
93
|
+
FiltersToWhere: ({ converter, modelIds }: import("./Browser/FiltersToWhere").FiltersToWhereProps) => React.JSX.Element | null;
|
|
89
94
|
Folder: {
|
|
90
95
|
ExtensionField: {
|
|
91
|
-
createDecorator: (decorator: import("@webiny/react-composition").Decorator<import("@webiny/react-composition").GenericComponent<import("@webiny/app-headless-cms-common").FieldElementProps>>) => (props: import("@webiny/app-aco").FieldDecoratorProps) =>
|
|
96
|
+
createDecorator: (decorator: import("@webiny/react-composition").Decorator<import("@webiny/react-composition").GenericComponent<import("@webiny/app-headless-cms-common").FieldElementProps>>) => (props: import("@webiny/app-aco").FieldDecoratorProps) => React.JSX.Element;
|
|
92
97
|
};
|
|
93
|
-
Action: (({ modelIds, ...props }: import("./Browser/FolderAction").FolderActionProps) =>
|
|
94
|
-
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) =>
|
|
98
|
+
Action: (({ modelIds, ...props }: import("./Browser/FolderAction").FolderActionProps) => React.JSX.Element | null) & {
|
|
99
|
+
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) => React.JSX.Element;
|
|
95
100
|
};
|
|
96
101
|
};
|
|
97
102
|
Table: {
|
|
98
|
-
Column: (({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
99
|
-
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
103
|
+
Column: (({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element) & {
|
|
104
|
+
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element;
|
|
100
105
|
originalName: string;
|
|
101
106
|
displayName: string;
|
|
102
107
|
} & {
|
|
103
|
-
original: (({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
104
|
-
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
108
|
+
original: (({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element) & {
|
|
109
|
+
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element;
|
|
105
110
|
originalName: string;
|
|
106
111
|
displayName: string;
|
|
107
112
|
};
|
|
108
113
|
originalName: string;
|
|
109
114
|
displayName: string;
|
|
110
115
|
} & {
|
|
111
|
-
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
112
|
-
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) =>
|
|
116
|
+
createDecorator: (decorator: import("@webiny/react-composition").ComponentDecorator<(({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element) & {
|
|
117
|
+
original: ({ modelIds, ...props }: import("./Browser/Table/Column").ColumnProps) => React.JSX.Element;
|
|
113
118
|
originalName: string;
|
|
114
119
|
displayName: string;
|
|
115
|
-
}>) => (props: unknown) =>
|
|
120
|
+
}>) => (props: unknown) => React.JSX.Element;
|
|
116
121
|
} & {
|
|
117
122
|
useTableRow: <TUserRow = Record<string, any>>() => import("@webiny/app-aco").TableRowContextData<import("../../../../types").TableItem & import("@webiny/ui/DataTable").DefaultData & TUserRow>;
|
|
118
123
|
isFolderRow: (row: import("@webiny/app-aco/table.types").BaseTableItem) => row is import("@webiny/app-aco/table.types").FolderTableItem;
|
|
119
124
|
};
|
|
120
125
|
};
|
|
121
|
-
FolderAction: (({ modelIds, ...props }: import("./Browser/FolderAction").FolderActionProps) =>
|
|
122
|
-
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) =>
|
|
126
|
+
FolderAction: (({ modelIds, ...props }: import("./Browser/FolderAction").FolderActionProps) => React.JSX.Element | null) & {
|
|
127
|
+
OptionsMenuItem: (props: import("@webiny/app-admin").OptionsMenuItemProps) => React.JSX.Element;
|
|
123
128
|
};
|
|
124
129
|
};
|
|
125
130
|
};
|
|
126
|
-
export declare const ContentEntryListWithConfig: ({ onProperties, children }: import("@webiny/react-properties").WithConfigProps) =>
|
|
131
|
+
export declare const ContentEntryListWithConfig: ({ onProperties, children }: import("@webiny/react-properties").WithConfigProps) => React.JSX.Element;
|
|
127
132
|
export declare function useContentEntryListConfig(): {
|
|
128
133
|
browser: {
|
|
129
134
|
bulkActions: import("./Browser/BulkAction").BulkActionConfig[];
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
3
4
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
5
|
Object.defineProperty(exports, "__esModule", {
|
|
5
6
|
value: true
|
|
@@ -8,11 +9,19 @@ exports.ContentEntryListWithConfig = exports.ContentEntryListConfig = void 0;
|
|
|
8
9
|
exports.useContentEntryListConfig = useContentEntryListConfig;
|
|
9
10
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
10
11
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
var _react = require("react");
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
13
|
var _reactProperties = require("@webiny/react-properties");
|
|
13
14
|
var _Browser = require("./Browser");
|
|
15
|
+
var _reactComposition = require("@webiny/react-composition");
|
|
14
16
|
var base = (0, _reactProperties.createConfigurableComponent)("ContentEntryListConfig");
|
|
15
|
-
var
|
|
17
|
+
var ScopedContentEntryListConfig = function ScopedContentEntryListConfig(_ref) {
|
|
18
|
+
var children = _ref.children;
|
|
19
|
+
return /*#__PURE__*/_react.default.createElement(_reactComposition.CompositionScope, {
|
|
20
|
+
name: "cms"
|
|
21
|
+
}, /*#__PURE__*/_react.default.createElement(base.Config, null, children));
|
|
22
|
+
};
|
|
23
|
+
ScopedContentEntryListConfig.displayName = "ContentEntryListConfig";
|
|
24
|
+
var ContentEntryListConfig = exports.ContentEntryListConfig = Object.assign(ScopedContentEntryListConfig, {
|
|
16
25
|
Browser: _Browser.Browser
|
|
17
26
|
});
|
|
18
27
|
var ContentEntryListWithConfig = exports.ContentEntryListWithConfig = base.WithConfig;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","require","_reactProperties","_Browser","base","createConfigurableComponent","ContentEntryListConfig","exports","Object","assign","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactProperties","_Browser","_reactComposition","base","createConfigurableComponent","ScopedContentEntryListConfig","_ref","children","default","createElement","CompositionScope","name","Config","displayName","ContentEntryListConfig","exports","Object","assign","Browser","ContentEntryListWithConfig","WithConfig","useContentEntryListConfig","config","useConfig","browser","useMemo","_objectSpread2","bulkActions","_toConsumableArray2","filters","filtersToWhere"],"sources":["ContentEntryListConfig.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\nimport { createConfigurableComponent } from \"@webiny/react-properties\";\nimport { Browser, BrowserConfig } from \"./Browser\";\nimport { CompositionScope } from \"@webiny/react-composition\";\n\nconst base = createConfigurableComponent<ContentEntryListConfig>(\"ContentEntryListConfig\");\n\nconst ScopedContentEntryListConfig = ({ children }: { children: React.ReactNode }) => {\n return (\n <CompositionScope name={\"cms\"}>\n <base.Config>{children}</base.Config>\n </CompositionScope>\n );\n};\n\nScopedContentEntryListConfig.displayName = \"ContentEntryListConfig\";\n\nexport const ContentEntryListConfig = Object.assign(ScopedContentEntryListConfig, { Browser });\nexport const ContentEntryListWithConfig = base.WithConfig;\n\ninterface ContentEntryListConfig {\n browser: BrowserConfig;\n}\n\nexport function useContentEntryListConfig() {\n const config = base.useConfig();\n\n const browser = config.browser || {};\n\n return useMemo(\n () => ({\n browser: {\n ...browser,\n bulkActions: [...(browser.bulkActions || [])],\n filters: [...(browser.filters || [])],\n filtersToWhere: [...(browser.filtersToWhere || [])]\n }\n }),\n [config]\n );\n}\n"],"mappings":";;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,gBAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAH,OAAA;AAEA,IAAMI,IAAI,GAAG,IAAAC,4CAA2B,EAAyB,wBAAwB,CAAC;AAE1F,IAAMC,4BAA4B,GAAG,SAA/BA,4BAA4BA,CAAAC,IAAA,EAAoD;EAAA,IAA9CC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;EAC5C,oBACIV,MAAA,CAAAW,OAAA,CAAAC,aAAA,CAACP,iBAAA,CAAAQ,gBAAgB;IAACC,IAAI,EAAE;EAAM,gBAC1Bd,MAAA,CAAAW,OAAA,CAAAC,aAAA,CAACN,IAAI,CAACS,MAAM,QAAEL,QAAsB,CACtB,CAAC;AAE3B,CAAC;AAEDF,4BAA4B,CAACQ,WAAW,GAAG,wBAAwB;AAE5D,IAAMC,sBAAsB,GAAAC,OAAA,CAAAD,sBAAA,GAAGE,MAAM,CAACC,MAAM,CAACZ,4BAA4B,EAAE;EAAEa,OAAO,EAAPA;AAAQ,CAAC,CAAC;AACvF,IAAMC,0BAA0B,GAAAJ,OAAA,CAAAI,0BAAA,GAAGhB,IAAI,CAACiB,UAAU;AAMlD,SAASC,yBAAyBA,CAAA,EAAG;EACxC,IAAMC,MAAM,GAAGnB,IAAI,CAACoB,SAAS,CAAC,CAAC;EAE/B,IAAMC,OAAO,GAAGF,MAAM,CAACE,OAAO,IAAI,CAAC,CAAC;EAEpC,OAAO,IAAAC,cAAO,EACV;IAAA,OAAO;MACHD,OAAO,MAAAE,cAAA,CAAAlB,OAAA,MAAAkB,cAAA,CAAAlB,OAAA,MACAgB,OAAO;QACVG,WAAW,MAAAC,mBAAA,CAAApB,OAAA,EAAOgB,OAAO,CAACG,WAAW,IAAI,EAAE,CAAE;QAC7CE,OAAO,MAAAD,mBAAA,CAAApB,OAAA,EAAOgB,OAAO,CAACK,OAAO,IAAI,EAAE,CAAE;QACrCC,cAAc,MAAAF,mBAAA,CAAApB,OAAA,EAAOgB,OAAO,CAACM,cAAc,IAAI,EAAE;MAAE;IAE3D,CAAC;EAAA,CAAC,EACF,CAACR,MAAM,CACX,CAAC;AACL","ignoreList":[]}
|
|
@@ -35,7 +35,7 @@ var BottomMargin = /*#__PURE__*/(0, _base.default)("div", process.env.NODE_ENV =
|
|
|
35
35
|
} : {
|
|
36
36
|
name: "1azpx8r",
|
|
37
37
|
styles: "margin-bottom:20px",
|
|
38
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MultiValueDynamicZone.tsx"],"names":[],"mappings":"AA0B+B","file":"MultiValueDynamicZone.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport { ReactComponent as DeleteIcon } from \"@material-design-icons/svg/outlined/delete_outline.svg\";\nimport { ReactComponent as CloneIcon } from \"@material-design-icons/svg/outlined/library_add.svg\";\nimport { ReactComponent as ArrowUpIcon } from \"@material-design-icons/svg/outlined/arrow_drop_up.svg\";\nimport { ReactComponent as ArrowDownIcon } from \"@material-design-icons/svg/outlined/arrow_drop_down.svg\";\nimport { AddTemplateButton, AddTemplateIcon } from \"./AddTemplate\";\nimport { TemplateIcon } from \"./TemplateIcon\";\nimport { ParentFieldProvider, useModelField } from \"~/admin/hooks\";\nimport { Fields } from \"~/admin/components/ContentEntryForm/Fields\";\nimport {\n    BindComponent,\n    BindComponentRenderProp,\n    CmsDynamicZoneTemplate,\n    CmsModelFieldRendererProps,\n    CmsModel,\n    CmsModelField,\n    CmsDynamicZoneTemplateWithTypename\n} from \"~/types\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { TemplateProvider } from \"~/admin/plugins/fieldRenderers/dynamicZone/TemplateProvider\";\nimport { ParentValueIndexProvider } from \"~/admin/components/ModelFieldProvider\";\nimport { useConfirmationDialog } from \"@webiny/app-admin\";\n\nconst BottomMargin = styled.div`\n    margin-bottom: 20px;\n`;\n\ntype GetBind = CmsModelFieldRendererProps[\"getBind\"];\n\nexport interface MultiValueItemContainerProps {\n    value: TemplateValue;\n    contentModel: CmsModel;\n    isFirst: boolean;\n    isLast: boolean;\n    onMoveUp: () => void;\n    onMoveDown: () => void;\n    onDelete: () => void;\n    onClone: (value: TemplateValue) => void;\n    title: React.ReactNode;\n    description: string;\n    icon: JSX.Element;\n    template: CmsDynamicZoneTemplate;\n    children: React.ReactNode;\n}\n\nexport const MultiValueItemContainer = makeDecoratable(\n    \"MultiValueItemContainer\",\n    ({ children, ...props }: MultiValueItemContainerProps) => {\n        const actions = (\n            <AccordionItem.Actions>\n                <AccordionItem.Action\n                    icon={<ArrowUpIcon />}\n                    onClick={props.onMoveUp}\n                    disabled={props.isFirst}\n                />\n                <AccordionItem.Action\n                    icon={<ArrowDownIcon />}\n                    onClick={props.onMoveDown}\n                    disabled={props.isLast}\n                />\n                <AccordionItem.Divider />\n                <AccordionItem.Action\n                    icon={<CloneIcon />}\n                    onClick={() => props.onClone(props.value)}\n                />\n                <AccordionItem.Action icon={<DeleteIcon />} onClick={props.onDelete} />\n            </AccordionItem.Actions>\n        );\n\n        return (\n            <AccordionItem\n                title={props.title}\n                description={props.description}\n                icon={props.icon}\n                actions={actions}\n            >\n                {children}\n            </AccordionItem>\n        );\n    }\n);\n\nexport interface MultiValueItemItemProps {\n    template: CmsDynamicZoneTemplate;\n    contentModel: CmsModel;\n    Bind: BindComponent;\n}\n\nexport const MultiValueItem = makeDecoratable(\n    \"MultiValueItem\",\n    (props: MultiValueItemItemProps) => {\n        const { template, Bind, contentModel } = props;\n\n        return (\n            <TemplateProvider template={template}>\n                <Fields\n                    fields={template.fields}\n                    layout={template.layout || []}\n                    contentModel={contentModel}\n                    Bind={Bind}\n                />\n            </TemplateProvider>\n        );\n    }\n);\n\ninterface TemplateValue {\n    _templateId: string;\n    [key: string]: any;\n}\n\ninterface TemplateValueFormProps {\n    value: TemplateValue;\n    contentModel: CmsModel;\n    Bind: BindComponent;\n    isFirst: boolean;\n    isLast: boolean;\n    onMoveUp: () => void;\n    onMoveDown: () => void;\n    onDelete: () => void;\n    onClone: (value: TemplateValue) => void;\n}\n\nconst TemplateValueForm = ({\n    value,\n    contentModel,\n    Bind,\n    isLast,\n    isFirst,\n    onMoveUp,\n    onMoveDown,\n    onDelete,\n    onClone\n}: TemplateValueFormProps) => {\n    const { field } = useModelField();\n    const templates = field.settings?.templates || [];\n\n    const template: CmsDynamicZoneTemplate | undefined = templates.find(\n        tpl => tpl.id === value._templateId\n    );\n\n    if (!template) {\n        return null;\n    }\n\n    return (\n        <MultiValueItemContainer\n            value={value}\n            contentModel={contentModel}\n            isFirst={isFirst}\n            isLast={isLast}\n            onClone={onClone}\n            onDelete={onDelete}\n            onMoveUp={onMoveUp}\n            onMoveDown={onMoveDown}\n            title={template.name}\n            description={template.description}\n            icon={<TemplateIcon icon={template.icon} />}\n            template={template}\n        >\n            <MultiValueItem template={template} contentModel={contentModel} Bind={Bind} />\n        </MultiValueItemContainer>\n    );\n};\n\nexport interface MultiValueContainerProps extends MultiValueDynamicZoneProps {\n    children: React.ReactNode;\n}\n\nexport const MultiValueContainer = makeDecoratable(\n    \"MultiValueContainer\",\n    ({ children }: MultiValueContainerProps) => {\n        return (\n            <Accordion>\n                <>{children}</>\n            </Accordion>\n        );\n    }\n);\n\ninterface MultiValueDynamicZoneProps {\n    // TODO: this prop might be useless, because we now have a `useModelField` hook.\n    field: CmsModelField;\n    bind: BindComponentRenderProp;\n    contentModel: CmsModel;\n    getBind: GetBind;\n}\n\nexport const MultiValueDynamicZone = (props: MultiValueDynamicZoneProps) => {\n    const { showConfirmation } = useConfirmationDialog({\n        message: `Are you sure you want to delete this item? This action is not reversible.`,\n        acceptLabel: `Yes, I'm sure!`,\n        cancelLabel: `No, leave it.`\n    });\n\n    const { bind, getBind, contentModel } = props;\n    const onTemplate = (template: CmsDynamicZoneTemplateWithTypename) => {\n        bind.appendValue({ _templateId: template.id, __typename: template.__typename });\n    };\n\n    const cloneValue = (value: TemplateValue, index: number) => {\n        bind.appendValue(cloneDeep(value), index + 1);\n    };\n\n    const values: TemplateValue[] = bind.value || [];\n    const hasValues = values.length > 0;\n\n    const Bind = getBind();\n\n    return (\n        <>\n            {hasValues ? (\n                <ParentFieldProvider value={bind.value} path={Bind.parentName}>\n                    <MultiValueContainer {...props}>\n                        {values.map((value, index) => {\n                            const Bind = getBind(index);\n\n                            const onDelete = () => {\n                                showConfirmation(() => {\n                                    bind.removeValue(index);\n                                });\n                            };\n\n                            return (\n                                <ParentValueIndexProvider key={index} index={index}>\n                                    <Bind>\n                                        {() => (\n                                            <Bind.ValidationContainer>\n                                                <TemplateValueForm\n                                                    value={value}\n                                                    contentModel={contentModel}\n                                                    Bind={Bind}\n                                                    isFirst={index === 0}\n                                                    isLast={index === values.length - 1}\n                                                    onMoveUp={() => bind.moveValueUp(index)}\n                                                    onMoveDown={() => bind.moveValueDown(index)}\n                                                    onDelete={onDelete}\n                                                    onClone={value => cloneValue(value, index)}\n                                                />\n                                            </Bind.ValidationContainer>\n                                        )}\n                                    </Bind>\n                                </ParentValueIndexProvider>\n                            );\n                        })}\n                    </MultiValueContainer>\n                </ParentFieldProvider>\n            ) : null}\n            {hasValues ? (\n                <AddTemplateIcon onTemplate={onTemplate} />\n            ) : (\n                <BottomMargin>\n                    <AddTemplateButton onTemplate={onTemplate} />\n                </BottomMargin>\n            )}\n        </>\n    );\n};\n"]} */",
|
|
38
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MultiValueDynamicZone.tsx"],"names":[],"mappings":"AA0B+B","file":"MultiValueDynamicZone.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport { ReactComponent as DeleteIcon } from \"@material-design-icons/svg/outlined/delete_outline.svg\";\nimport { ReactComponent as CloneIcon } from \"@material-design-icons/svg/outlined/library_add.svg\";\nimport { ReactComponent as ArrowUpIcon } from \"@material-design-icons/svg/outlined/arrow_drop_up.svg\";\nimport { ReactComponent as ArrowDownIcon } from \"@material-design-icons/svg/outlined/arrow_drop_down.svg\";\nimport { AddTemplateButton, AddTemplateIcon } from \"./AddTemplate\";\nimport { TemplateIcon } from \"./TemplateIcon\";\nimport { ParentFieldProvider, useModelField } from \"~/admin/hooks\";\nimport { Fields } from \"~/admin/components/ContentEntryForm/Fields\";\nimport {\n    BindComponent,\n    BindComponentRenderProp,\n    CmsDynamicZoneTemplate,\n    CmsModelFieldRendererProps,\n    CmsModel,\n    CmsModelField,\n    CmsDynamicZoneTemplateWithTypename\n} from \"~/types\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { TemplateProvider } from \"~/admin/plugins/fieldRenderers/dynamicZone/TemplateProvider\";\nimport { ParentValueIndexProvider } from \"~/admin/components/ModelFieldProvider\";\nimport { useConfirmationDialog } from \"@webiny/app-admin\";\n\nconst BottomMargin = styled.div`\n    margin-bottom: 20px;\n`;\n\ntype GetBind = CmsModelFieldRendererProps[\"getBind\"];\n\nexport interface MultiValueItemContainerProps {\n    value: TemplateValue;\n    contentModel: CmsModel;\n    isFirst: boolean;\n    isLast: boolean;\n    onMoveUp: () => void;\n    onMoveDown: () => void;\n    onDelete: () => void;\n    onClone: (value: TemplateValue) => void;\n    title: React.ReactNode;\n    description: string;\n    icon: JSX.Element;\n    actions?: JSX.Element;\n    template: CmsDynamicZoneTemplate;\n    children: React.ReactNode;\n}\n\nexport const MultiValueItemContainer = makeDecoratable(\n    \"MultiValueItemContainer\",\n    ({ children, ...props }: MultiValueItemContainerProps) => {\n        const actions = (\n            <AccordionItem.Actions>\n                <AccordionItem.Action\n                    icon={<ArrowUpIcon />}\n                    tooltip={\"Move up\"}\n                    onClick={props.onMoveUp}\n                    disabled={props.isFirst}\n                />\n                <AccordionItem.Action\n                    icon={<ArrowDownIcon />}\n                    tooltip={\"Move down\"}\n                    onClick={props.onMoveDown}\n                    disabled={props.isLast}\n                />\n                <AccordionItem.Divider />\n                {props.actions ? <>{props.actions}</> : null}\n                <AccordionItem.Action\n                    tooltip={\"Duplicate\"}\n                    icon={<CloneIcon />}\n                    onClick={() => props.onClone(props.value)}\n                />\n                <AccordionItem.Action\n                    icon={<DeleteIcon />}\n                    onClick={props.onDelete}\n                    tooltip={\"Delete\"}\n                />\n            </AccordionItem.Actions>\n        );\n\n        return (\n            <AccordionItem\n                title={props.title}\n                description={props.description}\n                icon={props.icon}\n                actions={actions}\n            >\n                {children}\n            </AccordionItem>\n        );\n    }\n);\n\nexport interface MultiValueItemItemProps {\n    template: CmsDynamicZoneTemplate;\n    contentModel: CmsModel;\n    Bind: BindComponent;\n}\n\nexport const MultiValueItem = makeDecoratable(\n    \"MultiValueItem\",\n    (props: MultiValueItemItemProps) => {\n        const { template, Bind, contentModel } = props;\n\n        return (\n            <TemplateProvider template={template}>\n                <Fields\n                    fields={template.fields}\n                    layout={template.layout || []}\n                    contentModel={contentModel}\n                    Bind={Bind}\n                />\n            </TemplateProvider>\n        );\n    }\n);\n\ninterface TemplateValue {\n    _templateId: string;\n    [key: string]: any;\n}\n\ninterface TemplateValueFormProps {\n    value: TemplateValue;\n    contentModel: CmsModel;\n    Bind: BindComponent;\n    isFirst: boolean;\n    isLast: boolean;\n    onMoveUp: () => void;\n    onMoveDown: () => void;\n    onDelete: () => void;\n    onClone: (value: TemplateValue) => void;\n}\n\nconst TemplateValueForm = ({\n    value,\n    contentModel,\n    Bind,\n    isLast,\n    isFirst,\n    onMoveUp,\n    onMoveDown,\n    onDelete,\n    onClone\n}: TemplateValueFormProps) => {\n    const { field } = useModelField();\n    const templates = field.settings?.templates || [];\n\n    const template: CmsDynamicZoneTemplate | undefined = templates.find(\n        tpl => tpl.id === value._templateId\n    );\n\n    if (!template) {\n        return null;\n    }\n\n    return (\n        <MultiValueItemContainer\n            value={value}\n            contentModel={contentModel}\n            isFirst={isFirst}\n            isLast={isLast}\n            onClone={onClone}\n            onDelete={onDelete}\n            onMoveUp={onMoveUp}\n            onMoveDown={onMoveDown}\n            title={template.name}\n            description={template.description}\n            icon={<TemplateIcon icon={template.icon} />}\n            template={template}\n        >\n            <MultiValueItem template={template} contentModel={contentModel} Bind={Bind} />\n        </MultiValueItemContainer>\n    );\n};\n\nexport interface MultiValueContainerProps extends MultiValueDynamicZoneProps {\n    children: React.ReactNode;\n}\n\nexport const MultiValueContainer = makeDecoratable(\n    \"MultiValueContainer\",\n    ({ children }: MultiValueContainerProps) => {\n        return (\n            <Accordion>\n                <>{children}</>\n            </Accordion>\n        );\n    }\n);\n\ninterface MultiValueDynamicZoneProps {\n    // TODO: this prop might be useless, because we now have a `useModelField` hook.\n    field: CmsModelField;\n    bind: BindComponentRenderProp;\n    contentModel: CmsModel;\n    getBind: GetBind;\n}\n\nexport const MultiValueDynamicZone = (props: MultiValueDynamicZoneProps) => {\n    const { showConfirmation } = useConfirmationDialog({\n        message: `Are you sure you want to delete this item? This action is not reversible.`,\n        acceptLabel: `Yes, I'm sure!`,\n        cancelLabel: `No, leave it.`\n    });\n\n    const { bind, getBind, contentModel } = props;\n    const onTemplate = (template: CmsDynamicZoneTemplateWithTypename) => {\n        bind.appendValue({ _templateId: template.id, __typename: template.__typename });\n    };\n\n    const cloneValue = (value: TemplateValue, index: number) => {\n        bind.appendValue(cloneDeep(value), index + 1);\n    };\n\n    const values: TemplateValue[] = bind.value || [];\n    const hasValues = values.length > 0;\n\n    const Bind = getBind();\n\n    return (\n        <>\n            {hasValues ? (\n                <ParentFieldProvider value={bind.value} path={Bind.parentName}>\n                    <MultiValueContainer {...props}>\n                        {values.map((value, index) => {\n                            const Bind = getBind(index);\n\n                            const onDelete = () => {\n                                showConfirmation(() => {\n                                    bind.removeValue(index);\n                                });\n                            };\n\n                            return (\n                                <ParentValueIndexProvider key={index} index={index}>\n                                    <Bind>\n                                        {() => (\n                                            <Bind.ValidationContainer>\n                                                <TemplateValueForm\n                                                    value={value}\n                                                    contentModel={contentModel}\n                                                    Bind={Bind}\n                                                    isFirst={index === 0}\n                                                    isLast={index === values.length - 1}\n                                                    onMoveUp={() => bind.moveValueUp(index)}\n                                                    onMoveDown={() => bind.moveValueDown(index)}\n                                                    onDelete={onDelete}\n                                                    onClone={value => cloneValue(value, index)}\n                                                />\n                                            </Bind.ValidationContainer>\n                                        )}\n                                    </Bind>\n                                </ParentValueIndexProvider>\n                            );\n                        })}\n                    </MultiValueContainer>\n                </ParentFieldProvider>\n            ) : null}\n            {hasValues ? (\n                <AddTemplateIcon onTemplate={onTemplate} />\n            ) : (\n                <BottomMargin>\n                    <AddTemplateButton onTemplate={onTemplate} />\n                </BottomMargin>\n            )}\n        </>\n    );\n};\n"]} */",
|
|
39
39
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
40
40
|
});
|
|
41
41
|
var MultiValueItemContainer = exports.MultiValueItemContainer = (0, _reactComposition.makeDecoratable)("MultiValueItemContainer", function (_ref) {
|
|
@@ -43,20 +43,24 @@ var MultiValueItemContainer = exports.MultiValueItemContainer = (0, _reactCompos
|
|
|
43
43
|
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
44
44
|
var actions = /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Actions, null, /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
45
45
|
icon: /*#__PURE__*/_react.default.createElement(_arrow_drop_up.ReactComponent, null),
|
|
46
|
+
tooltip: "Move up",
|
|
46
47
|
onClick: props.onMoveUp,
|
|
47
48
|
disabled: props.isFirst
|
|
48
49
|
}), /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
49
50
|
icon: /*#__PURE__*/_react.default.createElement(_arrow_drop_down.ReactComponent, null),
|
|
51
|
+
tooltip: "Move down",
|
|
50
52
|
onClick: props.onMoveDown,
|
|
51
53
|
disabled: props.isLast
|
|
52
|
-
}), /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Divider, null), /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
54
|
+
}), /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Divider, null), props.actions ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, props.actions) : null, /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
55
|
+
tooltip: "Duplicate",
|
|
53
56
|
icon: /*#__PURE__*/_react.default.createElement(_library_add.ReactComponent, null),
|
|
54
57
|
onClick: function onClick() {
|
|
55
58
|
return props.onClone(props.value);
|
|
56
59
|
}
|
|
57
60
|
}), /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
58
61
|
icon: /*#__PURE__*/_react.default.createElement(_delete_outline.ReactComponent, null),
|
|
59
|
-
onClick: props.onDelete
|
|
62
|
+
onClick: props.onDelete,
|
|
63
|
+
tooltip: "Delete"
|
|
60
64
|
}));
|
|
61
65
|
return /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem, {
|
|
62
66
|
title: props.title,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_cloneDeep","_Accordion","_delete_outline","_library_add","_arrow_drop_up","_arrow_drop_down","_AddTemplate","_TemplateIcon","_hooks","_Fields","_reactComposition","_TemplateProvider","_ModelFieldProvider","_appAdmin","_excluded","_EMOTION_STRINGIFIED_CSS_ERROR__","BottomMargin","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","MultiValueItemContainer","exports","makeDecoratable","_ref","children","props","_objectWithoutProperties2","actions","createElement","AccordionItem","Actions","Action","icon","ReactComponent","onClick","onMoveUp","disabled","isFirst","onMoveDown","isLast","Divider","onClone","value","onDelete","title","description","MultiValueItem","template","Bind","contentModel","TemplateProvider","Fields","fields","layout","TemplateValueForm","_ref2","_useModelField","useModelField","field","templates","settings","find","tpl","id","_templateId","TemplateIcon","MultiValueContainer","_ref3","Accordion","Fragment","MultiValueDynamicZone","_useConfirmationDialo","useConfirmationDialog","message","acceptLabel","cancelLabel","showConfirmation","bind","getBind","onTemplate","appendValue","__typename","cloneValue","index","cloneDeep","values","hasValues","length","ParentFieldProvider","path","parentName","removeValue","ParentValueIndexProvider","key","ValidationContainer","moveValueUp","moveValueDown","AddTemplateIcon","AddTemplateButton"],"sources":["MultiValueDynamicZone.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport { ReactComponent as DeleteIcon } from \"@material-design-icons/svg/outlined/delete_outline.svg\";\nimport { ReactComponent as CloneIcon } from \"@material-design-icons/svg/outlined/library_add.svg\";\nimport { ReactComponent as ArrowUpIcon } from \"@material-design-icons/svg/outlined/arrow_drop_up.svg\";\nimport { ReactComponent as ArrowDownIcon } from \"@material-design-icons/svg/outlined/arrow_drop_down.svg\";\nimport { AddTemplateButton, AddTemplateIcon } from \"./AddTemplate\";\nimport { TemplateIcon } from \"./TemplateIcon\";\nimport { ParentFieldProvider, useModelField } from \"~/admin/hooks\";\nimport { Fields } from \"~/admin/components/ContentEntryForm/Fields\";\nimport {\n BindComponent,\n BindComponentRenderProp,\n CmsDynamicZoneTemplate,\n CmsModelFieldRendererProps,\n CmsModel,\n CmsModelField,\n CmsDynamicZoneTemplateWithTypename\n} from \"~/types\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { TemplateProvider } from \"~/admin/plugins/fieldRenderers/dynamicZone/TemplateProvider\";\nimport { ParentValueIndexProvider } from \"~/admin/components/ModelFieldProvider\";\nimport { useConfirmationDialog } from \"@webiny/app-admin\";\n\nconst BottomMargin = styled.div`\n margin-bottom: 20px;\n`;\n\ntype GetBind = CmsModelFieldRendererProps[\"getBind\"];\n\nexport interface MultiValueItemContainerProps {\n value: TemplateValue;\n contentModel: CmsModel;\n isFirst: boolean;\n isLast: boolean;\n onMoveUp: () => void;\n onMoveDown: () => void;\n onDelete: () => void;\n onClone: (value: TemplateValue) => void;\n title: React.ReactNode;\n description: string;\n icon: JSX.Element;\n template: CmsDynamicZoneTemplate;\n children: React.ReactNode;\n}\n\nexport const MultiValueItemContainer = makeDecoratable(\n \"MultiValueItemContainer\",\n ({ children, ...props }: MultiValueItemContainerProps) => {\n const actions = (\n <AccordionItem.Actions>\n <AccordionItem.Action\n icon={<ArrowUpIcon />}\n onClick={props.onMoveUp}\n disabled={props.isFirst}\n />\n <AccordionItem.Action\n icon={<ArrowDownIcon />}\n onClick={props.onMoveDown}\n disabled={props.isLast}\n />\n <AccordionItem.Divider />\n <AccordionItem.Action\n icon={<CloneIcon />}\n onClick={() => props.onClone(props.value)}\n />\n <AccordionItem.Action icon={<DeleteIcon />} onClick={props.onDelete} />\n </AccordionItem.Actions>\n );\n\n return (\n <AccordionItem\n title={props.title}\n description={props.description}\n icon={props.icon}\n actions={actions}\n >\n {children}\n </AccordionItem>\n );\n }\n);\n\nexport interface MultiValueItemItemProps {\n template: CmsDynamicZoneTemplate;\n contentModel: CmsModel;\n Bind: BindComponent;\n}\n\nexport const MultiValueItem = makeDecoratable(\n \"MultiValueItem\",\n (props: MultiValueItemItemProps) => {\n const { template, Bind, contentModel } = props;\n\n return (\n <TemplateProvider template={template}>\n <Fields\n fields={template.fields}\n layout={template.layout || []}\n contentModel={contentModel}\n Bind={Bind}\n />\n </TemplateProvider>\n );\n }\n);\n\ninterface TemplateValue {\n _templateId: string;\n [key: string]: any;\n}\n\ninterface TemplateValueFormProps {\n value: TemplateValue;\n contentModel: CmsModel;\n Bind: BindComponent;\n isFirst: boolean;\n isLast: boolean;\n onMoveUp: () => void;\n onMoveDown: () => void;\n onDelete: () => void;\n onClone: (value: TemplateValue) => void;\n}\n\nconst TemplateValueForm = ({\n value,\n contentModel,\n Bind,\n isLast,\n isFirst,\n onMoveUp,\n onMoveDown,\n onDelete,\n onClone\n}: TemplateValueFormProps) => {\n const { field } = useModelField();\n const templates = field.settings?.templates || [];\n\n const template: CmsDynamicZoneTemplate | undefined = templates.find(\n tpl => tpl.id === value._templateId\n );\n\n if (!template) {\n return null;\n }\n\n return (\n <MultiValueItemContainer\n value={value}\n contentModel={contentModel}\n isFirst={isFirst}\n isLast={isLast}\n onClone={onClone}\n onDelete={onDelete}\n onMoveUp={onMoveUp}\n onMoveDown={onMoveDown}\n title={template.name}\n description={template.description}\n icon={<TemplateIcon icon={template.icon} />}\n template={template}\n >\n <MultiValueItem template={template} contentModel={contentModel} Bind={Bind} />\n </MultiValueItemContainer>\n );\n};\n\nexport interface MultiValueContainerProps extends MultiValueDynamicZoneProps {\n children: React.ReactNode;\n}\n\nexport const MultiValueContainer = makeDecoratable(\n \"MultiValueContainer\",\n ({ children }: MultiValueContainerProps) => {\n return (\n <Accordion>\n <>{children}</>\n </Accordion>\n );\n }\n);\n\ninterface MultiValueDynamicZoneProps {\n // TODO: this prop might be useless, because we now have a `useModelField` hook.\n field: CmsModelField;\n bind: BindComponentRenderProp;\n contentModel: CmsModel;\n getBind: GetBind;\n}\n\nexport const MultiValueDynamicZone = (props: MultiValueDynamicZoneProps) => {\n const { showConfirmation } = useConfirmationDialog({\n message: `Are you sure you want to delete this item? This action is not reversible.`,\n acceptLabel: `Yes, I'm sure!`,\n cancelLabel: `No, leave it.`\n });\n\n const { bind, getBind, contentModel } = props;\n const onTemplate = (template: CmsDynamicZoneTemplateWithTypename) => {\n bind.appendValue({ _templateId: template.id, __typename: template.__typename });\n };\n\n const cloneValue = (value: TemplateValue, index: number) => {\n bind.appendValue(cloneDeep(value), index + 1);\n };\n\n const values: TemplateValue[] = bind.value || [];\n const hasValues = values.length > 0;\n\n const Bind = getBind();\n\n return (\n <>\n {hasValues ? (\n <ParentFieldProvider value={bind.value} path={Bind.parentName}>\n <MultiValueContainer {...props}>\n {values.map((value, index) => {\n const Bind = getBind(index);\n\n const onDelete = () => {\n showConfirmation(() => {\n bind.removeValue(index);\n });\n };\n\n return (\n <ParentValueIndexProvider key={index} index={index}>\n <Bind>\n {() => (\n <Bind.ValidationContainer>\n <TemplateValueForm\n value={value}\n contentModel={contentModel}\n Bind={Bind}\n isFirst={index === 0}\n isLast={index === values.length - 1}\n onMoveUp={() => bind.moveValueUp(index)}\n onMoveDown={() => bind.moveValueDown(index)}\n onDelete={onDelete}\n onClone={value => cloneValue(value, index)}\n />\n </Bind.ValidationContainer>\n )}\n </Bind>\n </ParentValueIndexProvider>\n );\n })}\n </MultiValueContainer>\n </ParentFieldProvider>\n ) : null}\n {hasValues ? (\n <AddTemplateIcon onTemplate={onTemplate} />\n ) : (\n <BottomMargin>\n <AddTemplateButton onTemplate={onTemplate} />\n </BottomMargin>\n )}\n </>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_cloneDeep","_Accordion","_delete_outline","_library_add","_arrow_drop_up","_arrow_drop_down","_AddTemplate","_TemplateIcon","_hooks","_Fields","_reactComposition","_TemplateProvider","_ModelFieldProvider","_appAdmin","_excluded","_EMOTION_STRINGIFIED_CSS_ERROR__","BottomMargin","_base","default","process","env","NODE_ENV","target","label","name","styles","map","toString","MultiValueItemContainer","exports","makeDecoratable","_ref","children","props","_objectWithoutProperties2","actions","createElement","AccordionItem","Actions","Action","icon","ReactComponent","tooltip","onClick","onMoveUp","disabled","isFirst","onMoveDown","isLast","Divider","Fragment","onClone","value","onDelete","title","description","MultiValueItem","template","Bind","contentModel","TemplateProvider","Fields","fields","layout","TemplateValueForm","_ref2","_useModelField","useModelField","field","templates","settings","find","tpl","id","_templateId","TemplateIcon","MultiValueContainer","_ref3","Accordion","MultiValueDynamicZone","_useConfirmationDialo","useConfirmationDialog","message","acceptLabel","cancelLabel","showConfirmation","bind","getBind","onTemplate","appendValue","__typename","cloneValue","index","cloneDeep","values","hasValues","length","ParentFieldProvider","path","parentName","removeValue","ParentValueIndexProvider","key","ValidationContainer","moveValueUp","moveValueDown","AddTemplateIcon","AddTemplateButton"],"sources":["MultiValueDynamicZone.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport { ReactComponent as DeleteIcon } from \"@material-design-icons/svg/outlined/delete_outline.svg\";\nimport { ReactComponent as CloneIcon } from \"@material-design-icons/svg/outlined/library_add.svg\";\nimport { ReactComponent as ArrowUpIcon } from \"@material-design-icons/svg/outlined/arrow_drop_up.svg\";\nimport { ReactComponent as ArrowDownIcon } from \"@material-design-icons/svg/outlined/arrow_drop_down.svg\";\nimport { AddTemplateButton, AddTemplateIcon } from \"./AddTemplate\";\nimport { TemplateIcon } from \"./TemplateIcon\";\nimport { ParentFieldProvider, useModelField } from \"~/admin/hooks\";\nimport { Fields } from \"~/admin/components/ContentEntryForm/Fields\";\nimport {\n BindComponent,\n BindComponentRenderProp,\n CmsDynamicZoneTemplate,\n CmsModelFieldRendererProps,\n CmsModel,\n CmsModelField,\n CmsDynamicZoneTemplateWithTypename\n} from \"~/types\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\nimport { TemplateProvider } from \"~/admin/plugins/fieldRenderers/dynamicZone/TemplateProvider\";\nimport { ParentValueIndexProvider } from \"~/admin/components/ModelFieldProvider\";\nimport { useConfirmationDialog } from \"@webiny/app-admin\";\n\nconst BottomMargin = styled.div`\n margin-bottom: 20px;\n`;\n\ntype GetBind = CmsModelFieldRendererProps[\"getBind\"];\n\nexport interface MultiValueItemContainerProps {\n value: TemplateValue;\n contentModel: CmsModel;\n isFirst: boolean;\n isLast: boolean;\n onMoveUp: () => void;\n onMoveDown: () => void;\n onDelete: () => void;\n onClone: (value: TemplateValue) => void;\n title: React.ReactNode;\n description: string;\n icon: JSX.Element;\n actions?: JSX.Element;\n template: CmsDynamicZoneTemplate;\n children: React.ReactNode;\n}\n\nexport const MultiValueItemContainer = makeDecoratable(\n \"MultiValueItemContainer\",\n ({ children, ...props }: MultiValueItemContainerProps) => {\n const actions = (\n <AccordionItem.Actions>\n <AccordionItem.Action\n icon={<ArrowUpIcon />}\n tooltip={\"Move up\"}\n onClick={props.onMoveUp}\n disabled={props.isFirst}\n />\n <AccordionItem.Action\n icon={<ArrowDownIcon />}\n tooltip={\"Move down\"}\n onClick={props.onMoveDown}\n disabled={props.isLast}\n />\n <AccordionItem.Divider />\n {props.actions ? <>{props.actions}</> : null}\n <AccordionItem.Action\n tooltip={\"Duplicate\"}\n icon={<CloneIcon />}\n onClick={() => props.onClone(props.value)}\n />\n <AccordionItem.Action\n icon={<DeleteIcon />}\n onClick={props.onDelete}\n tooltip={\"Delete\"}\n />\n </AccordionItem.Actions>\n );\n\n return (\n <AccordionItem\n title={props.title}\n description={props.description}\n icon={props.icon}\n actions={actions}\n >\n {children}\n </AccordionItem>\n );\n }\n);\n\nexport interface MultiValueItemItemProps {\n template: CmsDynamicZoneTemplate;\n contentModel: CmsModel;\n Bind: BindComponent;\n}\n\nexport const MultiValueItem = makeDecoratable(\n \"MultiValueItem\",\n (props: MultiValueItemItemProps) => {\n const { template, Bind, contentModel } = props;\n\n return (\n <TemplateProvider template={template}>\n <Fields\n fields={template.fields}\n layout={template.layout || []}\n contentModel={contentModel}\n Bind={Bind}\n />\n </TemplateProvider>\n );\n }\n);\n\ninterface TemplateValue {\n _templateId: string;\n [key: string]: any;\n}\n\ninterface TemplateValueFormProps {\n value: TemplateValue;\n contentModel: CmsModel;\n Bind: BindComponent;\n isFirst: boolean;\n isLast: boolean;\n onMoveUp: () => void;\n onMoveDown: () => void;\n onDelete: () => void;\n onClone: (value: TemplateValue) => void;\n}\n\nconst TemplateValueForm = ({\n value,\n contentModel,\n Bind,\n isLast,\n isFirst,\n onMoveUp,\n onMoveDown,\n onDelete,\n onClone\n}: TemplateValueFormProps) => {\n const { field } = useModelField();\n const templates = field.settings?.templates || [];\n\n const template: CmsDynamicZoneTemplate | undefined = templates.find(\n tpl => tpl.id === value._templateId\n );\n\n if (!template) {\n return null;\n }\n\n return (\n <MultiValueItemContainer\n value={value}\n contentModel={contentModel}\n isFirst={isFirst}\n isLast={isLast}\n onClone={onClone}\n onDelete={onDelete}\n onMoveUp={onMoveUp}\n onMoveDown={onMoveDown}\n title={template.name}\n description={template.description}\n icon={<TemplateIcon icon={template.icon} />}\n template={template}\n >\n <MultiValueItem template={template} contentModel={contentModel} Bind={Bind} />\n </MultiValueItemContainer>\n );\n};\n\nexport interface MultiValueContainerProps extends MultiValueDynamicZoneProps {\n children: React.ReactNode;\n}\n\nexport const MultiValueContainer = makeDecoratable(\n \"MultiValueContainer\",\n ({ children }: MultiValueContainerProps) => {\n return (\n <Accordion>\n <>{children}</>\n </Accordion>\n );\n }\n);\n\ninterface MultiValueDynamicZoneProps {\n // TODO: this prop might be useless, because we now have a `useModelField` hook.\n field: CmsModelField;\n bind: BindComponentRenderProp;\n contentModel: CmsModel;\n getBind: GetBind;\n}\n\nexport const MultiValueDynamicZone = (props: MultiValueDynamicZoneProps) => {\n const { showConfirmation } = useConfirmationDialog({\n message: `Are you sure you want to delete this item? This action is not reversible.`,\n acceptLabel: `Yes, I'm sure!`,\n cancelLabel: `No, leave it.`\n });\n\n const { bind, getBind, contentModel } = props;\n const onTemplate = (template: CmsDynamicZoneTemplateWithTypename) => {\n bind.appendValue({ _templateId: template.id, __typename: template.__typename });\n };\n\n const cloneValue = (value: TemplateValue, index: number) => {\n bind.appendValue(cloneDeep(value), index + 1);\n };\n\n const values: TemplateValue[] = bind.value || [];\n const hasValues = values.length > 0;\n\n const Bind = getBind();\n\n return (\n <>\n {hasValues ? (\n <ParentFieldProvider value={bind.value} path={Bind.parentName}>\n <MultiValueContainer {...props}>\n {values.map((value, index) => {\n const Bind = getBind(index);\n\n const onDelete = () => {\n showConfirmation(() => {\n bind.removeValue(index);\n });\n };\n\n return (\n <ParentValueIndexProvider key={index} index={index}>\n <Bind>\n {() => (\n <Bind.ValidationContainer>\n <TemplateValueForm\n value={value}\n contentModel={contentModel}\n Bind={Bind}\n isFirst={index === 0}\n isLast={index === values.length - 1}\n onMoveUp={() => bind.moveValueUp(index)}\n onMoveDown={() => bind.moveValueDown(index)}\n onDelete={onDelete}\n onClone={value => cloneValue(value, index)}\n />\n </Bind.ValidationContainer>\n )}\n </Bind>\n </ParentValueIndexProvider>\n );\n })}\n </MultiValueContainer>\n </ParentFieldProvider>\n ) : null}\n {hasValues ? (\n <AddTemplateIcon onTemplate={onTemplate} />\n ) : (\n <BottomMargin>\n <AddTemplateButton onTemplate={onTemplate} />\n </BottomMargin>\n )}\n </>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { BindComponentRenderProp, CmsModelFieldRendererProps, CmsModel, CmsModelField } from "../../../../types";
|
|
2
|
+
import { BindComponentRenderProp, CmsDynamicZoneTemplate, CmsModelFieldRendererProps, CmsModel, CmsModelField } from "../../../../types";
|
|
3
3
|
type GetBind = CmsModelFieldRendererProps["getBind"];
|
|
4
4
|
interface SingleValueDynamicZoneProps {
|
|
5
5
|
field: CmsModelField;
|
|
@@ -7,5 +7,39 @@ interface SingleValueDynamicZoneProps {
|
|
|
7
7
|
contentModel: CmsModel;
|
|
8
8
|
getBind: GetBind;
|
|
9
9
|
}
|
|
10
|
+
interface TemplateValue {
|
|
11
|
+
_templateId: string;
|
|
12
|
+
[key: string]: any;
|
|
13
|
+
}
|
|
14
|
+
export interface SingleValueItemContainerProps {
|
|
15
|
+
value: TemplateValue;
|
|
16
|
+
contentModel: CmsModel;
|
|
17
|
+
onDelete: () => void;
|
|
18
|
+
title: React.ReactNode;
|
|
19
|
+
description: string;
|
|
20
|
+
icon: JSX.Element;
|
|
21
|
+
actions?: JSX.Element;
|
|
22
|
+
template: CmsDynamicZoneTemplate;
|
|
23
|
+
children: React.ReactNode;
|
|
24
|
+
}
|
|
25
|
+
export declare const SingleValueItemContainer: ((props: SingleValueItemContainerProps) => React.JSX.Element) & {
|
|
26
|
+
original: (props: SingleValueItemContainerProps) => React.JSX.Element;
|
|
27
|
+
originalName: string;
|
|
28
|
+
displayName: string;
|
|
29
|
+
} & {
|
|
30
|
+
original: ((props: SingleValueItemContainerProps) => React.JSX.Element) & {
|
|
31
|
+
original: (props: SingleValueItemContainerProps) => React.JSX.Element;
|
|
32
|
+
originalName: string;
|
|
33
|
+
displayName: string;
|
|
34
|
+
};
|
|
35
|
+
originalName: string;
|
|
36
|
+
displayName: string;
|
|
37
|
+
} & {
|
|
38
|
+
createDecorator: (decorator: import("@webiny/app-admin").ComponentDecorator<((props: SingleValueItemContainerProps) => React.JSX.Element) & {
|
|
39
|
+
original: (props: SingleValueItemContainerProps) => React.JSX.Element;
|
|
40
|
+
originalName: string;
|
|
41
|
+
displayName: string;
|
|
42
|
+
}>) => (props: unknown) => React.JSX.Element;
|
|
43
|
+
};
|
|
10
44
|
export declare const SingleValueDynamicZone: ({ field, bind, contentModel, getBind }: SingleValueDynamicZoneProps) => React.JSX.Element;
|
|
11
45
|
export {};
|
|
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.SingleValueDynamicZone = void 0;
|
|
7
|
+
exports.SingleValueItemContainer = exports.SingleValueDynamicZone = void 0;
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
var _delete_outline = require("@material-design-icons/svg/outlined/delete_outline.svg");
|
|
10
10
|
var _Accordion = require("@webiny/ui/Accordion");
|
|
@@ -15,6 +15,25 @@ var _Fields = require("../../../components/ContentEntryForm/Fields");
|
|
|
15
15
|
var _ParentValue = require("../../../components/ContentEntryForm/ParentValue");
|
|
16
16
|
var _ModelFieldProvider = require("../../../components/ModelFieldProvider");
|
|
17
17
|
var _appAdmin = require("@webiny/app-admin");
|
|
18
|
+
var SingleValueItemContainer = exports.SingleValueItemContainer = (0, _appAdmin.makeDecoratable)("SingleValueItemContainer", function (props) {
|
|
19
|
+
var template = props.template,
|
|
20
|
+
actions = props.actions,
|
|
21
|
+
children = props.children;
|
|
22
|
+
return /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem, {
|
|
23
|
+
title: template.name,
|
|
24
|
+
description: template.description,
|
|
25
|
+
icon: /*#__PURE__*/_react.default.createElement(_TemplateIcon.TemplateIcon, {
|
|
26
|
+
icon: template.icon
|
|
27
|
+
}),
|
|
28
|
+
open: true,
|
|
29
|
+
interactive: false,
|
|
30
|
+
actions: /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Actions, null, actions ?? null, /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
31
|
+
icon: /*#__PURE__*/_react.default.createElement(_delete_outline.ReactComponent, null),
|
|
32
|
+
onClick: props.onDelete,
|
|
33
|
+
tooltip: "Delete"
|
|
34
|
+
}))
|
|
35
|
+
}, children);
|
|
36
|
+
});
|
|
18
37
|
var SingleValueDynamicZone = exports.SingleValueDynamicZone = function SingleValueDynamicZone(_ref) {
|
|
19
38
|
var field = _ref.field,
|
|
20
39
|
bind = _ref.bind,
|
|
@@ -49,18 +68,16 @@ var SingleValueDynamicZone = exports.SingleValueDynamicZone = function SingleVal
|
|
|
49
68
|
index: -1
|
|
50
69
|
}, /*#__PURE__*/_react.default.createElement(_ModelFieldProvider.ModelFieldProvider, {
|
|
51
70
|
field: field
|
|
52
|
-
}, /*#__PURE__*/_react.default.createElement(_Accordion.Accordion, null, /*#__PURE__*/_react.default.createElement(
|
|
71
|
+
}, /*#__PURE__*/_react.default.createElement(_Accordion.Accordion, null, /*#__PURE__*/_react.default.createElement(SingleValueItemContainer, {
|
|
72
|
+
template: template,
|
|
73
|
+
value: bind.value,
|
|
74
|
+
contentModel: contentModel,
|
|
75
|
+
onDelete: unsetValue,
|
|
53
76
|
title: template.name,
|
|
54
77
|
description: template.description,
|
|
55
78
|
icon: /*#__PURE__*/_react.default.createElement(_TemplateIcon.TemplateIcon, {
|
|
56
79
|
icon: template.icon
|
|
57
|
-
})
|
|
58
|
-
open: true,
|
|
59
|
-
interactive: false,
|
|
60
|
-
actions: /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Actions, null, /*#__PURE__*/_react.default.createElement(_Accordion.AccordionItem.Action, {
|
|
61
|
-
icon: /*#__PURE__*/_react.default.createElement(_delete_outline.ReactComponent, null),
|
|
62
|
-
onClick: unsetValue
|
|
63
|
-
}))
|
|
80
|
+
})
|
|
64
81
|
}, /*#__PURE__*/_react.default.createElement(_TemplateProvider.TemplateProvider, {
|
|
65
82
|
template: template
|
|
66
83
|
}, /*#__PURE__*/_react.default.createElement(_Fields.Fields, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_delete_outline","_Accordion","_AddTemplate","_TemplateIcon","_TemplateProvider","_Fields","_ParentValue","_ModelFieldProvider","_appAdmin","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_delete_outline","_Accordion","_AddTemplate","_TemplateIcon","_TemplateProvider","_Fields","_ParentValue","_ModelFieldProvider","_appAdmin","SingleValueItemContainer","exports","makeDecoratable","props","template","actions","children","default","createElement","AccordionItem","title","name","description","icon","TemplateIcon","open","interactive","Actions","Action","ReactComponent","onClick","onDelete","tooltip","SingleValueDynamicZone","_ref","field","bind","contentModel","getBind","_useConfirmationDialo","useConfirmationDialog","message","acceptLabel","cancelLabel","showConfirmation","onTemplate","onChange","_templateId","id","__typename","templates","settings","value","find","tpl","undefined","Bind","unsetValue","Fragment","ParentFieldProvider","path","parentName","ParentValueIndexProvider","index","ModelFieldProvider","Accordion","TemplateProvider","Fields","fields","layout","AddTemplateButton"],"sources":["SingleValueDynamicZone.tsx"],"sourcesContent":["import React from \"react\";\nimport { ReactComponent as DeleteIcon } from \"@material-design-icons/svg/outlined/delete_outline.svg\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport { AddTemplateButton } from \"./AddTemplate\";\nimport { TemplateIcon } from \"./TemplateIcon\";\nimport { TemplateProvider } from \"./TemplateProvider\";\nimport {\n BindComponentRenderProp,\n CmsDynamicZoneTemplate,\n CmsModelFieldRendererProps,\n CmsModel,\n CmsModelField,\n CmsDynamicZoneTemplateWithTypename\n} from \"~/types\";\nimport { Fields } from \"~/admin/components/ContentEntryForm/Fields\";\nimport { ParentFieldProvider } from \"~/admin/components/ContentEntryForm/ParentValue\";\nimport {\n ParentValueIndexProvider,\n ModelFieldProvider\n} from \"~/admin/components/ModelFieldProvider\";\nimport { makeDecoratable, useConfirmationDialog } from \"@webiny/app-admin\";\n\ntype GetBind = CmsModelFieldRendererProps[\"getBind\"];\n\ninterface SingleValueDynamicZoneProps {\n field: CmsModelField;\n bind: BindComponentRenderProp;\n contentModel: CmsModel;\n getBind: GetBind;\n}\n\ninterface TemplateValue {\n _templateId: string;\n [key: string]: any;\n}\n\nexport interface SingleValueItemContainerProps {\n value: TemplateValue;\n contentModel: CmsModel;\n onDelete: () => void;\n title: React.ReactNode;\n description: string;\n icon: JSX.Element;\n actions?: JSX.Element;\n template: CmsDynamicZoneTemplate;\n children: React.ReactNode;\n}\n\nexport const SingleValueItemContainer = makeDecoratable(\n \"SingleValueItemContainer\",\n (props: SingleValueItemContainerProps) => {\n const { template, actions, children } = props;\n return (\n <AccordionItem\n title={template.name}\n description={template.description}\n icon={<TemplateIcon icon={template.icon} />}\n open={true}\n interactive={false}\n actions={\n <AccordionItem.Actions>\n {actions ?? null}\n <AccordionItem.Action\n icon={<DeleteIcon />}\n onClick={props.onDelete}\n tooltip={\"Delete\"}\n />\n </AccordionItem.Actions>\n }\n >\n {children}\n </AccordionItem>\n );\n }\n);\n\nexport const SingleValueDynamicZone = ({\n field,\n bind,\n contentModel,\n getBind\n}: SingleValueDynamicZoneProps) => {\n const { showConfirmation } = useConfirmationDialog({\n message: `Are you sure you want to remove this item? This action is not reversible.`,\n acceptLabel: `Yes, I'm sure!`,\n cancelLabel: `No, leave it.`\n });\n\n const onTemplate = (template: CmsDynamicZoneTemplateWithTypename) => {\n bind.onChange({ _templateId: template.id, __typename: template.__typename });\n };\n\n const templates = field.settings?.templates || [];\n\n const template: CmsDynamicZoneTemplate | undefined = bind.value\n ? templates.find(tpl => tpl.id === bind.value._templateId)\n : undefined;\n\n const Bind = getBind();\n\n const unsetValue = () => {\n showConfirmation(() => {\n bind.onChange(null);\n });\n };\n\n return (\n <>\n {template ? (\n <ParentFieldProvider value={bind.value} path={Bind.parentName}>\n <ParentValueIndexProvider index={-1}>\n <ModelFieldProvider field={field}>\n <Accordion>\n <SingleValueItemContainer\n template={template}\n value={bind.value}\n contentModel={contentModel}\n onDelete={unsetValue}\n title={template.name}\n description={template.description}\n icon={<TemplateIcon icon={template.icon} />}\n >\n <TemplateProvider template={template}>\n <Fields\n fields={template.fields}\n layout={template.layout || []}\n contentModel={contentModel}\n Bind={Bind}\n />\n </TemplateProvider>\n </SingleValueItemContainer>\n </Accordion>\n </ModelFieldProvider>\n </ParentValueIndexProvider>\n </ParentFieldProvider>\n ) : null}\n {bind.value ? null : <AddTemplateButton onTemplate={onTemplate} />}\n </>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -9,6 +9,7 @@ export type DynamicZoneContainerProps = {
|
|
|
9
9
|
title?: string;
|
|
10
10
|
description?: string;
|
|
11
11
|
className?: string;
|
|
12
|
+
actions?: JSX.Element;
|
|
12
13
|
};
|
|
13
14
|
export declare const DynamicZoneContainer: ((props: DynamicZoneContainerProps) => React.JSX.Element) & {
|
|
14
15
|
original: (props: DynamicZoneContainerProps) => React.JSX.Element;
|
|
@@ -34,7 +34,8 @@ var DynamicZoneContainer = exports.DynamicZoneContainer = (0, _reactComposition.
|
|
|
34
34
|
title: title,
|
|
35
35
|
description: description,
|
|
36
36
|
className: className || defaultClassName,
|
|
37
|
-
open: open
|
|
37
|
+
open: open,
|
|
38
|
+
actions: props.actions ?? null
|
|
38
39
|
}, children)), isValid === false && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, {
|
|
39
40
|
error: true
|
|
40
41
|
}, message));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_emotion","_Accordion","_SingleValueDynamicZone","_MultiValueDynamicZone","_AccordionRenderSettings","_FormElementMessage","_reactComposition","_templateObject","noBottomPadding","css","_taggedTemplateLiteral2","default","DynamicZoneContainer","exports","makeDecoratable","props","field","_props$bind$validatio","bind","validation","isValid","message","_props$title","title","label","_props$description","description","helpText","className","children","defaultClassName","multipleValues","undefined","_getAccordionRenderSe","getAccordionRenderSettings","open","createElement","Fragment","Accordion","AccordionItem","FormElementMessage","error","DynamicZoneContent","_ref","getBind","contentModel","templates","settings","length","console","info","concat","fieldId","Bind","Component","MultiValueDynamicZone","SingleValueDynamicZone","ValidationContainer","dynamicZoneFieldRenderer","type","name","renderer","rendererName","canUse","_ref2","render","renderSettings","_ref3","AccordionRenderSettings"],"sources":["dynamicZoneRenderer.tsx"],"sourcesContent":["import React from \"react\";\nimport { css } from \"emotion\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport {\n BindComponent,\n BindComponentRenderProp,\n CmsModel,\n CmsModelField,\n CmsModelFieldRendererPlugin,\n CmsModelFieldRendererProps\n} from \"~/types\";\nimport { SingleValueDynamicZone } from \"./SingleValueDynamicZone\";\nimport { MultiValueDynamicZone } from \"./MultiValueDynamicZone\";\nimport { AccordionRenderSettings, getAccordionRenderSettings } from \"../AccordionRenderSettings\";\nimport { FormElementMessage } from \"@webiny/ui/FormElementMessage\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\n\nconst noBottomPadding = css`\n > .webiny-ui-accordion-item__content {\n padding-bottom: 0 !important;\n }\n`;\n\nexport type DynamicZoneContainerProps = {\n field: CmsModelField;\n getBind: (index?: number, key?: string) => BindComponent;\n contentModel: CmsModel;\n bind: BindComponentRenderProp;\n children: React.ReactNode;\n title?: string;\n description?: string;\n className?: string;\n};\n\nexport const DynamicZoneContainer = makeDecoratable(\n \"DynamicZoneContainer\",\n (props: DynamicZoneContainerProps) => {\n const {\n field,\n bind: {\n validation: { isValid, message }\n },\n title = field.label,\n description = field.helpText,\n className,\n children\n } = props;\n\n const defaultClassName = field.multipleValues ? noBottomPadding : undefined;\n const { open } = getAccordionRenderSettings(field);\n\n return (\n <>\n <Accordion>\n <AccordionItem\n title={title}\n description={description}\n className={className || defaultClassName}\n open={open}\n >\n {children}\n </AccordionItem>\n </Accordion>\n {isValid === false && (\n <FormElementMessage error={true}>{message}</FormElementMessage>\n )}\n </>\n );\n }\n);\n\nconst DynamicZoneContent = ({ field, getBind, contentModel }: CmsModelFieldRendererProps) => {\n const templates = field.settings?.templates || [];\n if (!templates.length) {\n console.info(\n `Skipping \"${field.fieldId}\" field. There are no templates defined for this dynamic zone.`\n );\n return null;\n }\n\n const Bind = getBind();\n\n const Component = field.multipleValues ? MultiValueDynamicZone : SingleValueDynamicZone;\n\n return (\n <Bind>\n {bind => {\n return (\n <Bind.ValidationContainer>\n <DynamicZoneContainer\n field={field}\n bind={bind}\n getBind={getBind}\n contentModel={contentModel}\n >\n <Component\n bind={bind}\n field={field}\n getBind={getBind}\n contentModel={contentModel}\n />\n </DynamicZoneContainer>\n </Bind.ValidationContainer>\n );\n }}\n </Bind>\n );\n};\n\nexport const dynamicZoneFieldRenderer: CmsModelFieldRendererPlugin = {\n type: \"cms-editor-field-renderer\",\n name: \"cms-editor-field-renderer-dynamic-zone\",\n renderer: {\n rendererName: \"dynamicZone\",\n name: \"Dynamic Zone\",\n description: \"Renders a dynamic zone.\",\n canUse({ field }) {\n return field.type === \"dynamicZone\";\n },\n render(props) {\n return <DynamicZoneContent {...props} />;\n },\n renderSettings({ field }) {\n return <AccordionRenderSettings field={field} />;\n }\n }\n};\n"],"mappings":";;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AASA,IAAAG,uBAAA,GAAAH,OAAA;AACA,IAAAI,sBAAA,GAAAJ,OAAA;AACA,IAAAK,wBAAA,GAAAL,OAAA;AACA,IAAAM,mBAAA,GAAAN,OAAA;AACA,IAAAO,iBAAA,GAAAP,OAAA;AAA4D,IAAAQ,eAAA;AAE5D,IAAMC,eAAe,OAAGC,YAAG,EAAAF,eAAA,KAAAA,eAAA,OAAAG,uBAAA,CAAAC,OAAA,qGAI1B;
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_emotion","_Accordion","_SingleValueDynamicZone","_MultiValueDynamicZone","_AccordionRenderSettings","_FormElementMessage","_reactComposition","_templateObject","noBottomPadding","css","_taggedTemplateLiteral2","default","DynamicZoneContainer","exports","makeDecoratable","props","field","_props$bind$validatio","bind","validation","isValid","message","_props$title","title","label","_props$description","description","helpText","className","children","defaultClassName","multipleValues","undefined","_getAccordionRenderSe","getAccordionRenderSettings","open","createElement","Fragment","Accordion","AccordionItem","actions","FormElementMessage","error","DynamicZoneContent","_ref","getBind","contentModel","templates","settings","length","console","info","concat","fieldId","Bind","Component","MultiValueDynamicZone","SingleValueDynamicZone","ValidationContainer","dynamicZoneFieldRenderer","type","name","renderer","rendererName","canUse","_ref2","render","renderSettings","_ref3","AccordionRenderSettings"],"sources":["dynamicZoneRenderer.tsx"],"sourcesContent":["import React from \"react\";\nimport { css } from \"emotion\";\nimport { Accordion, AccordionItem } from \"@webiny/ui/Accordion\";\nimport {\n BindComponent,\n BindComponentRenderProp,\n CmsModel,\n CmsModelField,\n CmsModelFieldRendererPlugin,\n CmsModelFieldRendererProps\n} from \"~/types\";\nimport { SingleValueDynamicZone } from \"./SingleValueDynamicZone\";\nimport { MultiValueDynamicZone } from \"./MultiValueDynamicZone\";\nimport { AccordionRenderSettings, getAccordionRenderSettings } from \"../AccordionRenderSettings\";\nimport { FormElementMessage } from \"@webiny/ui/FormElementMessage\";\nimport { makeDecoratable } from \"@webiny/react-composition\";\n\nconst noBottomPadding = css`\n > .webiny-ui-accordion-item__content {\n padding-bottom: 0 !important;\n }\n`;\n\nexport type DynamicZoneContainerProps = {\n field: CmsModelField;\n getBind: (index?: number, key?: string) => BindComponent;\n contentModel: CmsModel;\n bind: BindComponentRenderProp;\n children: React.ReactNode;\n title?: string;\n description?: string;\n className?: string;\n actions?: JSX.Element;\n};\n\nexport const DynamicZoneContainer = makeDecoratable(\n \"DynamicZoneContainer\",\n (props: DynamicZoneContainerProps) => {\n const {\n field,\n bind: {\n validation: { isValid, message }\n },\n title = field.label,\n description = field.helpText,\n className,\n children\n } = props;\n\n const defaultClassName = field.multipleValues ? noBottomPadding : undefined;\n const { open } = getAccordionRenderSettings(field);\n\n return (\n <>\n <Accordion>\n <AccordionItem\n title={title}\n description={description}\n className={className || defaultClassName}\n open={open}\n actions={props.actions ?? null}\n >\n {children}\n </AccordionItem>\n </Accordion>\n {isValid === false && (\n <FormElementMessage error={true}>{message}</FormElementMessage>\n )}\n </>\n );\n }\n);\n\nconst DynamicZoneContent = ({ field, getBind, contentModel }: CmsModelFieldRendererProps) => {\n const templates = field.settings?.templates || [];\n if (!templates.length) {\n console.info(\n `Skipping \"${field.fieldId}\" field. There are no templates defined for this dynamic zone.`\n );\n return null;\n }\n\n const Bind = getBind();\n\n const Component = field.multipleValues ? MultiValueDynamicZone : SingleValueDynamicZone;\n\n return (\n <Bind>\n {bind => {\n return (\n <Bind.ValidationContainer>\n <DynamicZoneContainer\n field={field}\n bind={bind}\n getBind={getBind}\n contentModel={contentModel}\n >\n <Component\n bind={bind}\n field={field}\n getBind={getBind}\n contentModel={contentModel}\n />\n </DynamicZoneContainer>\n </Bind.ValidationContainer>\n );\n }}\n </Bind>\n );\n};\n\nexport const dynamicZoneFieldRenderer: CmsModelFieldRendererPlugin = {\n type: \"cms-editor-field-renderer\",\n name: \"cms-editor-field-renderer-dynamic-zone\",\n renderer: {\n rendererName: \"dynamicZone\",\n name: \"Dynamic Zone\",\n description: \"Renders a dynamic zone.\",\n canUse({ field }) {\n return field.type === \"dynamicZone\";\n },\n render(props) {\n return <DynamicZoneContent {...props} />;\n },\n renderSettings({ field }) {\n return <AccordionRenderSettings field={field} />;\n }\n }\n};\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/app-headless-cms",
|
|
3
|
-
"version": "5.42.3-beta.
|
|
3
|
+
"version": "5.42.3-beta.4",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -27,30 +27,30 @@
|
|
|
27
27
|
"@material-design-icons/svg": "0.14.13",
|
|
28
28
|
"@svgr/webpack": "6.5.1",
|
|
29
29
|
"@types/react": "18.2.79",
|
|
30
|
-
"@webiny/app": "5.42.3-beta.
|
|
31
|
-
"@webiny/app-aco": "5.42.3-beta.
|
|
32
|
-
"@webiny/app-admin": "5.42.3-beta.
|
|
33
|
-
"@webiny/app-graphql-playground": "5.42.3-beta.
|
|
34
|
-
"@webiny/app-headless-cms-common": "5.42.3-beta.
|
|
35
|
-
"@webiny/app-i18n": "5.42.3-beta.
|
|
36
|
-
"@webiny/app-plugin-admin-welcome-screen": "5.42.3-beta.
|
|
37
|
-
"@webiny/app-security": "5.42.3-beta.
|
|
38
|
-
"@webiny/app-tenancy": "5.42.3-beta.
|
|
39
|
-
"@webiny/app-trash-bin": "5.42.3-beta.
|
|
40
|
-
"@webiny/error": "5.42.3-beta.
|
|
41
|
-
"@webiny/feature-flags": "5.42.3-beta.
|
|
42
|
-
"@webiny/form": "5.42.3-beta.
|
|
43
|
-
"@webiny/lexical-editor": "5.42.3-beta.
|
|
44
|
-
"@webiny/lexical-nodes": "5.42.3-beta.
|
|
45
|
-
"@webiny/lexical-theme": "5.42.3-beta.
|
|
46
|
-
"@webiny/plugins": "5.42.3-beta.
|
|
47
|
-
"@webiny/react-composition": "5.42.3-beta.
|
|
48
|
-
"@webiny/react-properties": "5.42.3-beta.
|
|
49
|
-
"@webiny/react-router": "5.42.3-beta.
|
|
50
|
-
"@webiny/theme": "5.42.3-beta.
|
|
51
|
-
"@webiny/ui": "5.42.3-beta.
|
|
52
|
-
"@webiny/utils": "5.42.3-beta.
|
|
53
|
-
"@webiny/validation": "5.42.3-beta.
|
|
30
|
+
"@webiny/app": "5.42.3-beta.4",
|
|
31
|
+
"@webiny/app-aco": "5.42.3-beta.4",
|
|
32
|
+
"@webiny/app-admin": "5.42.3-beta.4",
|
|
33
|
+
"@webiny/app-graphql-playground": "5.42.3-beta.4",
|
|
34
|
+
"@webiny/app-headless-cms-common": "5.42.3-beta.4",
|
|
35
|
+
"@webiny/app-i18n": "5.42.3-beta.4",
|
|
36
|
+
"@webiny/app-plugin-admin-welcome-screen": "5.42.3-beta.4",
|
|
37
|
+
"@webiny/app-security": "5.42.3-beta.4",
|
|
38
|
+
"@webiny/app-tenancy": "5.42.3-beta.4",
|
|
39
|
+
"@webiny/app-trash-bin": "5.42.3-beta.4",
|
|
40
|
+
"@webiny/error": "5.42.3-beta.4",
|
|
41
|
+
"@webiny/feature-flags": "5.42.3-beta.4",
|
|
42
|
+
"@webiny/form": "5.42.3-beta.4",
|
|
43
|
+
"@webiny/lexical-editor": "5.42.3-beta.4",
|
|
44
|
+
"@webiny/lexical-nodes": "5.42.3-beta.4",
|
|
45
|
+
"@webiny/lexical-theme": "5.42.3-beta.4",
|
|
46
|
+
"@webiny/plugins": "5.42.3-beta.4",
|
|
47
|
+
"@webiny/react-composition": "5.42.3-beta.4",
|
|
48
|
+
"@webiny/react-properties": "5.42.3-beta.4",
|
|
49
|
+
"@webiny/react-router": "5.42.3-beta.4",
|
|
50
|
+
"@webiny/theme": "5.42.3-beta.4",
|
|
51
|
+
"@webiny/ui": "5.42.3-beta.4",
|
|
52
|
+
"@webiny/utils": "5.42.3-beta.4",
|
|
53
|
+
"@webiny/validation": "5.42.3-beta.4",
|
|
54
54
|
"apollo-cache": "1.3.5",
|
|
55
55
|
"apollo-client": "2.6.10",
|
|
56
56
|
"apollo-link": "1.2.14",
|
|
@@ -79,7 +79,7 @@
|
|
|
79
79
|
},
|
|
80
80
|
"devDependencies": {
|
|
81
81
|
"@emotion/babel-plugin": "11.11.0",
|
|
82
|
-
"@webiny/project-utils": "5.42.3-beta.
|
|
82
|
+
"@webiny/project-utils": "5.42.3-beta.4",
|
|
83
83
|
"babel-plugin-module-resolver": "5.0.2",
|
|
84
84
|
"rimraf": "6.0.1",
|
|
85
85
|
"ttypescript": "1.5.15",
|
|
@@ -108,5 +108,5 @@
|
|
|
108
108
|
]
|
|
109
109
|
}
|
|
110
110
|
},
|
|
111
|
-
"gitHead": "
|
|
111
|
+
"gitHead": "ddd9afd2185a8e20317f263a3c11f84688b3d8a0"
|
|
112
112
|
}
|