cx 26.0.13 → 26.1.0

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 (251) hide show
  1. package/build/ui/VDOM.d.ts +1 -20
  2. package/build/ui/VDOM.js +1 -3
  3. package/build/ui/Widget.d.ts +1 -1
  4. package/build/ui/app/startAppLoop.js +2 -10
  5. package/build/widgets/form/Checkbox.d.ts +0 -1
  6. package/build/widgets/form/Checkbox.js +1 -0
  7. package/build/widgets/form/ColorField.d.ts +0 -1
  8. package/build/widgets/form/ColorField.js +2 -2
  9. package/build/widgets/form/DateTimeField.d.ts +0 -2
  10. package/build/widgets/form/DateTimeField.js +1 -0
  11. package/build/widgets/form/DateTimePicker.d.ts +0 -2
  12. package/build/widgets/form/DateTimePicker.js +1 -0
  13. package/build/widgets/form/Radio.d.ts +0 -1
  14. package/build/widgets/form/Slider.js +9 -1
  15. package/build/widgets/form/Switch.d.ts +0 -1
  16. package/build/widgets/form/Switch.js +1 -1
  17. package/build/widgets/form/Wheel.d.ts +0 -1
  18. package/build/widgets/grid/Grid.d.ts +0 -2
  19. package/build/widgets/grid/GridCellEditor.js +3 -1
  20. package/build/widgets/overlay/Overlay.d.ts +3 -0
  21. package/build/widgets/overlay/Overlay.js +3 -2
  22. package/build/widgets/overlay/createHotPromiseWindowFactory.js +0 -1
  23. package/dist/manifest.js +810 -810
  24. package/dist/ui.js +3 -10
  25. package/dist/widgets.js +18 -7
  26. package/package.json +9 -8
  27. package/src/charts/Chart.ts +108 -108
  28. package/src/data/ArrayElementView.ts +90 -90
  29. package/src/data/AugmentedViewBase.ts +88 -88
  30. package/src/data/Binding.ts +104 -104
  31. package/src/data/ExposedRecordView.ts +95 -95
  32. package/src/data/ExposedValueView.ts +89 -89
  33. package/src/data/Expression.spec.ts +229 -229
  34. package/src/data/Expression.ts +233 -233
  35. package/src/data/Grouper.spec.ts +57 -57
  36. package/src/data/Grouper.ts +158 -158
  37. package/src/data/NestedDataView.ts +43 -43
  38. package/src/data/ReadOnlyDataView.ts +39 -39
  39. package/src/data/Ref.ts +104 -104
  40. package/src/data/Selector.ts +10 -10
  41. package/src/data/Store.ts +52 -52
  42. package/src/data/StoreProxy.ts +19 -19
  43. package/src/data/StoreRef.ts +66 -66
  44. package/src/data/StringTemplate.spec.ts +132 -132
  45. package/src/data/StringTemplate.ts +93 -93
  46. package/src/data/StructuredSelector.spec.ts +113 -113
  47. package/src/data/StructuredSelector.ts +146 -146
  48. package/src/data/SubscribableView.ts +63 -63
  49. package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
  50. package/src/data/ZoomIntoPropertyView.ts +45 -45
  51. package/src/data/computable.spec.ts +87 -87
  52. package/src/data/createStructuredSelector.ts +62 -62
  53. package/src/data/getAccessor.spec.ts +11 -11
  54. package/src/data/getAccessor.ts +74 -74
  55. package/src/data/getSelector.spec.ts +43 -43
  56. package/src/data/getSelector.ts +66 -66
  57. package/src/data/ops/filter.spec.ts +35 -35
  58. package/src/data/ops/filter.ts +9 -9
  59. package/src/data/ops/merge.ts +13 -13
  60. package/src/data/ops/removeTreeNodes.spec.ts +37 -37
  61. package/src/data/ops/updateArray.spec.ts +69 -69
  62. package/src/data/test-types.ts +7 -7
  63. package/src/hooks/useTrigger.ts +26 -26
  64. package/src/index.scss +6 -6
  65. package/src/jsx-dev-runtime.ts +4 -4
  66. package/src/jsx-runtime.spec.tsx +38 -9
  67. package/src/svg/BoundedObject.ts +101 -101
  68. package/src/svg/util/Rect.ts +105 -105
  69. package/src/ui/CSSHelper.ts +17 -17
  70. package/src/ui/Culture.ts +159 -159
  71. package/src/ui/DataProxy.ts +55 -55
  72. package/src/ui/FocusManager.ts +171 -171
  73. package/src/ui/Instance.ts +866 -866
  74. package/src/ui/Prop.ts +140 -140
  75. package/src/ui/RenderingContext.ts +99 -99
  76. package/src/ui/Rescope.ts +49 -49
  77. package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
  78. package/src/ui/VDOM.ts +1 -34
  79. package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
  80. package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
  81. package/src/ui/adapter/TreeAdapter.ts +185 -185
  82. package/src/ui/app/History.ts +133 -133
  83. package/src/ui/app/Url.spec.ts +50 -50
  84. package/src/ui/app/startAppLoop.tsx +5 -9
  85. package/src/ui/app/startHotAppLoop.ts +41 -41
  86. package/src/ui/layout/Content.ts +30 -30
  87. package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
  88. package/src/util/Console.ts +13 -13
  89. package/src/util/Format.spec.ts +69 -69
  90. package/src/util/Format.ts +267 -267
  91. package/src/util/addEventListenerWithOptions.ts +41 -41
  92. package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
  93. package/src/util/color/rgbToHsl.ts +35 -35
  94. package/src/util/getActiveElement.ts +4 -4
  95. package/src/util/hasKey.ts +18 -18
  96. package/src/util/index.ts +55 -55
  97. package/src/util/innerTextTrim.ts +10 -10
  98. package/src/util/isArray.ts +3 -3
  99. package/src/util/isDataRecord.ts +5 -5
  100. package/src/util/isDefined.ts +3 -3
  101. package/src/util/isString.ts +3 -3
  102. package/src/widgets/DocumentTitle.ts +95 -95
  103. package/src/widgets/Sandbox.ts +103 -103
  104. package/src/widgets/autoFocus.ts +9 -9
  105. package/src/widgets/cx.ts +63 -63
  106. package/src/widgets/form/Checkbox.tsx +0 -1
  107. package/src/widgets/form/ColorField.tsx +15 -12
  108. package/src/widgets/form/DateTimeField.tsx +0 -2
  109. package/src/widgets/form/DateTimePicker.tsx +0 -2
  110. package/src/widgets/form/Radio.tsx +0 -1
  111. package/src/widgets/form/Slider.tsx +12 -4
  112. package/src/widgets/form/Switch.tsx +2 -3
  113. package/src/widgets/form/Wheel.tsx +0 -1
  114. package/src/widgets/grid/Grid.tsx +0 -1
  115. package/src/widgets/grid/GridCell.ts +143 -143
  116. package/src/widgets/grid/GridCellEditor.tsx +7 -1
  117. package/src/widgets/icons/calendar.tsx +17 -17
  118. package/src/widgets/icons/check.tsx +13 -13
  119. package/src/widgets/icons/clear.tsx +15 -15
  120. package/src/widgets/icons/close.tsx +20 -20
  121. package/src/widgets/icons/cx.tsx +38 -38
  122. package/src/widgets/icons/drop-down.tsx +15 -15
  123. package/src/widgets/icons/file.tsx +13 -13
  124. package/src/widgets/icons/folder-open.tsx +15 -15
  125. package/src/widgets/icons/folder.tsx +13 -13
  126. package/src/widgets/icons/forward.tsx +22 -22
  127. package/src/widgets/icons/loading.tsx +24 -24
  128. package/src/widgets/icons/menu.tsx +17 -17
  129. package/src/widgets/icons/pixel-picker.tsx +18 -18
  130. package/src/widgets/icons/search.tsx +13 -13
  131. package/src/widgets/icons/sort-asc.tsx +14 -14
  132. package/src/widgets/icons/square.tsx +18 -18
  133. package/src/widgets/nav/Route.ts +142 -142
  134. package/src/widgets/overlay/Dropdown.tsx +762 -762
  135. package/src/widgets/overlay/MsgBox.tsx +141 -141
  136. package/src/widgets/overlay/Overlay.tsx +5 -1
  137. package/src/widgets/overlay/Toast.ts +111 -111
  138. package/src/widgets/overlay/Window.tsx +299 -299
  139. package/src/widgets/overlay/alerts.ts +46 -46
  140. package/src/widgets/overlay/captureMouse.ts +195 -195
  141. package/src/widgets/overlay/createHotPromiseWindowFactory.ts +0 -1
  142. package/src/widgets/overlay/index.d.ts +11 -11
  143. package/src/widgets/overlay/index.ts +11 -11
  144. package/src/widgets/overlay/tooltip-ops.ts +173 -173
  145. package/build/data/ArrayElementView.spec.d.ts +0 -1
  146. package/build/data/ArrayElementView.spec.js +0 -81
  147. package/build/data/Binding.spec.d.ts +0 -1
  148. package/build/data/Binding.spec.js +0 -61
  149. package/build/data/Expression.spec.d.ts +0 -1
  150. package/build/data/Expression.spec.js +0 -196
  151. package/build/data/Grouper.spec.d.ts +0 -1
  152. package/build/data/Grouper.spec.js +0 -48
  153. package/build/data/Ref.spec.d.ts +0 -1
  154. package/build/data/Ref.spec.js +0 -72
  155. package/build/data/Store.spec.d.ts +0 -1
  156. package/build/data/Store.spec.js +0 -19
  157. package/build/data/StoreRef.spec.d.ts +0 -1
  158. package/build/data/StoreRef.spec.js +0 -22
  159. package/build/data/StringTemplate.spec.d.ts +0 -1
  160. package/build/data/StringTemplate.spec.js +0 -112
  161. package/build/data/StructuredSelector.spec.d.ts +0 -1
  162. package/build/data/StructuredSelector.spec.js +0 -102
  163. package/build/data/View.spec.d.ts +0 -1
  164. package/build/data/View.spec.js +0 -44
  165. package/build/data/ZoomIntoPropertyView.spec.d.ts +0 -1
  166. package/build/data/ZoomIntoPropertyView.spec.js +0 -54
  167. package/build/data/comparer.spec.d.ts +0 -1
  168. package/build/data/comparer.spec.js +0 -50
  169. package/build/data/computable.spec.d.ts +0 -1
  170. package/build/data/computable.spec.js +0 -56
  171. package/build/data/createAccessorModelProxy.spec.d.ts +0 -1
  172. package/build/data/createAccessorModelProxy.spec.js +0 -30
  173. package/build/data/createStructuredSelector.spec.d.ts +0 -1
  174. package/build/data/createStructuredSelector.spec.js +0 -42
  175. package/build/data/diff/diffs.spec.d.ts +0 -1
  176. package/build/data/diff/diffs.spec.js +0 -45
  177. package/build/data/getAccessor.spec.d.ts +0 -1
  178. package/build/data/getAccessor.spec.js +0 -10
  179. package/build/data/getSelector.spec.d.ts +0 -1
  180. package/build/data/getSelector.spec.js +0 -36
  181. package/build/data/ops/append.spec.d.ts +0 -1
  182. package/build/data/ops/append.spec.js +0 -24
  183. package/build/data/ops/filter.spec.d.ts +0 -1
  184. package/build/data/ops/filter.spec.js +0 -25
  185. package/build/data/ops/findTreeNode.spec.d.ts +0 -1
  186. package/build/data/ops/findTreeNode.spec.js +0 -20
  187. package/build/data/ops/merge.spec.d.ts +0 -1
  188. package/build/data/ops/merge.spec.js +0 -23
  189. package/build/data/ops/removeTreeNodes.spec.d.ts +0 -1
  190. package/build/data/ops/removeTreeNodes.spec.js +0 -35
  191. package/build/data/ops/updateArray.spec.d.ts +0 -1
  192. package/build/data/ops/updateArray.spec.js +0 -33
  193. package/build/data/ops/updateTree.spec.d.ts +0 -1
  194. package/build/data/ops/updateTree.spec.js +0 -44
  195. package/build/hooks/invokeCallback.spec.d.ts +0 -1
  196. package/build/hooks/invokeCallback.spec.js +0 -44
  197. package/build/hooks/resolveCallback.spec.d.ts +0 -1
  198. package/build/hooks/resolveCallback.spec.js +0 -35
  199. package/build/hooks/store.spec.d.ts +0 -1
  200. package/build/hooks/store.spec.js +0 -48
  201. package/build/hooks/useTrigger.spec.d.ts +0 -1
  202. package/build/hooks/useTrigger.spec.js +0 -59
  203. package/build/ui/Controller.spec.d.ts +0 -1
  204. package/build/ui/Controller.spec.js +0 -247
  205. package/build/ui/Cx.spec.d.ts +0 -1
  206. package/build/ui/Cx.spec.js +0 -153
  207. package/build/ui/DataProxy.spec.d.ts +0 -1
  208. package/build/ui/DataProxy.spec.js +0 -208
  209. package/build/ui/IsolatedScope.spec.d.ts +0 -1
  210. package/build/ui/IsolatedScope.spec.js +0 -42
  211. package/build/ui/PureContainer.spec.d.ts +0 -1
  212. package/build/ui/PureContainer.spec.js +0 -149
  213. package/build/ui/Repeater.spec.d.ts +0 -1
  214. package/build/ui/Repeater.spec.js +0 -109
  215. package/build/ui/Rescope.spec.d.ts +0 -1
  216. package/build/ui/Rescope.spec.js +0 -134
  217. package/build/ui/Restate.spec.d.ts +0 -1
  218. package/build/ui/Restate.spec.js +0 -257
  219. package/build/ui/adapter/ArrayAdapter.spec.d.ts +0 -1
  220. package/build/ui/adapter/ArrayAdapter.spec.js +0 -44
  221. package/build/ui/adapter/TreeAdapter.spec.d.ts +0 -1
  222. package/build/ui/adapter/TreeAdapter.spec.js +0 -71
  223. package/build/ui/app/Url.spec.d.ts +0 -1
  224. package/build/ui/app/Url.spec.js +0 -43
  225. package/build/ui/createFunctionalComponent.spec.d.ts +0 -1
  226. package/build/ui/createFunctionalComponent.spec.js +0 -272
  227. package/build/ui/layout/ContentPlaceholder.spec.d.ts +0 -1
  228. package/build/ui/layout/ContentPlaceholder.spec.js +0 -333
  229. package/build/ui/layout/FirstVisibleChildLayout.spec.d.ts +0 -1
  230. package/build/ui/layout/FirstVisibleChildLayout.spec.js +0 -101
  231. package/build/util/Format.spec.d.ts +0 -1
  232. package/build/util/Format.spec.js +0 -58
  233. package/build/util/TraversalStack.spec.d.ts +0 -1
  234. package/build/util/TraversalStack.spec.js +0 -43
  235. package/build/util/date/upperBoundCheck.spec.d.ts +0 -1
  236. package/build/util/date/upperBoundCheck.spec.js +0 -22
  237. package/build/util/getSearchQueryPredicate.spec.d.ts +0 -1
  238. package/build/util/getSearchQueryPredicate.spec.js +0 -33
  239. package/build/util/isValidIdentifierName.spec.d.ts +0 -1
  240. package/build/util/isValidIdentifierName.spec.js +0 -28
  241. package/build/util/routeAppend.spec.d.ts +0 -1
  242. package/build/util/routeAppend.spec.js +0 -14
  243. package/build/widgets/AccessorBindings.spec.d.ts +0 -1
  244. package/build/widgets/AccessorBindings.spec.js +0 -40
  245. package/build/widgets/HtmlElement.spec.d.ts +0 -1
  246. package/build/widgets/HtmlElement.spec.js +0 -38
  247. package/build/widgets/form/ValidationGroup.spec.d.ts +0 -1
  248. package/build/widgets/form/ValidationGroup.spec.js +0 -62
  249. package/build/widgets/nav/Route.spec.d.ts +0 -1
  250. package/build/widgets/nav/Route.spec.js +0 -15
  251. package/dist/manifest.d.ts +0 -1443
