@ngxs/store 18.1.6 → 19.0.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 (145) hide show
  1. package/experimental/index.d.ts +6 -5
  2. package/fesm2022/ngxs-store-experimental.mjs +8 -25
  3. package/fesm2022/ngxs-store-experimental.mjs.map +1 -1
  4. package/fesm2022/ngxs-store-internals-testing.mjs +8 -9
  5. package/fesm2022/ngxs-store-internals-testing.mjs.map +1 -1
  6. package/fesm2022/ngxs-store-internals.mjs +6 -6
  7. package/fesm2022/ngxs-store-internals.mjs.map +1 -1
  8. package/fesm2022/ngxs-store-operators.mjs.map +1 -1
  9. package/fesm2022/ngxs-store-plugins.mjs.map +1 -1
  10. package/fesm2022/ngxs-store.mjs +101 -72
  11. package/fesm2022/ngxs-store.mjs.map +1 -1
  12. package/index.d.ts +11 -1
  13. package/package.json +2 -14
  14. package/schematics/src/actions/actions.factory.js +1 -2
  15. package/schematics/src/actions/actions.factory.js.map +1 -1
  16. package/schematics/src/ng-add/add-declaration.js +2 -3
  17. package/schematics/src/ng-add/add-declaration.js.map +1 -1
  18. package/schematics/src/ng-add/ng-add.factory.js +1 -2
  19. package/schematics/src/ng-add/ng-add.factory.js.map +1 -1
  20. package/schematics/src/starter-kit/starter-kit.factory.js +1 -2
  21. package/schematics/src/starter-kit/starter-kit.factory.js.map +1 -1
  22. package/schematics/src/state/state.factory.js +1 -2
  23. package/schematics/src/state/state.factory.js.map +1 -1
  24. package/schematics/src/store/store.factory.js +1 -2
  25. package/schematics/src/store/store.factory.js.map +1 -1
  26. package/schematics/src/utils/common/properties.js +1 -2
  27. package/schematics/src/utils/common/properties.js.map +1 -1
  28. package/schematics/src/utils/config.js +2 -3
  29. package/schematics/src/utils/config.js.map +1 -1
  30. package/schematics/src/utils/generate-utils.js +1 -2
  31. package/schematics/src/utils/generate-utils.js.map +1 -1
  32. package/schematics/src/utils/normalize-options.js +3 -4
  33. package/schematics/src/utils/normalize-options.js.map +1 -1
  34. package/schematics/src/utils/project.js +4 -5
  35. package/schematics/src/utils/project.js.map +1 -1
  36. package/schematics/src/utils/versions.json +1 -1
  37. package/esm2022/experimental/index.mjs +0 -2
  38. package/esm2022/experimental/ngxs-store-experimental.mjs +0 -5
  39. package/esm2022/experimental/pending-tasks.mjs +0 -30
  40. package/esm2022/index.mjs +0 -13
  41. package/esm2022/internals/custom-rxjs-operators.mjs +0 -19
  42. package/esm2022/internals/custom-rxjs-subjects.mjs +0 -92
  43. package/esm2022/internals/index.mjs +0 -11
  44. package/esm2022/internals/initial-state.mjs +0 -17
  45. package/esm2022/internals/internal-tokens.mjs +0 -5
  46. package/esm2022/internals/memoize.mjs +0 -43
  47. package/esm2022/internals/metadata.mjs +0 -57
  48. package/esm2022/internals/ngxs-app-bootstrapped-state.mjs +0 -19
  49. package/esm2022/internals/ngxs-store-internals.mjs +0 -5
  50. package/esm2022/internals/state-stream.mjs +0 -33
  51. package/esm2022/internals/state-token.mjs +0 -17
  52. package/esm2022/internals/symbols.mjs +0 -11
  53. package/esm2022/internals/testing/fresh-platform.mjs +0 -72
  54. package/esm2022/internals/testing/helpers/ngxs-test.component.mjs +0 -16
  55. package/esm2022/internals/testing/helpers/ngxs-test.module.mjs +0 -20
  56. package/esm2022/internals/testing/index.mjs +0 -4
  57. package/esm2022/internals/testing/ngxs-store-internals-testing.mjs +0 -5
  58. package/esm2022/internals/testing/ngxs.setup.mjs +0 -49
  59. package/esm2022/internals/testing/skip-console-logging.mjs +0 -37
  60. package/esm2022/internals/testing/symbol.mjs +0 -2
  61. package/esm2022/ngxs-store.mjs +0 -5
  62. package/esm2022/operators/append.mjs +0 -20
  63. package/esm2022/operators/compose.mjs +0 -6
  64. package/esm2022/operators/iif.mjs +0 -38
  65. package/esm2022/operators/index.mjs +0 -14
  66. package/esm2022/operators/insert-item.mjs +0 -29
  67. package/esm2022/operators/ngxs-store-operators.mjs +0 -5
  68. package/esm2022/operators/patch.mjs +0 -21
  69. package/esm2022/operators/remove-item.mjs +0 -22
  70. package/esm2022/operators/types.mjs +0 -2
  71. package/esm2022/operators/update-item.mjs +0 -40
  72. package/esm2022/operators/utils.mjs +0 -19
  73. package/esm2022/plugins/actions.mjs +0 -16
  74. package/esm2022/plugins/index.mjs +0 -4
  75. package/esm2022/plugins/ngxs-store-plugins.mjs +0 -5
  76. package/esm2022/plugins/symbols.mjs +0 -15
  77. package/esm2022/plugins/utils.mjs +0 -51
  78. package/esm2022/src/actions/action-registry.mjs +0 -34
  79. package/esm2022/src/actions/symbols.mjs +0 -2
  80. package/esm2022/src/actions-stream.mjs +0 -61
  81. package/esm2022/src/configs/messages.config.mjs +0 -48
  82. package/esm2022/src/decorators/action.mjs +0 -31
  83. package/esm2022/src/decorators/select/select-factory.mjs +0 -29
  84. package/esm2022/src/decorators/select/select.mjs +0 -29
  85. package/esm2022/src/decorators/select/symbols.mjs +0 -29
  86. package/esm2022/src/decorators/selector/selector.mjs +0 -29
  87. package/esm2022/src/decorators/selector/symbols.mjs +0 -2
  88. package/esm2022/src/decorators/selector-options.mjs +0 -21
  89. package/esm2022/src/decorators/state.mjs +0 -35
  90. package/esm2022/src/dev-features/ngxs-development.module.mjs +0 -28
  91. package/esm2022/src/dev-features/ngxs-unhandled-actions-logger.mjs +0 -43
  92. package/esm2022/src/dev-features/symbols.mjs +0 -7
  93. package/esm2022/src/execution/dispatch-outside-zone-ngxs-execution-strategy.mjs +0 -52
  94. package/esm2022/src/execution/internal-ngxs-execution-strategy.mjs +0 -21
  95. package/esm2022/src/execution/noop-ngxs-execution-strategy.mjs +0 -17
  96. package/esm2022/src/execution/symbols.mjs +0 -28
  97. package/esm2022/src/internal/dispatcher.mjs +0 -125
  98. package/esm2022/src/internal/fallback-subscriber.mjs +0 -29
  99. package/esm2022/src/internal/internals.mjs +0 -205
  100. package/esm2022/src/internal/lifecycle-state-manager.mjs +0 -81
  101. package/esm2022/src/internal/provide-internal-tokens.mjs +0 -20
  102. package/esm2022/src/internal/state-context-factory.mjs +0 -70
  103. package/esm2022/src/internal/state-factory.mjs +0 -311
  104. package/esm2022/src/internal/state-operations.mjs +0 -60
  105. package/esm2022/src/internal/state-operators.mjs +0 -20
  106. package/esm2022/src/internal/unhandled-rxjs-error-callback.mjs +0 -46
  107. package/esm2022/src/ivy/ivy-enabled-in-dev-mode.mjs +0 -25
  108. package/esm2022/src/module.mjs +0 -27
  109. package/esm2022/src/modules/ngxs-feature.module.mjs +0 -18
  110. package/esm2022/src/modules/ngxs-root.module.mjs +0 -18
  111. package/esm2022/src/ngxs-unhandled-error-handler.mjs +0 -29
  112. package/esm2022/src/operators/leave-ngxs.mjs +0 -9
  113. package/esm2022/src/operators/of-action.mjs +0 -104
  114. package/esm2022/src/plugin-manager.mjs +0 -34
  115. package/esm2022/src/plugin_api.mjs +0 -2
  116. package/esm2022/src/private_api.mjs +0 -5
  117. package/esm2022/src/public_api.mjs +0 -20
  118. package/esm2022/src/selectors/create-model-selector.mjs +0 -30
  119. package/esm2022/src/selectors/create-pick-selector.mjs +0 -16
  120. package/esm2022/src/selectors/create-property-selectors.mjs +0 -20
  121. package/esm2022/src/selectors/create-selector.mjs +0 -9
  122. package/esm2022/src/selectors/index.mjs +0 -6
  123. package/esm2022/src/selectors/private_api.mjs +0 -2
  124. package/esm2022/src/selectors/selector-checks.util.mjs +0 -43
  125. package/esm2022/src/selectors/selector-metadata.mjs +0 -35
  126. package/esm2022/src/selectors/selector-models.mjs +0 -2
  127. package/esm2022/src/selectors/selector-types.util.mjs +0 -2
  128. package/esm2022/src/selectors/selector-utils.mjs +0 -95
  129. package/esm2022/src/standalone-features/feature-providers.mjs +0 -18
  130. package/esm2022/src/standalone-features/index.mjs +0 -5
  131. package/esm2022/src/standalone-features/initializers.mjs +0 -94
  132. package/esm2022/src/standalone-features/plugin.mjs +0 -33
  133. package/esm2022/src/standalone-features/preboot.mjs +0 -31
  134. package/esm2022/src/standalone-features/provide-states.mjs +0 -26
  135. package/esm2022/src/standalone-features/provide-store.mjs +0 -26
  136. package/esm2022/src/standalone-features/root-providers.mjs +0 -34
  137. package/esm2022/src/store.mjs +0 -117
  138. package/esm2022/src/symbols.mjs +0 -86
  139. package/esm2022/src/utils/create-dispatch-map.mjs +0 -11
  140. package/esm2022/src/utils/create-select-map.mjs +0 -13
  141. package/esm2022/src/utils/dispatch.mjs +0 -7
  142. package/esm2022/src/utils/freeze.mjs +0 -20
  143. package/esm2022/src/utils/public_api.mjs +0 -5
  144. package/esm2022/src/utils/select.mjs +0 -19
  145. package/esm2022/src/utils/store-validators.mjs +0 -25
