cx 26.0.14 → 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 (263) 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/Widget.js +0 -5
  5. package/build/ui/app/startAppLoop.js +2 -10
  6. package/build/util/Component.js +5 -0
  7. package/build/util/test/createTestRenderer.d.ts +3 -1
  8. package/build/util/test/createTestRenderer.js +8 -2
  9. package/build/widgets/form/Checkbox.d.ts +0 -1
  10. package/build/widgets/form/Checkbox.js +1 -0
  11. package/build/widgets/form/ColorField.d.ts +0 -1
  12. package/build/widgets/form/ColorField.js +2 -2
  13. package/build/widgets/form/DateTimeField.d.ts +0 -2
  14. package/build/widgets/form/DateTimeField.js +1 -0
  15. package/build/widgets/form/DateTimePicker.d.ts +0 -2
  16. package/build/widgets/form/DateTimePicker.js +1 -0
  17. package/build/widgets/form/Radio.d.ts +0 -1
  18. package/build/widgets/form/Slider.js +9 -1
  19. package/build/widgets/form/Switch.d.ts +0 -1
  20. package/build/widgets/form/Switch.js +1 -1
  21. package/build/widgets/form/Wheel.d.ts +0 -1
  22. package/build/widgets/grid/Grid.d.ts +0 -2
  23. package/build/widgets/grid/GridCellEditor.js +3 -1
  24. package/build/widgets/icons/calendar.js +4 -3
  25. package/build/widgets/icons/check.js +2 -2
  26. package/build/widgets/icons/clear.js +2 -2
  27. package/build/widgets/icons/close.js +2 -2
  28. package/build/widgets/icons/cx.js +2 -2
  29. package/build/widgets/icons/drop-down.js +2 -2
  30. package/build/widgets/icons/file.js +2 -2
  31. package/build/widgets/icons/folder-open.js +2 -2
  32. package/build/widgets/icons/folder.js +2 -2
  33. package/build/widgets/icons/forward.js +2 -2
  34. package/build/widgets/icons/loading.js +2 -2
  35. package/build/widgets/icons/menu.js +2 -2
  36. package/build/widgets/icons/pixel-picker.js +2 -2
  37. package/build/widgets/icons/search.js +2 -2
  38. package/build/widgets/icons/sort-asc.js +2 -2
  39. package/build/widgets/icons/square.js +2 -2
  40. package/build/widgets/overlay/Overlay.d.ts +3 -0
  41. package/build/widgets/overlay/Overlay.js +3 -2
  42. package/dist/manifest.js +867 -867
  43. package/dist/ui.js +4 -18
  44. package/dist/util.js +4 -0
  45. package/dist/widgets.js +395 -319
  46. package/package.json +11 -8
  47. package/src/charts/Chart.ts +108 -108
  48. package/src/core.d.ts +182 -182
  49. package/src/data/Expression.spec.ts +229 -229
  50. package/src/data/Expression.ts +233 -233
  51. package/src/data/Grouper.ts +158 -158
  52. package/src/data/Selector.ts +10 -10
  53. package/src/data/StringTemplate.spec.ts +132 -132
  54. package/src/data/StructuredSelector.ts +146 -146
  55. package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
  56. package/src/data/comparer.ts +78 -78
  57. package/src/data/computable.spec.ts +87 -87
  58. package/src/data/createStructuredSelector.ts +62 -62
  59. package/src/data/getAccessor.spec.ts +11 -11
  60. package/src/data/getAccessor.ts +74 -74
  61. package/src/data/getSelector.spec.ts +43 -43
  62. package/src/data/getSelector.ts +66 -66
  63. package/src/data/ops/filter.spec.ts +35 -35
  64. package/src/data/ops/filter.ts +9 -9
  65. package/src/data/ops/merge.ts +13 -13
  66. package/src/data/ops/removeTreeNodes.spec.ts +37 -37
  67. package/src/data/ops/updateArray.spec.ts +69 -69
  68. package/src/data/ops/updateArray.ts +31 -31
  69. package/src/data/test-types.ts +7 -7
  70. package/src/hooks/invokeCallback.spec.tsx +4 -4
  71. package/src/hooks/resolveCallback.spec.tsx +4 -4
  72. package/src/hooks/store.spec.tsx +15 -15
  73. package/src/hooks/useTrigger.spec.tsx +16 -10
  74. package/src/hooks/useTrigger.ts +26 -26
  75. package/src/index.scss +6 -6
  76. package/src/jsx-runtime.ts +79 -79
  77. package/src/svg/BoundedObject.ts +101 -101
  78. package/src/svg/util/Rect.ts +105 -105
  79. package/src/ui/CSS.ts +87 -87
  80. package/src/ui/CSSHelper.ts +17 -17
  81. package/src/ui/ContentResolver.spec.tsx +31 -29
  82. package/src/ui/Controller.spec.tsx +47 -39
  83. package/src/ui/Culture.ts +159 -159
  84. package/src/ui/Cx.spec.tsx +10 -8
  85. package/src/ui/DataProxy.spec.tsx +18 -18
  86. package/src/ui/Instance.ts +866 -866
  87. package/src/ui/IsolatedScope.spec.tsx +16 -9
  88. package/src/ui/Prop.ts +140 -140
  89. package/src/ui/PureContainer.spec.tsx +20 -18
  90. package/src/ui/RenderingContext.ts +99 -99
  91. package/src/ui/Repeater.spec.tsx +8 -6
  92. package/src/ui/Rescope.spec.tsx +13 -13
  93. package/src/ui/Restate.spec.tsx +31 -27
  94. package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
  95. package/src/ui/VDOM.ts +1 -34
  96. package/src/ui/Widget.tsx +0 -7
  97. package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
  98. package/src/ui/adapter/TreeAdapter.ts +185 -185
  99. package/src/ui/app/History.ts +133 -133
  100. package/src/ui/app/Url.spec.ts +50 -50
  101. package/src/ui/app/startAppLoop.tsx +5 -9
  102. package/src/ui/app/startHotAppLoop.ts +41 -41
  103. package/src/ui/createFunctionalComponent.spec.tsx +20 -18
  104. package/src/ui/layout/ContentPlaceholder.spec.tsx +46 -34
  105. package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +31 -19
  106. package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
  107. package/src/ui/selection/PropertySelection.ts +87 -87
  108. package/src/util/Component.spec.ts +30 -0
  109. package/src/util/Component.ts +301 -296
  110. package/src/util/Console.ts +13 -13
  111. package/src/util/DOM.ts +88 -88
  112. package/src/util/hasKey.ts +18 -18
  113. package/src/util/index.ts +55 -55
  114. package/src/util/isArray.ts +3 -3
  115. package/src/util/isDefined.ts +3 -3
  116. package/src/util/isString.ts +3 -3
  117. package/src/util/test/createTestRenderer.tsx +9 -2
  118. package/src/widgets/AccessorBindings.spec.tsx +4 -4
  119. package/src/widgets/DocumentTitle.ts +95 -95
  120. package/src/widgets/HtmlElement.spec.tsx +6 -6
  121. package/src/widgets/ReactElementWrapper.spec.tsx +37 -37
  122. package/src/widgets/autoFocus.ts +9 -9
  123. package/src/widgets/cx.ts +63 -63
  124. package/src/widgets/form/Checkbox.tsx +0 -1
  125. package/src/widgets/form/ColorField.tsx +15 -12
  126. package/src/widgets/form/DateTimeField.tsx +0 -2
  127. package/src/widgets/form/DateTimePicker.tsx +0 -2
  128. package/src/widgets/form/Radio.tsx +0 -1
  129. package/src/widgets/form/Slider.tsx +12 -4
  130. package/src/widgets/form/Switch.tsx +2 -3
  131. package/src/widgets/form/ValidationGroup.spec.tsx +12 -12
  132. package/src/widgets/form/Wheel.tsx +0 -1
  133. package/src/widgets/grid/Grid.tsx +0 -1
  134. package/src/widgets/grid/GridCellEditor.tsx +7 -1
  135. package/src/widgets/icons/calendar.tsx +20 -15
  136. package/src/widgets/icons/check.tsx +2 -1
  137. package/src/widgets/icons/clear.tsx +2 -1
  138. package/src/widgets/icons/close.tsx +2 -2
  139. package/src/widgets/icons/cx.tsx +2 -1
  140. package/src/widgets/icons/drop-down.tsx +2 -1
  141. package/src/widgets/icons/file.tsx +2 -1
  142. package/src/widgets/icons/folder-open.tsx +2 -1
  143. package/src/widgets/icons/folder.tsx +2 -1
  144. package/src/widgets/icons/forward.tsx +2 -1
  145. package/src/widgets/icons/loading.tsx +2 -1
  146. package/src/widgets/icons/menu.tsx +2 -1
  147. package/src/widgets/icons/pixel-picker.tsx +2 -2
  148. package/src/widgets/icons/search.tsx +2 -1
  149. package/src/widgets/icons/sort-asc.tsx +2 -1
  150. package/src/widgets/icons/square.tsx +2 -1
  151. package/src/widgets/nav/Route.spec.tsx +2 -2
  152. package/src/widgets/overlay/Overlay.tsx +5 -1
  153. package/src/widgets/overlay/captureMouse.ts +195 -195
  154. package/src/widgets/overlay/createHotPromiseWindowFactory.ts +71 -71
  155. package/src/widgets/overlay/index.d.ts +11 -11
  156. package/src/widgets/overlay/tooltip-ops.ts +173 -173
  157. package/build/data/ArrayElementView.spec.d.ts +0 -1
  158. package/build/data/ArrayElementView.spec.js +0 -81
  159. package/build/data/Binding.spec.d.ts +0 -1
  160. package/build/data/Binding.spec.js +0 -61
  161. package/build/data/Expression.spec.d.ts +0 -1
  162. package/build/data/Expression.spec.js +0 -196
  163. package/build/data/Grouper.spec.d.ts +0 -1
  164. package/build/data/Grouper.spec.js +0 -48
  165. package/build/data/Ref.spec.d.ts +0 -1
  166. package/build/data/Ref.spec.js +0 -72
  167. package/build/data/Store.spec.d.ts +0 -1
  168. package/build/data/Store.spec.js +0 -19
  169. package/build/data/StoreRef.spec.d.ts +0 -1
  170. package/build/data/StoreRef.spec.js +0 -22
  171. package/build/data/StringTemplate.spec.d.ts +0 -1
  172. package/build/data/StringTemplate.spec.js +0 -112
  173. package/build/data/StructuredSelector.spec.d.ts +0 -1
  174. package/build/data/StructuredSelector.spec.js +0 -102
  175. package/build/data/View.spec.d.ts +0 -1
  176. package/build/data/View.spec.js +0 -44
  177. package/build/data/ZoomIntoPropertyView.spec.d.ts +0 -1
  178. package/build/data/ZoomIntoPropertyView.spec.js +0 -54
  179. package/build/data/comparer.spec.d.ts +0 -1
  180. package/build/data/comparer.spec.js +0 -50
  181. package/build/data/computable.spec.d.ts +0 -1
  182. package/build/data/computable.spec.js +0 -56
  183. package/build/data/createAccessorModelProxy.spec.d.ts +0 -1
  184. package/build/data/createAccessorModelProxy.spec.js +0 -30
  185. package/build/data/createStructuredSelector.spec.d.ts +0 -1
  186. package/build/data/createStructuredSelector.spec.js +0 -42
  187. package/build/data/diff/diffs.spec.d.ts +0 -1
  188. package/build/data/diff/diffs.spec.js +0 -45
  189. package/build/data/getAccessor.spec.d.ts +0 -1
  190. package/build/data/getAccessor.spec.js +0 -10
  191. package/build/data/getSelector.spec.d.ts +0 -1
  192. package/build/data/getSelector.spec.js +0 -36
  193. package/build/data/ops/append.spec.d.ts +0 -1
  194. package/build/data/ops/append.spec.js +0 -24
  195. package/build/data/ops/filter.spec.d.ts +0 -1
  196. package/build/data/ops/filter.spec.js +0 -25
  197. package/build/data/ops/findTreeNode.spec.d.ts +0 -1
  198. package/build/data/ops/findTreeNode.spec.js +0 -20
  199. package/build/data/ops/merge.spec.d.ts +0 -1
  200. package/build/data/ops/merge.spec.js +0 -23
  201. package/build/data/ops/removeTreeNodes.spec.d.ts +0 -1
  202. package/build/data/ops/removeTreeNodes.spec.js +0 -35
  203. package/build/data/ops/updateArray.spec.d.ts +0 -1
  204. package/build/data/ops/updateArray.spec.js +0 -33
  205. package/build/data/ops/updateTree.spec.d.ts +0 -1
  206. package/build/data/ops/updateTree.spec.js +0 -44
  207. package/build/hooks/invokeCallback.spec.d.ts +0 -1
  208. package/build/hooks/invokeCallback.spec.js +0 -44
  209. package/build/hooks/resolveCallback.spec.d.ts +0 -1
  210. package/build/hooks/resolveCallback.spec.js +0 -35
  211. package/build/hooks/store.spec.d.ts +0 -1
  212. package/build/hooks/store.spec.js +0 -48
  213. package/build/hooks/useTrigger.spec.d.ts +0 -1
  214. package/build/hooks/useTrigger.spec.js +0 -59
  215. package/build/ui/Controller.spec.d.ts +0 -1
  216. package/build/ui/Controller.spec.js +0 -247
  217. package/build/ui/Cx.spec.d.ts +0 -1
  218. package/build/ui/Cx.spec.js +0 -153
  219. package/build/ui/DataProxy.spec.d.ts +0 -1
  220. package/build/ui/DataProxy.spec.js +0 -208
  221. package/build/ui/IsolatedScope.spec.d.ts +0 -1
  222. package/build/ui/IsolatedScope.spec.js +0 -42
  223. package/build/ui/PureContainer.spec.d.ts +0 -1
  224. package/build/ui/PureContainer.spec.js +0 -149
  225. package/build/ui/Repeater.spec.d.ts +0 -1
  226. package/build/ui/Repeater.spec.js +0 -109
  227. package/build/ui/Rescope.spec.d.ts +0 -1
  228. package/build/ui/Rescope.spec.js +0 -134
  229. package/build/ui/Restate.spec.d.ts +0 -1
  230. package/build/ui/Restate.spec.js +0 -257
  231. package/build/ui/adapter/ArrayAdapter.spec.d.ts +0 -1
  232. package/build/ui/adapter/ArrayAdapter.spec.js +0 -44
  233. package/build/ui/adapter/TreeAdapter.spec.d.ts +0 -1
  234. package/build/ui/adapter/TreeAdapter.spec.js +0 -71
  235. package/build/ui/app/Url.spec.d.ts +0 -1
  236. package/build/ui/app/Url.spec.js +0 -43
  237. package/build/ui/createFunctionalComponent.spec.d.ts +0 -1
  238. package/build/ui/createFunctionalComponent.spec.js +0 -272
  239. package/build/ui/layout/ContentPlaceholder.spec.d.ts +0 -1
  240. package/build/ui/layout/ContentPlaceholder.spec.js +0 -333
  241. package/build/ui/layout/FirstVisibleChildLayout.spec.d.ts +0 -1
  242. package/build/ui/layout/FirstVisibleChildLayout.spec.js +0 -101
  243. package/build/util/Format.spec.d.ts +0 -1
  244. package/build/util/Format.spec.js +0 -58
  245. package/build/util/TraversalStack.spec.d.ts +0 -1
  246. package/build/util/TraversalStack.spec.js +0 -43
  247. package/build/util/date/upperBoundCheck.spec.d.ts +0 -1
  248. package/build/util/date/upperBoundCheck.spec.js +0 -22
  249. package/build/util/getSearchQueryPredicate.spec.d.ts +0 -1
  250. package/build/util/getSearchQueryPredicate.spec.js +0 -33
  251. package/build/util/isValidIdentifierName.spec.d.ts +0 -1
  252. package/build/util/isValidIdentifierName.spec.js +0 -28
  253. package/build/util/routeAppend.spec.d.ts +0 -1
  254. package/build/util/routeAppend.spec.js +0 -14
  255. package/build/widgets/AccessorBindings.spec.d.ts +0 -1
  256. package/build/widgets/AccessorBindings.spec.js +0 -40
  257. package/build/widgets/HtmlElement.spec.d.ts +0 -1
  258. package/build/widgets/HtmlElement.spec.js +0 -38
  259. package/build/widgets/form/ValidationGroup.spec.d.ts +0 -1
  260. package/build/widgets/form/ValidationGroup.spec.js +0 -62
  261. package/build/widgets/nav/Route.spec.d.ts +0 -1
  262. package/build/widgets/nav/Route.spec.js +0 -15
  263. 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,31 +1,31 @@
