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
package/src/data/Ref.ts CHANGED
@@ -1,104 +1,104 @@
1
- import { isFunction } from "../util/isFunction";
2
- import { Component } from "../util/Component";
3
- import { Binding } from "./Binding";
4
- import { View } from "./View";
5
- import { CanMemoize } from "./Selector";
6
-
7
- export interface RefConfig<T> {
8
- store?: View;
9
- path?: string;
10
- get?: () => T;
11
- set?: (value: T) => boolean;
12
- }
13
-
14
- export class Ref<T = any> extends Component implements CanMemoize<T> {
15
- declare isRef?: boolean;
16
-
17
- constructor(config: RefConfig<T>) {
18
- super(config);
19
- this.get = this.get.bind(this);
20
- if (this.set) this.set = this.set.bind(this);
21
- }
22
-
23
- get(): T {
24
- throw new Error("Ref's get method is not implemented.");
25
- }
26
-
27
- set(value: T): boolean {
28
- throw new Error("Ref's set method is not implemented.");
29
- }
30
-
31
- delete(): boolean {
32
- throw new Error("Ref's delete method is not implemented.");
33
- }
34
-
35
- // Component.init() override - no-op for compatibility
36
- init(): void;
37
- // Initialize ref value if it's currently undefined
38
- init(value: T): boolean;
39
- init(value?: T): boolean | void {
40
- if (value === undefined) return; // Component.init() compatibility
41
- if (this.get() === undefined) return this.set(value);
42
- return false;
43
- }
44
-
45
- toggle(): boolean {
46
- return this.set(!this.get() as T);
47
- }
48
-
49
- update(cb: (currentValue: T, ...args: any[]) => T, ...args: any[]): boolean {
50
- return this.set(cb(this.get(), ...args));
51
- }
52
-
53
- as(config: any): Ref {
54
- return Ref.create(config, {
55
- get: this.get,
56
- set: this.set,
57
- });
58
- }
59
-
60
- ref<ST = any>(path: string): Ref<ST> {
61
- let binding = Binding.get(path);
62
- return Ref.create({
63
- get: () => binding.value(this.get()),
64
- set: (value: any) => {
65
- let data = this.get();
66
- let newData = binding.set(data as Record<string, any>, value);
67
- if (data === newData) return false;
68
- return this.set(newData as T);
69
- },
70
- }) as Ref<ST>;
71
- }
72
-
73
- //allows the function to be passed as a selector, e.g. to computable or addTrigger
74
- memoize(): () => T {
75
- return this.get;
76
- }
77
- }
78
-
79
- Ref.prototype.isRef = true;
80
-
81
- Ref.factory = function (alias: any, config?: any, more?: any): Ref {
82
- if (isFunction(alias)) {
83
- let cfg = {
84
- ...config,
85
- ...more,
86
- };
87
-
88
- if (cfg.store) Object.assign(cfg, cfg.store.getMethods());
89
-
90
- let result = alias(cfg);
91
- if (result instanceof Ref) return result;
92
-
93
- return this.create({
94
- ...config,
95
- ...more,
96
- ...result,
97
- });
98
- }
99
-
100
- return this.create({
101
- ...config,
102
- ...more,
103
- });
104
- };
1
+ import { isFunction } from "../util/isFunction";
2
+ import { Component } from "../util/Component";
3
+ import { Binding } from "./Binding";
4
+ import { View } from "./View";
5
+ import { CanMemoize } from "./Selector";
6
+
7
+ export interface RefConfig<T> {
8
+ store?: View;
9
+ path?: string;
10
+ get?: () => T;
11
+ set?: (value: T) => boolean;
12
+ }
13
+
14
+ export class Ref<T = any> extends Component implements CanMemoize<T> {
15
+ declare isRef?: boolean;
16
+
17
+ constructor(config: RefConfig<T>) {
18
+ super(config);
19
+ this.get = this.get.bind(this);
20
+ if (this.set) this.set = this.set.bind(this);
21
+ }
22
+
23
+ get(): T {
24
+ throw new Error("Ref's get method is not implemented.");
25
+ }
26
+
27
+ set(value: T): boolean {
28
+ throw new Error("Ref's set method is not implemented.");
29
+ }
30
+
31
+ delete(): boolean {
32
+ throw new Error("Ref's delete method is not implemented.");
33
+ }
34
+
35
+ // Component.init() override - no-op for compatibility
36
+ init(): void;
37
+ // Initialize ref value if it's currently undefined
38
+ init(value: T): boolean;
39
+ init(value?: T): boolean | void {
40
+ if (value === undefined) return; // Component.init() compatibility
41
+ if (this.get() === undefined) return this.set(value);
42
+ return false;
43
+ }
44
+
45
+ toggle(): boolean {
46
+ return this.set(!this.get() as T);
47
+ }
48
+
49
+ update(cb: (currentValue: T, ...args: any[]) => T, ...args: any[]): boolean {
50
+ return this.set(cb(this.get(), ...args));
51
+ }
52
+
53
+ as(config: any): Ref {
54
+ return Ref.create(config, {
55
+ get: this.get,
56
+ set: this.set,
57
+ });
58
+ }
59
+
60
+ ref<ST = any>(path: string): Ref<ST> {
61
+ let binding = Binding.get(path);
62
+ return Ref.create({
63
+ get: () => binding.value(this.get()),
64
+ set: (value: any) => {
65
+ let data = this.get();
66
+ let newData = binding.set(data as Record<string, any>, value);
67
+ if (data === newData) return false;
68
+ return this.set(newData as T);
69
+ },
70
+ }) as Ref<ST>;
71
+ }
72
+
73
+ //allows the function to be passed as a selector, e.g. to computable or addTrigger
74
+ memoize(): () => T {
75
+ return this.get;
76
+ }
77
+ }
78
+
79
+ Ref.prototype.isRef = true;
80
+
81
+ Ref.factory = function (alias: any, config?: any, more?: any): Ref {
82
+ if (isFunction(alias)) {
83
+ let cfg = {
84
+ ...config,
85
+ ...more,
86
+ };
87
+
88
+ if (cfg.store) Object.assign(cfg, cfg.store.getMethods());
89
+
90
+ let result = alias(cfg);
91
+ if (result instanceof Ref) return result;
92
+
93
+ return this.create({
94
+ ...config,
95
+ ...more,
96
+ ...result,
97
+ });
98
+ }
99
+
100
+ return this.create({
101
+ ...config,
102
+ ...more,
103
+ });
104
+ };
@@ -1,10 +1,10 @@
1
- export interface Selector<T = any> {
2
- (data: any): T;
3
- memoize?: (warmupData?: unknown) => Selector<T>;
4
- }
5
-
6
- export interface CanMemoize<T = any> {
7
- memoize(warmupData?: unknown): Selector<T>;
8
- }
9
-
10
- export type MemoSelector<T = any> = Selector<T> & CanMemoize<T>;
1
+ export interface Selector<T = any> {
2
+ (data: any): T;
3
+ memoize?: (warmupData?: unknown) => Selector<T>;
4
+ }
5
+
6
+ export interface CanMemoize<T = any> {
7
+ memoize(warmupData?: unknown): Selector<T>;
8
+ }
9
+
10
+ export type MemoSelector<T = any> = Selector<T> & CanMemoize<T>;
package/src/data/Store.ts CHANGED
@@ -1,52 +1,52 @@
1
- import { Binding } from "./Binding";
2
- import { SubscribableView, SubscribableViewConfig } from "./SubscribableView";
3
-
4
- export interface StoreConfig<D = any> extends Omit<SubscribableViewConfig, "store"> {
5
- data?: D;
6
- }
7
-
8
- export class Store<D extends Record<string, any> = any> extends SubscribableView<D> {
9
- data: D;
10
-
11
- constructor(config: StoreConfig<D> = {}) {
12
- super(config);
13
- this.data = config.data ?? ({} as D);
14
- this.meta = {
15
- version: 0,
16
- };
17
- }
18
-
19
- getData(): D {
20
- return this.data;
21
- }
22
-
23
- setItem(path: string, value: any): boolean {
24
- let next = Binding.get(path).set(this.data, value);
25
- if (next != this.data) {
26
- this.data = next;
27
- this.meta.version++;
28
- this.notify(path);
29
- return true;
30
- }
31
- return false;
32
- }
33
-
34
- deleteItem(path: string): boolean {
35
- let next = Binding.get(path).delete(this.data);
36
- if (next != this.data) {
37
- this.data = next;
38
- this.meta.version++;
39
- this.notify(path);
40
- return true;
41
- }
42
- return false;
43
- }
44
-
45
- clear(): void {
46
- this.data = {} as D;
47
- this.meta.version++;
48
- this.notify();
49
- }
50
- }
51
-
52
- Store.prototype.async = false;
1
+ import { Binding } from "./Binding";
2
+ import { SubscribableView, SubscribableViewConfig } from "./SubscribableView";
3
+
4
+ export interface StoreConfig<D = any> extends Omit<SubscribableViewConfig, "store"> {
5
+ data?: D;
6
+ }
7
+
8
+ export class Store<D extends Record<string, any> = any> extends SubscribableView<D> {
9
+ data: D;
10
+
11
+ constructor(config: StoreConfig<D> = {}) {
12
+ super(config);
13
+ this.data = config.data ?? ({} as D);
14
+ this.meta = {
15
+ version: 0,
16
+ };
17
+ }
18
+
19
+ getData(): D {
20
+ return this.data;
21
+ }
22
+
23
+ setItem(path: string, value: any): boolean {
24
+ let next = Binding.get(path).set(this.data, value);
25
+ if (next != this.data) {
26
+ this.data = next;
27
+ this.meta.version++;
28
+ this.notify(path);
29
+ return true;
30
+ }
31
+ return false;
32
+ }
33
+
34
+ deleteItem(path: string): boolean {
35
+ let next = Binding.get(path).delete(this.data);
36
+ if (next != this.data) {
37
+ this.data = next;
38
+ this.meta.version++;
39
+ this.notify(path);
40
+ return true;
41
+ }
42
+ return false;
43
+ }
44
+
45
+ clear(): void {
46
+ this.data = {} as D;
47
+ this.meta.version++;
48
+ this.notify();
49
+ }
50
+ }
51
+
52
+ Store.prototype.async = false;
@@ -1,19 +1,19 @@
1
- import { View } from "./View";
2
-
3
- export class StoreProxy extends View {
4
- declare store: View;
5
-
6
- constructor(getStore: () => View) {
7
- super({
8
- store: getStore(),
9
- });
10
-
11
- Object.defineProperty(this, "store", {
12
- get: getStore,
13
- });
14
- }
15
-
16
- getData(): any {
17
- return this.store.getData();
18
- }
19
- }
1
+ import { View } from "./View";
2
+
3
+ export class StoreProxy extends View {
4
+ declare store: View;
5
+
6
+ constructor(getStore: () => View) {
7
+ super({
8
+ store: getStore(),
9
+ });
10
+
11
+ Object.defineProperty(this, "store", {
12
+ get: getStore,
13
+ });
14
+ }
15
+
16
+ getData(): any {
17
+ return this.store.getData();
18
+ }
19
+ }
@@ -1,66 +1,66 @@
1
- import { isAccessorChain } from "./createAccessorModelProxy";
2
- import { Ref, RefConfig } from "./Ref";
3
- import { View } from "./View";
4
-
5
- interface StoreRefConfig<T> extends RefConfig<T> {
6
- store: View;
7
- path: string;
8
- }
9
-
10
- export class StoreRef<T = any> extends Ref<T> {
11
- declare store: View;
12
- declare path: string;
13
-
14
- constructor(config: StoreRefConfig<T>) {
15
- super(config);
16
- if (isAccessorChain(this.path)) this.path = this.path.toString();
17
- }
18
-
19
- get() {
20
- return this.store.get(this.path);
21
- }
22
-
23
- set(value: T): boolean {
24
- return this.store.set(this.path, value);
25
- }
26
-
27
- init(): void;
28
- init(value: T): boolean;
29
- init(value?: T): boolean | void {
30
- if (value === undefined) return;
31
- return this.store.init(this.path, value);
32
- }
33
-
34
- toggle() {
35
- return this.store.toggle(this.path);
36
- }
37
-
38
- delete() {
39
- return this.store.delete(this.path);
40
- }
41
-
42
- update(cb: (currentValue: T, ...args: any[]) => T, ...args: any[]): boolean {
43
- return this.store.update(this.path, cb, ...args);
44
- }
45
-
46
- //allows the function to be passed as a selector, e.g. to computable or addTrigger
47
- memoize() {
48
- return this.get;
49
- }
50
-
51
- ref<ST = any>(path: string): StoreRef<ST> {
52
- return new StoreRef<ST>({
53
- path: `${this.path}.${path}`,
54
- store: this.store,
55
- });
56
- }
57
-
58
- as(config: RefConfig<T>) {
59
- return StoreRef.create(config, {
60
- path: this.path,
61
- store: this.store,
62
- get: this.get,
63
- set: this.set,
64
- });
65
- }
66
- }
1
+ import { isAccessorChain } from "./createAccessorModelProxy";
2
+ import { Ref, RefConfig } from "./Ref";
3
+ import { View } from "./View";
4
+
5
+ interface StoreRefConfig<T> extends RefConfig<T> {
6
+ store: View;
7
+ path: string;
8
+ }
9
+
10
+ export class StoreRef<T = any> extends Ref<T> {
11
+ declare store: View;
12
+ declare path: string;
13
+
14
+ constructor(config: StoreRefConfig<T>) {
15
+ super(config);
16
+ if (isAccessorChain(this.path)) this.path = this.path.toString();
17
+ }
18
+
19
+ get() {
20
+ return this.store.get(this.path);
21
+ }
22
+
23
+ set(value: T): boolean {
24
+ return this.store.set(this.path, value);
25
+ }
26
+
27
+ init(): void;
28
+ init(value: T): boolean;
29
+ init(value?: T): boolean | void {
30
+ if (value === undefined) return;
31
+ return this.store.init(this.path, value);
32
+ }
33
+
34
+ toggle() {
35
+ return this.store.toggle(this.path);
36
+ }
37
+
38
+ delete() {
39
+ return this.store.delete(this.path);
40
+ }
41
+
42
+ update(cb: (currentValue: T, ...args: any[]) => T, ...args: any[]): boolean {
43
+ return this.store.update(this.path, cb, ...args);
44
+ }
45
+
46
+ //allows the function to be passed as a selector, e.g. to computable or addTrigger
47
+ memoize() {
48
+ return this.get;
49
+ }
50
+
51
+ ref<ST = any>(path: string): StoreRef<ST> {
52
+ return new StoreRef<ST>({
53
+ path: `${this.path}.${path}`,
54
+ store: this.store,
55
+ });
56
+ }
57
+
58
+ as(config: RefConfig<T>) {
59
+ return StoreRef.create(config, {
60
+ path: this.path,
61
+ store: this.store,
62
+ get: this.get,
63
+ set: this.set,
64
+ });
65
+ }
66
+ }