@webiny/app-admin 6.3.0-beta.1 → 6.3.0-beta.3
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/base/Base/DefaultFieldRenderers.js +69 -5
- package/base/Base/DefaultFieldRenderers.js.map +1 -1
- package/base/Base/DefaultLayoutRenderers.js +5 -1
- package/base/Base/DefaultLayoutRenderers.js.map +1 -1
- package/base/Base/FieldRenderers/CheckboxesRenderer.d.ts +13 -0
- package/base/Base/FieldRenderers/CheckboxesRenderer.js +28 -0
- package/base/Base/FieldRenderers/CheckboxesRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/CodeEditorRenderer.d.ts +15 -0
- package/base/Base/FieldRenderers/CodeEditorRenderer.js +17 -0
- package/base/Base/FieldRenderers/CodeEditorRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/DateTimeInputsRenderer.d.ts +17 -0
- package/base/Base/FieldRenderers/DateTimeInputsRenderer.js +66 -0
- package/base/Base/FieldRenderers/DateTimeInputsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/DateTimeRenderer.d.ts +21 -0
- package/base/Base/FieldRenderers/DateTimeRenderer.js +46 -0
- package/base/Base/FieldRenderers/DateTimeRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/FilePickerRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/FilePickerRenderer.js +47 -0
- package/base/Base/FieldRenderers/FilePickerRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/FileUrlPickerRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/FileUrlPickerRenderer.js +25 -0
- package/base/Base/FieldRenderers/FileUrlPickerRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/HiddenRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/HiddenRenderer.js +5 -0
- package/base/Base/FieldRenderers/HiddenRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/HorizontalTabsRenderer.d.ts +5 -0
- package/base/Base/FieldRenderers/HorizontalTabsRenderer.js +27 -0
- package/base/Base/FieldRenderers/HorizontalTabsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/InputRenderer.d.ts +4 -7
- package/base/Base/FieldRenderers/InputRenderer.js +2 -2
- package/base/Base/FieldRenderers/InputRenderer.js.map +1 -1
- package/base/Base/FieldRenderers/NumberInputRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/NumberInputRenderer.js +23 -0
- package/base/Base/FieldRenderers/NumberInputRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/NumberInputsRenderer.d.ts +14 -0
- package/base/Base/FieldRenderers/NumberInputsRenderer.js +49 -0
- package/base/Base/FieldRenderers/NumberInputsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/DynamicZoneRenderer.d.ts +14 -0
- package/base/Base/FieldRenderers/ObjectRenderer/DynamicZoneRenderer.js +20 -0
- package/base/Base/FieldRenderers/ObjectRenderer/DynamicZoneRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/KeyValueTagsRenderer.d.ts +14 -0
- package/base/Base/FieldRenderers/ObjectRenderer/KeyValueTagsRenderer.js +65 -0
- package/base/Base/FieldRenderers/ObjectRenderer/KeyValueTagsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/MultiValueDynamicZone.d.ts +10 -0
- package/base/Base/FieldRenderers/ObjectRenderer/MultiValueDynamicZone.js +109 -0
- package/base/Base/FieldRenderers/ObjectRenderer/MultiValueDynamicZone.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectAccordionMultipleRenderer.d.ts +17 -0
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectAccordionMultipleRenderer.js +55 -0
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectAccordionMultipleRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectFieldComponents.d.ts +7 -3
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectFieldComponents.js +15 -19
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectFieldComponents.js.map +1 -1
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectRenderer.d.ts +5 -8
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectRenderer.js +7 -50
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectRenderer.js.map +1 -1
- package/base/Base/FieldRenderers/ObjectRenderer/SingleValueDynamicZone.d.ts +10 -0
- package/base/Base/FieldRenderers/ObjectRenderer/SingleValueDynamicZone.js +64 -0
- package/base/Base/FieldRenderers/ObjectRenderer/SingleValueDynamicZone.js.map +1 -0
- package/base/Base/FieldRenderers/ObjectRenderer/TemplatePicker.d.ts +10 -0
- package/base/Base/FieldRenderers/ObjectRenderer/TemplatePicker.js +85 -0
- package/base/Base/FieldRenderers/ObjectRenderer/TemplatePicker.js.map +1 -0
- package/base/Base/FieldRenderers/PassthroughRenderer.d.ts +3 -6
- package/base/Base/FieldRenderers/PassthroughRenderer.js +9 -23
- package/base/Base/FieldRenderers/PassthroughRenderer.js.map +1 -1
- package/base/Base/FieldRenderers/RadioButtonsRenderer.d.ts +13 -0
- package/base/Base/FieldRenderers/RadioButtonsRenderer.js +27 -0
- package/base/Base/FieldRenderers/RadioButtonsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/SelectRenderer.d.ts +6 -8
- package/base/Base/FieldRenderers/SelectRenderer.js +8 -5
- package/base/Base/FieldRenderers/SelectRenderer.js.map +1 -1
- package/base/Base/FieldRenderers/SwitchRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/SwitchRenderer.js +19 -0
- package/base/Base/FieldRenderers/SwitchRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/TagsRenderer.d.ts +12 -0
- package/base/Base/FieldRenderers/TagsRenderer.js +21 -0
- package/base/Base/FieldRenderers/TagsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/TextInputsRenderer.d.ts +14 -0
- package/base/Base/FieldRenderers/TextInputsRenderer.js +48 -0
- package/base/Base/FieldRenderers/TextInputsRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/TextareaRenderer.d.ts +3 -6
- package/base/Base/FieldRenderers/TextareaRenderer.js +3 -4
- package/base/Base/FieldRenderers/TextareaRenderer.js.map +1 -1
- package/base/Base/FieldRenderers/TextareasRenderer.d.ts +14 -0
- package/base/Base/FieldRenderers/TextareasRenderer.js +51 -0
- package/base/Base/FieldRenderers/TextareasRenderer.js.map +1 -0
- package/base/Base/FieldRenderers/VerticalTabsRenderer.js +2 -2
- package/base/Base/FieldRenderers/VerticalTabsRenderer.js.map +1 -1
- package/base/Base/Menus.js +5 -64
- package/base/Base/Menus.js.map +1 -1
- package/base/Base/RoutesConfig.js +6 -0
- package/base/Base/RoutesConfig.js.map +1 -1
- package/exports/admin/build-params.d.ts +2 -0
- package/exports/admin/build-params.js +3 -0
- package/exports/admin/build-params.js.map +1 -1
- package/exports/admin/form.d.ts +5 -0
- package/exports/admin/form.js +8 -0
- package/exports/admin/form.js.map +1 -1
- package/exports/admin/ui.d.ts +1 -0
- package/exports/admin/ui.js +1 -0
- package/exports/admin/ui.js.map +1 -1
- package/exports/admin.d.ts +3 -1
- package/exports/admin.js +3 -1
- package/exports/admin.js.map +1 -1
- package/features/formModel/ConditionRuleEvaluator.d.ts +9 -0
- package/features/formModel/ConditionRuleEvaluator.js +56 -0
- package/features/formModel/ConditionRuleEvaluator.js.map +1 -0
- package/features/formModel/Field.d.ts +50 -4
- package/features/formModel/Field.js +254 -35
- package/features/formModel/Field.js.map +1 -1
- package/features/formModel/FieldBuilder.d.ts +17 -35
- package/features/formModel/FieldBuilder.js +63 -100
- package/features/formModel/FieldBuilder.js.map +1 -1
- package/features/formModel/FieldBuilder.test.js +127 -13
- package/features/formModel/FieldBuilder.test.js.map +1 -1
- package/features/formModel/FieldBuilderRegistry.d.ts +4 -0
- package/features/formModel/FieldBuilderRegistry.js +31 -0
- package/features/formModel/FieldBuilderRegistry.js.map +1 -0
- package/features/formModel/FocusManager.d.ts +14 -0
- package/features/formModel/FocusManager.js +109 -0
- package/features/formModel/FocusManager.js.map +1 -0
- package/features/formModel/FormModel.d.ts +27 -31
- package/features/formModel/FormModel.js +210 -403
- package/features/formModel/FormModel.js.map +1 -1
- package/features/formModel/FormModel.test.js +2044 -193
- package/features/formModel/FormModel.test.js.map +1 -1
- package/features/formModel/FormModelFactory.d.ts +4 -2
- package/features/formModel/FormModelFactory.js +13 -3
- package/features/formModel/FormModelFactory.js.map +1 -1
- package/features/formModel/FormView.d.ts +2 -0
- package/features/formModel/FormView.js +44 -37
- package/features/formModel/FormView.js.map +1 -1
- package/features/formModel/LayoutBuilderFactory.d.ts +61 -0
- package/features/formModel/LayoutBuilderFactory.js +386 -0
- package/features/formModel/LayoutBuilderFactory.js.map +1 -0
- package/features/formModel/LayoutMutator.d.ts +11 -0
- package/features/formModel/LayoutMutator.js +136 -0
- package/features/formModel/LayoutMutator.js.map +1 -0
- package/features/formModel/LayoutResolver.d.ts +26 -0
- package/features/formModel/LayoutResolver.js +239 -0
- package/features/formModel/LayoutResolver.js.map +1 -0
- package/features/formModel/ObjectField.d.ts +55 -4
- package/features/formModel/ObjectField.js +499 -82
- package/features/formModel/ObjectField.js.map +1 -1
- package/features/formModel/Rules.test.d.ts +1 -0
- package/features/formModel/Rules.test.js +289 -0
- package/features/formModel/Rules.test.js.map +1 -0
- package/features/formModel/abstractions.d.ts +402 -52
- package/features/formModel/abstractions.js +55 -0
- package/features/formModel/abstractions.js.map +1 -1
- package/features/formModel/createFieldRenderer.d.ts +20 -0
- package/features/formModel/createFieldRenderer.js +15 -0
- package/features/formModel/createFieldRenderer.js.map +1 -0
- package/features/formModel/demo/FieldRenderersDemoPresenter.d.ts +18 -0
- package/features/formModel/demo/FieldRenderersDemoPresenter.js +225 -0
- package/features/formModel/demo/FieldRenderersDemoPresenter.js.map +1 -0
- package/features/formModel/demo/FormModelDemo.d.ts +4 -0
- package/features/formModel/demo/FormModelDemo.js +230 -0
- package/features/formModel/demo/FormModelDemo.js.map +1 -0
- package/features/formModel/demo/FormModelDemoPresenter.d.ts +22 -0
- package/features/formModel/demo/FormModelDemoPresenter.js +121 -0
- package/features/formModel/demo/FormModelDemoPresenter.js.map +1 -0
- package/features/formModel/demo/FormModelPhase11Presenter.d.ts +25 -0
- package/features/formModel/demo/FormModelPhase11Presenter.js +104 -0
- package/features/formModel/demo/FormModelPhase11Presenter.js.map +1 -0
- package/features/formModel/demo/FormModelPhase8c1Presenter.d.ts +23 -0
- package/features/formModel/demo/FormModelPhase8c1Presenter.js +62 -0
- package/features/formModel/demo/FormModelPhase8c1Presenter.js.map +1 -0
- package/features/formModel/feature.js +12 -0
- package/features/formModel/feature.js.map +1 -1
- package/features/formModel/fieldTypes/BooleanFieldType.d.ts +19 -0
- package/features/formModel/fieldTypes/BooleanFieldType.js +23 -0
- package/features/formModel/fieldTypes/BooleanFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/DateTimeFieldType.d.ts +173 -0
- package/features/formModel/fieldTypes/DateTimeFieldType.js +369 -0
- package/features/formModel/fieldTypes/DateTimeFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/FileFieldType.d.ts +18 -0
- package/features/formModel/fieldTypes/FileFieldType.js +20 -0
- package/features/formModel/fieldTypes/FileFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/FileUrlFieldType.d.ts +18 -0
- package/features/formModel/fieldTypes/FileUrlFieldType.js +20 -0
- package/features/formModel/fieldTypes/FileUrlFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/NumberFieldType.d.ts +19 -0
- package/features/formModel/fieldTypes/NumberFieldType.js +27 -0
- package/features/formModel/fieldTypes/NumberFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/ObjectFieldType.d.ts +34 -0
- package/features/formModel/fieldTypes/ObjectFieldType.js +109 -0
- package/features/formModel/fieldTypes/ObjectFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/TextFieldType.d.ts +18 -0
- package/features/formModel/fieldTypes/TextFieldType.js +20 -0
- package/features/formModel/fieldTypes/TextFieldType.js.map +1 -0
- package/features/formModel/fieldTypes/index.d.ts +7 -0
- package/features/formModel/fieldTypes/index.js +9 -0
- package/features/formModel/fieldTypes/index.js.map +1 -0
- package/features/formModel/index.d.ts +13 -4
- package/features/formModel/index.js +21 -2
- package/features/formModel/index.js.map +1 -1
- package/features/formModel/renderers.d.ts +15 -1
- package/features/formModel/renderers.js +15 -1
- package/features/formModel/renderers.js.map +1 -1
- package/features/tools/LexicalContext/LexicalContext.d.ts +14 -0
- package/features/tools/LexicalContext/LexicalContext.js +22 -0
- package/features/tools/LexicalContext/LexicalContext.js.map +1 -0
- package/features/tools/LexicalContext/abstractions.d.ts +11 -0
- package/features/tools/LexicalContext/abstractions.js +4 -0
- package/features/tools/LexicalContext/abstractions.js.map +1 -0
- package/features/tools/LexicalContext/index.d.ts +2 -0
- package/features/tools/LexicalContext/index.js +3 -0
- package/features/tools/LexicalContext/index.js.map +1 -0
- package/features/tools/feature.js +2 -0
- package/features/tools/feature.js.map +1 -1
- package/features/tools/index.d.ts +1 -0
- package/features/tools/index.js +1 -0
- package/features/tools/index.js.map +1 -1
- package/index.d.ts +8 -1
- package/index.js +7 -0
- package/index.js.map +1 -1
- package/package.json +31 -25
- package/presentation/installation/components/SystemInstaller/steps/AdminUserStep/createPasswordValidator.js +1 -1
- package/presentation/installation/components/SystemInstaller/steps/AdminUserStep/createPasswordValidator.js.map +1 -1
- package/presentation/lexicalContext/useLexicalContext.d.ts +3 -0
- package/presentation/lexicalContext/useLexicalContext.js +14 -0
- package/presentation/lexicalContext/useLexicalContext.js.map +1 -0
- package/presentation/textToLexicalTool/TextToLexicalTool.d.ts +3 -0
- package/presentation/textToLexicalTool/TextToLexicalTool.js +6 -2
- package/presentation/textToLexicalTool/TextToLexicalTool.js.map +1 -1
- package/presentation/textToLexicalTool/textToLexicalState.d.ts +2 -1
- package/presentation/textToLexicalTool/textToLexicalState.js +15 -3
- package/presentation/textToLexicalTool/textToLexicalState.js.map +1 -1
- package/routes.d.ts +1 -0
- package/routes.js +4 -0
- package/routes.js.map +1 -1
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectListFlatRenderer.d.ts +0 -21
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectListFlatRenderer.js +0 -28
- package/base/Base/FieldRenderers/ObjectRenderer/ObjectListFlatRenderer.js.map +0 -1
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
import { runInAction } from "mobx";
|
|
2
|
+
import { isObjectField } from "./ObjectField.js";
|
|
3
|
+
import { LayoutBuilderFactory } from "./LayoutBuilderFactory.js";
|
|
4
|
+
export class LayoutResolver {
|
|
5
|
+
constructor(_fields, _activeTabs, _evaluateRules) {
|
|
6
|
+
this._fields = _fields;
|
|
7
|
+
this._activeTabs = _activeTabs;
|
|
8
|
+
this._evaluateRules = _evaluateRules;
|
|
9
|
+
}
|
|
10
|
+
resolve(layout) {
|
|
11
|
+
return layout.map(node => this.resolveNode(node)).filter(Boolean);
|
|
12
|
+
}
|
|
13
|
+
resolveChildLayout(layout, children) {
|
|
14
|
+
return layout.map(node => this.resolveChildNode(node, children)).filter(Boolean);
|
|
15
|
+
}
|
|
16
|
+
collectFieldIds(layout) {
|
|
17
|
+
return LayoutBuilderFactory.collectFieldIds(layout);
|
|
18
|
+
}
|
|
19
|
+
resolveNode(node) {
|
|
20
|
+
switch (node.type) {
|
|
21
|
+
case "row":
|
|
22
|
+
return this.resolveRowNode(node);
|
|
23
|
+
case "separator":
|
|
24
|
+
return this.resolveSeparatorNode();
|
|
25
|
+
case "tabs":
|
|
26
|
+
return this.resolveTabsNode(node);
|
|
27
|
+
case "element":
|
|
28
|
+
return this.resolveElementNode(node);
|
|
29
|
+
case "object":
|
|
30
|
+
return this.resolveObjectNode(node);
|
|
31
|
+
default:
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
resolveRowNode(node) {
|
|
36
|
+
const fields = node.fieldIds.map(id => this._fields.get(id)).filter(f => f !== undefined && f.visible).map(f => f.vm);
|
|
37
|
+
if (fields.length === 0) {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
return {
|
|
41
|
+
type: "row",
|
|
42
|
+
fields
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
resolveSeparatorNode() {
|
|
46
|
+
return {
|
|
47
|
+
type: "separator"
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
resolveTabsNode(node) {
|
|
51
|
+
if (node.tabs.length === 0) {
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
const containerState = this._evaluateRules(node.rules);
|
|
55
|
+
if (!containerState.visible) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
const tabKey = node.id || LayoutBuilderFactory.tabsNodeKey(node);
|
|
59
|
+
const tabs = [];
|
|
60
|
+
for (const tab of node.tabs) {
|
|
61
|
+
const tabState = this._evaluateRules(tab.rules);
|
|
62
|
+
if (!tabState.visible) {
|
|
63
|
+
continue;
|
|
64
|
+
}
|
|
65
|
+
tabs.push({
|
|
66
|
+
id: tab.id,
|
|
67
|
+
label: tab.label,
|
|
68
|
+
description: tab.description,
|
|
69
|
+
icon: tab.icon,
|
|
70
|
+
hasErrors: this.tabHasErrors(tab.layout),
|
|
71
|
+
disabled: containerState.disabled || tabState.disabled,
|
|
72
|
+
layout: tab.layout.map(child => this.resolveNode(child)).filter(Boolean)
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
if (tabs.length === 0) {
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
const storedActive = this._activeTabs.get(tabKey);
|
|
79
|
+
const validActive = tabs.find(t => t.id === storedActive) ? storedActive : tabs[0].id;
|
|
80
|
+
return {
|
|
81
|
+
type: "tabs",
|
|
82
|
+
id: node.id,
|
|
83
|
+
renderer: node.renderer,
|
|
84
|
+
tabs,
|
|
85
|
+
disabled: containerState.disabled,
|
|
86
|
+
activeTabId: validActive,
|
|
87
|
+
setActiveTab: id => {
|
|
88
|
+
runInAction(() => {
|
|
89
|
+
this._activeTabs.set(tabKey, id);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
resolveElementNode(node) {
|
|
95
|
+
return {
|
|
96
|
+
type: "element",
|
|
97
|
+
renderer: node.renderer,
|
|
98
|
+
props: node.props
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
resolveObjectNode(node) {
|
|
102
|
+
const field = this._fields.get(node.fieldName);
|
|
103
|
+
if (!field || !field.visible) {
|
|
104
|
+
return null;
|
|
105
|
+
}
|
|
106
|
+
return {
|
|
107
|
+
type: "row",
|
|
108
|
+
fields: [field.vm]
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
resolveChildNode(node, children) {
|
|
112
|
+
switch (node.type) {
|
|
113
|
+
case "row":
|
|
114
|
+
{
|
|
115
|
+
const fields = node.fieldIds.map(id => children.get(id)).filter(f => f !== undefined && f.visible).map(f => f.vm);
|
|
116
|
+
if (fields.length === 0) {
|
|
117
|
+
return null;
|
|
118
|
+
}
|
|
119
|
+
return {
|
|
120
|
+
type: "row",
|
|
121
|
+
fields
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
case "separator":
|
|
125
|
+
return {
|
|
126
|
+
type: "separator"
|
|
127
|
+
};
|
|
128
|
+
case "element":
|
|
129
|
+
return this.resolveElementNode(node);
|
|
130
|
+
case "object":
|
|
131
|
+
{
|
|
132
|
+
const field = children.get(node.fieldName);
|
|
133
|
+
if (!field || !field.visible) {
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
return {
|
|
137
|
+
type: "row",
|
|
138
|
+
fields: [field.vm]
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
case "tabs":
|
|
142
|
+
return this.resolveChildTabsNode(node, children);
|
|
143
|
+
default:
|
|
144
|
+
return null;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
resolveChildTabsNode(node, children) {
|
|
148
|
+
if (node.tabs.length === 0) {
|
|
149
|
+
return null;
|
|
150
|
+
}
|
|
151
|
+
const containerState = this._evaluateRules(node.rules);
|
|
152
|
+
if (!containerState.visible) {
|
|
153
|
+
return null;
|
|
154
|
+
}
|
|
155
|
+
const tabKey = node.id || LayoutBuilderFactory.tabsNodeKey(node);
|
|
156
|
+
const tabs = [];
|
|
157
|
+
for (const tab of node.tabs) {
|
|
158
|
+
const tabState = this._evaluateRules(tab.rules);
|
|
159
|
+
if (!tabState.visible) {
|
|
160
|
+
continue;
|
|
161
|
+
}
|
|
162
|
+
tabs.push({
|
|
163
|
+
id: tab.id,
|
|
164
|
+
label: tab.label,
|
|
165
|
+
description: tab.description,
|
|
166
|
+
icon: tab.icon,
|
|
167
|
+
hasErrors: this.childTabHasErrors(tab.layout, children),
|
|
168
|
+
disabled: containerState.disabled || tabState.disabled,
|
|
169
|
+
layout: tab.layout.map(child => this.resolveChildNode(child, children)).filter(Boolean)
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
if (tabs.length === 0) {
|
|
173
|
+
return null;
|
|
174
|
+
}
|
|
175
|
+
const storedActive = this._activeTabs.get(tabKey);
|
|
176
|
+
const validActive = tabs.find(t => t.id === storedActive) ? storedActive : tabs[0].id;
|
|
177
|
+
return {
|
|
178
|
+
type: "tabs",
|
|
179
|
+
id: node.id,
|
|
180
|
+
renderer: node.renderer,
|
|
181
|
+
tabs,
|
|
182
|
+
disabled: containerState.disabled,
|
|
183
|
+
activeTabId: validActive,
|
|
184
|
+
setActiveTab: id => {
|
|
185
|
+
runInAction(() => {
|
|
186
|
+
this._activeTabs.set(tabKey, id);
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
tabHasErrors(layout) {
|
|
192
|
+
const fieldIds = this.collectFieldIds(layout);
|
|
193
|
+
for (const id of fieldIds) {
|
|
194
|
+
const field = this._fields.get(id);
|
|
195
|
+
if (!field) {
|
|
196
|
+
continue;
|
|
197
|
+
}
|
|
198
|
+
if (field.vm.validation.isValid === false) {
|
|
199
|
+
return true;
|
|
200
|
+
}
|
|
201
|
+
if (isObjectField(field) && field.hasErrors) {
|
|
202
|
+
return true;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
return false;
|
|
206
|
+
}
|
|
207
|
+
childTabHasErrors(layout, children) {
|
|
208
|
+
for (const node of layout) {
|
|
209
|
+
if (node.type === "row") {
|
|
210
|
+
for (const id of node.fieldIds) {
|
|
211
|
+
const field = children.get(id);
|
|
212
|
+
if (!field) {
|
|
213
|
+
continue;
|
|
214
|
+
}
|
|
215
|
+
if (field.vm.validation.isValid === false) {
|
|
216
|
+
return true;
|
|
217
|
+
}
|
|
218
|
+
if (isObjectField(field) && field.hasErrors) {
|
|
219
|
+
return true;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
} else if (node.type === "object") {
|
|
223
|
+
const field = children.get(node.fieldName);
|
|
224
|
+
if (field && isObjectField(field) && field.hasErrors) {
|
|
225
|
+
return true;
|
|
226
|
+
}
|
|
227
|
+
} else if (node.type === "tabs") {
|
|
228
|
+
for (const tab of node.tabs) {
|
|
229
|
+
if (this.childTabHasErrors(tab.layout, children)) {
|
|
230
|
+
return true;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return false;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
//# sourceMappingURL=LayoutResolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["runInAction","isObjectField","LayoutBuilderFactory","LayoutResolver","constructor","_fields","_activeTabs","_evaluateRules","resolve","layout","map","node","resolveNode","filter","Boolean","resolveChildLayout","children","resolveChildNode","collectFieldIds","type","resolveRowNode","resolveSeparatorNode","resolveTabsNode","resolveElementNode","resolveObjectNode","fields","fieldIds","id","get","f","undefined","visible","vm","length","tabs","containerState","rules","tabKey","tabsNodeKey","tab","tabState","push","label","description","icon","hasErrors","tabHasErrors","disabled","child","storedActive","validActive","find","t","renderer","activeTabId","setActiveTab","set","props","field","fieldName","resolveChildTabsNode","childTabHasErrors","validation","isValid"],"sources":["LayoutResolver.ts"],"sourcesContent":["import { runInAction } from \"mobx\";\nimport type { ObservableMap } from \"mobx\";\nimport { isObjectField } from \"./ObjectField.js\";\nimport { LayoutBuilderFactory } from \"./LayoutBuilderFactory.js\";\nimport type {\n IField,\n IRule,\n LayoutNode,\n LayoutNodeVM,\n IRowNode,\n IRowNodeVM,\n ISeparatorNodeVM,\n ITabsNode,\n ITabsNodeVM,\n ITabDefinitionVM,\n IElementNode,\n IElementNodeVM,\n IObjectNode\n} from \"./abstractions.js\";\n\ntype RuleEvaluatorFn = (rules: IRule[] | undefined) => { visible: boolean; disabled: boolean };\n\nexport class LayoutResolver {\n constructor(\n private _fields: Map<string, IField>,\n private _activeTabs: ObservableMap<string, string>,\n private _evaluateRules: RuleEvaluatorFn\n ) {}\n\n resolve(layout: LayoutNode[]): LayoutNodeVM[] {\n return layout.map(node => this.resolveNode(node)).filter(Boolean) as LayoutNodeVM[];\n }\n\n resolveChildLayout(layout: LayoutNode[], children: Map<string, IField>): LayoutNodeVM[] {\n return layout\n .map(node => this.resolveChildNode(node, children))\n .filter(Boolean) as LayoutNodeVM[];\n }\n\n collectFieldIds(layout: LayoutNode[]): string[] {\n return LayoutBuilderFactory.collectFieldIds(layout);\n }\n\n private resolveNode(node: LayoutNode): LayoutNodeVM | null {\n switch (node.type) {\n case \"row\":\n return this.resolveRowNode(node);\n case \"separator\":\n return this.resolveSeparatorNode();\n case \"tabs\":\n return this.resolveTabsNode(node);\n case \"element\":\n return this.resolveElementNode(node);\n case \"object\":\n return this.resolveObjectNode(node);\n default:\n return null;\n }\n }\n\n private resolveRowNode(node: IRowNode): IRowNodeVM | null {\n const fields = node.fieldIds\n .map(id => this._fields.get(id))\n .filter((f): f is IField => f !== undefined && f.visible)\n .map(f => f.vm);\n\n if (fields.length === 0) {\n return null;\n }\n\n return { type: \"row\", fields };\n }\n\n private resolveSeparatorNode(): ISeparatorNodeVM {\n return { type: \"separator\" };\n }\n\n private resolveTabsNode(node: ITabsNode): ITabsNodeVM | null {\n if (node.tabs.length === 0) {\n return null;\n }\n\n const containerState = this._evaluateRules(node.rules);\n if (!containerState.visible) {\n return null;\n }\n\n const tabKey = node.id || LayoutBuilderFactory.tabsNodeKey(node);\n\n const tabs: ITabDefinitionVM[] = [];\n for (const tab of node.tabs) {\n const tabState = this._evaluateRules(tab.rules);\n if (!tabState.visible) {\n continue;\n }\n tabs.push({\n id: tab.id,\n label: tab.label,\n description: tab.description,\n icon: tab.icon,\n hasErrors: this.tabHasErrors(tab.layout),\n disabled: containerState.disabled || tabState.disabled,\n layout: tab.layout\n .map(child => this.resolveNode(child))\n .filter(Boolean) as LayoutNodeVM[]\n });\n }\n\n if (tabs.length === 0) {\n return null;\n }\n\n const storedActive = this._activeTabs.get(tabKey);\n const validActive = tabs.find(t => t.id === storedActive) ? storedActive! : tabs[0].id;\n\n return {\n type: \"tabs\",\n id: node.id,\n renderer: node.renderer,\n tabs,\n disabled: containerState.disabled,\n activeTabId: validActive,\n setActiveTab: (id: string) => {\n runInAction(() => {\n this._activeTabs.set(tabKey, id);\n });\n }\n };\n }\n\n private resolveElementNode(node: IElementNode): IElementNodeVM {\n return {\n type: \"element\",\n renderer: node.renderer,\n props: node.props\n };\n }\n\n private resolveObjectNode(node: IObjectNode): IRowNodeVM | null {\n const field = this._fields.get(node.fieldName);\n if (!field || !field.visible) {\n return null;\n }\n return { type: \"row\", fields: [field.vm] };\n }\n\n private resolveChildNode(node: LayoutNode, children: Map<string, IField>): LayoutNodeVM | null {\n switch (node.type) {\n case \"row\": {\n const fields = node.fieldIds\n .map(id => children.get(id))\n .filter((f): f is IField => f !== undefined && f.visible)\n .map(f => f.vm);\n if (fields.length === 0) {\n return null;\n }\n return { type: \"row\", fields };\n }\n case \"separator\":\n return { type: \"separator\" };\n case \"element\":\n return this.resolveElementNode(node);\n case \"object\": {\n const field = children.get(node.fieldName);\n if (!field || !field.visible) {\n return null;\n }\n return { type: \"row\", fields: [field.vm] };\n }\n case \"tabs\":\n return this.resolveChildTabsNode(node, children);\n default:\n return null;\n }\n }\n\n private resolveChildTabsNode(\n node: ITabsNode,\n children: Map<string, IField>\n ): ITabsNodeVM | null {\n if (node.tabs.length === 0) {\n return null;\n }\n const containerState = this._evaluateRules(node.rules);\n if (!containerState.visible) {\n return null;\n }\n const tabKey = node.id || LayoutBuilderFactory.tabsNodeKey(node);\n const tabs: ITabDefinitionVM[] = [];\n for (const tab of node.tabs) {\n const tabState = this._evaluateRules(tab.rules);\n if (!tabState.visible) {\n continue;\n }\n tabs.push({\n id: tab.id,\n label: tab.label,\n description: tab.description,\n icon: tab.icon,\n hasErrors: this.childTabHasErrors(tab.layout, children),\n disabled: containerState.disabled || tabState.disabled,\n layout: tab.layout\n .map(child => this.resolveChildNode(child, children))\n .filter(Boolean) as LayoutNodeVM[]\n });\n }\n if (tabs.length === 0) {\n return null;\n }\n const storedActive = this._activeTabs.get(tabKey);\n const validActive = tabs.find(t => t.id === storedActive) ? storedActive! : tabs[0].id;\n return {\n type: \"tabs\",\n id: node.id,\n renderer: node.renderer,\n tabs,\n disabled: containerState.disabled,\n activeTabId: validActive,\n setActiveTab: (id: string) => {\n runInAction(() => {\n this._activeTabs.set(tabKey, id);\n });\n }\n };\n }\n\n private tabHasErrors(layout: LayoutNode[]): boolean {\n const fieldIds = this.collectFieldIds(layout);\n for (const id of fieldIds) {\n const field = this._fields.get(id);\n if (!field) {\n continue;\n }\n if (field.vm.validation.isValid === false) {\n return true;\n }\n if (isObjectField(field) && field.hasErrors) {\n return true;\n }\n }\n return false;\n }\n\n private childTabHasErrors(layout: LayoutNode[], children: Map<string, IField>): boolean {\n for (const node of layout) {\n if (node.type === \"row\") {\n for (const id of node.fieldIds) {\n const field = children.get(id);\n if (!field) {\n continue;\n }\n if (field.vm.validation.isValid === false) {\n return true;\n }\n if (isObjectField(field) && field.hasErrors) {\n return true;\n }\n }\n } else if (node.type === \"object\") {\n const field = children.get(node.fieldName);\n if (field && isObjectField(field) && field.hasErrors) {\n return true;\n }\n } else if (node.type === \"tabs\") {\n for (const tab of node.tabs) {\n if (this.childTabHasErrors(tab.layout, children)) {\n return true;\n }\n }\n }\n }\n return false;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import type { IObjectFieldConfig, IObjectField, IListItemField, IField, IObjectFieldVM, IFieldValidation, IFormModel, FieldTypeMap, BeforeChangeCallback, AfterChangeCallback, AfterSetValueCallback, OnBlurCallback } from "./abstractions.js";
|
|
1
|
+
import type { IObjectFieldConfig, IObjectField, IObjectFieldTemplates, IListItemField, IField, IObjectFieldVM, IFieldValidation, IFormModel, IFieldBuilder, IFieldBuilderRegistry, IRule, ITemplateVM, FieldTypeMap, LayoutNode, BeforeChangeCallback, AfterChangeCallback, AfterSetValueCallback, OnBlurCallback, ComputedFieldCallback } from "./abstractions.js";
|
|
2
|
+
/** Reserved key used as the template discriminator in templated object data. */
|
|
3
|
+
export declare const TEMPLATE_DISCRIMINATOR = "_templateId";
|
|
2
4
|
export declare function isObjectField(field: IField): field is ObjectField;
|
|
3
5
|
/**
|
|
4
6
|
* ObjectField — hierarchical field with children, using composition.
|
|
@@ -11,36 +13,85 @@ export declare class ObjectField implements IObjectField {
|
|
|
11
13
|
private _form;
|
|
12
14
|
private _children;
|
|
13
15
|
private _items;
|
|
16
|
+
private _templates;
|
|
17
|
+
private _isTemplated;
|
|
18
|
+
private _activeTemplateId;
|
|
19
|
+
/** Inner layout for non-templated objects (single layout, applied per item too). */
|
|
20
|
+
private _ownLayout;
|
|
21
|
+
/** Per-template inner layouts for templated objects. */
|
|
22
|
+
private _templateLayouts;
|
|
23
|
+
private _validating;
|
|
14
24
|
constructor(config: IObjectFieldConfig);
|
|
25
|
+
private _findTemplate;
|
|
26
|
+
private _rebuildChildrenForTemplate;
|
|
15
27
|
get name(): string;
|
|
16
28
|
get type(): string;
|
|
17
29
|
get visible(): boolean;
|
|
30
|
+
get disabled(): boolean;
|
|
18
31
|
setDisabled(value: boolean): void;
|
|
19
32
|
setVisible(value: boolean): void;
|
|
20
|
-
|
|
33
|
+
setAncestorRules(rules: IRule[]): void;
|
|
34
|
+
setForm(form: IFormModel, parentPath?: string): void;
|
|
21
35
|
setValidation(validation: IFieldValidation): void;
|
|
22
36
|
addBeforeChange(cb: BeforeChangeCallback): void;
|
|
23
37
|
addAfterChange(cb: AfterChangeCallback): void;
|
|
24
38
|
addAfterSetValue(cb: AfterSetValueCallback): void;
|
|
25
39
|
addOnBlur(cb: OnBlurCallback): void;
|
|
40
|
+
addRequiredWhen(fn: (form: IFormModel) => boolean, message?: string): void;
|
|
41
|
+
setComputed(fn: ComputedFieldCallback): void;
|
|
42
|
+
setComputedUntilDirty(fn: ComputedFieldCallback): void;
|
|
26
43
|
blur(): void;
|
|
27
44
|
remove(): void;
|
|
45
|
+
get qualifiedName(): string;
|
|
46
|
+
focus(): void;
|
|
47
|
+
requestFocus(): void;
|
|
48
|
+
clearFocusRequest(): void;
|
|
49
|
+
getInnerLayout(): LayoutNode[] | null;
|
|
28
50
|
get isList(): boolean;
|
|
51
|
+
get isTemplated(): boolean;
|
|
52
|
+
get activeTemplateId(): string | null;
|
|
53
|
+
get availableTemplates(): ITemplateVM[];
|
|
54
|
+
setTemplate(templateId: string): void;
|
|
55
|
+
get templates(): IObjectFieldTemplates;
|
|
56
|
+
private _addTemplate;
|
|
57
|
+
private _removeTemplate;
|
|
58
|
+
setInnerLayout(layout: LayoutNode[] | Record<string, LayoutNode[]>): void;
|
|
59
|
+
/**
|
|
60
|
+
* Walk an inner layout for nested `object` nodes and forward each one to
|
|
61
|
+
* the matching child field. The recursion bottoms out naturally: each
|
|
62
|
+
* matched child is itself an ObjectField and will run `_applyNestedObjectLayouts`
|
|
63
|
+
* against its own children whenever they materialise.
|
|
64
|
+
*/
|
|
65
|
+
private _applyNestedObjectLayouts;
|
|
66
|
+
/**
|
|
67
|
+
* Returns the inner layout that should apply to a freshly-built children
|
|
68
|
+
* Map for the given templateId (templated objects/lists) or for the
|
|
69
|
+
* non-templated case. Used to seed nested object layouts on newly-created
|
|
70
|
+
* children before they go live.
|
|
71
|
+
*/
|
|
72
|
+
private _innerLayoutFor;
|
|
73
|
+
private _resolveLayoutForChildren;
|
|
29
74
|
get children(): Map<string, IField>;
|
|
30
75
|
get items(): IListItemField[];
|
|
76
|
+
private _getItemData;
|
|
31
77
|
getChild(name: string): IField | undefined;
|
|
78
|
+
fields(factory: (registry: IFieldBuilderRegistry) => Record<string, IFieldBuilder | undefined>): void;
|
|
32
79
|
getListItemChild(index: number, name: string): IField | undefined;
|
|
33
80
|
getData(): any;
|
|
34
81
|
getValue<T = unknown>(): T;
|
|
35
82
|
setValue(value: unknown): void;
|
|
36
83
|
setValueSilent(value: unknown): void;
|
|
37
|
-
addItem(data?: Record<string, unknown>): void;
|
|
84
|
+
addItem(templateIdOrData?: string | Record<string, unknown>, data?: Record<string, unknown>): void;
|
|
38
85
|
removeItem(index: number): void;
|
|
39
86
|
moveItem(fromIndex: number, toIndex: number): void;
|
|
87
|
+
duplicateItem(index: number): void;
|
|
88
|
+
private _templateChildBuilders;
|
|
40
89
|
private _addItemInternal;
|
|
41
90
|
resetValidation(): void;
|
|
42
91
|
as<T extends keyof FieldTypeMap>(type: T): FieldTypeMap[T];
|
|
43
92
|
get vm(): IObjectFieldVM;
|
|
44
93
|
get hasErrors(): boolean;
|
|
45
|
-
validate(
|
|
94
|
+
validate(options?: {
|
|
95
|
+
force?: boolean;
|
|
96
|
+
}): Promise<boolean>;
|
|
46
97
|
}
|