1
- export function updateArray<T = any>(
2
- array: T[] | undefined,
3
- updateCallback: (item: T, index: number) => T,
4
- itemFilter?: null | ((item: T, index: number) => boolean),
5
- removeFilter?: (item: T, index: number) => boolean,
6
- ): T[] | undefined {
7
- if (!array) return array;
8
-
9
- const newArray: T[] = [];
10
- let dirty: boolean = false;
11
-
12
- for (let index = 0; index < array.length; index++) {
13
- const item = array[index];
14
-
15
- if (removeFilter && removeFilter(item, index)) {
16
- dirty = true;
17
- continue;
18
- }
19
-
20
- if (!itemFilter || itemFilter(item, index)) {
21
- const newItem = updateCallback(item, index);
22
- newArray.push(newItem);
23
-
24
- if (newItem !== item) dirty = true;
25
- } else {
26
- newArray.push(item);
27
- }
28
- }
29
-
30
- return dirty ? newArray : array;
31
- }
1
+ export function updateArray<T = any>(
2
+ array: T[] | undefined,
3
+ updateCallback: (item: T, index: number) => T,
4
+ itemFilter?: null | ((item: T, index: number) => boolean),
5
+ removeFilter?: (item: T, index: number) => boolean,
6
+ ): T[] | undefined {
7
+ if (!array) return array;
8
+
9
+ const newArray: T[] = [];
10
+ let dirty: boolean = false;
11
+
12
+ for (let index = 0; index < array.length; index++) {
13
+ const item = array[index];
14
+
15
+ if (removeFilter && removeFilter(item, index)) {
16
+ dirty = true;
17
+ continue;
18
+ }
19
+
20
+ if (!itemFilter || itemFilter(item, index)) {
21
+ const newItem = updateCallback(item, index);
22
+ newArray.push(newItem);
23
+
24
+ if (newItem !== item) dirty = true;
25
+ } else {
26
+ newArray.push(item);
27
+ }
28
+ }
29
+
30
+ return dirty ? newArray : array;
31
+ }
@@ -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?
@@ -5,7 +5,7 @@ import { createTestRenderer } from "../util/test/createTestRenderer";
5
5
  import { invokeCallback } from "./invokeCallback";
