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.
Files changed (113) hide show
  1. package/build/ui/Widget.js +0 -5
  2. package/build/util/Component.js +5 -0
  3. package/build/util/test/createTestRenderer.d.ts +3 -1
  4. package/build/util/test/createTestRenderer.js +8 -2
  5. package/build/widgets/icons/calendar.js +4 -3
  6. package/build/widgets/icons/check.js +2 -2
  7. package/build/widgets/icons/clear.js +2 -2
  8. package/build/widgets/icons/close.js +2 -2
  9. package/build/widgets/icons/cx.js +2 -2
  10. package/build/widgets/icons/drop-down.js +2 -2
  11. package/build/widgets/icons/file.js +2 -2
  12. package/build/widgets/icons/folder-open.js +2 -2
  13. package/build/widgets/icons/folder.js +2 -2
  14. package/build/widgets/icons/forward.js +2 -2
  15. package/build/widgets/icons/loading.js +2 -2
  16. package/build/widgets/icons/menu.js +2 -2
  17. package/build/widgets/icons/pixel-picker.js +2 -2
  18. package/build/widgets/icons/search.js +2 -2
  19. package/build/widgets/icons/sort-asc.js +2 -2
  20. package/build/widgets/icons/square.js +2 -2
  21. package/dist/manifest.js +896 -896
  22. package/dist/ui.js +1 -8
  23. package/dist/util.js +4 -0
  24. package/dist/widgets.js +377 -313
  25. package/package.json +3 -1
  26. package/src/core.d.ts +182 -182
  27. package/src/data/ArrayElementView.ts +90 -90
  28. package/src/data/AugmentedViewBase.ts +88 -88
  29. package/src/data/Binding.ts +104 -104
  30. package/src/data/ExposedRecordView.ts +95 -95
  31. package/src/data/ExposedValueView.ts +89 -89
  32. package/src/data/Grouper.spec.ts +57 -57
  33. package/src/data/NestedDataView.ts +43 -43
  34. package/src/data/ReadOnlyDataView.ts +39 -39
  35. package/src/data/Ref.ts +104 -104
  36. package/src/data/Store.ts +52 -52
  37. package/src/data/StoreProxy.ts +19 -19
  38. package/src/data/StoreRef.ts +66 -66
  39. package/src/data/StringTemplate.ts +93 -93
  40. package/src/data/StructuredSelector.spec.ts +113 -113
  41. package/src/data/SubscribableView.ts +63 -63
  42. package/src/data/ZoomIntoPropertyView.ts +45 -45
  43. package/src/data/comparer.ts +78 -78
  44. package/src/data/ops/updateArray.ts +31 -31
  45. package/src/hooks/invokeCallback.spec.tsx +4 -4
  46. package/src/hooks/resolveCallback.spec.tsx +4 -4
  47. package/src/hooks/store.spec.tsx +15 -15
  48. package/src/hooks/useTrigger.spec.tsx +16 -10
  49. package/src/jsx-dev-runtime.ts +4 -4
  50. package/src/jsx-runtime.ts +79 -79
  51. package/src/ui/CSS.ts +87 -87
  52. package/src/ui/ContentResolver.spec.tsx +31 -29
  53. package/src/ui/Controller.spec.tsx +47 -39
  54. package/src/ui/Cx.spec.tsx +10 -8
  55. package/src/ui/DataProxy.spec.tsx +18 -18
  56. package/src/ui/DataProxy.ts +55 -55
  57. package/src/ui/FocusManager.ts +171 -171
  58. package/src/ui/IsolatedScope.spec.tsx +16 -9
  59. package/src/ui/PureContainer.spec.tsx +20 -18
  60. package/src/ui/Repeater.spec.tsx +8 -6
  61. package/src/ui/Rescope.spec.tsx +13 -13
  62. package/src/ui/Rescope.ts +49 -49
  63. package/src/ui/Restate.spec.tsx +31 -27
  64. package/src/ui/VDOM.ts +1 -1
  65. package/src/ui/Widget.tsx +0 -7
  66. package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
  67. package/src/ui/createFunctionalComponent.spec.tsx +20 -18
  68. package/src/ui/layout/Content.ts +30 -30
  69. package/src/ui/layout/ContentPlaceholder.spec.tsx +46 -34
  70. package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +31 -19
  71. package/src/ui/selection/PropertySelection.ts +87 -87
  72. package/src/util/Component.spec.ts +30 -0
  73. package/src/util/Component.ts +301 -296
  74. package/src/util/DOM.ts +88 -88
  75. package/src/util/Format.spec.ts +69 -69
  76. package/src/util/Format.ts +267 -267
  77. package/src/util/addEventListenerWithOptions.ts +41 -41
  78. package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
  79. package/src/util/color/rgbToHsl.ts +35 -35
  80. package/src/util/getActiveElement.ts +4 -4
  81. package/src/util/innerTextTrim.ts +10 -10
  82. package/src/util/isDataRecord.ts +5 -5
  83. package/src/util/test/createTestRenderer.tsx +9 -2
  84. package/src/widgets/AccessorBindings.spec.tsx +4 -4
  85. package/src/widgets/HtmlElement.spec.tsx +6 -6
  86. package/src/widgets/ReactElementWrapper.spec.tsx +37 -37
  87. package/src/widgets/Sandbox.ts +103 -103
  88. package/src/widgets/form/ValidationGroup.spec.tsx +12 -12
  89. package/src/widgets/grid/GridCell.ts +143 -143
  90. package/src/widgets/icons/calendar.tsx +22 -17
  91. package/src/widgets/icons/check.tsx +14 -13
  92. package/src/widgets/icons/clear.tsx +16 -15
  93. package/src/widgets/icons/close.tsx +20 -20
  94. package/src/widgets/icons/cx.tsx +39 -38
  95. package/src/widgets/icons/drop-down.tsx +16 -15
  96. package/src/widgets/icons/file.tsx +14 -13
  97. package/src/widgets/icons/folder-open.tsx +16 -15
  98. package/src/widgets/icons/folder.tsx +14 -13
  99. package/src/widgets/icons/forward.tsx +23 -22
  100. package/src/widgets/icons/loading.tsx +25 -24
  101. package/src/widgets/icons/menu.tsx +18 -17
  102. package/src/widgets/icons/pixel-picker.tsx +18 -18
  103. package/src/widgets/icons/search.tsx +14 -13
  104. package/src/widgets/icons/sort-asc.tsx +15 -14
  105. package/src/widgets/icons/square.tsx +19 -18
  106. package/src/widgets/nav/Route.spec.tsx +2 -2
  107. package/src/widgets/nav/Route.ts +142 -142
  108. package/src/widgets/overlay/Dropdown.tsx +762 -762
  109. package/src/widgets/overlay/MsgBox.tsx +141 -141
  110. package/src/widgets/overlay/Toast.ts +111 -111
  111. package/src/widgets/overlay/Window.tsx +299 -299
  112. package/src/widgets/overlay/alerts.ts +46 -46
  113. 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
- store.set("count", 5);
220
+ await act(async () => {
221
+ store.set("count", 5);
222
+ });
221
223
 
222
224
  // Re-render
223
225
  tree = component.toJSON();
@@ -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
- store.update("data", (data) => [{ value: "A" }, ...data]);
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",
@@ -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);
@@ -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
- controller!.setNickname("Sale");
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].forEach((detached) => {
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
- store.set("person.firstName", "Jack");
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].forEach((detached) => {
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