@@ -1,66 +1,66 @@
1
- import { expr } from "cx/ui";
2
- import { Binding } from "./Binding";
3
- import { Expression } from "./Expression";
4
- import { StringTemplate } from "./StringTemplate";
5
- import { isArray } from "../util/isArray";
6
- import { createStructuredSelector, StructuredSelectorConfig } from "./createStructuredSelector";
7
- import { isSelector } from "./isSelector";
8
- import { isAccessorChain } from "./createAccessorModelProxy";
9
- import { isString } from "../util/isString";
10
- import { hasKey, hasStringAtKey, hasFunctionAtKey } from "../util/hasKey";
11
- import { isFunction } from "../util";
12
-
13
- type Selector<T> = (data: any) => T;
14
-
15
- var undefinedF = () => undefined;
16
- var nullF = () => null;
17
-
18
- export function getSelector(config: unknown): Selector<any> {
19
- if (config === undefined) return undefinedF;
20
- if (config === null) return nullF;
21
-
22
- switch (typeof config) {
23
- case "object":
24
- if (isArray(config)) {
25
- let selectors = config.map((x) => getSelector(x));
26
- return (data) => selectors.map((elementSelector) => elementSelector(data));
27
- }
28
-
29
- //toString converts accessor chains to binding paths
30
- if (hasKey(config, "bind") && config.bind != null) return Binding.get(config.bind.toString()).value;
31
-
32
- if (hasStringAtKey(config, "tpl")) return StringTemplate.get(config.tpl);
33
-
34
- if (hasKey(config, "expr") && (isString(config.expr) || isFunction(config.expr)))
35
- return Expression.get(config.expr as any);
36
-
37
- if (hasFunctionAtKey(config, "get")) return config.get;
38
-
39
- let selectors: StructuredSelectorConfig = {};
40
- let constants: Record<string, any> = {};
41
-
42
- let obj = config as Record<string, any>;
43
- for (let key in obj) {
44
- switch (typeof obj[key]) {
45
- case "bigint":
46
- case "boolean":
47
- case "number":
48
- case "string":
49
- constants[key] = obj[key];
50
- break;
51
- default:
52
- if (isSelector(obj[key])) selectors[key] = getSelector(obj[key]);
53
- else constants[key] = obj[key];
54
- break;
55
- }
56
- }
57
- return createStructuredSelector(selectors, constants);
58
-
59
- case "function":
60
- if (isAccessorChain(config)) return Binding.get(config.toString()).value;
61
- return config as Selector<any>;
62
-
63
- default:
64
- return () => config;
65
- }
66
- }
1
+ import { expr } from "cx/ui";
2
+ import { Binding } from "./Binding";
3
+ import { Expression } from "./Expression";
4
+ import { StringTemplate } from "./StringTemplate";
5
+ import { isArray } from "../util/isArray";
6
+ import { createStructuredSelector, StructuredSelectorConfig } from "./createStructuredSelector";
7
+ import { isSelector } from "./isSelector";
8
+ import { isAccessorChain } from "./createAccessorModelProxy";
9
+ import { isString } from "../util/isString";
10
+ import { hasKey, hasStringAtKey, hasFunctionAtKey } from "../util/hasKey";
11
+ import { isFunction } from "../util";
12
+
13
+ type Selector<T> = (data: any) => T;
14
+
15
+ var undefinedF = () => undefined;
16
+ var nullF = () => null;
17
+
18
+ export function getSelector(config: unknown): Selector<any> {
19
+ if (config === undefined) return undefinedF;
20
+ if (config === null) return nullF;
21
+
22
+ switch (typeof config) {
23
+ case "object":
24
+ if (isArray(config)) {
25
+ let selectors = config.map((x) => getSelector(x));
26
+ return (data) => selectors.map((elementSelector) => elementSelector(data));
27
+ }
28
+
29
+ //toString converts accessor chains to binding paths
30
+ if (hasKey(config, "bind") && config.bind != null) return Binding.get(config.bind.toString()).value;
31
+
32
+ if (hasStringAtKey(config, "tpl")) return StringTemplate.get(config.tpl);
33
+
34
+ if (hasKey(config, "expr") && (isString(config.expr) || isFunction(config.expr)))
35
+ return Expression.get(config.expr as any);
36
+
37
+ if (hasFunctionAtKey(config, "get")) return config.get;
38
+
39
+ let selectors: StructuredSelectorConfig = {};
40
+ let constants: Record<string, any> = {};
41
+
42
+ let obj = config as Record<string, any>;
43
+ for (let key in obj) {
44
+ switch (typeof obj[key]) {
45
+ case "bigint":
46
+ case "boolean":
47
+ case "number":
48
+ case "string":
49
+ constants[key] = obj[key];
50
+ break;
51
+ default:
52
+ if (isSelector(obj[key])) selectors[key] = getSelector(obj[key]);
53
+ else constants[key] = obj[key];
54
+ break;
55
+ }
56
+ }
57
+ return createStructuredSelector(selectors, constants);
58
+
59
+ case "function":
60
+ if (isAccessorChain(config)) return Binding.get(config.toString()).value;
61
+ return config as Selector<any>;
62
+
63
+ default:
64
+ return () => config;
65
+ }
66
+ }
@@ -1,35 +1,35 @@
1
- import assert from "assert";
2
- import { Store } from "../Store";
3
- import { filter } from "./filter";
4
-
5
- describe("filter", function () {
6
- it("should filter array elements", function () {
7
- let store = new Store({
8
- data: {
9
- array: [1, 2, 3],
10
- },
11
- });
12
-
13
- assert(store.update("array", filter, (x: number) => x > 1));
14
- assert.deepEqual(store.get("array"), [2, 3]);
15
- });
16
-
17
- it("should work with undefined arrays", function () {
18
- let store = new Store();
19
- assert.equal(
20
- false,
21
- store.update("array", filter, (x) => x > 1),
22
- );
23
- assert.deepEqual(store.get("array"), undefined);
24
- });
25
-
26
- it("returns same array if all elements satisfy condition", function () {
27
- let array = [1, 2, 3];
28
- let store = new Store({ data: { array } });
29
- assert.equal(
30
- false,
31
- store.update("array", filter, (x) => x > 0),
32
- );
33
- assert(store.get("array") === array);
34
- });
35
- });
1
+ import assert from "assert";
2
+ import { Store } from "../Store";
3
+ import { filter } from "./filter";
4
+
5
+ describe("filter", function () {
6
+ it("should filter array elements", function () {
7
+ let store = new Store({
8
+ data: {
9
+ array: [1, 2, 3],
10
+ },
11
+ });
12
+
13
+ assert(store.update("array", filter, (x: number) => x > 1));
14
+ assert.deepEqual(store.get("array"), [2, 3]);
15
+ });
16
+
17
+ it("should work with undefined arrays", function () {
18
+ let store = new Store();
19
+ assert.equal(
20
+ false,
21
+ store.update("array", filter, (x) => x > 1),
22
+ );
23
+ assert.deepEqual(store.get("array"), undefined);
24
+ });
25
+
26
+ it("returns same array if all elements satisfy condition", function () {
27
+ let array = [1, 2, 3];
28
+ let store = new Store({ data: { array } });
29
+ assert.equal(
30
+ false,
31
+ store.update("array", filter, (x) => x > 0),
32
+ );
33
+ assert(store.get("array") === array);
34
+ });
35
+ });
@@ -1,9 +1,9 @@
1
- export function filter<T = any>(array: T[], callback: (item: T, index: number, array: T[]) => boolean): T[] {
2
- if (array == null) return array;
3
-
4
- const result = array.filter(callback);
5
-
6
- if (result.length === array.length) return array;
7
-
8
- return result;
9
- }
1
+ export function filter<T = any>(array: T[], callback: (item: T, index: number, array: T[]) => boolean): T[] {
2
+ if (array == null) return array;
3
+
4
+ const result = array.filter(callback);
5
+
6
+ if (result.length === array.length) return array;
7
+
8
+ return result;
9
+ }
@@ -1,13 +1,13 @@
1
- import { Binding } from "../Binding";
2
-
3
- export function merge<T extends object>(item: T, data?: Partial<T>): T {
4
- let result = item;
5
-
6
- if (data) {
7
- for (const key in data) {
8
- result = Binding.get(key).set(result, data[key] as any);
9
- }
10
- }
11
-
12
- return result;
13
- }
1
+ import { Binding } from "../Binding";
2
+
3
+ export function merge<T extends object>(item: T, data?: Partial<T>): T {
4
+ let result = item;
5
+
6
+ if (data) {
7
+ for (const key in data) {
8
+ result = Binding.get(key).set(result, data[key] as any);
9
+ }
10
+ }
11
+
12
+ return result;
13
+ }
@@ -1,37 +1,37 @@
1
- import { Store } from "../Store";
2
- import { removeTreeNodes } from "./removeTreeNodes";
3
- import assert from "assert";
4
-
5
- describe("removeTreeNodes", function () {
6
- it("removes all nodes that satisfy criteria", function () {
7
- let store = new Store({
8
- data: {
9
- array: [
10
- {
11
- id: "n1",
12
- value: 1,
13
- children: [
14
- {
15
- id: "n11",
16
- value: 2,
17
- },
18
- {
19
- id: "n12",
20
- value: 3,
21
- },
22
- ],
23
- },
24
- ],
25
- },
26
- });
27
-
28
- assert(store.update("array", removeTreeNodes, (x: any) => x.value > 1, "children"));
29
- assert.deepEqual(store.get("array"), [
30
- {
31
- id: "n1",
32
- value: 1,
33
- children: [],
34
- },
35
- ]);
36
- });
37
- });
1
+ import { Store } from "../Store";
2
+ import { removeTreeNodes } from "./removeTreeNodes";
3
+ import assert from "assert";
4
+
5
+ describe("removeTreeNodes", function () {
6
+ it("removes all nodes that satisfy criteria", function () {
7
+ let store = new Store({
8
+ data: {
9
+ array: [
10
+ {
11
+ id: "n1",
12
+ value: 1,
13
+ children: [
14
+ {
15
+ id: "n11",
16
+ value: 2,
17
+ },
18
+ {
19
+ id: "n12",
20
+ value: 3,
21
+ },
22
+ ],
23
+ },
24
+ ],
25
+ },
26
+ });
27
+
28
+ assert(store.update("array", removeTreeNodes, (x: any) => x.value > 1, "children"));
29
+ assert.deepEqual(store.get("array"), [
30
+ {
31
+ id: "n1",
32
+ value: 1,
33
+ children: [],
34
+ },
35
+ ]);
36
+ });
37
+ });
@@ -1,69 +1,69 @@
1
- import { Store } from "../Store";
2
- import { updateArray } from "./updateArray";
3
- import assert from "assert";
4
-
5
- describe("updateArray", function () {
6
- it("updates all elements that satisfy criteria", function () {
7
- let store = new Store({
8
- data: { array: [1, 2, 3, 4, 5, 6] },
9
- });
10
-
11
- assert(
12
- store.update(
13
- "array",
14
- updateArray,
15
- (x) => x + 1,
16
- (x) => x > 3,
17
- ),
18
- );
19
- assert.deepEqual(store.get("array"), [1, 2, 3, 5, 6, 7]);
20
- });
21
-
22
- it("does not modify data if not necessary", function () {
23
- let array = [1, 2, 3, 4, 5, 6];
24
- let store = new Store({
25
- data: { array },
26
- });
27
-
28
- assert(
29
- false ===
30
- store.update(
31
- "array",
32
- updateArray,
33
- (x) => x + 1,
34
- (x) => x > 10,
35
- ),
36
- );
37
- assert(store.get("array") === array);
38
- });
39
-
40
- it("works with null or undefined", function () {
41
- let store = new Store();
42
- assert(
43
- false ===
44
- store.update(
45
- "array",
46
- updateArray,
47
- (x) => x + 1,
48
- (x) => x > 0,
49
- ),
50
- );
51
- });
52
-
53
- it("can remove elements given the criteria", function () {
54
- let store = new Store({
55
- data: { array: [1, 2, 3, 4, 5, 6] },
56
- });
57
-
58
- assert(
59
- store.update(
60
- "array",
61
- updateArray,
62
- (x) => x + 1,
63
- (x) => x > 3,
64
- (x) => x <= 3,
65
- ),
66
- );
67
- assert.deepEqual(store.get("array"), [5, 6, 7]);
68
- });
69
- });
1
+ import { Store } from "../Store";
2
+ import { updateArray } from "./updateArray";
3
+ import assert from "assert";
4
+
5
+ describe("updateArray", function () {
6
+ it("updates all elements that satisfy criteria", function () {
7
+ let store = new Store({
8
+ data: { array: [1, 2, 3, 4, 5, 6] },
9
+ });
10
+
11
+ assert(
12
+ store.update(
13
+ "array",
14
+ updateArray,
15
+ (x) => x + 1,
16
+ (x) => x > 3,
17
+ ),
18
+ );
19
+ assert.deepEqual(store.get("array"), [1, 2, 3, 5, 6, 7]);
20
+ });
21
+
22
+ it("does not modify data if not necessary", function () {
23
+ let array = [1, 2, 3, 4, 5, 6];
24
+ let store = new Store({
25
+ data: { array },
26
+ });
27
+
28
+ assert(
29
+ false ===
30
+ store.update(
31
+ "array",
32
+ updateArray,
33
+ (x) => x + 1,
34
+ (x) => x > 10,
35
+ ),
36
+ );
37
+ assert(store.get("array") === array);
38
+ });
39
+
40
+ it("works with null or undefined", function () {
41
+ let store = new Store();
42
+ assert(
43
+ false ===
44
+ store.update(
45
+ "array",
46
+ updateArray,
47
+ (x) => x + 1,
48
+ (x) => x > 0,
49
+ ),
50
+ );
51
+ });
52
+
53
+ it("can remove elements given the criteria", function () {
54
+ let store = new Store({
55
+ data: { array: [1, 2, 3, 4, 5, 6] },
56
+ });
57
+
58
+ assert(
59
+ store.update(
60
+ "array",
61
+ updateArray,
62
+ (x) => x + 1,
63
+ (x) => x > 3,
64
+ (x) => x <= 3,
65
+ ),
66
+ );
67
+ assert.deepEqual(store.get("array"), [5, 6, 7]);
68
+ });
69
+ });
@@ -1,7 +1,7 @@
1
- import { AccessorChain } from "./createAccessorModelProxy";
2
-
3
- // Test what AccessorChain<string[]> looks like
4
- type Test1 = AccessorChain<string[]>;
5
- type Test2 = AccessorChain<string[]>["length"];
6
-
7
- // The issue: does AccessorChain properly map array properties?
1
+ import { AccessorChain } from "./createAccessorModelProxy";
2
+
3
+ // Test what AccessorChain<string[]> looks like
4
+ type Test1 = AccessorChain<string[]>;
5
+ type Test2 = AccessorChain<string[]>["length"];
6
+
7
+ // The issue: does AccessorChain properly map array properties?
@@ -1,26 +1,26 @@
1
- import { getCurrentInstance } from "../ui/createFunctionalComponent";
2
- import { isArray } from "../util/isArray";
3
- import { computable, ComputableSelector } from "../data/computable";
4
- import { useStore } from "./store";
5
-
6
- export function addExploreCallback(callback: (...args: any[]) => any): () => void {
7
- let instance = getCurrentInstance();
8
- if (!instance.computables) instance.computables = [];
9
- instance.computables.push(callback);
10
- return () => {
11
- if (instance.computables) {
12
- instance.computables = instance.computables.filter((cb: unknown) => cb !== callback);
13
- }
14
- };
15
- }
16
-
17
- export function useTrigger(
18
- args: ComputableSelector[],
19
- callback: (...args: any[]) => void,
20
- autoRun?: boolean,
21
- ): () => void {
22
- if (!isArray(args)) throw new Error("First argument to useTrigger should be an array.");
23
- let store = useStore();
24
- let selector = computable(...args, callback).memoize(!autoRun && store.getData());
25
- return addExploreCallback(selector);
26
- }
1
+ import { getCurrentInstance } from "../ui/createFunctionalComponent";
2
+ import { isArray } from "../util/isArray";
3
+ import { computable, ComputableSelector } from "../data/computable";
4
+ import { useStore } from "./store";
5
+
6
+ export function addExploreCallback(callback: (...args: any[]) => any): () => void {
7
+ let instance = getCurrentInstance();
8
+ if (!instance.computables) instance.computables = [];
9
+ instance.computables.push(callback);
10
+ return () => {
11
+ if (instance.computables) {
12
+ instance.computables = instance.computables.filter((cb: unknown) => cb !== callback);
13
+ }
14
+ };
15
+ }
16
+
17
+ export function useTrigger(
18
+ args: ComputableSelector[],
19
+ callback: (...args: any[]) => void,
20
+ autoRun?: boolean,
21
+ ): () => void {
22
+ if (!isArray(args)) throw new Error("First argument to useTrigger should be an array.");
23
+ let store = useStore();
24
+ let selector = computable(...args, callback).memoize(!autoRun && store.getData());
25
+ return addExploreCallback(selector);
26
+ }
package/src/index.scss CHANGED
@@ -1,6 +1,6 @@
1
- @import "global";
2
- @import "util/index";
3
- @import "ui/index";
4
- @import "widgets/index";
5
- @import "svg/index";
6
- @import "charts/index";
1
+ @import "global";
2
+ @import "util/index";
3
+ @import "ui/index";
4
+ @import "widgets/index";
5
+ @import "svg/index";
6
+ @import "charts/index";
@@ -1,4 +1,4 @@
1
- import { jsx, jsxs } from "./jsx-runtime";
2
-
3
- export const jsxDEV = jsx;
4
- export const jsxsDEV = jsxs;
1
+ import { jsx, jsxs } from "./jsx-runtime";
2
+
3
+ export const jsxDEV = jsx;
4
+ export const jsxsDEV = jsxs;
@@ -1,7 +1,34 @@
1
1
  import assert from "assert";
