@webiny/website-builder-sdk 0.0.0-unstable.6f45466a1d → 0.0.0-unstable.7be00a75a9
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/BindingsApi.js +29 -36
- package/BindingsApi.js.map +1 -1
- package/BindingsProcessor.js +34 -43
- package/BindingsProcessor.js.map +1 -1
- package/BindingsProcessor.test.js +82 -78
- package/BindingsProcessor.test.js.map +1 -1
- package/BindingsResolver.js +92 -122
- package/BindingsResolver.js.map +1 -1
- package/BindingsResolver.test.js +399 -363
- package/BindingsResolver.test.js.map +1 -1
- package/ComponentInputTraverser.js +28 -49
- package/ComponentInputTraverser.js.map +1 -1
- package/ComponentManifestToAstConverter.js +20 -21
- package/ComponentManifestToAstConverter.js.map +1 -1
- package/ComponentRegistry.js +33 -22
- package/ComponentRegistry.js.map +1 -1
- package/ComponentResolver.js +25 -29
- package/ComponentResolver.js.map +1 -1
- package/ConstraintEvaluator.d.ts +36 -0
- package/ConstraintEvaluator.js +288 -0
- package/ConstraintEvaluator.js.map +1 -0
- package/ConstraintEvaluator.test.d.ts +1 -0
- package/ConstraintEvaluator.test.js +1634 -0
- package/ConstraintEvaluator.test.js.map +1 -0
- package/ContentSdk.d.ts +3 -3
- package/ContentSdk.js +83 -90
- package/ContentSdk.js.map +1 -1
- package/DocumentStore.js +47 -59
- package/DocumentStore.js.map +1 -1
- package/DocumentStoreManager.js +17 -16
- package/DocumentStoreManager.js.map +1 -1
- package/EditingSdk.d.ts +2 -2
- package/EditingSdk.js +87 -121
- package/EditingSdk.js.map +1 -1
- package/ElementFactory.d.ts +2 -3
- package/ElementFactory.js +125 -164
- package/ElementFactory.js.map +1 -1
- package/ElementFactory.test.d.ts +1 -0
- package/ElementFactory.test.js +251 -0
- package/ElementFactory.test.js.map +1 -0
- package/Environment.js +18 -19
- package/Environment.js.map +1 -1
- package/FunctionConverter.js +8 -7
- package/FunctionConverter.js.map +1 -1
- package/HashObject.js +11 -12
- package/HashObject.js.map +1 -1
- package/HotkeyManager.js +41 -48
- package/HotkeyManager.js.map +1 -1
- package/IBindingsUpdater.js +0 -3
- package/IRedirects.js +0 -3
- package/InheritanceProcessor.js +99 -139
- package/InheritanceProcessor.js.map +1 -1
- package/InheritanceProcessor.test.js +178 -179
- package/InheritanceProcessor.test.js.map +1 -1
- package/InheritedValueResolver.js +15 -20
- package/InheritedValueResolver.js.map +1 -1
- package/InputBindingsProcessor.js +187 -289
- package/InputBindingsProcessor.js.map +1 -1
- package/InputsBindingsProcessor.test.js +334 -314
- package/InputsBindingsProcessor.test.js.map +1 -1
- package/InputsUpdater.d.ts +1 -1
- package/InputsUpdater.js +23 -26
- package/InputsUpdater.js.map +1 -1
- package/LiveSdk.d.ts +2 -2
- package/LiveSdk.js +12 -13
- package/LiveSdk.js.map +1 -1
- package/Logger.js +9 -8
- package/Logger.js.map +1 -1
- package/MouseTracker.js +77 -83
- package/MouseTracker.js.map +1 -1
- package/NullSdk.d.ts +4 -3
- package/NullSdk.js +22 -14
- package/NullSdk.js.map +1 -1
- package/PreviewDocument.js +27 -30
- package/PreviewDocument.js.map +1 -1
- package/PreviewSdk.d.ts +2 -2
- package/PreviewSdk.js +16 -17
- package/PreviewSdk.js.map +1 -1
- package/PreviewViewport.js +51 -63
- package/PreviewViewport.js.map +1 -1
- package/ResizeObserver.js +24 -31
- package/ResizeObserver.js.map +1 -1
- package/StylesBindingsProcessor.js +40 -79
- package/StylesBindingsProcessor.js.map +1 -1
- package/StylesUpdater.d.ts +1 -1
- package/StylesUpdater.js +20 -25
- package/StylesUpdater.js.map +1 -1
- package/Theme.js +29 -25
- package/Theme.js.map +1 -1
- package/ViewportManager.js +89 -101
- package/ViewportManager.js.map +1 -1
- package/constants.d.ts +1 -0
- package/constants.js +7 -5
- package/constants.js.map +1 -1
- package/createElement.js +5 -6
- package/createElement.js.map +1 -1
- package/createInput.js +85 -143
- package/createInput.js.map +1 -1
- package/createTheme.js +2 -3
- package/createTheme.js.map +1 -1
- package/dataProviders/ApiClient.js +40 -49
- package/dataProviders/ApiClient.js.map +1 -1
- package/dataProviders/DefaultDataProvider.d.ts +2 -2
- package/dataProviders/DefaultDataProvider.js +55 -44
- package/dataProviders/DefaultDataProvider.js.map +1 -1
- package/dataProviders/GET_PAGE_BY_ID.d.ts +1 -1
- package/dataProviders/GET_PAGE_BY_ID.js +3 -1
- package/dataProviders/GET_PAGE_BY_ID.js.map +1 -1
- package/dataProviders/GET_PAGE_BY_PATH.d.ts +1 -1
- package/dataProviders/GET_PAGE_BY_PATH.js +3 -1
- package/dataProviders/GET_PAGE_BY_PATH.js.map +1 -1
- package/dataProviders/LIST_PUBLISHED_PAGES.d.ts +1 -1
- package/dataProviders/LIST_PUBLISHED_PAGES.js +16 -5
- package/dataProviders/LIST_PUBLISHED_PAGES.js.map +1 -1
- package/dataProviders/NullDataProvider.d.ts +12 -4
- package/dataProviders/NullDataProvider.js +21 -13
- package/dataProviders/NullDataProvider.js.map +1 -1
- package/dataProviders/RedirectsProvider.js +24 -27
- package/dataProviders/RedirectsProvider.js.map +1 -1
- package/defaultBreakpoints.js +23 -22
- package/defaultBreakpoints.js.map +1 -1
- package/documentOperations/$addElementReferenceToParent.d.ts +1 -1
- package/documentOperations/$addElementReferenceToParent.js +30 -26
- package/documentOperations/$addElementReferenceToParent.js.map +1 -1
- package/documentOperations/AddElement.js +8 -7
- package/documentOperations/AddElement.js.map +1 -1
- package/documentOperations/AddToParent.d.ts +2 -2
- package/documentOperations/AddToParent.js +14 -13
- package/documentOperations/AddToParent.js.map +1 -1
- package/documentOperations/IDocumentOperation.js +0 -3
- package/documentOperations/RemoveElement.js +10 -7
- package/documentOperations/RemoveElement.js.map +1 -1
- package/documentOperations/SetGlobalInputBinding.js +23 -22
- package/documentOperations/SetGlobalInputBinding.js.map +1 -1
- package/documentOperations/SetGlobalStyleBinding.js +23 -23
- package/documentOperations/SetGlobalStyleBinding.js.map +1 -1
- package/documentOperations/SetInputBindingOverride.js +30 -29
- package/documentOperations/SetInputBindingOverride.js.map +1 -1
- package/documentOperations/SetStyleBindingOverride.js +30 -31
- package/documentOperations/SetStyleBindingOverride.js.map +1 -1
- package/documentOperations/index.js +9 -8
- package/documentOperations/index.js.map +1 -1
- package/findMatchingAstNode.js +11 -13
- package/findMatchingAstNode.js.map +1 -1
- package/generateElementId.js +2 -2
- package/generateElementId.js.map +1 -1
- package/headersProvider.js +4 -3
- package/headersProvider.js.map +1 -1
- package/index.d.ts +1 -0
- package/index.js +1 -2
- package/jsonPatch.js +5 -9
- package/jsonPatch.js.map +1 -1
- package/messages.js +12 -11
- package/messages.js.map +1 -1
- package/messenger/MessageOrigin.js +12 -11
- package/messenger/MessageOrigin.js.map +1 -1
- package/messenger/Messenger.js +58 -71
- package/messenger/Messenger.js.map +1 -1
- package/messenger/index.js +0 -2
- package/package.json +16 -16
- package/registerComponentGroup.js +5 -6
- package/registerComponentGroup.js.map +1 -1
- package/types/ShorthandCssProperties.js +0 -3
- package/types/WebsiteBuilderTheme.d.ts +7 -0
- package/types/WebsiteBuilderTheme.js +0 -3
- package/types.d.ts +173 -11
- package/types.js +0 -3
- package/IBindingsUpdater.js.map +0 -1
- package/IRedirects.js.map +0 -1
- package/documentOperations/IDocumentOperation.js.map +0 -1
- package/index.js.map +0 -1
- package/messenger/index.js.map +0 -1
- package/types/ShorthandCssProperties.js.map +0 -1
- package/types/WebsiteBuilderTheme.js.map +0 -1
- package/types.js.map +0 -1
package/ElementFactory.js
CHANGED
|
@@ -3,181 +3,142 @@ import { DocumentOperations } from "./documentOperations/index.js";
|
|
|
3
3
|
import { ComponentManifestToAstConverter } from "./ComponentManifestToAstConverter.js";
|
|
4
4
|
import { ComponentInputTraverser } from "./ComponentInputTraverser.js";
|
|
5
5
|
const defaultStyles = {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
};
|
|
9
|
-
const withDefaultStyles = styles => {
|
|
10
|
-
return {
|
|
11
|
-
...defaultStyles,
|
|
12
|
-
...styles
|
|
13
|
-
};
|
|
6
|
+
display: "flex",
|
|
7
|
+
flexDirection: "column"
|
|
14
8
|
};
|
|
9
|
+
const withDefaultStyles = (styles)=>({
|
|
10
|
+
...defaultStyles,
|
|
11
|
+
...styles
|
|
12
|
+
});
|
|
15
13
|
const defaultOperations = {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
return new DocumentOperations.AddToParent(element, index);
|
|
21
|
-
},
|
|
22
|
-
setInputBinding: (elementId, bindingPath, binding) => {
|
|
23
|
-
return new DocumentOperations.SetGlobalInputBinding(elementId, bindingPath, binding);
|
|
24
|
-
},
|
|
25
|
-
setStyleBinding: (elementId, bindingPath, binding) => {
|
|
26
|
-
return new DocumentOperations.SetGlobalStyleBinding(elementId, bindingPath, binding);
|
|
27
|
-
}
|
|
14
|
+
addElement: (element)=>new DocumentOperations.AddElement(element),
|
|
15
|
+
addToParent: (element, index)=>new DocumentOperations.AddToParent(element, index),
|
|
16
|
+
setInputBinding: (elementId, bindingPath, binding)=>new DocumentOperations.SetGlobalInputBinding(elementId, bindingPath, binding),
|
|
17
|
+
setStyleBinding: (elementId, bindingPath, binding)=>new DocumentOperations.SetGlobalStyleBinding(elementId, bindingPath, binding)
|
|
28
18
|
};
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
documentOps.push(...this.generateOperations({
|
|
47
|
-
element,
|
|
48
|
-
inputsAst,
|
|
49
|
-
bindings: {
|
|
50
|
-
inputs: bindings?.inputs ?? componentManifest.defaults?.inputs ?? {},
|
|
51
|
-
styles: withDefaultStyles(bindings?.styles ?? componentManifest.defaults?.styles ?? {}),
|
|
52
|
-
overrides: bindings?.overrides ?? {}
|
|
53
|
-
},
|
|
54
|
-
operations: defaultOperations
|
|
55
|
-
}));
|
|
56
|
-
return {
|
|
57
|
-
element,
|
|
58
|
-
operations: documentOps
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
generateOperations({
|
|
62
|
-
element,
|
|
63
|
-
inputsAst,
|
|
64
|
-
bindings,
|
|
65
|
-
operations
|
|
66
|
-
}) {
|
|
67
|
-
const ops = this.generateOperationsFromBindings({
|
|
68
|
-
elementId: element.id,
|
|
69
|
-
inputsAst,
|
|
70
|
-
bindings,
|
|
71
|
-
operations,
|
|
72
|
-
ignoreDefaultValues: false
|
|
73
|
-
});
|
|
74
|
-
if (bindings.overrides) {
|
|
75
|
-
for (const [breakpoint, overrides] of Object.entries(bindings.overrides)) {
|
|
76
|
-
ops.push(...this.generateOperationsFromBindings({
|
|
77
|
-
elementId: element.id,
|
|
78
|
-
inputsAst,
|
|
79
|
-
bindings: {
|
|
80
|
-
inputs: overrides.inputs ?? {},
|
|
81
|
-
styles: overrides.styles ?? {}
|
|
82
|
-
},
|
|
83
|
-
operations: {
|
|
84
|
-
...operations,
|
|
85
|
-
setInputBinding: (elementId, bindingPath, binding) => {
|
|
86
|
-
return new DocumentOperations.SetInputBindingOverride(elementId, bindingPath, binding, breakpoint);
|
|
19
|
+
class ElementFactory {
|
|
20
|
+
constructor(components){
|
|
21
|
+
this.components = components;
|
|
22
|
+
}
|
|
23
|
+
createElementFromComponent({ componentName, parentId, slot, index, bindings }) {
|
|
24
|
+
const { element, componentManifest, inputsAst } = this.createElement(componentName, parentId, slot);
|
|
25
|
+
const documentOps = [
|
|
26
|
+
defaultOperations.addElement(element),
|
|
27
|
+
defaultOperations.addToParent(element, index)
|
|
28
|
+
];
|
|
29
|
+
documentOps.push(...this.generateOperations({
|
|
30
|
+
element,
|
|
31
|
+
inputsAst,
|
|
32
|
+
bindings: {
|
|
33
|
+
inputs: bindings?.inputs ?? componentManifest.defaults?.inputs ?? {},
|
|
34
|
+
styles: withDefaultStyles(bindings?.styles ?? componentManifest.defaults?.styles ?? {}),
|
|
35
|
+
overrides: bindings?.overrides ?? {}
|
|
87
36
|
},
|
|
88
|
-
|
|
89
|
-
return new DocumentOperations.SetStyleBindingOverride(elementId, bindingPath, binding, breakpoint);
|
|
90
|
-
}
|
|
91
|
-
},
|
|
92
|
-
ignoreDefaultValues: true
|
|
37
|
+
operations: defaultOperations
|
|
93
38
|
}));
|
|
94
|
-
|
|
39
|
+
return {
|
|
40
|
+
element,
|
|
41
|
+
operations: documentOps
|
|
42
|
+
};
|
|
95
43
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
ignoreDefaultValues
|
|
104
|
-
}) {
|
|
105
|
-
const inputData = bindings.inputs;
|
|
106
|
-
const traverser = new ComponentInputTraverser(inputsAst);
|
|
107
|
-
const ops = [];
|
|
108
|
-
traverser.traverse(inputData, (node, path, value) => {
|
|
109
|
-
const isCreateElement = value?.action === "CreateElement";
|
|
110
|
-
const isList = node.list;
|
|
111
|
-
const isObject = node.type === "object";
|
|
112
|
-
if (isCreateElement) {
|
|
113
|
-
const factory = new ElementFactory(this.components);
|
|
114
|
-
const newElement = factory.createElementFromComponent({
|
|
115
|
-
componentName: value.params.component,
|
|
116
|
-
index: isList ? this.extractIndex(path) : 0,
|
|
117
|
-
slot: path,
|
|
118
|
-
parentId: elementId,
|
|
119
|
-
bindings: value.params
|
|
44
|
+
generateOperations({ element, inputsAst, bindings, operations }) {
|
|
45
|
+
const ops = this.generateOperationsFromBindings({
|
|
46
|
+
elementId: element.id,
|
|
47
|
+
inputsAst,
|
|
48
|
+
bindings,
|
|
49
|
+
operations,
|
|
50
|
+
ignoreDefaultValues: false
|
|
120
51
|
});
|
|
121
|
-
const
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
52
|
+
if (bindings.overrides) for (const [breakpoint, overrides] of Object.entries(bindings.overrides))ops.push(...this.generateOperationsFromBindings({
|
|
53
|
+
elementId: element.id,
|
|
54
|
+
inputsAst,
|
|
55
|
+
bindings: {
|
|
56
|
+
inputs: overrides.inputs ?? {},
|
|
57
|
+
styles: overrides.styles ?? {}
|
|
58
|
+
},
|
|
59
|
+
operations: {
|
|
60
|
+
...operations,
|
|
61
|
+
setInputBinding: (elementId, bindingPath, binding)=>new DocumentOperations.SetInputBindingOverride(elementId, bindingPath, binding, breakpoint),
|
|
62
|
+
setStyleBinding: (elementId, bindingPath, binding)=>new DocumentOperations.SetStyleBindingOverride(elementId, bindingPath, binding, breakpoint)
|
|
63
|
+
},
|
|
64
|
+
ignoreDefaultValues: true
|
|
128
65
|
}));
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
66
|
+
return ops;
|
|
67
|
+
}
|
|
68
|
+
generateOperationsFromBindings({ elementId, inputsAst, bindings, operations, ignoreDefaultValues }) {
|
|
69
|
+
const inputData = bindings.inputs;
|
|
70
|
+
const traverser = new ComponentInputTraverser(inputsAst);
|
|
71
|
+
const ops = [];
|
|
72
|
+
traverser.traverse(inputData, (node, path, value)=>{
|
|
73
|
+
const isCreateElement = value?.action === "CreateElement";
|
|
74
|
+
const isList = node.list;
|
|
75
|
+
const isObject = "object" === node.type;
|
|
76
|
+
if (isCreateElement) {
|
|
77
|
+
const factory = new ElementFactory(this.components);
|
|
78
|
+
const newElement = factory.createElementFromComponent({
|
|
79
|
+
componentName: value.params.component,
|
|
80
|
+
index: isList ? void 0 : 0,
|
|
81
|
+
slot: path,
|
|
82
|
+
parentId: elementId,
|
|
83
|
+
bindings: value.params
|
|
84
|
+
});
|
|
85
|
+
const newElementId = newElement.element.id;
|
|
86
|
+
ops.push(...newElement.operations);
|
|
87
|
+
if (isList) ops.push(operations.setInputBinding(elementId, path, {
|
|
88
|
+
id: generateElementId(),
|
|
89
|
+
type: node.type,
|
|
90
|
+
translatable: node.input.translatable,
|
|
91
|
+
list: node.list
|
|
92
|
+
}));
|
|
93
|
+
else ops.push(operations.setInputBinding(elementId, path, {
|
|
94
|
+
id: generateElementId(),
|
|
95
|
+
static: newElementId,
|
|
96
|
+
type: node.type,
|
|
97
|
+
translatable: node.input.translatable,
|
|
98
|
+
list: node.list
|
|
99
|
+
}));
|
|
100
|
+
} else {
|
|
101
|
+
if (isObject && isList) return;
|
|
102
|
+
ops.push(operations.setInputBinding(elementId, path, {
|
|
103
|
+
id: generateElementId(),
|
|
104
|
+
static: ignoreDefaultValues ? void 0 : value ?? node.input.defaultValue,
|
|
105
|
+
type: node.type,
|
|
106
|
+
list: node.list,
|
|
107
|
+
translatable: node.input.translatable
|
|
108
|
+
}));
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
for(const key in bindings.styles)ops.push(operations.setStyleBinding(elementId, key, {
|
|
112
|
+
static: bindings.styles[key]
|
|
138
113
|
}));
|
|
139
|
-
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
// Process styles
|
|
143
|
-
for (const key in bindings.styles) {
|
|
144
|
-
ops.push(operations.setStyleBinding(elementId, key, {
|
|
145
|
-
static: bindings.styles[key]
|
|
146
|
-
}));
|
|
114
|
+
return ops;
|
|
147
115
|
}
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
116
|
+
getComponentManifest(componentName) {
|
|
117
|
+
const manifest = this.components[componentName];
|
|
118
|
+
if (!manifest) throw new Error(`Component "${componentName}" not registered.`);
|
|
119
|
+
return manifest;
|
|
120
|
+
}
|
|
121
|
+
createElement(componentName, parentId, slot) {
|
|
122
|
+
const element = {
|
|
123
|
+
type: "Webiny/Element",
|
|
124
|
+
id: generateElementId(),
|
|
125
|
+
parent: {
|
|
126
|
+
id: parentId,
|
|
127
|
+
slot
|
|
128
|
+
},
|
|
129
|
+
component: {
|
|
130
|
+
name: componentName
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
const componentManifest = this.getComponentManifest(componentName);
|
|
134
|
+
const inputsAst = ComponentManifestToAstConverter.convert(componentManifest.inputs ?? []);
|
|
135
|
+
return {
|
|
136
|
+
element,
|
|
137
|
+
inputsAst,
|
|
138
|
+
componentManifest
|
|
139
|
+
};
|
|
154
140
|
}
|
|
155
|
-
return manifest;
|
|
156
|
-
}
|
|
157
|
-
extractIndex(path) {
|
|
158
|
-
const match = path.match(/\/(\d+)\//);
|
|
159
|
-
return match ? parseInt(match[1], 10) : 0;
|
|
160
|
-
}
|
|
161
|
-
createElement(componentName, parentId, slot) {
|
|
162
|
-
const element = {
|
|
163
|
-
type: "Webiny/Element",
|
|
164
|
-
id: generateElementId(),
|
|
165
|
-
parent: {
|
|
166
|
-
id: parentId,
|
|
167
|
-
slot
|
|
168
|
-
},
|
|
169
|
-
component: {
|
|
170
|
-
name: componentName
|
|
171
|
-
}
|
|
172
|
-
};
|
|
173
|
-
const componentManifest = this.getComponentManifest(componentName);
|
|
174
|
-
const inputsAst = ComponentManifestToAstConverter.convert(componentManifest.inputs ?? []);
|
|
175
|
-
return {
|
|
176
|
-
element,
|
|
177
|
-
inputsAst,
|
|
178
|
-
componentManifest
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
141
|
}
|
|
142
|
+
export { ElementFactory };
|
|
182
143
|
|
|
183
144
|
//# sourceMappingURL=ElementFactory.js.map
|
package/ElementFactory.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["generateElementId","DocumentOperations","ComponentManifestToAstConverter","ComponentInputTraverser","defaultStyles","display","flexDirection","withDefaultStyles","styles","defaultOperations","addElement","element","AddElement","addToParent","index","AddToParent","setInputBinding","elementId","bindingPath","binding","SetGlobalInputBinding","setStyleBinding","SetGlobalStyleBinding","ElementFactory","constructor","components","createElementFromComponent","componentName","parentId","slot","bindings","componentManifest","inputsAst","createElement","documentOps","push","generateOperations","inputs","defaults","overrides","operations","ops","generateOperationsFromBindings","id","ignoreDefaultValues","breakpoint","Object","entries","SetInputBindingOverride","SetStyleBindingOverride","inputData","traverser","traverse","node","path","value","isCreateElement","action","isList","list","isObject","type","factory","newElement","params","component","extractIndex","newElementId","static","translatable","input","undefined","defaultValue","key","getComponentManifest","manifest","Error","match","parseInt","parent","name","convert"],"sources":["ElementFactory.ts"],"sourcesContent":["import { generateElementId } from \"./generateElementId.js\";\nimport type {\n DocumentElement,\n ComponentManifest,\n InputValueBinding,\n StyleValueBinding,\n CssProperties\n} from \"~/types.js\";\nimport { type IDocumentOperation, DocumentOperations } from \"./documentOperations/index.js\";\nimport {\n ComponentManifestToAstConverter,\n type InputAstNode\n} from \"./ComponentManifestToAstConverter.js\";\nimport { ComponentInputTraverser } from \"./ComponentInputTraverser.js\";\n\nconst defaultStyles = {\n display: \"flex\",\n flexDirection: \"column\"\n};\n\nconst withDefaultStyles = (styles: CssProperties) => {\n return { ...defaultStyles, ...styles };\n};\n\nexport interface ElementFactoryCreateElementParams {\n componentName: string;\n parentId: string;\n slot: string;\n index: number;\n bindings?: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n overrides?: {\n [breakpoint: string]: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n };\n };\n };\n}\n\ninterface GenerateOperationsParams {\n element: DocumentElement;\n inputsAst: InputAstNode[];\n operations: ElementFactoryOperations;\n bindings: {\n inputs: Record<string, any>;\n styles: Record<string, any>;\n overrides: {\n [breakpoint: string]: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n };\n };\n };\n}\n\ninterface GenerateOperationsFromBindingsParams {\n elementId: string;\n inputsAst: InputAstNode[];\n bindings: {\n inputs: Record<string, any>;\n styles: Record<string, any>;\n };\n operations: ElementFactoryOperations;\n ignoreDefaultValues: boolean;\n}\n\ntype ElementFactoryOperations = {\n addElement: (element: DocumentElement) => IDocumentOperation;\n addToParent: (element: DocumentElement, index: number) => IDocumentOperation;\n setInputBinding: (\n elementId: string,\n bindingPath: string,\n binding: InputValueBinding\n ) => IDocumentOperation;\n setStyleBinding: (\n elementId: string,\n bindingPath: string,\n binding: StyleValueBinding\n ) => IDocumentOperation;\n};\n\nconst defaultOperations: ElementFactoryOperations = {\n addElement: (element: DocumentElement) => {\n return new DocumentOperations.AddElement(element);\n },\n addToParent: (element: DocumentElement, index: number) => {\n return new DocumentOperations.AddToParent(element, index);\n },\n setInputBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetGlobalInputBinding(elementId, bindingPath, binding);\n },\n setStyleBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetGlobalStyleBinding(elementId, bindingPath, binding);\n }\n};\n\nexport class ElementFactory {\n constructor(private components: Record<string, ComponentManifest>) {}\n\n public createElementFromComponent({\n componentName,\n parentId,\n slot,\n index,\n bindings\n }: ElementFactoryCreateElementParams) {\n const { element, componentManifest, inputsAst } = this.createElement(\n componentName,\n parentId,\n slot\n );\n\n const documentOps: IDocumentOperation[] = [\n defaultOperations.addElement(element),\n defaultOperations.addToParent(element, index)\n ];\n\n documentOps.push(\n ...this.generateOperations({\n element,\n inputsAst,\n bindings: {\n inputs: bindings?.inputs ?? componentManifest.defaults?.inputs ?? {},\n styles: withDefaultStyles(\n bindings?.styles ?? componentManifest.defaults?.styles ?? {}\n ),\n overrides: bindings?.overrides ?? {}\n },\n operations: defaultOperations\n })\n );\n\n return { element, operations: documentOps };\n }\n\n public generateOperations({\n element,\n inputsAst,\n bindings,\n operations\n }: GenerateOperationsParams): IDocumentOperation[] {\n const ops = this.generateOperationsFromBindings({\n elementId: element.id,\n inputsAst,\n bindings,\n operations,\n ignoreDefaultValues: false\n });\n\n if (bindings.overrides) {\n for (const [breakpoint, overrides] of Object.entries(bindings.overrides)) {\n ops.push(\n ...this.generateOperationsFromBindings({\n elementId: element.id,\n inputsAst,\n bindings: {\n inputs: overrides.inputs ?? {},\n styles: overrides.styles ?? {}\n },\n operations: {\n ...operations,\n setInputBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetInputBindingOverride(\n elementId,\n bindingPath,\n binding,\n breakpoint\n );\n },\n setStyleBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetStyleBindingOverride(\n elementId,\n bindingPath,\n binding,\n breakpoint\n );\n }\n },\n ignoreDefaultValues: true\n })\n );\n }\n }\n\n return ops;\n }\n\n private generateOperationsFromBindings({\n elementId,\n inputsAst,\n bindings,\n operations,\n ignoreDefaultValues\n }: GenerateOperationsFromBindingsParams): IDocumentOperation[] {\n const inputData = bindings.inputs;\n const traverser = new ComponentInputTraverser(inputsAst);\n\n const ops: IDocumentOperation[] = [];\n\n traverser.traverse(inputData, (node, path, value) => {\n const isCreateElement = value?.action === \"CreateElement\";\n const isList = node.list;\n const isObject = node.type === \"object\";\n\n if (isCreateElement) {\n const factory = new ElementFactory(this.components);\n const newElement = factory.createElementFromComponent({\n componentName: value.params.component,\n index: isList ? this.extractIndex(path) : 0,\n slot: path,\n parentId: elementId,\n bindings: value.params\n });\n\n const newElementId = newElement.element.id;\n\n ops.push(\n ...newElement.operations,\n operations.setInputBinding(elementId, path, {\n id: generateElementId(),\n static: node.list ? [newElementId] : newElementId,\n type: node.type,\n translatable: node.input.translatable,\n list: node.list\n })\n );\n } else if (isObject && isList) {\n return;\n } else {\n ops.push(\n operations.setInputBinding(elementId, path, {\n id: generateElementId(),\n static: ignoreDefaultValues\n ? undefined\n : (value ?? node.input.defaultValue),\n type: node.type,\n list: node.list,\n translatable: node.input.translatable\n })\n );\n }\n });\n\n // Process styles\n for (const key in bindings.styles) {\n ops.push(\n operations.setStyleBinding(elementId, key, {\n static: bindings.styles[key]\n })\n );\n }\n\n return ops;\n }\n\n private getComponentManifest(componentName: string): ComponentManifest {\n const manifest = this.components[componentName];\n if (!manifest) {\n throw new Error(`Component \"${componentName}\" not registered.`);\n }\n\n return manifest;\n }\n\n private extractIndex(path: string): number {\n const match = path.match(/\\/(\\d+)\\//);\n return match ? parseInt(match[1], 10) : 0;\n }\n\n private createElement(componentName: string, parentId: string, slot: string) {\n const element: DocumentElement = {\n type: \"Webiny/Element\",\n id: generateElementId(),\n parent: { id: parentId, slot },\n component: { name: componentName }\n };\n\n const componentManifest = this.getComponentManifest(componentName);\n const inputsAst = ComponentManifestToAstConverter.convert(componentManifest.inputs ?? []);\n\n return {\n element,\n inputsAst,\n componentManifest\n };\n }\n}\n"],"mappings":"AAAA,SAASA,iBAAiB;AAQ1B,SAAkCC,kBAAkB;AACpD,SACIC,+BAA+B;AAGnC,SAASC,uBAAuB;AAEhC,MAAMC,aAAa,GAAG;EAClBC,OAAO,EAAE,MAAM;EACfC,aAAa,EAAE;AACnB,CAAC;AAED,MAAMC,iBAAiB,GAAIC,MAAqB,IAAK;EACjD,OAAO;IAAE,GAAGJ,aAAa;IAAE,GAAGI;EAAO,CAAC;AAC1C,CAAC;AA6DD,MAAMC,iBAA2C,GAAG;EAChDC,UAAU,EAAGC,OAAwB,IAAK;IACtC,OAAO,IAAIV,kBAAkB,CAACW,UAAU,CAACD,OAAO,CAAC;EACrD,CAAC;EACDE,WAAW,EAAEA,CAACF,OAAwB,EAAEG,KAAa,KAAK;IACtD,OAAO,IAAIb,kBAAkB,CAACc,WAAW,CAACJ,OAAO,EAAEG,KAAK,CAAC;EAC7D,CAAC;EACDE,eAAe,EAAEA,CAACC,SAAS,EAAEC,WAAW,EAAEC,OAAO,KAAK;IAClD,OAAO,IAAIlB,kBAAkB,CAACmB,qBAAqB,CAACH,SAAS,EAAEC,WAAW,EAAEC,OAAO,CAAC;EACxF,CAAC;EACDE,eAAe,EAAEA,CAACJ,SAAS,EAAEC,WAAW,EAAEC,OAAO,KAAK;IAClD,OAAO,IAAIlB,kBAAkB,CAACqB,qBAAqB,CAACL,SAAS,EAAEC,WAAW,EAAEC,OAAO,CAAC;EACxF;AACJ,CAAC;AAED,OAAO,MAAMI,cAAc,CAAC;EACxBC,WAAWA,CAASC,UAA6C,EAAE;IAAA,KAA/CA,UAA6C,GAA7CA,UAA6C;EAAG;EAE7DC,0BAA0BA,CAAC;IAC9BC,aAAa;IACbC,QAAQ;IACRC,IAAI;IACJf,KAAK;IACLgB;EAC+B,CAAC,EAAE;IAClC,MAAM;MAAEnB,OAAO;MAAEoB,iBAAiB;MAAEC;IAAU,CAAC,GAAG,IAAI,CAACC,aAAa,CAChEN,aAAa,EACbC,QAAQ,EACRC,IACJ,CAAC;IAED,MAAMK,WAAiC,GAAG,CACtCzB,iBAAiB,CAACC,UAAU,CAACC,OAAO,CAAC,EACrCF,iBAAiB,CAACI,WAAW,CAACF,OAAO,EAAEG,KAAK,CAAC,CAChD;IAEDoB,WAAW,CAACC,IAAI,CACZ,GAAG,IAAI,CAACC,kBAAkB,CAAC;MACvBzB,OAAO;MACPqB,SAAS;MACTF,QAAQ,EAAE;QACNO,MAAM,EAAEP,QAAQ,EAAEO,MAAM,IAAIN,iBAAiB,CAACO,QAAQ,EAAED,MAAM,IAAI,CAAC,CAAC;QACpE7B,MAAM,EAAED,iBAAiB,CACrBuB,QAAQ,EAAEtB,MAAM,IAAIuB,iBAAiB,CAACO,QAAQ,EAAE9B,MAAM,IAAI,CAAC,CAC/D,CAAC;QACD+B,SAAS,EAAET,QAAQ,EAAES,SAAS,IAAI,CAAC;MACvC,CAAC;MACDC,UAAU,EAAE/B;IAChB,CAAC,CACL,CAAC;IAED,OAAO;MAAEE,OAAO;MAAE6B,UAAU,EAAEN;IAAY,CAAC;EAC/C;EAEOE,kBAAkBA,CAAC;IACtBzB,OAAO;IACPqB,SAAS;IACTF,QAAQ;IACRU;EACsB,CAAC,EAAwB;IAC/C,MAAMC,GAAG,GAAG,IAAI,CAACC,8BAA8B,CAAC;MAC5CzB,SAAS,EAAEN,OAAO,CAACgC,EAAE;MACrBX,SAAS;MACTF,QAAQ;MACRU,UAAU;MACVI,mBAAmB,EAAE;IACzB,CAAC,CAAC;IAEF,IAAId,QAAQ,CAACS,SAAS,EAAE;MACpB,KAAK,MAAM,CAACM,UAAU,EAAEN,SAAS,CAAC,IAAIO,MAAM,CAACC,OAAO,CAACjB,QAAQ,CAACS,SAAS,CAAC,EAAE;QACtEE,GAAG,CAACN,IAAI,CACJ,GAAG,IAAI,CAACO,8BAA8B,CAAC;UACnCzB,SAAS,EAAEN,OAAO,CAACgC,EAAE;UACrBX,SAAS;UACTF,QAAQ,EAAE;YACNO,MAAM,EAAEE,SAAS,CAACF,MAAM,IAAI,CAAC,CAAC;YAC9B7B,MAAM,EAAE+B,SAAS,CAAC/B,MAAM,IAAI,CAAC;UACjC,CAAC;UACDgC,UAAU,EAAE;YACR,GAAGA,UAAU;YACbxB,eAAe,EAAEA,CAACC,SAAS,EAAEC,WAAW,EAAEC,OAAO,KAAK;cAClD,OAAO,IAAIlB,kBAAkB,CAAC+C,uBAAuB,CACjD/B,SAAS,EACTC,WAAW,EACXC,OAAO,EACP0B,UACJ,CAAC;YACL,CAAC;YACDxB,eAAe,EAAEA,CAACJ,SAAS,EAAEC,WAAW,EAAEC,OAAO,KAAK;cAClD,OAAO,IAAIlB,kBAAkB,CAACgD,uBAAuB,CACjDhC,SAAS,EACTC,WAAW,EACXC,OAAO,EACP0B,UACJ,CAAC;YACL;UACJ,CAAC;UACDD,mBAAmB,EAAE;QACzB,CAAC,CACL,CAAC;MACL;IACJ;IAEA,OAAOH,GAAG;EACd;EAEQC,8BAA8BA,CAAC;IACnCzB,SAAS;IACTe,SAAS;IACTF,QAAQ;IACRU,UAAU;IACVI;EACkC,CAAC,EAAwB;IAC3D,MAAMM,SAAS,GAAGpB,QAAQ,CAACO,MAAM;IACjC,MAAMc,SAAS,GAAG,IAAIhD,uBAAuB,CAAC6B,SAAS,CAAC;IAExD,MAAMS,GAAyB,GAAG,EAAE;IAEpCU,SAAS,CAACC,QAAQ,CAACF,SAAS,EAAE,CAACG,IAAI,EAAEC,IAAI,EAAEC,KAAK,KAAK;MACjD,MAAMC,eAAe,GAAGD,KAAK,EAAEE,MAAM,KAAK,eAAe;MACzD,MAAMC,MAAM,GAAGL,IAAI,CAACM,IAAI;MACxB,MAAMC,QAAQ,GAAGP,IAAI,CAACQ,IAAI,KAAK,QAAQ;MAEvC,IAAIL,eAAe,EAAE;QACjB,MAAMM,OAAO,GAAG,IAAIvC,cAAc,CAAC,IAAI,CAACE,UAAU,CAAC;QACnD,MAAMsC,UAAU,GAAGD,OAAO,CAACpC,0BAA0B,CAAC;UAClDC,aAAa,EAAE4B,KAAK,CAACS,MAAM,CAACC,SAAS;UACrCnD,KAAK,EAAE4C,MAAM,GAAG,IAAI,CAACQ,YAAY,CAACZ,IAAI,CAAC,GAAG,CAAC;UAC3CzB,IAAI,EAAEyB,IAAI;UACV1B,QAAQ,EAAEX,SAAS;UACnBa,QAAQ,EAAEyB,KAAK,CAACS;QACpB,CAAC,CAAC;QAEF,MAAMG,YAAY,GAAGJ,UAAU,CAACpD,OAAO,CAACgC,EAAE;QAE1CF,GAAG,CAACN,IAAI,CACJ,GAAG4B,UAAU,CAACvB,UAAU,EACxBA,UAAU,CAACxB,eAAe,CAACC,SAAS,EAAEqC,IAAI,EAAE;UACxCX,EAAE,EAAE3C,iBAAiB,CAAC,CAAC;UACvBoE,MAAM,EAAEf,IAAI,CAACM,IAAI,GAAG,CAACQ,YAAY,CAAC,GAAGA,YAAY;UACjDN,IAAI,EAAER,IAAI,CAACQ,IAAI;UACfQ,YAAY,EAAEhB,IAAI,CAACiB,KAAK,CAACD,YAAY;UACrCV,IAAI,EAAEN,IAAI,CAACM;QACf,CAAC,CACL,CAAC;MACL,CAAC,MAAM,IAAIC,QAAQ,IAAIF,MAAM,EAAE;QAC3B;MACJ,CAAC,MAAM;QACHjB,GAAG,CAACN,IAAI,CACJK,UAAU,CAACxB,eAAe,CAACC,SAAS,EAAEqC,IAAI,EAAE;UACxCX,EAAE,EAAE3C,iBAAiB,CAAC,CAAC;UACvBoE,MAAM,EAAExB,mBAAmB,GACrB2B,SAAS,GACRhB,KAAK,IAAIF,IAAI,CAACiB,KAAK,CAACE,YAAa;UACxCX,IAAI,EAAER,IAAI,CAACQ,IAAI;UACfF,IAAI,EAAEN,IAAI,CAACM,IAAI;UACfU,YAAY,EAAEhB,IAAI,CAACiB,KAAK,CAACD;QAC7B,CAAC,CACL,CAAC;MACL;IACJ,CAAC,CAAC;;IAEF;IACA,KAAK,MAAMI,GAAG,IAAI3C,QAAQ,CAACtB,MAAM,EAAE;MAC/BiC,GAAG,CAACN,IAAI,CACJK,UAAU,CAACnB,eAAe,CAACJ,SAAS,EAAEwD,GAAG,EAAE;QACvCL,MAAM,EAAEtC,QAAQ,CAACtB,MAAM,CAACiE,GAAG;MAC/B,CAAC,CACL,CAAC;IACL;IAEA,OAAOhC,GAAG;EACd;EAEQiC,oBAAoBA,CAAC/C,aAAqB,EAAqB;IACnE,MAAMgD,QAAQ,GAAG,IAAI,CAAClD,UAAU,CAACE,aAAa,CAAC;IAC/C,IAAI,CAACgD,QAAQ,EAAE;MACX,MAAM,IAAIC,KAAK,CAAC,cAAcjD,aAAa,mBAAmB,CAAC;IACnE;IAEA,OAAOgD,QAAQ;EACnB;EAEQT,YAAYA,CAACZ,IAAY,EAAU;IACvC,MAAMuB,KAAK,GAAGvB,IAAI,CAACuB,KAAK,CAAC,WAAW,CAAC;IACrC,OAAOA,KAAK,GAAGC,QAAQ,CAACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC;EAC7C;EAEQ5C,aAAaA,CAACN,aAAqB,EAAEC,QAAgB,EAAEC,IAAY,EAAE;IACzE,MAAMlB,OAAwB,GAAG;MAC7BkD,IAAI,EAAE,gBAAgB;MACtBlB,EAAE,EAAE3C,iBAAiB,CAAC,CAAC;MACvB+E,MAAM,EAAE;QAAEpC,EAAE,EAAEf,QAAQ;QAAEC;MAAK,CAAC;MAC9BoC,SAAS,EAAE;QAAEe,IAAI,EAAErD;MAAc;IACrC,CAAC;IAED,MAAMI,iBAAiB,GAAG,IAAI,CAAC2C,oBAAoB,CAAC/C,aAAa,CAAC;IAClE,MAAMK,SAAS,GAAG9B,+BAA+B,CAAC+E,OAAO,CAAClD,iBAAiB,CAACM,MAAM,IAAI,EAAE,CAAC;IAEzF,OAAO;MACH1B,OAAO;MACPqB,SAAS;MACTD;IACJ,CAAC;EACL;AACJ","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"ElementFactory.js","sources":["../src/ElementFactory.ts"],"sourcesContent":["import { generateElementId } from \"./generateElementId.js\";\nimport type {\n DocumentElement,\n ComponentManifest,\n InputValueBinding,\n StyleValueBinding,\n CssProperties\n} from \"~/types.js\";\nimport { type IDocumentOperation, DocumentOperations } from \"./documentOperations/index.js\";\nimport {\n ComponentManifestToAstConverter,\n type InputAstNode\n} from \"./ComponentManifestToAstConverter.js\";\nimport { ComponentInputTraverser } from \"./ComponentInputTraverser.js\";\n\nconst defaultStyles = {\n display: \"flex\",\n flexDirection: \"column\"\n};\n\nconst withDefaultStyles = (styles: CssProperties) => {\n return { ...defaultStyles, ...styles };\n};\n\nexport interface ElementFactoryCreateElementParams {\n componentName: string;\n parentId: string;\n slot: string;\n index?: number;\n bindings?: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n overrides?: {\n [breakpoint: string]: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n };\n };\n };\n}\n\ninterface GenerateOperationsParams {\n element: DocumentElement;\n inputsAst: InputAstNode[];\n operations: ElementFactoryOperations;\n bindings: {\n inputs: Record<string, any>;\n styles: Record<string, any>;\n overrides: {\n [breakpoint: string]: {\n inputs?: Record<string, any>;\n styles?: Record<string, any>;\n };\n };\n };\n}\n\ninterface GenerateOperationsFromBindingsParams {\n elementId: string;\n inputsAst: InputAstNode[];\n bindings: {\n inputs: Record<string, any>;\n styles: Record<string, any>;\n };\n operations: ElementFactoryOperations;\n ignoreDefaultValues: boolean;\n}\n\ntype ElementFactoryOperations = {\n addElement: (element: DocumentElement) => IDocumentOperation;\n addToParent: (element: DocumentElement, index?: number) => IDocumentOperation;\n setInputBinding: (\n elementId: string,\n bindingPath: string,\n binding: InputValueBinding\n ) => IDocumentOperation;\n setStyleBinding: (\n elementId: string,\n bindingPath: string,\n binding: StyleValueBinding\n ) => IDocumentOperation;\n};\n\nconst defaultOperations: ElementFactoryOperations = {\n addElement: (element: DocumentElement) => {\n return new DocumentOperations.AddElement(element);\n },\n addToParent: (element: DocumentElement, index?: number) => {\n return new DocumentOperations.AddToParent(element, index);\n },\n setInputBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetGlobalInputBinding(elementId, bindingPath, binding);\n },\n setStyleBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetGlobalStyleBinding(elementId, bindingPath, binding);\n }\n};\n\nexport class ElementFactory {\n constructor(private components: Record<string, ComponentManifest>) {}\n\n public createElementFromComponent({\n componentName,\n parentId,\n slot,\n index,\n bindings\n }: ElementFactoryCreateElementParams) {\n const { element, componentManifest, inputsAst } = this.createElement(\n componentName,\n parentId,\n slot\n );\n\n const documentOps: IDocumentOperation[] = [\n defaultOperations.addElement(element),\n defaultOperations.addToParent(element, index)\n ];\n\n documentOps.push(\n ...this.generateOperations({\n element,\n inputsAst,\n bindings: {\n inputs: bindings?.inputs ?? componentManifest.defaults?.inputs ?? {},\n styles: withDefaultStyles(\n bindings?.styles ?? componentManifest.defaults?.styles ?? {}\n ),\n overrides: bindings?.overrides ?? {}\n },\n operations: defaultOperations\n })\n );\n\n return { element, operations: documentOps };\n }\n\n public generateOperations({\n element,\n inputsAst,\n bindings,\n operations\n }: GenerateOperationsParams): IDocumentOperation[] {\n const ops = this.generateOperationsFromBindings({\n elementId: element.id,\n inputsAst,\n bindings,\n operations,\n ignoreDefaultValues: false\n });\n\n if (bindings.overrides) {\n for (const [breakpoint, overrides] of Object.entries(bindings.overrides)) {\n ops.push(\n ...this.generateOperationsFromBindings({\n elementId: element.id,\n inputsAst,\n bindings: {\n inputs: overrides.inputs ?? {},\n styles: overrides.styles ?? {}\n },\n operations: {\n ...operations,\n setInputBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetInputBindingOverride(\n elementId,\n bindingPath,\n binding,\n breakpoint\n );\n },\n setStyleBinding: (elementId, bindingPath, binding) => {\n return new DocumentOperations.SetStyleBindingOverride(\n elementId,\n bindingPath,\n binding,\n breakpoint\n );\n }\n },\n ignoreDefaultValues: true\n })\n );\n }\n }\n\n return ops;\n }\n\n private generateOperationsFromBindings({\n elementId,\n inputsAst,\n bindings,\n operations,\n ignoreDefaultValues\n }: GenerateOperationsFromBindingsParams): IDocumentOperation[] {\n const inputData = bindings.inputs;\n const traverser = new ComponentInputTraverser(inputsAst);\n\n const ops: IDocumentOperation[] = [];\n\n traverser.traverse(inputData, (node, path, value) => {\n const isCreateElement = value?.action === \"CreateElement\";\n const isList = node.list;\n const isObject = node.type === \"object\";\n\n if (isCreateElement) {\n const factory = new ElementFactory(this.components);\n const newElement = factory.createElementFromComponent({\n componentName: value.params.component,\n // undefined index = append to end of the slot array\n index: isList ? undefined : 0,\n slot: path,\n parentId: elementId,\n bindings: value.params\n });\n\n const newElementId = newElement.element.id;\n\n ops.push(...newElement.operations);\n\n if (isList) {\n // For list slots, AddToParent already manages the static array.\n // We only set metadata here.\n ops.push(\n operations.setInputBinding(elementId, path, {\n id: generateElementId(),\n type: node.type,\n translatable: node.input.translatable,\n list: node.list\n })\n );\n } else {\n ops.push(\n operations.setInputBinding(elementId, path, {\n id: generateElementId(),\n static: newElementId,\n type: node.type,\n translatable: node.input.translatable,\n list: node.list\n })\n );\n }\n } else if (isObject && isList) {\n return;\n } else {\n ops.push(\n operations.setInputBinding(elementId, path, {\n id: generateElementId(),\n static: ignoreDefaultValues\n ? undefined\n : (value ?? node.input.defaultValue),\n type: node.type,\n list: node.list,\n translatable: node.input.translatable\n })\n );\n }\n });\n\n // Process styles\n for (const key in bindings.styles) {\n ops.push(\n operations.setStyleBinding(elementId, key, {\n static: bindings.styles[key]\n })\n );\n }\n\n return ops;\n }\n\n private getComponentManifest(componentName: string): ComponentManifest {\n const manifest = this.components[componentName];\n if (!manifest) {\n throw new Error(`Component \"${componentName}\" not registered.`);\n }\n\n return manifest;\n }\n\n private createElement(componentName: string, parentId: string, slot: string) {\n const element: DocumentElement = {\n type: \"Webiny/Element\",\n id: generateElementId(),\n parent: { id: parentId, slot },\n component: { name: componentName }\n };\n\n const componentManifest = this.getComponentManifest(componentName);\n const inputsAst = ComponentManifestToAstConverter.convert(componentManifest.inputs ?? []);\n\n return {\n element,\n inputsAst,\n componentManifest\n };\n }\n}\n"],"names":["defaultStyles","withDefaultStyles","styles","defaultOperations","element","DocumentOperations","index","elementId","bindingPath","binding","ElementFactory","components","componentName","parentId","slot","bindings","componentManifest","inputsAst","documentOps","operations","ops","breakpoint","overrides","Object","ignoreDefaultValues","inputData","traverser","ComponentInputTraverser","node","path","value","isCreateElement","isList","isObject","factory","newElement","undefined","newElementId","generateElementId","key","manifest","Error","ComponentManifestToAstConverter"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { ElementFactory } from "./ElementFactory.js";
|
|
3
|
+
import { DocumentOperations } from "./documentOperations/index.js";
|
|
4
|
+
const components = {
|
|
5
|
+
"Webiny/Root": {
|
|
6
|
+
name: "Webiny/Root",
|
|
7
|
+
label: "Main Content",
|
|
8
|
+
tags: [],
|
|
9
|
+
inputs: [
|
|
10
|
+
{
|
|
11
|
+
type: "slot",
|
|
12
|
+
list: true,
|
|
13
|
+
renderer: "Webiny/Slot",
|
|
14
|
+
defaultValue: [],
|
|
15
|
+
name: "children"
|
|
16
|
+
}
|
|
17
|
+
]
|
|
18
|
+
},
|
|
19
|
+
"FunnelBuilder/Funnel": {
|
|
20
|
+
name: "FunnelBuilder/Funnel",
|
|
21
|
+
label: "Funnel",
|
|
22
|
+
tags: [],
|
|
23
|
+
inputs: [
|
|
24
|
+
{
|
|
25
|
+
type: "object",
|
|
26
|
+
renderer: "Webiny/Object",
|
|
27
|
+
name: "fields",
|
|
28
|
+
list: true,
|
|
29
|
+
fields: [],
|
|
30
|
+
defaultValue: []
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
type: "number",
|
|
34
|
+
renderer: "Webiny/Number",
|
|
35
|
+
name: "activeStep",
|
|
36
|
+
label: "Active Step",
|
|
37
|
+
defaultValue: 0
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
type: "slot",
|
|
41
|
+
list: true,
|
|
42
|
+
renderer: "Webiny/Slot",
|
|
43
|
+
defaultValue: [],
|
|
44
|
+
name: "steps"
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
type: "object",
|
|
48
|
+
renderer: "FunnelBuilder/ConditionRulesRenderer",
|
|
49
|
+
name: "conditionRules",
|
|
50
|
+
list: true,
|
|
51
|
+
fields: []
|
|
52
|
+
}
|
|
53
|
+
]
|
|
54
|
+
},
|
|
55
|
+
"FunnelBuilder/Step": {
|
|
56
|
+
name: "FunnelBuilder/Step",
|
|
57
|
+
label: "Funnel Step",
|
|
58
|
+
tags: [],
|
|
59
|
+
inputs: [
|
|
60
|
+
{
|
|
61
|
+
type: "text",
|
|
62
|
+
renderer: "Webiny/Input",
|
|
63
|
+
name: "label",
|
|
64
|
+
label: "Label"
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
type: "slot",
|
|
68
|
+
list: true,
|
|
69
|
+
renderer: "Webiny/Slot",
|
|
70
|
+
defaultValue: [],
|
|
71
|
+
name: "children"
|
|
72
|
+
}
|
|
73
|
+
]
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
function serializeOp(op) {
|
|
77
|
+
if (op instanceof DocumentOperations.AddElement) return {
|
|
78
|
+
type: "AddElement",
|
|
79
|
+
element: op["element"]
|
|
80
|
+
};
|
|
81
|
+
if (op instanceof DocumentOperations.AddToParent) return {
|
|
82
|
+
type: "AddToParent",
|
|
83
|
+
element: op["element"],
|
|
84
|
+
index: op["index"]
|
|
85
|
+
};
|
|
86
|
+
if (op instanceof DocumentOperations.SetGlobalInputBinding) return {
|
|
87
|
+
type: "SetGlobalInputBinding",
|
|
88
|
+
elementId: op["elementId"],
|
|
89
|
+
bindingPath: op["bindingPath"],
|
|
90
|
+
binding: op["binding"]
|
|
91
|
+
};
|
|
92
|
+
if (op instanceof DocumentOperations.SetGlobalStyleBinding) return {
|
|
93
|
+
type: "SetGlobalStyleBinding",
|
|
94
|
+
elementId: op["elementId"],
|
|
95
|
+
bindingPath: op["bindingPath"],
|
|
96
|
+
binding: op["binding"]
|
|
97
|
+
};
|
|
98
|
+
return op;
|
|
99
|
+
}
|
|
100
|
+
describe("ElementFactory", ()=>{
|
|
101
|
+
it("should produce correct operation sequence for a Funnel with two Steps", ()=>{
|
|
102
|
+
const factory = new ElementFactory(components);
|
|
103
|
+
const result = factory.createElementFromComponent({
|
|
104
|
+
componentName: "FunnelBuilder/Funnel",
|
|
105
|
+
parentId: "root",
|
|
106
|
+
slot: "children",
|
|
107
|
+
index: 0,
|
|
108
|
+
bindings: {
|
|
109
|
+
inputs: {
|
|
110
|
+
fields: [],
|
|
111
|
+
activeStep: 0,
|
|
112
|
+
steps: [
|
|
113
|
+
{
|
|
114
|
+
action: "CreateElement",
|
|
115
|
+
params: {
|
|
116
|
+
component: "FunnelBuilder/Step",
|
|
117
|
+
inputs: {
|
|
118
|
+
label: "Step 1",
|
|
119
|
+
children: []
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
{
|
|
124
|
+
action: "CreateElement",
|
|
125
|
+
params: {
|
|
126
|
+
component: "FunnelBuilder/Step",
|
|
127
|
+
inputs: {
|
|
128
|
+
label: "Final Step",
|
|
129
|
+
children: []
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
]
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
const ops = result.operations.map(serializeOp);
|
|
138
|
+
const funnelId = result.element.id;
|
|
139
|
+
expect(ops[0].type).toBe("AddElement");
|
|
140
|
+
expect(ops[0].element.component.name).toBe("FunnelBuilder/Funnel");
|
|
141
|
+
expect(ops[1].type).toBe("AddToParent");
|
|
142
|
+
expect(ops[1].element.id).toBe(funnelId);
|
|
143
|
+
expect(ops[1].index).toBe(0);
|
|
144
|
+
expect(ops[2].type).toBe("SetGlobalInputBinding");
|
|
145
|
+
expect(ops[2].elementId).toBe(funnelId);
|
|
146
|
+
expect(ops[2].bindingPath).toBe("activeStep");
|
|
147
|
+
expect(ops[2].binding.static).toBe(0);
|
|
148
|
+
const step1Id = ops[3].element.id;
|
|
149
|
+
expect(ops[3].type).toBe("AddElement");
|
|
150
|
+
expect(ops[3].element.component.name).toBe("FunnelBuilder/Step");
|
|
151
|
+
expect(ops[3].element.parent).toEqual({
|
|
152
|
+
id: funnelId,
|
|
153
|
+
slot: "steps"
|
|
154
|
+
});
|
|
155
|
+
expect(ops[4].type).toBe("AddToParent");
|
|
156
|
+
expect(ops[4].element.id).toBe(step1Id);
|
|
157
|
+
expect(ops[4].index).toBeUndefined();
|
|
158
|
+
expect(ops[5].bindingPath).toBe("label");
|
|
159
|
+
expect(ops[5].binding.static).toBe("Step 1");
|
|
160
|
+
expect(ops[6].bindingPath).toBe("children");
|
|
161
|
+
expect(ops[6].binding.static).toEqual([]);
|
|
162
|
+
expect(ops[7].bindingPath).toBe("display");
|
|
163
|
+
expect(ops[8].bindingPath).toBe("flexDirection");
|
|
164
|
+
expect(ops[9].type).toBe("SetGlobalInputBinding");
|
|
165
|
+
expect(ops[9].elementId).toBe(funnelId);
|
|
166
|
+
expect(ops[9].bindingPath).toBe("steps");
|
|
167
|
+
expect(ops[9].binding.static).toBeUndefined();
|
|
168
|
+
expect(ops[9].binding.type).toBe("slot");
|
|
169
|
+
expect(ops[9].binding.list).toBe(true);
|
|
170
|
+
expect(ops[10].element.component.name).toBe("FunnelBuilder/Step");
|
|
171
|
+
expect(ops[11].index).toBeUndefined();
|
|
172
|
+
expect(ops[12].binding.static).toBe("Final Step");
|
|
173
|
+
expect(ops[13].binding.static).toEqual([]);
|
|
174
|
+
expect(ops[16].type).toBe("SetGlobalInputBinding");
|
|
175
|
+
expect(ops[16].elementId).toBe(funnelId);
|
|
176
|
+
expect(ops[16].bindingPath).toBe("steps");
|
|
177
|
+
expect(ops[16].binding.static).toBeUndefined();
|
|
178
|
+
expect(ops[17].bindingPath).toBe("display");
|
|
179
|
+
expect(ops[18].bindingPath).toBe("flexDirection");
|
|
180
|
+
expect(ops).toHaveLength(19);
|
|
181
|
+
});
|
|
182
|
+
it("should produce correct document after applying all operations", ()=>{
|
|
183
|
+
const factory = new ElementFactory(components);
|
|
184
|
+
const result = factory.createElementFromComponent({
|
|
185
|
+
componentName: "FunnelBuilder/Funnel",
|
|
186
|
+
parentId: "root",
|
|
187
|
+
slot: "children",
|
|
188
|
+
index: 0,
|
|
189
|
+
bindings: {
|
|
190
|
+
inputs: {
|
|
191
|
+
fields: [],
|
|
192
|
+
activeStep: 0,
|
|
193
|
+
steps: [
|
|
194
|
+
{
|
|
195
|
+
action: "CreateElement",
|
|
196
|
+
params: {
|
|
197
|
+
component: "FunnelBuilder/Step",
|
|
198
|
+
inputs: {
|
|
199
|
+
label: "Step 1",
|
|
200
|
+
children: []
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
action: "CreateElement",
|
|
206
|
+
params: {
|
|
207
|
+
component: "FunnelBuilder/Step",
|
|
208
|
+
inputs: {
|
|
209
|
+
label: "Final Step",
|
|
210
|
+
children: []
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
]
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
const document = {
|
|
219
|
+
state: {},
|
|
220
|
+
elements: {
|
|
221
|
+
root: {
|
|
222
|
+
type: "Webiny/Element",
|
|
223
|
+
id: "root",
|
|
224
|
+
component: {
|
|
225
|
+
name: "Webiny/Root"
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
},
|
|
229
|
+
bindings: {}
|
|
230
|
+
};
|
|
231
|
+
for (const op of result.operations)op.apply(document);
|
|
232
|
+
const funnelId = result.element.id;
|
|
233
|
+
const stepElements = Object.values(document.elements).filter((el)=>"FunnelBuilder/Step" === el.component.name);
|
|
234
|
+
expect(stepElements).toHaveLength(2);
|
|
235
|
+
const labels = stepElements.map((el)=>document.bindings[el.id]?.inputs?.label?.static);
|
|
236
|
+
expect(labels).toContain("Step 1");
|
|
237
|
+
expect(labels).toContain("Final Step");
|
|
238
|
+
const stepsBinding = document.bindings[funnelId]?.inputs?.steps;
|
|
239
|
+
expect(stepsBinding?.list).toBe(true);
|
|
240
|
+
expect(stepsBinding?.type).toBe("slot");
|
|
241
|
+
expect(stepsBinding?.static).toHaveLength(2);
|
|
242
|
+
const step1 = stepElements.find((el)=>document.bindings[el.id]?.inputs?.label?.static === "Step 1");
|
|
243
|
+
const step2 = stepElements.find((el)=>document.bindings[el.id]?.inputs?.label?.static === "Final Step");
|
|
244
|
+
expect(stepsBinding?.static).toEqual([
|
|
245
|
+
step1.id,
|
|
246
|
+
step2.id
|
|
247
|
+
]);
|
|
248
|
+
});
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
//# sourceMappingURL=ElementFactory.test.js.map
|