cx 26.1.0 → 26.1.1
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/build/ui/Widget.js +0 -5
- package/build/util/Component.js +5 -0
- package/build/util/test/createTestRenderer.d.ts +3 -1
- package/build/util/test/createTestRenderer.js +8 -2
- package/build/widgets/icons/calendar.js +4 -3
- package/build/widgets/icons/check.js +2 -2
- package/build/widgets/icons/clear.js +2 -2
- package/build/widgets/icons/close.js +2 -2
- package/build/widgets/icons/cx.js +2 -2
- package/build/widgets/icons/drop-down.js +2 -2
- package/build/widgets/icons/file.js +2 -2
- package/build/widgets/icons/folder-open.js +2 -2
- package/build/widgets/icons/folder.js +2 -2
- package/build/widgets/icons/forward.js +2 -2
- package/build/widgets/icons/loading.js +2 -2
- package/build/widgets/icons/menu.js +2 -2
- package/build/widgets/icons/pixel-picker.js +2 -2
- package/build/widgets/icons/search.js +2 -2
- package/build/widgets/icons/sort-asc.js +2 -2
- package/build/widgets/icons/square.js +2 -2
- package/dist/manifest.js +896 -896
- package/dist/ui.js +1 -8
- package/dist/util.js +4 -0
- package/dist/widgets.js +377 -313
- package/package.json +3 -1
- package/src/core.d.ts +182 -182
- package/src/data/ArrayElementView.ts +90 -90
- package/src/data/AugmentedViewBase.ts +88 -88
- package/src/data/Binding.ts +104 -104
- package/src/data/ExposedRecordView.ts +95 -95
- package/src/data/ExposedValueView.ts +89 -89
- package/src/data/Grouper.spec.ts +57 -57
- package/src/data/NestedDataView.ts +43 -43
- package/src/data/ReadOnlyDataView.ts +39 -39
- package/src/data/Ref.ts +104 -104
- package/src/data/Store.ts +52 -52
- package/src/data/StoreProxy.ts +19 -19
- package/src/data/StoreRef.ts +66 -66
- package/src/data/StringTemplate.ts +93 -93
- package/src/data/StructuredSelector.spec.ts +113 -113
- package/src/data/SubscribableView.ts +63 -63
- package/src/data/ZoomIntoPropertyView.ts +45 -45
- package/src/data/comparer.ts +78 -78
- package/src/data/ops/updateArray.ts +31 -31
- package/src/hooks/invokeCallback.spec.tsx +4 -4
- package/src/hooks/resolveCallback.spec.tsx +4 -4
- package/src/hooks/store.spec.tsx +15 -15
- package/src/hooks/useTrigger.spec.tsx +16 -10
- package/src/jsx-dev-runtime.ts +4 -4
- package/src/jsx-runtime.ts +79 -79
- package/src/ui/CSS.ts +87 -87
- package/src/ui/ContentResolver.spec.tsx +31 -29
- package/src/ui/Controller.spec.tsx +47 -39
- package/src/ui/Cx.spec.tsx +10 -8
- package/src/ui/DataProxy.spec.tsx +18 -18
- package/src/ui/DataProxy.ts +55 -55
- package/src/ui/FocusManager.ts +171 -171
- package/src/ui/IsolatedScope.spec.tsx +16 -9
- package/src/ui/PureContainer.spec.tsx +20 -18
- package/src/ui/Repeater.spec.tsx +8 -6
- package/src/ui/Rescope.spec.tsx +13 -13
- package/src/ui/Rescope.ts +49 -49
- package/src/ui/Restate.spec.tsx +31 -27
- package/src/ui/VDOM.ts +1 -1
- package/src/ui/Widget.tsx +0 -7
- package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
- package/src/ui/createFunctionalComponent.spec.tsx +20 -18
- package/src/ui/layout/Content.ts +30 -30
- package/src/ui/layout/ContentPlaceholder.spec.tsx +46 -34
- package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +31 -19
- package/src/ui/selection/PropertySelection.ts +87 -87
- package/src/util/Component.spec.ts +30 -0
- package/src/util/Component.ts +301 -296
- package/src/util/DOM.ts +88 -88
- package/src/util/Format.spec.ts +69 -69
- package/src/util/Format.ts +267 -267
- package/src/util/addEventListenerWithOptions.ts +41 -41
- package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
- package/src/util/color/rgbToHsl.ts +35 -35
- package/src/util/getActiveElement.ts +4 -4
- package/src/util/innerTextTrim.ts +10 -10
- package/src/util/isDataRecord.ts +5 -5
- package/src/util/test/createTestRenderer.tsx +9 -2
- package/src/widgets/AccessorBindings.spec.tsx +4 -4
- package/src/widgets/HtmlElement.spec.tsx +6 -6
- package/src/widgets/ReactElementWrapper.spec.tsx +37 -37
- package/src/widgets/Sandbox.ts +103 -103
- package/src/widgets/form/ValidationGroup.spec.tsx +12 -12
- package/src/widgets/grid/GridCell.ts +143 -143
- package/src/widgets/icons/calendar.tsx +22 -17
- package/src/widgets/icons/check.tsx +14 -13
- package/src/widgets/icons/clear.tsx +16 -15
- package/src/widgets/icons/close.tsx +20 -20
- package/src/widgets/icons/cx.tsx +39 -38
- package/src/widgets/icons/drop-down.tsx +16 -15
- package/src/widgets/icons/file.tsx +14 -13
- package/src/widgets/icons/folder-open.tsx +16 -15
- package/src/widgets/icons/folder.tsx +14 -13
- package/src/widgets/icons/forward.tsx +23 -22
- package/src/widgets/icons/loading.tsx +25 -24
- package/src/widgets/icons/menu.tsx +18 -17
- package/src/widgets/icons/pixel-picker.tsx +18 -18
- package/src/widgets/icons/search.tsx +14 -13
- package/src/widgets/icons/sort-asc.tsx +15 -14
- package/src/widgets/icons/square.tsx +19 -18
- package/src/widgets/nav/Route.spec.tsx +2 -2
- package/src/widgets/nav/Route.ts +142 -142
- package/src/widgets/overlay/Dropdown.tsx +762 -762
- package/src/widgets/overlay/MsgBox.tsx +141 -141
- package/src/widgets/overlay/Toast.ts +111 -111
- package/src/widgets/overlay/Window.tsx +299 -299
- package/src/widgets/overlay/alerts.ts +46 -46
- package/src/widgets/overlay/index.ts +11 -11
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Store } from "../data/Store";
|
|
2
2
|
import assert from "assert";
|
|
3
|
-
import { createTestRenderer } from "../util/test/createTestRenderer";
|
|
3
|
+
import { createTestRenderer, act } from "../util/test/createTestRenderer";
|
|
4
4
|
import { bind } from "./bind";
|
|
5
5
|
import { PureContainer } from "./PureContainer";
|
|
6
6
|
|
|
7
7
|
describe("PureContainer", () => {
|
|
8
|
-
it("renders static text children", () => {
|
|
8
|
+
it("renders static text children", async () => {
|
|
9
9
|
let widget = (
|
|
10
10
|
<cx>
|
|
11
11
|
<PureContainer>
|
|
@@ -15,7 +15,7 @@ describe("PureContainer", () => {
|
|
|
15
15
|
);
|
|
16
16
|
|
|
17
17
|
let store = new Store();
|
|
18
|
-
const component = createTestRenderer(store, widget);
|
|
18
|
+
const component = await createTestRenderer(store, widget);
|
|
19
19
|
|
|
20
20
|
let tree = component.toJSON();
|
|
21
21
|
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
@@ -26,7 +26,7 @@ describe("PureContainer", () => {
|
|
|
26
26
|
});
|
|
27
27
|
});
|
|
28
28
|
|
|
29
|
-
it("renders multiple children", () => {
|
|
29
|
+
it("renders multiple children", async () => {
|
|
30
30
|
let widget = (
|
|
31
31
|
<cx>
|
|
32
32
|
<PureContainer>
|
|
@@ -38,7 +38,7 @@ describe("PureContainer", () => {
|
|
|
38
38
|
);
|
|
39
39
|
|
|
40
40
|
let store = new Store();
|
|
41
|
-
const component = createTestRenderer(store, widget);
|
|
41
|
+
const component = await createTestRenderer(store, widget);
|
|
42
42
|
|
|
43
43
|
let tree = component.toJSON();
|
|
44
44
|
assert(Array.isArray(tree), "Expected array of elements");
|
|
@@ -62,7 +62,7 @@ describe("PureContainer", () => {
|
|
|
62
62
|
]);
|
|
63
63
|
});
|
|
64
64
|
|
|
65
|
-
it("renders children with data bindings", () => {
|
|
65
|
+
it("renders children with data bindings", async () => {
|
|
66
66
|
let widget = (
|
|
67
67
|
<cx>
|
|
68
68
|
<PureContainer>
|
|
@@ -77,7 +77,7 @@ describe("PureContainer", () => {
|
|
|
77
77
|
},
|
|
78
78
|
});
|
|
79
79
|
|
|
80
|
-
const component = createTestRenderer(store, widget);
|
|
80
|
+
const component = await createTestRenderer(store, widget);
|
|
81
81
|
|
|
82
82
|
let tree = component.toJSON();
|
|
83
83
|
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
@@ -88,7 +88,7 @@ describe("PureContainer", () => {
|
|
|
88
88
|
});
|
|
89
89
|
});
|
|
90
90
|
|
|
91
|
-
it("renders nested containers", () => {
|
|
91
|
+
it("renders nested containers", async () => {
|
|
92
92
|
let widget = (
|
|
93
93
|
<cx>
|
|
94
94
|
<PureContainer>
|
|
@@ -102,7 +102,7 @@ describe("PureContainer", () => {
|
|
|
102
102
|
);
|
|
103
103
|
|
|
104
104
|
let store = new Store();
|
|
105
|
-
const component = createTestRenderer(store, widget);
|
|
105
|
+
const component = await createTestRenderer(store, widget);
|
|
106
106
|
|
|
107
107
|
let tree = component.toJSON();
|
|
108
108
|
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
@@ -119,7 +119,7 @@ describe("PureContainer", () => {
|
|
|
119
119
|
});
|
|
120
120
|
});
|
|
121
121
|
|
|
122
|
-
it("conditionally renders children based on visible binding", () => {
|
|
122
|
+
it("conditionally renders children based on visible binding", async () => {
|
|
123
123
|
let widget = (
|
|
124
124
|
<cx>
|
|
125
125
|
<PureContainer>
|
|
@@ -135,7 +135,7 @@ describe("PureContainer", () => {
|
|
|
135
135
|
},
|
|
136
136
|
});
|
|
137
137
|
|
|
138
|
-
const component = createTestRenderer(store, widget);
|
|
138
|
+
const component = await createTestRenderer(store, widget);
|
|
139
139
|
|
|
140
140
|
let tree = component.toJSON();
|
|
141
141
|
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
@@ -146,7 +146,7 @@ describe("PureContainer", () => {
|
|
|
146
146
|
});
|
|
147
147
|
});
|
|
148
148
|
|
|
149
|
-
it("handles empty children", () => {
|
|
149
|
+
it("handles empty children", async () => {
|
|
150
150
|
let widget = (
|
|
151
151
|
<cx>
|
|
152
152
|
<PureContainer>
|
|
@@ -156,7 +156,7 @@ describe("PureContainer", () => {
|
|
|
156
156
|
);
|
|
157
157
|
|
|
158
158
|
let store = new Store();
|
|
159
|
-
const component = createTestRenderer(store, widget);
|
|
159
|
+
const component = await createTestRenderer(store, widget);
|
|
160
160
|
|
|
161
161
|
let tree = component.toJSON();
|
|
162
162
|
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
@@ -167,7 +167,7 @@ describe("PureContainer", () => {
|
|
|
167
167
|
});
|
|
168
168
|
});
|
|
169
169
|
|
|
170
|
-
it("renders children from items property", () => {
|
|
170
|
+
it("renders children from items property", async () => {
|
|
171
171
|
let widget = (
|
|
172
172
|
<cx>
|
|
173
173
|
<PureContainer items={[<div key="1">Item 1</div>, <div key="2">Item 2</div>]} />
|
|
@@ -175,7 +175,7 @@ describe("PureContainer", () => {
|
|
|
175
175
|
);
|
|
176
176
|
|
|
177
177
|
let store = new Store();
|
|
178
|
-
const component = createTestRenderer(store, widget);
|
|
178
|
+
const component = await createTestRenderer(store, widget);
|
|
179
179
|
|
|
180
180
|
let tree = component.toJSON();
|
|
181
181
|
assert(Array.isArray(tree), "Expected array of elements");
|
|
@@ -192,7 +192,7 @@ describe("PureContainer", () => {
|
|
|
192
192
|
});
|
|
193
193
|
});
|
|
194
194
|
|
|
195
|
-
it("updates children when store data changes", () => {
|
|
195
|
+
it("updates children when store data changes", async () => {
|
|
196
196
|
let widget = (
|
|
197
197
|
<cx>
|
|
198
198
|
<PureContainer>
|
|
@@ -207,7 +207,7 @@ describe("PureContainer", () => {
|
|
|
207
207
|
},
|
|
208
208
|
});
|
|
209
209
|
|
|
210
|
-
const component = createTestRenderer(store, widget);
|
|
210
|
+
const component = await createTestRenderer(store, widget);
|
|
211
211
|
|
|
212
212
|
let tree = component.toJSON();
|
|
213
213
|
assert.deepEqual(tree, {
|
|
@@ -217,7 +217,9 @@ describe("PureContainer", () => {
|
|
|
217
217
|
});
|
|
218
218
|
|
|
219
219
|
// Update the store
|
|
220
|
-
|
|
220
|
+
await act(async () => {
|
|
221
|
+
store.set("count", 5);
|
|
222
|
+
});
|
|
221
223
|
|
|
222
224
|
// Re-render
|
|
223
225
|
tree = component.toJSON();
|
package/src/ui/Repeater.spec.tsx
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { Store } from "../data/Store";
|
|
2
2
|
import { Repeater } from "./Repeater";
|
|
3
3
|
import { bind } from "./bind";
|
|
4
|
-
import { createTestRenderer } from "../util/test/createTestRenderer";
|
|
4
|
+
import { createTestRenderer, act } from "../util/test/createTestRenderer";
|
|
5
5
|
|
|
6
6
|
import assert from "assert";
|
|
7
7
|
|
|
8
8
|
describe("Repeater", () => {
|
|
9
|
-
it("allows sorting", () => {
|
|
9
|
+
it("allows sorting", async () => {
|
|
10
10
|
let data = [
|
|
11
11
|
{
|
|
12
12
|
value: "C",
|
|
@@ -31,7 +31,7 @@ describe("Repeater", () => {
|
|
|
31
31
|
|
|
32
32
|
let store = new Store();
|
|
33
33
|
|
|
34
|
-
const component = createTestRenderer(store, widget);
|
|
34
|
+
const component = await createTestRenderer(store, widget);
|
|
35
35
|
|
|
36
36
|
let tree = component.toJSON();
|
|
37
37
|
assert.deepEqual(tree, {
|
|
@@ -57,7 +57,7 @@ describe("Repeater", () => {
|
|
|
57
57
|
});
|
|
58
58
|
});
|
|
59
59
|
|
|
60
|
-
it("changes are properly updated", () => {
|
|
60
|
+
it("changes are properly updated", async () => {
|
|
61
61
|
let divInstances: any[] = [];
|
|
62
62
|
let widget = (
|
|
63
63
|
<cx>
|
|
@@ -87,7 +87,7 @@ describe("Repeater", () => {
|
|
|
87
87
|
},
|
|
88
88
|
});
|
|
89
89
|
|
|
90
|
-
const component = createTestRenderer(store, widget);
|
|
90
|
+
const component = await createTestRenderer(store, widget);
|
|
91
91
|
|
|
92
92
|
let tree = component.toJSON();
|
|
93
93
|
assert.deepEqual(tree, {
|
|
@@ -109,7 +109,9 @@ describe("Repeater", () => {
|
|
|
109
109
|
|
|
110
110
|
divInstances = [];
|
|
111
111
|
|
|
112
|
-
|
|
112
|
+
await act(async () => {
|
|
113
|
+
store.update("data", (data) => [{ value: "A" }, ...data]);
|
|
114
|
+
});
|
|
113
115
|
|
|
114
116
|
assert.deepEqual(component.toJSON(), {
|
|
115
117
|
type: "div",
|
package/src/ui/Rescope.spec.tsx
CHANGED
|
@@ -8,7 +8,7 @@ import assert from "assert";
|
|
|
8
8
|
import { PureContainer } from "./PureContainer";
|
|
9
9
|
|
|
10
10
|
describe("Rescope", () => {
|
|
11
|
-
it("allows simple access to nested data", () => {
|
|
11
|
+
it("allows simple access to nested data", async () => {
|
|
12
12
|
let store = new Store({
|
|
13
13
|
data: {
|
|
14
14
|
$page: {
|
|
@@ -27,7 +27,7 @@ describe("Rescope", () => {
|
|
|
27
27
|
</cx>
|
|
28
28
|
);
|
|
29
29
|
|
|
30
|
-
const component = createTestRenderer(store, widget);
|
|
30
|
+
const component = await createTestRenderer(store, widget);
|
|
31
31
|
|
|
32
32
|
let tree = component.toJSON();
|
|
33
33
|
assert.deepEqual(tree, {
|
|
@@ -37,7 +37,7 @@ describe("Rescope", () => {
|
|
|
37
37
|
});
|
|
38
38
|
});
|
|
39
39
|
|
|
40
|
-
it("allows parent access through $root", () => {
|
|
40
|
+
it("allows parent access through $root", async () => {
|
|
41
41
|
let store = new Store({
|
|
42
42
|
data: {
|
|
43
43
|
layout: {
|
|
@@ -59,7 +59,7 @@ describe("Rescope", () => {
|
|
|
59
59
|
</cx>
|
|
60
60
|
);
|
|
61
61
|
|
|
62
|
-
const component = createTestRenderer(store, widget);
|
|
62
|
+
const component = await createTestRenderer(store, widget);
|
|
63
63
|
|
|
64
64
|
let tree = component.toJSON();
|
|
65
65
|
assert.deepEqual(tree, {
|
|
@@ -69,7 +69,7 @@ describe("Rescope", () => {
|
|
|
69
69
|
});
|
|
70
70
|
});
|
|
71
71
|
|
|
72
|
-
it("allows nested data access through data", () => {
|
|
72
|
+
it("allows nested data access through data", async () => {
|
|
73
73
|
let store = new Store({
|
|
74
74
|
data: {
|
|
75
75
|
layout: {
|
|
@@ -86,7 +86,7 @@ describe("Rescope", () => {
|
|
|
86
86
|
</cx>
|
|
87
87
|
);
|
|
88
88
|
|
|
89
|
-
const component = createTestRenderer(store, widget);
|
|
89
|
+
const component = await createTestRenderer(store, widget);
|
|
90
90
|
|
|
91
91
|
let tree = component.toJSON();
|
|
92
92
|
assert.deepEqual(tree, {
|
|
@@ -96,7 +96,7 @@ describe("Rescope", () => {
|
|
|
96
96
|
});
|
|
97
97
|
});
|
|
98
98
|
|
|
99
|
-
it("nested data mutations are correctly propagated to the parent store", () => {
|
|
99
|
+
it("nested data mutations are correctly propagated to the parent store", async () => {
|
|
100
100
|
let store = new Store({
|
|
101
101
|
data: {
|
|
102
102
|
item: {
|
|
@@ -108,7 +108,7 @@ describe("Rescope", () => {
|
|
|
108
108
|
let widget = (
|
|
109
109
|
<cx>
|
|
110
110
|
<Rescope bind="$page" data={{ $value: { bind: "item.value" } }}>
|
|
111
|
-
<PureContainer
|
|
111
|
+
<PureContainer
|
|
112
112
|
controller={{
|
|
113
113
|
onInit() {
|
|
114
114
|
this.store.set("$value", 2);
|
|
@@ -120,7 +120,7 @@ describe("Rescope", () => {
|
|
|
120
120
|
</cx>
|
|
121
121
|
);
|
|
122
122
|
|
|
123
|
-
const component = createTestRenderer(store, widget);
|
|
123
|
+
const component = await createTestRenderer(store, widget);
|
|
124
124
|
|
|
125
125
|
let tree = component.toJSON();
|
|
126
126
|
assert.deepEqual(tree, {
|
|
@@ -130,7 +130,7 @@ describe("Rescope", () => {
|
|
|
130
130
|
});
|
|
131
131
|
});
|
|
132
132
|
|
|
133
|
-
it("visible is calculated based on the inner scope", () => {
|
|
133
|
+
it("visible is calculated based on the inner scope", async () => {
|
|
134
134
|
let store = new Store({
|
|
135
135
|
data: {
|
|
136
136
|
layout: {
|
|
@@ -153,7 +153,7 @@ describe("Rescope", () => {
|
|
|
153
153
|
</cx>
|
|
154
154
|
);
|
|
155
155
|
|
|
156
|
-
const component = createTestRenderer(store, widget);
|
|
156
|
+
const component = await createTestRenderer(store, widget);
|
|
157
157
|
|
|
158
158
|
let tree = component.toJSON();
|
|
159
159
|
assert.deepEqual(tree, {
|
|
@@ -163,7 +163,7 @@ describe("Rescope", () => {
|
|
|
163
163
|
});
|
|
164
164
|
});
|
|
165
165
|
|
|
166
|
-
it("controllers see inner scope", () => {
|
|
166
|
+
it("controllers see inner scope", async () => {
|
|
167
167
|
let store = new Store({
|
|
168
168
|
data: {
|
|
169
169
|
$page: {
|
|
@@ -191,7 +191,7 @@ describe("Rescope", () => {
|
|
|
191
191
|
</cx>
|
|
192
192
|
);
|
|
193
193
|
|
|
194
|
-
const component = createTestRenderer(store, widget);
|
|
194
|
+
const component = await createTestRenderer(store, widget);
|
|
195
195
|
|
|
196
196
|
component.toJSON();
|
|
197
197
|
assert.equal(testName, "John");
|
package/src/ui/Rescope.ts
CHANGED
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
import { Widget } from "./Widget";
|
|
2
|
-
import { PureContainerBase, PureContainerConfig } from "./PureContainer";
|
|
3
|
-
import { Binding } from "../data/Binding";
|
|
4
|
-
import { ZoomIntoPropertyView } from "../data/ZoomIntoPropertyView";
|
|
5
|
-
import { StructuredInstanceDataAccessor } from "./StructuredInstanceDataAccessor";
|
|
6
|
-
import { isObject } from "../util/isObject";
|
|
7
|
-
import { StructuredProp } from "./Prop";
|
|
8
|
-
|
|
9
|
-
export interface RescopeConfig extends PureContainerConfig {
|
|
10
|
-
bind: string;
|
|
11
|
-
rootName?: string;
|
|
12
|
-
rootAlias?: string;
|
|
13
|
-
data?: StructuredProp;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export class Rescope extends PureContainerBase<RescopeConfig> {
|
|
17
|
-
declare bind: string;
|
|
18
|
-
declare binding: any;
|
|
19
|
-
declare rootAlias?: string;
|
|
20
|
-
declare rootName: string;
|
|
21
|
-
declare data?: any;
|
|
22
|
-
|
|
23
|
-
init() {
|
|
24
|
-
this.binding = Binding.get(this.bind);
|
|
25
|
-
if (this.rootAlias) this.rootName = this.rootAlias;
|
|
26
|
-
super.init();
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
initInstance(context: any, instance: any) {
|
|
30
|
-
instance.store = new ZoomIntoPropertyView({
|
|
31
|
-
store: instance.parentStore,
|
|
32
|
-
binding: this.binding,
|
|
33
|
-
rootName: this.rootName,
|
|
34
|
-
nestedData: isObject(this.data)
|
|
35
|
-
? new StructuredInstanceDataAccessor({ instance, data: this.data, useParentStore: true })
|
|
36
|
-
: undefined,
|
|
37
|
-
});
|
|
38
|
-
super.initInstance(context, instance);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
applyParentStore(instance: any) {
|
|
42
|
-
instance.store.setStore(instance.parentStore);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
Rescope.prototype.bind = "$page";
|
|
47
|
-
Rescope.prototype.rootName = "$root";
|
|
48
|
-
|
|
49
|
-
Widget.alias("rescope", Rescope);
|
|
1
|
+
import { Widget } from "./Widget";
|
|
2
|
+
import { PureContainerBase, PureContainerConfig } from "./PureContainer";
|
|
3
|
+
import { Binding } from "../data/Binding";
|
|
4
|
+
import { ZoomIntoPropertyView } from "../data/ZoomIntoPropertyView";
|
|
5
|
+
import { StructuredInstanceDataAccessor } from "./StructuredInstanceDataAccessor";
|
|
6
|
+
import { isObject } from "../util/isObject";
|
|
7
|
+
import { StructuredProp } from "./Prop";
|
|
8
|
+
|
|
9
|
+
export interface RescopeConfig extends PureContainerConfig {
|
|
10
|
+
bind: string;
|
|
11
|
+
rootName?: string;
|
|
12
|
+
rootAlias?: string;
|
|
13
|
+
data?: StructuredProp;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export class Rescope extends PureContainerBase<RescopeConfig> {
|
|
17
|
+
declare bind: string;
|
|
18
|
+
declare binding: any;
|
|
19
|
+
declare rootAlias?: string;
|
|
20
|
+
declare rootName: string;
|
|
21
|
+
declare data?: any;
|
|
22
|
+
|
|
23
|
+
init() {
|
|
24
|
+
this.binding = Binding.get(this.bind);
|
|
25
|
+
if (this.rootAlias) this.rootName = this.rootAlias;
|
|
26
|
+
super.init();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
initInstance(context: any, instance: any) {
|
|
30
|
+
instance.store = new ZoomIntoPropertyView({
|
|
31
|
+
store: instance.parentStore,
|
|
32
|
+
binding: this.binding,
|
|
33
|
+
rootName: this.rootName,
|
|
34
|
+
nestedData: isObject(this.data)
|
|
35
|
+
? new StructuredInstanceDataAccessor({ instance, data: this.data, useParentStore: true })
|
|
36
|
+
: undefined,
|
|
37
|
+
});
|
|
38
|
+
super.initInstance(context, instance);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
applyParentStore(instance: any) {
|
|
42
|
+
instance.store.setStore(instance.parentStore);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
Rescope.prototype.bind = "$page";
|
|
47
|
+
Rescope.prototype.rootName = "$root";
|
|
48
|
+
|
|
49
|
+
Widget.alias("rescope", Rescope);
|
package/src/ui/Restate.spec.tsx
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Restate } from "./Restate";
|
|
2
2
|
import { Store } from "../data/Store";
|
|
3
|
-
import { createTestRenderer } from "../util/test/createTestRenderer";
|
|
3
|
+
import { createTestRenderer, act } from "../util/test/createTestRenderer";
|
|
4
4
|
import assert from "assert";
|
|
5
5
|
import { Controller } from "./Controller";
|
|
6
6
|
import { bind } from "./bind";
|
|
7
7
|
import { FirstVisibleChildLayout } from "./layout/FirstVisibleChildLayout";
|
|
8
8
|
|
|
9
9
|
describe("Restate", () => {
|
|
10
|
-
it("provides a blank slate", () => {
|
|
10
|
+
it("provides a blank slate", async () => {
|
|
11
11
|
let widget = (
|
|
12
12
|
<cx>
|
|
13
13
|
<div>
|
|
@@ -30,7 +30,7 @@ describe("Restate", () => {
|
|
|
30
30
|
},
|
|
31
31
|
});
|
|
32
32
|
|
|
33
|
-
const component = createTestRenderer(store, widget);
|
|
33
|
+
const component = await createTestRenderer(store, widget);
|
|
34
34
|
|
|
35
35
|
let tree = component.toJSON();
|
|
36
36
|
assert.deepEqual(tree, {
|
|
@@ -51,7 +51,7 @@ describe("Restate", () => {
|
|
|
51
51
|
});
|
|
52
52
|
});
|
|
53
53
|
|
|
54
|
-
it("wires declared data", () => {
|
|
54
|
+
it("wires declared data", async () => {
|
|
55
55
|
let widget = (
|
|
56
56
|
<cx>
|
|
57
57
|
<div>
|
|
@@ -80,7 +80,7 @@ describe("Restate", () => {
|
|
|
80
80
|
changed = true;
|
|
81
81
|
});
|
|
82
82
|
|
|
83
|
-
const component = createTestRenderer(store, widget);
|
|
83
|
+
const component = await createTestRenderer(store, widget);
|
|
84
84
|
|
|
85
85
|
let tree = component.toJSON();
|
|
86
86
|
|
|
@@ -89,7 +89,7 @@ describe("Restate", () => {
|
|
|
89
89
|
assert(changed);
|
|
90
90
|
});
|
|
91
91
|
|
|
92
|
-
it("causes a global update if internal data changes", () => {
|
|
92
|
+
it("causes a global update if internal data changes", async () => {
|
|
93
93
|
let controller: TestController | undefined;
|
|
94
94
|
|
|
95
95
|
class TestController extends Controller {
|
|
@@ -122,7 +122,7 @@ describe("Restate", () => {
|
|
|
122
122
|
changed = true;
|
|
123
123
|
});
|
|
124
124
|
|
|
125
|
-
const component = createTestRenderer(store, widget);
|
|
125
|
+
const component = await createTestRenderer(store, widget);
|
|
126
126
|
|
|
127
127
|
let tree = component.toJSON();
|
|
128
128
|
assert.deepEqual(tree, {
|
|
@@ -137,7 +137,9 @@ describe("Restate", () => {
|
|
|
137
137
|
],
|
|
138
138
|
});
|
|
139
139
|
|
|
140
|
-
|
|
140
|
+
await act(async () => {
|
|
141
|
+
controller!.setNickname("Sale");
|
|
142
|
+
});
|
|
141
143
|
|
|
142
144
|
let tree2 = component.toJSON();
|
|
143
145
|
assert.deepEqual(tree2, {
|
|
@@ -153,7 +155,7 @@ describe("Restate", () => {
|
|
|
153
155
|
});
|
|
154
156
|
});
|
|
155
157
|
|
|
156
|
-
it("doesn't notify parent if not necessary in detached mode", () => {
|
|
158
|
+
it("doesn't notify parent if not necessary in detached mode", async () => {
|
|
157
159
|
class TestController extends Controller {
|
|
158
160
|
onInit() {
|
|
159
161
|
this.store.init("nickname", "Sale");
|
|
@@ -181,13 +183,13 @@ describe("Restate", () => {
|
|
|
181
183
|
changed = true;
|
|
182
184
|
});
|
|
183
185
|
|
|
184
|
-
const component = createTestRenderer(store, widget);
|
|
186
|
+
const component = await createTestRenderer(store, widget);
|
|
185
187
|
|
|
186
188
|
let tree = component.toJSON();
|
|
187
189
|
assert(!changed);
|
|
188
190
|
});
|
|
189
191
|
|
|
190
|
-
it("shared state can be used across components inside and outside Restate", () => {
|
|
192
|
+
it("shared state can be used across components inside and outside Restate", async () => {
|
|
191
193
|
let widget = (
|
|
192
194
|
<cx>
|
|
193
195
|
<div>
|
|
@@ -213,7 +215,7 @@ describe("Restate", () => {
|
|
|
213
215
|
//console.log(store.getData());
|
|
214
216
|
});
|
|
215
217
|
|
|
216
|
-
const component = createTestRenderer(store, widget);
|
|
218
|
+
const component = await createTestRenderer(store, widget);
|
|
217
219
|
|
|
218
220
|
let tree = component.toJSON();
|
|
219
221
|
assert.deepEqual(store.getData(), {
|
|
@@ -226,8 +228,8 @@ describe("Restate", () => {
|
|
|
226
228
|
});
|
|
227
229
|
});
|
|
228
230
|
|
|
229
|
-
it("updates if shared state is changed from outside", () => {
|
|
230
|
-
[true, false]
|
|
231
|
+
it("updates if shared state is changed from outside", async () => {
|
|
232
|
+
for (const detached of [true, false]) {
|
|
231
233
|
let widget = (
|
|
232
234
|
<cx>
|
|
233
235
|
<div>
|
|
@@ -246,7 +248,7 @@ describe("Restate", () => {
|
|
|
246
248
|
|
|
247
249
|
let store = new Store();
|
|
248
250
|
|
|
249
|
-
const component = createTestRenderer(store, widget);
|
|
251
|
+
const component = await createTestRenderer(store, widget);
|
|
250
252
|
|
|
251
253
|
let tree = component.toJSON();
|
|
252
254
|
assert.deepEqual(tree, {
|
|
@@ -265,7 +267,9 @@ describe("Restate", () => {
|
|
|
265
267
|
},
|
|
266
268
|
],
|
|
267
269
|
});
|
|
268
|
-
|
|
270
|
+
await act(async () => {
|
|
271
|
+
store.set("person.firstName", "Jack");
|
|
272
|
+
});
|
|
269
273
|
|
|
270
274
|
tree = component.toJSON();
|
|
271
275
|
assert.deepEqual(tree, {
|
|
@@ -284,11 +288,11 @@ describe("Restate", () => {
|
|
|
284
288
|
},
|
|
285
289
|
],
|
|
286
290
|
});
|
|
287
|
-
}
|
|
291
|
+
}
|
|
288
292
|
});
|
|
289
293
|
|
|
290
|
-
it("allows field initialization in data declaration", () => {
|
|
291
|
-
[true, false]
|
|
294
|
+
it("allows field initialization in data declaration", async () => {
|
|
295
|
+
for (const detached of [true, false]) {
|
|
292
296
|
let widget = (
|
|
293
297
|
<cx>
|
|
294
298
|
<div>
|
|
@@ -306,7 +310,7 @@ describe("Restate", () => {
|
|
|
306
310
|
|
|
307
311
|
let store = new Store();
|
|
308
312
|
|
|
309
|
-
const component = createTestRenderer(store, widget);
|
|
313
|
+
const component = await createTestRenderer(store, widget);
|
|
310
314
|
|
|
311
315
|
let tree = component.toJSON();
|
|
312
316
|
assert.deepEqual(tree, {
|
|
@@ -320,10 +324,10 @@ describe("Restate", () => {
|
|
|
320
324
|
},
|
|
321
325
|
],
|
|
322
326
|
});
|
|
323
|
-
}
|
|
327
|
+
}
|
|
324
328
|
});
|
|
325
329
|
|
|
326
|
-
it("updates if internal data changes", () => {
|
|
330
|
+
it("updates if internal data changes", async () => {
|
|
327
331
|
class TestController extends Controller {
|
|
328
332
|
onInit() {
|
|
329
333
|
this.store.init("nickname", "Sale");
|
|
@@ -348,7 +352,7 @@ describe("Restate", () => {
|
|
|
348
352
|
changed = true;
|
|
349
353
|
});
|
|
350
354
|
|
|
351
|
-
const component = createTestRenderer(store, widget);
|
|
355
|
+
const component = await createTestRenderer(store, widget);
|
|
352
356
|
|
|
353
357
|
let tree = component.toJSON();
|
|
354
358
|
assert.deepEqual(tree, {
|
|
@@ -364,7 +368,7 @@ describe("Restate", () => {
|
|
|
364
368
|
});
|
|
365
369
|
});
|
|
366
370
|
|
|
367
|
-
it("works with FirstVisibleChildLayout", () => {
|
|
371
|
+
it("works with FirstVisibleChildLayout", async () => {
|
|
368
372
|
let widget = (
|
|
369
373
|
<cx>
|
|
370
374
|
<div>
|
|
@@ -380,7 +384,7 @@ describe("Restate", () => {
|
|
|
380
384
|
|
|
381
385
|
let store = new Store();
|
|
382
386
|
|
|
383
|
-
const component = createTestRenderer(store, widget);
|
|
387
|
+
const component = await createTestRenderer(store, widget);
|
|
384
388
|
|
|
385
389
|
let tree = component.toJSON();
|
|
386
390
|
assert.deepEqual(tree, {
|
|
@@ -390,7 +394,7 @@ describe("Restate", () => {
|
|
|
390
394
|
});
|
|
391
395
|
});
|
|
392
396
|
|
|
393
|
-
it("is transparent to FirstVisibleChildLayout", () => {
|
|
397
|
+
it("is transparent to FirstVisibleChildLayout", async () => {
|
|
394
398
|
let widget = (
|
|
395
399
|
<cx>
|
|
396
400
|
<div>
|
|
@@ -406,7 +410,7 @@ describe("Restate", () => {
|
|
|
406
410
|
|
|
407
411
|
let store = new Store();
|
|
408
412
|
|
|
409
|
-
const component = createTestRenderer(store, widget);
|
|
413
|
+
const component = await createTestRenderer(store, widget);
|
|
410
414
|
|
|
411
415
|
let tree = component.toJSON();
|
|
412
416
|
assert.deepEqual(tree, {
|
package/src/ui/VDOM.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { VDOM } from "cx-react";
|
|
1
|
+
export { VDOM } from "cx-react";
|
package/src/ui/Widget.tsx
CHANGED
|
@@ -152,13 +152,6 @@ export abstract class Widget<
|
|
|
152
152
|
if (this.styles) this.style = this.styles;
|
|
153
153
|
|
|
154
154
|
if (this.styled) this.style = parseStyle(this.style);
|
|
155
|
-
else if (this.style) {
|
|
156
|
-
Console.warn(
|
|
157
|
-
"Components that allow use of the style attribute should set styled = true on their prototype. This will be an error in future versions.",
|
|
158
|
-
);
|
|
159
|
-
this.style = parseStyle(this.style);
|
|
160
|
-
this.styled = true;
|
|
161
|
-
}
|
|
162
155
|
|
|
163
156
|
if (typeof this.if !== "undefined") this.visible = this.if;
|
|
164
157
|
|