2
- import { TextField } from "./widgets/form/TextField";
3
- import { NumberField } from "./widgets/form/NumberField";
4
2
  import { Button } from "./widgets/Button";
3
+ import { Widget, WidgetConfig } from "./ui/Widget";
4
+ import { StringProp, NumberProp, BooleanProp } from "./core";
5
+
6
+ // Minimal mock implementations to avoid side effects from importing real widgets
7
+
8
+ interface TextFieldConfig extends WidgetConfig {
9
+ value?: StringProp;
10
+ placeholder?: StringProp;
11
+ disabled?: BooleanProp;
12
+ readOnly?: BooleanProp;
13
+ required?: BooleanProp;
14
+ minLength?: NumberProp;
15
+ maxLength?: NumberProp;
16
+ validationErrorText?: StringProp;
17
+ }
18
+
19
+ class TextField extends Widget<TextFieldConfig> {}
20
+
21
+ interface NumberFieldConfig extends WidgetConfig {
22
+ value?: NumberProp;
23
+ placeholder?: StringProp;
24
+ minValue?: NumberProp;
25
+ maxValue?: NumberProp;
26
+ format?: StringProp;
27
+ disabled?: BooleanProp;
28
+ increment?: NumberProp;
29
+ }
30
+
31
+ class NumberField extends Widget<NumberFieldConfig> {}
5
32
  import { Checkbox } from "./widgets/form/Checkbox";
6
33
  import { bind } from "./ui/bind";
7
34
  import { expr } from "./ui/expr";
@@ -343,13 +370,15 @@ describe("jsx-runtime type inference", () => {
343
370
  optional?: boolean;
344
371
  }
345
372
 
346
- const ComponentWithRequiredProps = createFunctionalComponent<RequiredPropsConfig>(({ title, count, optional }) => (
347
- <cx>
348
- <div text={title} />
349
- <div text={String(count)} />
350
- {optional && <div text="optional shown" />}
351
- </cx>
352
- ));
373
+ const ComponentWithRequiredProps = createFunctionalComponent<RequiredPropsConfig>(
374
+ ({ title, count, optional }) => (
375
+ <cx>
376
+ <div text={title} />
377
+ <div text={String(count)} />
378
+ {optional && <div text="optional shown" />}
379
+ </cx>
380
+ ),
381
+ );
353
382
 
354
383
  it("accepts all required props provided", () => {
355
384
  const widget = (