@@ -1,205 +0,0 @@
1
- import { InjectionToken, inject } from '@angular/core';
2
- import { ɵMETA_KEY } from '@ngxs/store/internals';
3
- import { NgxsConfig } from '../symbols';
4
- /**
5
- * Get a deeply nested value. Example:
6
- *
7
- * getValue({ foo: bar: [] }, 'foo.bar') //=> []
8
- *
9
- * Note: This is not as fast as the `fastPropGetter` but is strict Content Security Policy compliant.
10
- * See perf hit: https://jsperf.com/fast-value-getter-given-path/1
11
- *
12
- * @ignore
13
- */
14
- function compliantPropGetter(paths) {
15
- return obj => {
16
- for (let i = 0; i < paths.length; i++) {
17
- if (!obj)
18
- return undefined;
19
- obj = obj[paths[i]];
20
- }
21
- return obj;
22
- };
23
- }
24
- /**
25
- * The generated function is faster than:
26
- * - pluck (Observable operator)
27
- * - memoize
28
- *
29
- * @ignore
30
- */
31
- function fastPropGetter(paths) {
32
- const segments = paths;
33
- let seg = 'store.' + segments[0];
34
- let i = 0;
35
- const l = segments.length;
36
- let expr = seg;
37
- while (++i < l) {
38
- expr = expr + ' && ' + (seg = seg + '.' + segments[i]);
39
- }
40
- const fn = new Function('store', 'return ' + expr + ';');
41
- return fn;
42
- }
43
- /**
44
- * Get a deeply nested value. Example:
45
- *
46
- * getValue({ foo: bar: [] }, 'foo.bar') //=> []
47
- *
48
- * @ignore
49
- *
50
- * Marked for removal. It's only used within `createSelectorFn`.
51
- */
52
- export function propGetter(paths, config) {
53
- if (config?.compatibility?.strictContentSecurityPolicy) {
54
- return compliantPropGetter(paths);
55
- }
56
- else {
57
- return fastPropGetter(paths);
58
- }
59
- }
60
- // This injection token selects the prop getter implementation once the app is
61
- // bootstrapped, as the `propGetter` function's behavior determines the implementation
62
- // each time it's called. It accepts the config as the second argument. We no longer
63
- // need to check for the `strictContentSecurityPolicy` every time the prop getter
64
- // implementation is selected. Now, the `propGetter` function is only used within
65
- // `createSelectorFn`, which, in turn, is solely used by the `Select` decorator.
66
- // We've been trying to deprecate the `Select` decorator because it's unstable with
67
- // server-side rendering and micro-frontend applications.
68
- export const ɵPROP_GETTER = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'PROP_GETTER' : '', {
69
- providedIn: 'root',
70
- factory: () => inject(NgxsConfig).compatibility?.strictContentSecurityPolicy
71
- ? compliantPropGetter
72
- : fastPropGetter
73
- });
74
- /**
75
- * Given an array of states, it will return a object graph. Example:
76
- * const states = [
77
- * Cart,
78
- * CartSaved,
79
- * CartSavedItems
80
- * ]
81
- *
82
- * would return:
83
- *
84
- * const graph = {
85
- * cart: ['saved'],
86
- * saved: ['items'],
87
- * items: []
88
- * };
89
- *
90
- * @ignore
91
- */
92
- export function buildGraph(stateClasses) {
93
- const findName = (stateClass) => {
94
- const meta = stateClasses.find(g => g === stateClass);
95
- if (typeof ngDevMode !== 'undefined' && ngDevMode && !meta) {
96
- throw new Error(`Child state not found: ${stateClass}. \r\nYou may have forgotten to add states to module`);
97
- }
98
- return meta[ɵMETA_KEY].name;
99
- };
100
- return stateClasses.reduce((result, stateClass) => {
101
- const { name, children } = stateClass[ɵMETA_KEY];
102
- result[name] = (children || []).map(findName);
103
- return result;
104
- }, {});
105
- }
106
- /**
107
- * Given a states array, returns object graph
108
- * returning the name and state metadata. Example:
109
- *
110
- * const graph = {
111
- * cart: { metadata }
112
- * };
113
- *
114
- * @ignore
115
- */
116
- export function nameToState(states) {
117
- return states.reduce((result, stateClass) => {
118
- const meta = stateClass[ɵMETA_KEY];
119
- result[meta.name] = stateClass;
120
- return result;
121
- }, {});
122
- }
123
- /**
124
- * Given a object relationship graph will return the full path
125
- * for the child items. Example:
126
- *
127
- * const graph = {
128
- * cart: ['saved'],
129
- * saved: ['items'],
130
- * items: []
131
- * };
132
- *
133
- * would return:
134
- *
135
- * const r = {
136
- * cart: 'cart',
137
- * saved: 'cart.saved',
138
- * items: 'cart.saved.items'
139
- * };
140
- *
141
- * @ignore
142
- */
143
- export function findFullParentPath(obj, newObj = {}) {
144
- const visit = (child, keyToFind) => {
145
- for (const key in child) {
146
- if (child.hasOwnProperty(key) && child[key].indexOf(keyToFind) >= 0) {
147
- const parent = visit(child, key);
148
- return parent !== null ? `${parent}.${key}` : key;
149
- }
150
- }
151
- return null;
152
- };
153
- for (const key in obj) {
154
- if (obj.hasOwnProperty(key)) {
155
- const parent = visit(obj, key);
156
- newObj[key] = parent ? `${parent}.${key}` : key;
157
- }
158
- }
159
- return newObj;
160
- }
161
- /**
162
- * Given a object graph, it will return the items topologically sorted Example:
163
- *
164
- * const graph = {
165
- * cart: ['saved'],
166
- * saved: ['items'],
167
- * items: []
168
- * };
169
- *
170
- * would return:
171
- *
172
- * const results = [
173
- * 'items',
174
- * 'saved',
175
- * 'cart'
176
- * ];
177
- *
178
- * @ignore
179
- */
180
- export function topologicalSort(graph) {
181
- const sorted = [];
182
- const visited = {};
183
- const visit = (name, ancestors = []) => {
184
- if (!Array.isArray(ancestors)) {
185
- ancestors = [];
186
- }
187
- ancestors.push(name);
188
- visited[name] = true;
189
- graph[name].forEach((dep) => {
190
- if (typeof ngDevMode !== 'undefined' && ngDevMode && ancestors.indexOf(dep) >= 0) {
191
- throw new Error(`Circular dependency '${dep}' is required by '${name}': ${ancestors.join(' -> ')}`);
192
- }
193
- if (visited[dep]) {
194
- return;
195
- }
196
- visit(dep, ancestors.slice(0));
197
- });
198
- if (sorted.indexOf(name) < 0) {
199
- sorted.push(name);
200
- }
201
- };
202
- Object.keys(graph).forEach(k => visit(k));
203
- return sorted.reverse();
204
- }
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"internals.js","sourceRoot":"","sources":["../../../../../packages/store/src/internal/internals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGvD,OAAO,EACL,SAAS,EAIV,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AA6BxC;;;;;;;;;GASG;AACH,SAAS,mBAAmB,CAAC,KAAe;IAC1C,OAAO,GAAG,CAAC,EAAE;QACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,IAAI,CAAC,GAAG;gBAAE,OAAO,SAAS,CAAC;YAC3B,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,SAAS,cAAc,CAAC,KAAe;IACrC,MAAM,QAAQ,GAAG,KAAK,CAAC;IACvB,IAAI,GAAG,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IACjC,IAAI,CAAC,GAAG,CAAC,CAAC;IACV,MAAM,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;IAE1B,IAAI,IAAI,GAAG,GAAG,CAAC;IACf,OAAO,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;QACf,IAAI,GAAG,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,EAAE,GAAG,IAAI,QAAQ,CAAC,OAAO,EAAE,SAAS,GAAG,IAAI,GAAG,GAAG,CAAC,CAAC;IAEzD,OAAwB,EAAE,CAAC;AAC7B,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,UAAU,CAAC,KAAe,EAAE,MAAkB;IAC5D,IAAI,MAAM,EAAE,aAAa,EAAE,2BAA2B,EAAE,CAAC;QACvD,OAAO,mBAAmB,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;SAAM,CAAC;QACN,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;AACH,CAAC;AAED,8EAA8E;AAC9E,sFAAsF;AACtF,oFAAoF;AACpF,iFAAiF;AACjF,iFAAiF;AACjF,gFAAgF;AAChF,mFAAmF;AACnF,yDAAyD;AACzD,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,cAAc,CAC5C,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,EAClE;IACE,UAAU,EAAE,MAAM;IAClB,OAAO,EAAE,GAAG,EAAE,CACZ,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,2BAA2B;QAC3D,CAAC,CAAC,mBAAmB;QACrB,CAAC,CAAC,cAAc;CACrB,CACF,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,UAAU,UAAU,CAAC,YAAmC;IAC5D,MAAM,QAAQ,GAAG,CAAC,UAA+B,EAAE,EAAE;QACnD,MAAM,IAAI,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,UAAU,CAAC,CAAC;QAEtD,IAAI,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,IAAI,CAAC,IAAI,EAAE,CAAC;YAC3D,MAAM,IAAI,KAAK,CACb,0BAA0B,UAAU,sDAAsD,CAC3F,CAAC;QACJ,CAAC;QAED,OAAO,IAAK,CAAC,SAAS,CAAE,CAAC,IAAK,CAAC;IACjC,CAAC,CAAC;IAEF,OAAO,YAAY,CAAC,MAAM,CACxB,CAAC,MAAqB,EAAE,UAA+B,EAAE,EAAE;QACzD,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,SAAS,CAAE,CAAC;QAClD,MAAM,CAAC,IAAK,CAAC,GAAG,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC/C,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,EAAE,CACH,CAAC;AACJ,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,WAAW,CACzB,MAA6B;IAE7B,OAAO,MAAM,CAAC,MAAM,CAClB,CAAC,MAA2C,EAAE,UAA+B,EAAE,EAAE;QAC/E,MAAM,IAAI,GAAG,UAAU,CAAC,SAAS,CAAE,CAAC;QACpC,MAAM,CAAC,IAAI,CAAC,IAAK,CAAC,GAAG,UAAU,CAAC;QAChC,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,EAAE,CACH,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,kBAAkB,CAChC,GAAkB,EAClB,SAAiC,EAAE;IAEnC,MAAM,KAAK,GAAG,CAAC,KAAoB,EAAE,SAAiB,EAAiB,EAAE;QACvE,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;YACxB,IAAI,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;gBACpE,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;gBACjC,OAAO,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;YACpD,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;QAClD,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,eAAe,CAAC,KAAoB;IAClD,MAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,MAAM,OAAO,GAA4B,EAAE,CAAC;IAE5C,MAAM,KAAK,GAAG,CAAC,IAAY,EAAE,YAAsB,EAAE,EAAE,EAAE;QACvD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9B,SAAS,GAAG,EAAE,CAAC;QACjB,CAAC;QAED,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;QAErB,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,EAAE;YAClC,IAAI,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,IAAI,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACjF,MAAM,IAAI,KAAK,CACb,wBAAwB,GAAG,qBAAqB,IAAI,MAAM,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CACnF,CAAC;YACJ,CAAC;YAED,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;gBACjB,OAAO;YACT,CAAC;YAED,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QAEH,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAE1C,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC;AAC1B,CAAC","sourcesContent":["import { InjectionToken, inject } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport {\n  ɵMETA_KEY,\n  ɵPlainObjectOf,\n  ɵStateClassInternal,\n  ɵActionHandlerMetaData\n} from '@ngxs/store/internals';\n\nimport { NgxsConfig } from '../symbols';\n\ndeclare const ngDevMode: boolean;\n\nexport type StateKeyGraph = ɵPlainObjectOf<string[]>;\nexport type StatesByName = ɵPlainObjectOf<ɵStateClassInternal>;\n\nexport interface StateOperations<T> {\n  getState(): T;\n\n  setState(val: T): void;\n\n  dispatch(actionOrActions: any | any[]): Observable<void>;\n}\n\nexport interface MappedStore {\n  name: string;\n  isInitialised: boolean;\n  actions: ɵPlainObjectOf<ɵActionHandlerMetaData[]>;\n  defaults: any;\n  instance: any;\n  path: string;\n}\n\nexport interface StatesAndDefaults {\n  defaults: any;\n  states: MappedStore[];\n}\n\n/**\n * Get a deeply nested value. Example:\n *\n *    getValue({ foo: bar: [] }, 'foo.bar') //=> []\n *\n * Note: This is not as fast as the `fastPropGetter` but is strict Content Security Policy compliant.\n * See perf hit: https://jsperf.com/fast-value-getter-given-path/1\n *\n * @ignore\n */\nfunction compliantPropGetter(paths: string[]): (x: any) => any {\n  return obj => {\n    for (let i = 0; i < paths.length; i++) {\n      if (!obj) return undefined;\n      obj = obj[paths[i]];\n    }\n    return obj;\n  };\n}\n\n/**\n * The generated function is faster than:\n * - pluck (Observable operator)\n * - memoize\n *\n * @ignore\n */\nfunction fastPropGetter(paths: string[]): (x: any) => any {\n  const segments = paths;\n  let seg = 'store.' + segments[0];\n  let i = 0;\n  const l = segments.length;\n\n  let expr = seg;\n  while (++i < l) {\n    expr = expr + ' && ' + (seg = seg + '.' + segments[i]);\n  }\n\n  const fn = new Function('store', 'return ' + expr + ';');\n\n  return <(x: any) => any>fn;\n}\n\n/**\n * Get a deeply nested value. Example:\n *\n *    getValue({ foo: bar: [] }, 'foo.bar') //=> []\n *\n * @ignore\n *\n * Marked for removal. It's only used within `createSelectorFn`.\n */\nexport function propGetter(paths: string[], config: NgxsConfig) {\n  if (config?.compatibility?.strictContentSecurityPolicy) {\n    return compliantPropGetter(paths);\n  } else {\n    return fastPropGetter(paths);\n  }\n}\n\n// This injection token selects the prop getter implementation once the app is\n// bootstrapped, as the `propGetter` function's behavior determines the implementation\n// each time it's called. It accepts the config as the second argument. We no longer\n// need to check for the `strictContentSecurityPolicy` every time the prop getter\n// implementation is selected. Now, the `propGetter` function is only used within\n// `createSelectorFn`, which, in turn, is solely used by the `Select` decorator.\n// We've been trying to deprecate the `Select` decorator because it's unstable with\n// server-side rendering and micro-frontend applications.\nexport const ɵPROP_GETTER = new InjectionToken<(paths: string[]) => (x: any) => any>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'PROP_GETTER' : '',\n  {\n    providedIn: 'root',\n    factory: () =>\n      inject(NgxsConfig).compatibility?.strictContentSecurityPolicy\n        ? compliantPropGetter\n        : fastPropGetter\n  }\n);\n\n/**\n * Given an array of states, it will return a object graph. Example:\n *    const states = [\n *      Cart,\n *      CartSaved,\n *      CartSavedItems\n *    ]\n *\n * would return:\n *\n *  const graph = {\n *    cart: ['saved'],\n *    saved: ['items'],\n *    items: []\n *  };\n *\n * @ignore\n */\nexport function buildGraph(stateClasses: ɵStateClassInternal[]): StateKeyGraph {\n  const findName = (stateClass: ɵStateClassInternal) => {\n    const meta = stateClasses.find(g => g === stateClass);\n\n    if (typeof ngDevMode !== 'undefined' && ngDevMode && !meta) {\n      throw new Error(\n        `Child state not found: ${stateClass}. \\r\\nYou may have forgotten to add states to module`\n      );\n    }\n\n    return meta![ɵMETA_KEY]!.name!;\n  };\n\n  return stateClasses.reduce<StateKeyGraph>(\n    (result: StateKeyGraph, stateClass: ɵStateClassInternal) => {\n      const { name, children } = stateClass[ɵMETA_KEY]!;\n      result[name!] = (children || []).map(findName);\n      return result;\n    },\n    {}\n  );\n}\n\n/**\n * Given a states array, returns object graph\n * returning the name and state metadata. Example:\n *\n *  const graph = {\n *    cart: { metadata }\n *  };\n *\n * @ignore\n */\nexport function nameToState(\n  states: ɵStateClassInternal[]\n): ɵPlainObjectOf<ɵStateClassInternal> {\n  return states.reduce<ɵPlainObjectOf<ɵStateClassInternal>>(\n    (result: ɵPlainObjectOf<ɵStateClassInternal>, stateClass: ɵStateClassInternal) => {\n      const meta = stateClass[ɵMETA_KEY]!;\n      result[meta.name!] = stateClass;\n      return result;\n    },\n    {}\n  );\n}\n\n/**\n * Given a object relationship graph will return the full path\n * for the child items. Example:\n *\n *  const graph = {\n *    cart: ['saved'],\n *    saved: ['items'],\n *    items: []\n *  };\n *\n * would return:\n *\n *  const r = {\n *    cart: 'cart',\n *    saved: 'cart.saved',\n *    items: 'cart.saved.items'\n *  };\n *\n * @ignore\n */\nexport function findFullParentPath(\n  obj: StateKeyGraph,\n  newObj: ɵPlainObjectOf<string> = {}\n): ɵPlainObjectOf<string> {\n  const visit = (child: StateKeyGraph, keyToFind: string): string | null => {\n    for (const key in child) {\n      if (child.hasOwnProperty(key) && child[key].indexOf(keyToFind) >= 0) {\n        const parent = visit(child, key);\n        return parent !== null ? `${parent}.${key}` : key;\n      }\n    }\n    return null;\n  };\n\n  for (const key in obj) {\n    if (obj.hasOwnProperty(key)) {\n      const parent = visit(obj, key);\n      newObj[key] = parent ? `${parent}.${key}` : key;\n    }\n  }\n\n  return newObj;\n}\n\n/**\n * Given a object graph, it will return the items topologically sorted Example:\n *\n *  const graph = {\n *    cart: ['saved'],\n *    saved: ['items'],\n *    items: []\n *  };\n *\n * would return:\n *\n *  const results = [\n *    'items',\n *    'saved',\n *    'cart'\n *  ];\n *\n * @ignore\n */\nexport function topologicalSort(graph: StateKeyGraph): string[] {\n  const sorted: string[] = [];\n  const visited: ɵPlainObjectOf<boolean> = {};\n\n  const visit = (name: string, ancestors: string[] = []) => {\n    if (!Array.isArray(ancestors)) {\n      ancestors = [];\n    }\n\n    ancestors.push(name);\n    visited[name] = true;\n\n    graph[name].forEach((dep: string) => {\n      if (typeof ngDevMode !== 'undefined' && ngDevMode && ancestors.indexOf(dep) >= 0) {\n        throw new Error(\n          `Circular dependency '${dep}' is required by '${name}': ${ancestors.join(' -> ')}`\n        );\n      }\n\n      if (visited[dep]) {\n        return;\n      }\n\n      visit(dep, ancestors.slice(0));\n    });\n\n    if (sorted.indexOf(name) < 0) {\n      sorted.push(name);\n    }\n  };\n\n  Object.keys(graph).forEach(k => visit(k));\n\n  return sorted.reverse();\n}\n"]}
@@ -1,81 +0,0 @@
1
- import { inject, Injectable } from '@angular/core';
2
- import { ɵNgxsAppBootstrappedState } from '@ngxs/store/internals';
3
- import { getValue, InitState, UpdateState } from '@ngxs/store/plugins';
4
- import { ReplaySubject } from 'rxjs';
5
- import { filter, mergeMap, pairwise, startWith, takeUntil, tap } from 'rxjs/operators';
6
- import { Store } from '../store';
7
- import { StateContextFactory } from './state-context-factory';
8
- import { InternalStateOperations } from './state-operations';
9
- import { NgxsSimpleChange } from '../symbols';
10
- import { getInvalidInitializationOrderMessage } from '../configs/messages.config';
11
- import * as i0 from "@angular/core";
12
- export class LifecycleStateManager {
13
- constructor() {
14
- this._store = inject(Store);
15
- this._internalStateOperations = inject(InternalStateOperations);
16
- this._stateContextFactory = inject(StateContextFactory);
17
- this._appBootstrappedState = inject(ɵNgxsAppBootstrappedState);
18
- this._destroy$ = new ReplaySubject(1);
19
- }
20
- ngOnDestroy() {
21
- this._destroy$.next();
22
- }
23
- ngxsBootstrap(action, results) {
24
- if (typeof ngDevMode !== 'undefined' && ngDevMode) {
25
- if (action instanceof InitState) {
26
- this._initStateHasBeenDispatched = true;
27
- }
28
- else if (
29
- // This is a dev mode-only check that ensures the correct order of
30
- // state initialization. The `NgxsModule.forRoot` or `provideStore` should
31
- // always come first, followed by `forFeature` and `provideStates`. If the
32
- // `UpdateState` is dispatched before the `InitState` is dispatched, it indicates
33
- // that modules or providers are in an invalid order.
34
- action instanceof UpdateState &&
35
- !this._initStateHasBeenDispatched) {
36
- console.error(getInvalidInitializationOrderMessage(action.addedStates));
37
- }
38
- }
39
- this._internalStateOperations
40
- .getRootStateOperations()
41
- .dispatch(action)
42
- .pipe(filter(() => !!results), tap(() => this._invokeInitOnStates(results.states)), mergeMap(() => this._appBootstrappedState), filter(appBootstrapped => !!appBootstrapped), takeUntil(this._destroy$))
43
- .subscribe(() => this._invokeBootstrapOnStates(results.states));
44
- }
45
- _invokeInitOnStates(mappedStores) {
46
- for (const mappedStore of mappedStores) {
47
- const instance = mappedStore.instance;
48
- if (instance.ngxsOnChanges) {
49
- this._store
50
- .select(state => getValue(state, mappedStore.path))
51
- .pipe(startWith(undefined), pairwise(), takeUntil(this._destroy$))
52
- .subscribe(([previousValue, currentValue]) => {
53
- const change = new NgxsSimpleChange(previousValue, currentValue, !mappedStore.isInitialised);
54
- instance.ngxsOnChanges(change);
55
- });
56
- }
57
- if (instance.ngxsOnInit) {
58
- instance.ngxsOnInit(this._getStateContext(mappedStore));
59
- }
60
- mappedStore.isInitialised = true;
61
- }
62
- }
63
- _invokeBootstrapOnStates(mappedStores) {
64
- for (const mappedStore of mappedStores) {
65
- const instance = mappedStore.instance;
66
- if (instance.ngxsAfterBootstrap) {
67
- instance.ngxsAfterBootstrap(this._getStateContext(mappedStore));
68
- }
69
- }
70
- }
71
- _getStateContext(mappedStore) {
72
- return this._stateContextFactory.createStateContext(mappedStore.path);
73
- }
74
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
75
- /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, providedIn: 'root' }); }
76
- }
77
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, decorators: [{
78
- type: Injectable,
79
- args: [{ providedIn: 'root' }]
80
- }] });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lifecycle-state-manager.js","sourceRoot":"","sources":["../../../../../packages/store/src/internal/lifecycle-state-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, OnDestroy } from '@angular/core';\nimport { ɵNgxsAppBootstrappedState } from '@ngxs/store/internals';\nimport { getValue, InitState, UpdateState } from '@ngxs/store/plugins';\nimport { ReplaySubject } from 'rxjs';\nimport { filter, mergeMap, pairwise, startWith, takeUntil, tap } from 'rxjs/operators';\n\nimport { Store } from '../store';\nimport { StateContextFactory } from './state-context-factory';\nimport { InternalStateOperations } from './state-operations';\nimport { MappedStore, StatesAndDefaults } from './internals';\nimport { NgxsLifeCycle, NgxsSimpleChange, StateContext } from '../symbols';\nimport { getInvalidInitializationOrderMessage } from '../configs/messages.config';\n\n@Injectable({ providedIn: 'root' })\nexport class LifecycleStateManager implements OnDestroy {\n  private _store = inject(Store);\n  private _internalStateOperations = inject(InternalStateOperations);\n  private _stateContextFactory = inject(StateContextFactory);\n  private _appBootstrappedState = inject(ɵNgxsAppBootstrappedState);\n\n  private readonly _destroy$ = new ReplaySubject<void>(1);\n\n  private _initStateHasBeenDispatched?: boolean;\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  ngxsBootstrap(\n    action: InitState | UpdateState,\n    results: StatesAndDefaults | undefined\n  ): void {\n    if (typeof ngDevMode !== 'undefined' && ngDevMode) {\n      if (action instanceof InitState) {\n        this._initStateHasBeenDispatched = true;\n      } else if (\n        // This is a dev mode-only check that ensures the correct order of\n        // state initialization. The `NgxsModule.forRoot` or `provideStore` should\n        // always come first, followed by `forFeature` and `provideStates`. If the\n        // `UpdateState` is dispatched before the `InitState` is dispatched, it indicates\n        // that modules or providers are in an invalid order.\n        action instanceof UpdateState &&\n        !this._initStateHasBeenDispatched\n      ) {\n        console.error(getInvalidInitializationOrderMessage(action.addedStates));\n      }\n    }\n\n    this._internalStateOperations\n      .getRootStateOperations()\n      .dispatch(action)\n      .pipe(\n        filter(() => !!results),\n        tap(() => this._invokeInitOnStates(results!.states)),\n        mergeMap(() => this._appBootstrappedState),\n        filter(appBootstrapped => !!appBootstrapped),\n        takeUntil(this._destroy$)\n      )\n      .subscribe(() => this._invokeBootstrapOnStates(results!.states));\n  }\n\n  private _invokeInitOnStates(mappedStores: MappedStore[]): void {\n    for (const mappedStore of mappedStores) {\n      const instance: NgxsLifeCycle = mappedStore.instance;\n\n      if (instance.ngxsOnChanges) {\n        this._store\n          .select(state => getValue(state, mappedStore.path))\n          .pipe(startWith(undefined), pairwise(), takeUntil(this._destroy$))\n          .subscribe(([previousValue, currentValue]) => {\n            const change = new NgxsSimpleChange(\n              previousValue,\n              currentValue,\n              !mappedStore.isInitialised\n            );\n            instance.ngxsOnChanges!(change);\n          });\n      }\n\n      if (instance.ngxsOnInit) {\n        instance.ngxsOnInit(this._getStateContext(mappedStore));\n      }\n\n      mappedStore.isInitialised = true;\n    }\n  }\n\n  private _invokeBootstrapOnStates(mappedStores: MappedStore[]) {\n    for (const mappedStore of mappedStores) {\n      const instance: NgxsLifeCycle = mappedStore.instance;\n      if (instance.ngxsAfterBootstrap) {\n        instance.ngxsAfterBootstrap(this._getStateContext(mappedStore));\n      }\n    }\n  }\n\n  private _getStateContext(mappedStore: MappedStore): StateContext<any> {\n    return this._stateContextFactory.createStateContext(mappedStore.path);\n  }\n}\n"]}
@@ -1,20 +0,0 @@
1
- import { makeEnvironmentProviders } from '@angular/core';
2
- import { ɵNGXS_STATE_CONTEXT_FACTORY, ɵNGXS_STATE_FACTORY } from '@ngxs/store/internals';
3
- import { StateFactory } from './state-factory';
4
- import { StateContextFactory } from './state-context-factory';
5
- // Backward compatibility is provided because these tokens are used by third-party
6
- // libraries. We expose a separate function to allow tree-shaking of these tokens
7
- // if they are not used in standard applications that do not rely on them.
8
- export function ɵprovideNgxsInternalStateTokens() {
9
- return makeEnvironmentProviders([
10
- {
11
- provide: ɵNGXS_STATE_CONTEXT_FACTORY,
12
- useExisting: StateContextFactory
13
- },
14
- {
15
- provide: ɵNGXS_STATE_FACTORY,
16
- useExisting: StateFactory
17
- }
18
- ]);
19
- }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1pbnRlcm5hbC10b2tlbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvaW50ZXJuYWwvcHJvdmlkZS1pbnRlcm5hbC10b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXpGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUU5RCxrRkFBa0Y7QUFDbEYsaUZBQWlGO0FBQ2pGLDBFQUEwRTtBQUMxRSxNQUFNLFVBQVUsK0JBQStCO0lBQzdDLE9BQU8sd0JBQXdCLENBQUM7UUFDOUI7WUFDRSxPQUFPLEVBQUUsMkJBQTJCO1lBQ3BDLFdBQVcsRUFBRSxtQkFBbUI7U0FDakM7UUFDRDtZQUNFLE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsV0FBVyxFQUFFLFlBQVk7U0FDMUI7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyDJtU5HWFNfU1RBVEVfQ09OVEVYVF9GQUNUT1JZLCDJtU5HWFNfU1RBVEVfRkFDVE9SWSB9IGZyb20gJ0BuZ3hzL3N0b3JlL2ludGVybmFscyc7XG5cbmltcG9ydCB7IFN0YXRlRmFjdG9yeSB9IGZyb20gJy4vc3RhdGUtZmFjdG9yeSc7XG5pbXBvcnQgeyBTdGF0ZUNvbnRleHRGYWN0b3J5IH0gZnJvbSAnLi9zdGF0ZS1jb250ZXh0LWZhY3RvcnknO1xuXG4vLyBCYWNrd2FyZCBjb21wYXRpYmlsaXR5IGlzIHByb3ZpZGVkIGJlY2F1c2UgdGhlc2UgdG9rZW5zIGFyZSB1c2VkIGJ5IHRoaXJkLXBhcnR5XG4vLyBsaWJyYXJpZXMuIFdlIGV4cG9zZSBhIHNlcGFyYXRlIGZ1bmN0aW9uIHRvIGFsbG93IHRyZWUtc2hha2luZyBvZiB0aGVzZSB0b2tlbnNcbi8vIGlmIHRoZXkgYXJlIG5vdCB1c2VkIGluIHN0YW5kYXJkIGFwcGxpY2F0aW9ucyB0aGF0IGRvIG5vdCByZWx5IG9uIHRoZW0uXG5leHBvcnQgZnVuY3Rpb24gybVwcm92aWRlTmd4c0ludGVybmFsU3RhdGVUb2tlbnMoKSB7XG4gIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IMm1TkdYU19TVEFURV9DT05URVhUX0ZBQ1RPUlksXG4gICAgICB1c2VFeGlzdGluZzogU3RhdGVDb250ZXh0RmFjdG9yeVxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogybVOR1hTX1NUQVRFX0ZBQ1RPUlksXG4gICAgICB1c2VFeGlzdGluZzogU3RhdGVGYWN0b3J5XG4gICAgfVxuICBdKTtcbn1cbiJdfQ==
@@ -1,70 +0,0 @@
1
- import { inject, Injectable } from '@angular/core';
2
- import { getValue, setValue } from '@ngxs/store/plugins';
3
- import { isStateOperator } from '@ngxs/store/operators';
4
- import { InternalStateOperations } from '../internal/state-operations';
5
- import { simplePatch } from './state-operators';
6
- import * as i0 from "@angular/core";
7
- /**
8
- * State Context factory class
9
- * @ignore
10
- */
11
- export class StateContextFactory {
12
- constructor() {
13
- this._internalStateOperations = inject(InternalStateOperations);
14
- }
15
- /**
16
- * Create the state context
17
- */
18
- createStateContext(path) {
19
- const root = this._internalStateOperations.getRootStateOperations();
20
- return {
21
- getState() {
22
- const currentAppState = root.getState();
23
- return getState(currentAppState, path);
24
- },
25
- patchState(val) {
26
- const currentAppState = root.getState();
27
- const patchOperator = simplePatch(val);
28
- setStateFromOperator(root, currentAppState, patchOperator, path);
29
- },
30
- setState(val) {
31
- const currentAppState = root.getState();
32
- if (isStateOperator(val)) {
33
- setStateFromOperator(root, currentAppState, val, path);
34
- }
35
- else {
36
- setStateValue(root, currentAppState, val, path);
37
- }
38
- },
39
- dispatch(actions) {
40
- return root.dispatch(actions);
41
- }
42
- };
43
- }
44
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
45
- /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, providedIn: 'root' }); }
46
- }
47
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, decorators: [{
48
- type: Injectable,
49
- args: [{ providedIn: 'root' }]
50
- }] });
51
- function setStateValue(root, currentAppState, newValue, path) {
52
- const newAppState = setValue(currentAppState, path, newValue);
53
- root.setState(newAppState);
54
- return newAppState;
55
- // In doing this refactoring I noticed that there is a 'bug' where the
56
- // application state is returned instead of this state slice.
57
- // This has worked this way since the beginning see:
58
- // https://github.com/ngxs/store/blame/324c667b4b7debd8eb979006c67ca0ae347d88cd/src/state-factory.ts
59
- // This needs to be fixed, but is a 'breaking' change.
60
- // I will do this fix in a subsequent PR and we can decide how to handle it.
61
- }
62
- function setStateFromOperator(root, currentAppState, stateOperator, path) {
63
- const local = getState(currentAppState, path);
64
- const newValue = stateOperator(local);
65
- return setStateValue(root, currentAppState, newValue, path);
66
- }
67
- function getState(currentAppState, path) {
68
- return getValue(currentAppState, path);
69
- }
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGUtY29udGV4dC1mYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3RvcmUvc3JjL2ludGVybmFsL3N0YXRlLWNvbnRleHQtZmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBZ0MsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFLdEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUVoRDs7O0dBR0c7QUFFSCxNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRVUsNkJBQXdCLEdBQUcsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUM7S0ErQnBFO0lBN0JDOztPQUVHO0lBQ0gsa0JBQWtCLENBQUksSUFBWTtRQUNoQyxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztRQUVwRSxPQUFPO1lBQ0wsUUFBUTtnQkFDTixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQ3hDLE9BQU8sUUFBUSxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUN6QyxDQUFDO1lBQ0QsVUFBVSxDQUFDLEdBQWU7Z0JBQ3hCLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztnQkFDeEMsTUFBTSxhQUFhLEdBQUcsV0FBVyxDQUFJLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQyxvQkFBb0IsQ0FBQyxJQUFJLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNuRSxDQUFDO1lBQ0QsUUFBUSxDQUFDLEdBQXlCO2dCQUNoQyxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQ3hDLElBQUksZUFBZSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7b0JBQ3pCLG9CQUFvQixDQUFDLElBQUksRUFBRSxlQUFlLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUN6RCxDQUFDO3FCQUFNLENBQUM7b0JBQ04sYUFBYSxDQUFDLElBQUksRUFBRSxlQUFlLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUNsRCxDQUFDO1lBQ0gsQ0FBQztZQUNELFFBQVEsQ0FBQyxPQUFvQjtnQkFDM0IsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ2hDLENBQUM7U0FDRixDQUFDO0lBQ0osQ0FBQztpSUEvQlUsbUJBQW1CO3FJQUFuQixtQkFBbUIsY0FETixNQUFNOzsyRkFDbkIsbUJBQW1CO2tCQUQvQixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRTs7QUFtQ2xDLFNBQVMsYUFBYSxDQUNwQixJQUEwQixFQUMxQixlQUFvQixFQUNwQixRQUFXLEVBQ1gsSUFBWTtJQUVaLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxlQUFlLEVBQUUsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzlELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDM0IsT0FBTyxXQUFXLENBQUM7SUFDbkIsc0VBQXNFO0lBQ3RFLDZEQUE2RDtJQUM3RCxvREFBb0Q7SUFDcEQsb0dBQW9HO0lBQ3BHLHNEQUFzRDtJQUN0RCw0RUFBNEU7QUFDOUUsQ0FBQztBQUVELFNBQVMsb0JBQW9CLENBQzNCLElBQTBCLEVBQzFCLGVBQW9CLEVBQ3BCLGFBQStCLEVBQy9CLElBQVk7SUFFWixNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlDLE1BQU0sUUFBUSxHQUFHLGFBQWEsQ0FBQyxLQUF5QixDQUFDLENBQUM7SUFDMUQsT0FBTyxhQUFhLENBQUMsSUFBSSxFQUFFLGVBQWUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUFJLGVBQW9CLEVBQUUsSUFBWTtJQUNyRCxPQUFPLFFBQVEsQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDekMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZ2V0VmFsdWUsIHNldFZhbHVlIH0gZnJvbSAnQG5neHMvc3RvcmUvcGx1Z2lucyc7XG5pbXBvcnQgeyBFeGlzdGluZ1N0YXRlLCBTdGF0ZU9wZXJhdG9yLCBpc1N0YXRlT3BlcmF0b3IgfSBmcm9tICdAbmd4cy9zdG9yZS9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBTdGF0ZUNvbnRleHQgfSBmcm9tICcuLi9zeW1ib2xzJztcbmltcG9ydCB7IFN0YXRlT3BlcmF0aW9ucyB9IGZyb20gJy4uL2ludGVybmFsL2ludGVybmFscyc7XG5pbXBvcnQgeyBJbnRlcm5hbFN0YXRlT3BlcmF0aW9ucyB9IGZyb20gJy4uL2ludGVybmFsL3N0YXRlLW9wZXJhdGlvbnMnO1xuaW1wb3J0IHsgc2ltcGxlUGF0Y2ggfSBmcm9tICcuL3N0YXRlLW9wZXJhdG9ycyc7XG5cbi8qKlxuICogU3RhdGUgQ29udGV4dCBmYWN0b3J5IGNsYXNzXG4gKiBAaWdub3JlXG4gKi9cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgU3RhdGVDb250ZXh0RmFjdG9yeSB7XG4gIHByaXZhdGUgX2ludGVybmFsU3RhdGVPcGVyYXRpb25zID0gaW5qZWN0KEludGVybmFsU3RhdGVPcGVyYXRpb25zKTtcblxuICAvKipcbiAgICogQ3JlYXRlIHRoZSBzdGF0ZSBjb250ZXh0XG4gICAqL1xuICBjcmVhdGVTdGF0ZUNvbnRleHQ8VD4ocGF0aDogc3RyaW5nKTogU3RhdGVDb250ZXh0PFQ+IHtcbiAgICBjb25zdCByb290ID0gdGhpcy5faW50ZXJuYWxTdGF0ZU9wZXJhdGlvbnMuZ2V0Um9vdFN0YXRlT3BlcmF0aW9ucygpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIGdldFN0YXRlKCk6IFQge1xuICAgICAgICBjb25zdCBjdXJyZW50QXBwU3RhdGUgPSByb290LmdldFN0YXRlKCk7XG4gICAgICAgIHJldHVybiBnZXRTdGF0ZShjdXJyZW50QXBwU3RhdGUsIHBhdGgpO1xuICAgICAgfSxcbiAgICAgIHBhdGNoU3RhdGUodmFsOiBQYXJ0aWFsPFQ+KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRBcHBTdGF0ZSA9IHJvb3QuZ2V0U3RhdGUoKTtcbiAgICAgICAgY29uc3QgcGF0Y2hPcGVyYXRvciA9IHNpbXBsZVBhdGNoPFQ+KHZhbCk7XG4gICAgICAgIHNldFN0YXRlRnJvbU9wZXJhdG9yKHJvb3QsIGN1cnJlbnRBcHBTdGF0ZSwgcGF0Y2hPcGVyYXRvciwgcGF0aCk7XG4gICAgICB9LFxuICAgICAgc2V0U3RhdGUodmFsOiBUIHwgU3RhdGVPcGVyYXRvcjxUPik6IHZvaWQge1xuICAgICAgICBjb25zdCBjdXJyZW50QXBwU3RhdGUgPSByb290LmdldFN0YXRlKCk7XG4gICAgICAgIGlmIChpc1N0YXRlT3BlcmF0b3IodmFsKSkge1xuICAgICAgICAgIHNldFN0YXRlRnJvbU9wZXJhdG9yKHJvb3QsIGN1cnJlbnRBcHBTdGF0ZSwgdmFsLCBwYXRoKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBzZXRTdGF0ZVZhbHVlKHJvb3QsIGN1cnJlbnRBcHBTdGF0ZSwgdmFsLCBwYXRoKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGRpc3BhdGNoKGFjdGlvbnM6IGFueSB8IGFueVtdKTogT2JzZXJ2YWJsZTx2b2lkPiB7XG4gICAgICAgIHJldHVybiByb290LmRpc3BhdGNoKGFjdGlvbnMpO1xuICAgICAgfVxuICAgIH07XG4gIH1cbn1cblxuZnVuY3Rpb24gc2V0U3RhdGVWYWx1ZTxUPihcbiAgcm9vdDogU3RhdGVPcGVyYXRpb25zPGFueT4sXG4gIGN1cnJlbnRBcHBTdGF0ZTogYW55LFxuICBuZXdWYWx1ZTogVCxcbiAgcGF0aDogc3RyaW5nXG4pOiBhbnkge1xuICBjb25zdCBuZXdBcHBTdGF0ZSA9IHNldFZhbHVlKGN1cnJlbnRBcHBTdGF0ZSwgcGF0aCwgbmV3VmFsdWUpO1xuICByb290LnNldFN0YXRlKG5ld0FwcFN0YXRlKTtcbiAgcmV0dXJuIG5ld0FwcFN0YXRlO1xuICAvLyBJbiBkb2luZyB0aGlzIHJlZmFjdG9yaW5nIEkgbm90aWNlZCB0aGF0IHRoZXJlIGlzIGEgJ2J1Zycgd2hlcmUgdGhlXG4gIC8vIGFwcGxpY2F0aW9uIHN0YXRlIGlzIHJldHVybmVkIGluc3RlYWQgb2YgdGhpcyBzdGF0ZSBzbGljZS5cbiAgLy8gVGhpcyBoYXMgd29ya2VkIHRoaXMgd2F5IHNpbmNlIHRoZSBiZWdpbm5pbmcgc2VlOlxuICAvLyBodHRwczovL2dpdGh1Yi5jb20vbmd4cy9zdG9yZS9ibGFtZS8zMjRjNjY3YjRiN2RlYmQ4ZWI5NzkwMDZjNjdjYTBhZTM0N2Q4OGNkL3NyYy9zdGF0ZS1mYWN0b3J5LnRzXG4gIC8vIFRoaXMgbmVlZHMgdG8gYmUgZml4ZWQsIGJ1dCBpcyBhICdicmVha2luZycgY2hhbmdlLlxuICAvLyBJIHdpbGwgZG8gdGhpcyBmaXggaW4gYSBzdWJzZXF1ZW50IFBSIGFuZCB3ZSBjYW4gZGVjaWRlIGhvdyB0byBoYW5kbGUgaXQuXG59XG5cbmZ1bmN0aW9uIHNldFN0YXRlRnJvbU9wZXJhdG9yPFQ+KFxuICByb290OiBTdGF0ZU9wZXJhdGlvbnM8YW55PixcbiAgY3VycmVudEFwcFN0YXRlOiBhbnksXG4gIHN0YXRlT3BlcmF0b3I6IFN0YXRlT3BlcmF0b3I8VD4sXG4gIHBhdGg6IHN0cmluZ1xuKSB7XG4gIGNvbnN0IGxvY2FsID0gZ2V0U3RhdGUoY3VycmVudEFwcFN0YXRlLCBwYXRoKTtcbiAgY29uc3QgbmV3VmFsdWUgPSBzdGF0ZU9wZXJhdG9yKGxvY2FsIGFzIEV4aXN0aW5nU3RhdGU8VD4pO1xuICByZXR1cm4gc2V0U3RhdGVWYWx1ZShyb290LCBjdXJyZW50QXBwU3RhdGUsIG5ld1ZhbHVlLCBwYXRoKTtcbn1cblxuZnVuY3Rpb24gZ2V0U3RhdGU8VD4oY3VycmVudEFwcFN0YXRlOiBhbnksIHBhdGg6IHN0cmluZyk6IFQge1xuICByZXR1cm4gZ2V0VmFsdWUoY3VycmVudEFwcFN0YXRlLCBwYXRoKTtcbn1cbiJdfQ==