6
6
 
7
7
  describe("invokeCallback", () => {
8
- it("works with functions", () => {
8
+ it("works with functions", async () => {
9
9
  const FComp = createFunctionalComponent(({ onTest }: { onTest: (v: any) => void }) => {
10
10
  invokeCallback(null!, onTest, "works");
11
11
  return (
@@ -17,7 +17,7 @@ describe("invokeCallback", () => {
17
17
 
18
18
  let store = new Store();
19
19
  let value;
20
- const component = createTestRenderer(store, {
20
+ const component = await createTestRenderer(store, {
21
21
  type: FComp,
22
22
  onTest: (v: any) => {
23
23
  value = v;
@@ -28,7 +28,7 @@ describe("invokeCallback", () => {
28
28
  assert.equal(value, "works");
29
29
  });
30
30
 
31
- it("works with controller methods", () => {
31
+ it("works with controller methods", async () => {
32
32
  const FComp = createFunctionalComponent(({ onTest }: { onTest: (v: any) => void }) => {
33
33
  return (
34
34
  <cx>
@@ -43,7 +43,7 @@ describe("invokeCallback", () => {
43
43
 
44
44
  let store = new Store();
45
45
  let value;
46
- const component = createTestRenderer(store, {
46
+ const component = await createTestRenderer(store, {
47
47
  type: FComp,
48
48
  onTest: "onTest",
49
49
  controller: {
@@ -5,7 +5,7 @@ import { createTestRenderer } from "../util/test/createTestRenderer";
5
5
  import { resolveCallback } from "./resolveCallback";
6
6
 
7
7
  describe("resolveCallback", () => {
8
- it("works with functions", () => {
8
+ it("works with functions", async () => {
9
9
  const FComp = createFunctionalComponent(({ onTest }: { onTest: (value: string) => void }) => {
10
10
  let callback = resolveCallback(onTest);
11
11
  assert(typeof callback === "function");
@@ -19,7 +19,7 @@ describe("resolveCallback", () => {
19
19
 
20
20
  let store = new Store();
21
21
  let value;
22
- const component = createTestRenderer(
22
+ const component = await createTestRenderer(
23
23
  store,
24
24
  <cx>
25
25
  <FComp
@@ -34,7 +34,7 @@ describe("resolveCallback", () => {
34
34
  assert.equal(value, "works");
35
35
  });
36
36
 
37
- it("works with controller methods", () => {
37
+ it("works with controller methods", async () => {
38
38
  const FComp = createFunctionalComponent(({ onTest }: { onTest: string | ((value: string) => void) }) => {
39
39
  let callback = resolveCallback(onTest);
40
40
  assert(typeof callback === "function");
@@ -51,7 +51,7 @@ describe("resolveCallback", () => {
51
51
 
52
52
  let store = new Store();
53
53
  let value;
54
- const component = createTestRenderer(
54
+ const component = await createTestRenderer(
55
55
  store,
56
56
  <cx>
57
57
  <FComp