@ngxs/store 18.1.6-dev.master-d290a0e → 18.1.6-dev.master-a9e7ff3

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 (144) 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/esm2022/experimental/index.mjs +0 -2
  37. package/esm2022/experimental/ngxs-store-experimental.mjs +0 -5
  38. package/esm2022/experimental/pending-tasks.mjs +0 -30
  39. package/esm2022/index.mjs +0 -13
  40. package/esm2022/internals/custom-rxjs-operators.mjs +0 -19
  41. package/esm2022/internals/custom-rxjs-subjects.mjs +0 -92
  42. package/esm2022/internals/index.mjs +0 -11
  43. package/esm2022/internals/initial-state.mjs +0 -17
  44. package/esm2022/internals/internal-tokens.mjs +0 -5
  45. package/esm2022/internals/memoize.mjs +0 -43
  46. package/esm2022/internals/metadata.mjs +0 -57
  47. package/esm2022/internals/ngxs-app-bootstrapped-state.mjs +0 -19
  48. package/esm2022/internals/ngxs-store-internals.mjs +0 -5
  49. package/esm2022/internals/state-stream.mjs +0 -33
  50. package/esm2022/internals/state-token.mjs +0 -17
  51. package/esm2022/internals/symbols.mjs +0 -11
  52. package/esm2022/internals/testing/fresh-platform.mjs +0 -72
  53. package/esm2022/internals/testing/helpers/ngxs-test.component.mjs +0 -16
  54. package/esm2022/internals/testing/helpers/ngxs-test.module.mjs +0 -20
  55. package/esm2022/internals/testing/index.mjs +0 -4
  56. package/esm2022/internals/testing/ngxs-store-internals-testing.mjs +0 -5
  57. package/esm2022/internals/testing/ngxs.setup.mjs +0 -49
  58. package/esm2022/internals/testing/skip-console-logging.mjs +0 -37
  59. package/esm2022/internals/testing/symbol.mjs +0 -2
  60. package/esm2022/ngxs-store.mjs +0 -5
  61. package/esm2022/operators/append.mjs +0 -20
  62. package/esm2022/operators/compose.mjs +0 -6
  63. package/esm2022/operators/iif.mjs +0 -38
  64. package/esm2022/operators/index.mjs +0 -14
  65. package/esm2022/operators/insert-item.mjs +0 -29
  66. package/esm2022/operators/ngxs-store-operators.mjs +0 -5
  67. package/esm2022/operators/patch.mjs +0 -21
  68. package/esm2022/operators/remove-item.mjs +0 -22
  69. package/esm2022/operators/types.mjs +0 -2
  70. package/esm2022/operators/update-item.mjs +0 -40
  71. package/esm2022/operators/utils.mjs +0 -19
  72. package/esm2022/plugins/actions.mjs +0 -16
  73. package/esm2022/plugins/index.mjs +0 -4
  74. package/esm2022/plugins/ngxs-store-plugins.mjs +0 -5
  75. package/esm2022/plugins/symbols.mjs +0 -15
  76. package/esm2022/plugins/utils.mjs +0 -51
  77. package/esm2022/src/actions/action-registry.mjs +0 -34
  78. package/esm2022/src/actions/symbols.mjs +0 -2
  79. package/esm2022/src/actions-stream.mjs +0 -61
  80. package/esm2022/src/configs/messages.config.mjs +0 -48
  81. package/esm2022/src/decorators/action.mjs +0 -31
  82. package/esm2022/src/decorators/select/select-factory.mjs +0 -29
  83. package/esm2022/src/decorators/select/select.mjs +0 -29
  84. package/esm2022/src/decorators/select/symbols.mjs +0 -29
  85. package/esm2022/src/decorators/selector/selector.mjs +0 -29
  86. package/esm2022/src/decorators/selector/symbols.mjs +0 -2
  87. package/esm2022/src/decorators/selector-options.mjs +0 -21
  88. package/esm2022/src/decorators/state.mjs +0 -35
  89. package/esm2022/src/dev-features/ngxs-development.module.mjs +0 -28
  90. package/esm2022/src/dev-features/ngxs-unhandled-actions-logger.mjs +0 -43
  91. package/esm2022/src/dev-features/symbols.mjs +0 -7
  92. package/esm2022/src/execution/dispatch-outside-zone-ngxs-execution-strategy.mjs +0 -52
  93. package/esm2022/src/execution/internal-ngxs-execution-strategy.mjs +0 -21
  94. package/esm2022/src/execution/noop-ngxs-execution-strategy.mjs +0 -17
  95. package/esm2022/src/execution/symbols.mjs +0 -28
  96. package/esm2022/src/internal/dispatcher.mjs +0 -125
  97. package/esm2022/src/internal/fallback-subscriber.mjs +0 -29
  98. package/esm2022/src/internal/internals.mjs +0 -205
  99. package/esm2022/src/internal/lifecycle-state-manager.mjs +0 -81
  100. package/esm2022/src/internal/provide-internal-tokens.mjs +0 -20
  101. package/esm2022/src/internal/state-context-factory.mjs +0 -70
  102. package/esm2022/src/internal/state-factory.mjs +0 -311
  103. package/esm2022/src/internal/state-operations.mjs +0 -60
  104. package/esm2022/src/internal/state-operators.mjs +0 -20
  105. package/esm2022/src/internal/unhandled-rxjs-error-callback.mjs +0 -46
  106. package/esm2022/src/ivy/ivy-enabled-in-dev-mode.mjs +0 -25
  107. package/esm2022/src/module.mjs +0 -27
  108. package/esm2022/src/modules/ngxs-feature.module.mjs +0 -18
  109. package/esm2022/src/modules/ngxs-root.module.mjs +0 -18
  110. package/esm2022/src/ngxs-unhandled-error-handler.mjs +0 -29
  111. package/esm2022/src/operators/leave-ngxs.mjs +0 -9
  112. package/esm2022/src/operators/of-action.mjs +0 -104
  113. package/esm2022/src/plugin-manager.mjs +0 -34
  114. package/esm2022/src/plugin_api.mjs +0 -2
  115. package/esm2022/src/private_api.mjs +0 -5
  116. package/esm2022/src/public_api.mjs +0 -20
  117. package/esm2022/src/selectors/create-model-selector.mjs +0 -30
  118. package/esm2022/src/selectors/create-pick-selector.mjs +0 -16
  119. package/esm2022/src/selectors/create-property-selectors.mjs +0 -20
  120. package/esm2022/src/selectors/create-selector.mjs +0 -9
  121. package/esm2022/src/selectors/index.mjs +0 -6
  122. package/esm2022/src/selectors/private_api.mjs +0 -2
  123. package/esm2022/src/selectors/selector-checks.util.mjs +0 -43
  124. package/esm2022/src/selectors/selector-metadata.mjs +0 -35
  125. package/esm2022/src/selectors/selector-models.mjs +0 -2
  126. package/esm2022/src/selectors/selector-types.util.mjs +0 -2
  127. package/esm2022/src/selectors/selector-utils.mjs +0 -95
  128. package/esm2022/src/standalone-features/feature-providers.mjs +0 -18
  129. package/esm2022/src/standalone-features/index.mjs +0 -5
  130. package/esm2022/src/standalone-features/initializers.mjs +0 -94
  131. package/esm2022/src/standalone-features/plugin.mjs +0 -33
  132. package/esm2022/src/standalone-features/preboot.mjs +0 -31
  133. package/esm2022/src/standalone-features/provide-states.mjs +0 -26
  134. package/esm2022/src/standalone-features/provide-store.mjs +0 -26
  135. package/esm2022/src/standalone-features/root-providers.mjs +0 -34
  136. package/esm2022/src/store.mjs +0 -117
  137. package/esm2022/src/symbols.mjs +0 -86
  138. package/esm2022/src/utils/create-dispatch-map.mjs +0 -11
  139. package/esm2022/src/utils/create-select-map.mjs +0 -13
  140. package/esm2022/src/utils/dispatch.mjs +0 -7
  141. package/esm2022/src/utils/freeze.mjs +0 -20
  142. package/esm2022/src/utils/public_api.mjs +0 -5
  143. package/esm2022/src/utils/select.mjs +0 -19
  144. package/esm2022/src/utils/store-validators.mjs +0 -25
@@ -1,18 +0,0 @@
1
- import { FEATURE_STATE_TOKEN } from '../symbols';
2
- import { PluginManager } from '../plugin-manager';
3
- /**
4
- * This function provides the required providers when calling `NgxsModule.forFeature`
5
- * or `provideStates`. It is shared between the NgModule and standalone APIs.
6
- */
7
- export function getFeatureProviders(states) {
8
- return [
9
- PluginManager,
10
- ...states,
11
- {
12
- provide: FEATURE_STATE_TOKEN,
13
- multi: true,
14
- useValue: states
15
- }
16
- ];
17
- }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVhdHVyZS1wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvc3RhbmRhbG9uZS1mZWF0dXJlcy9mZWF0dXJlLXByb3ZpZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWxEOzs7R0FHRztBQUNILE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxNQUFxQjtJQUN2RCxPQUFPO1FBQ0wsYUFBYTtRQUNiLEdBQUcsTUFBTTtRQUNUO1lBQ0UsT0FBTyxFQUFFLG1CQUFtQjtZQUM1QixLQUFLLEVBQUUsSUFBSTtZQUNYLFFBQVEsRUFBRSxNQUFNO1NBQ2pCO0tBQ0YsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgybVTdGF0ZUNsYXNzIH0gZnJvbSAnQG5neHMvc3RvcmUvaW50ZXJuYWxzJztcblxuaW1wb3J0IHsgRkVBVFVSRV9TVEFURV9UT0tFTiB9IGZyb20gJy4uL3N5bWJvbHMnO1xuaW1wb3J0IHsgUGx1Z2luTWFuYWdlciB9IGZyb20gJy4uL3BsdWdpbi1tYW5hZ2VyJztcblxuLyoqXG4gKiBUaGlzIGZ1bmN0aW9uIHByb3ZpZGVzIHRoZSByZXF1aXJlZCBwcm92aWRlcnMgd2hlbiBjYWxsaW5nIGBOZ3hzTW9kdWxlLmZvckZlYXR1cmVgXG4gKiBvciBgcHJvdmlkZVN0YXRlc2AuIEl0IGlzIHNoYXJlZCBiZXR3ZWVuIHRoZSBOZ01vZHVsZSBhbmQgc3RhbmRhbG9uZSBBUElzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0RmVhdHVyZVByb3ZpZGVycyhzdGF0ZXM6IMm1U3RhdGVDbGFzc1tdKTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAgUGx1Z2luTWFuYWdlcixcbiAgICAuLi5zdGF0ZXMsXG4gICAge1xuICAgICAgcHJvdmlkZTogRkVBVFVSRV9TVEFURV9UT0tFTixcbiAgICAgIG11bHRpOiB0cnVlLFxuICAgICAgdXNlVmFsdWU6IHN0YXRlc1xuICAgIH1cbiAgXTtcbn1cbiJdfQ==
@@ -1,5 +0,0 @@
1
- export { provideStore } from './provide-store';
2
- export { provideStates } from './provide-states';
3
- export { withNgxsPlugin } from './plugin';
4
- export { withNgxsPreboot } from './preboot';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvc3RhbmRhbG9uZS1mZWF0dXJlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDMUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IHByb3ZpZGVTdG9yZSB9IGZyb20gJy4vcHJvdmlkZS1zdG9yZSc7XG5leHBvcnQgeyBwcm92aWRlU3RhdGVzIH0gZnJvbSAnLi9wcm92aWRlLXN0YXRlcyc7XG5leHBvcnQgeyB3aXRoTmd4c1BsdWdpbiB9IGZyb20gJy4vcGx1Z2luJztcbmV4cG9ydCB7IHdpdGhOZ3hzUHJlYm9vdCB9IGZyb20gJy4vcHJlYm9vdCc7XG4iXX0=
@@ -1,94 +0,0 @@
1
- import { ENVIRONMENT_INITIALIZER, InjectionToken, inject } from '@angular/core';
2
- import { Store } from '../store';
3
- import { NGXS_PREBOOT_FNS } from './preboot';
4
- import { InitState, UpdateState } from '../plugin_api';
5
- import { FEATURE_STATE_TOKEN, ROOT_STATE_TOKEN } from '../symbols';
6
- import { StateFactory } from '../internal/state-factory';
7
- import { SelectFactory } from '../decorators/select/select-factory';
8
- import { InternalStateOperations } from '../internal/state-operations';
9
- import { LifecycleStateManager } from '../internal/lifecycle-state-manager';
10
- import { installOnUnhandhedErrorHandler } from '../internal/unhandled-rxjs-error-callback';
11
- /**
12
- * This function is shared by both NgModule and standalone features.
13
- * When using `NgxsModule.forRoot` and `provideStore`, we can depend on the
14
- * same initialization functionality.
15
- */
16
- export function rootStoreInitializer() {
17
- // Override the RxJS `config.onUnhandledError` within the root store initializer,
18
- // but only after other code has already executed.
19
- // If users have a custom `config.onUnhandledError`, we might overwrite it too
20
- // early and capture the original `config.onUnhandledError` before it is properly set.
21
- installOnUnhandhedErrorHandler();
22
- const prebootFns = inject(NGXS_PREBOOT_FNS, { optional: true }) || [];
23
- prebootFns.forEach(prebootFn => prebootFn());
24
- const factory = inject(StateFactory);
25
- const internalStateOperations = inject(InternalStateOperations);
26
- inject(Store);
27
- inject(SelectFactory);
28
- const states = inject(ROOT_STATE_TOKEN, { optional: true }) || [];
29
- const lifecycleStateManager = inject(LifecycleStateManager);
30
- // Add stores to the state graph and return their defaults.
31
- const results = factory.addAndReturnDefaults(states);
32
- internalStateOperations.setStateToTheCurrentWithNew(results);
33
- // Connect our actions stream.
34
- factory.connectActionHandlers();
35
- // Dispatch the init action and invoke init and bootstrap functions after.
36
- lifecycleStateManager.ngxsBootstrap(new InitState(), results);
37
- }
38
- /**
39
- * This function is utilized by both NgModule and standalone features.
40
- * When using `NgxsModule.forFeature` and `provideStates`, we can depend on
41
- * the same initialization functionality.
42
- */
43
- export function featureStatesInitializer() {
44
- inject(Store);
45
- const internalStateOperations = inject(InternalStateOperations);
46
- const factory = inject(StateFactory);
47
- const states = inject(FEATURE_STATE_TOKEN, { optional: true }) || [];
48
- const lifecycleStateManager = inject(LifecycleStateManager);
49
- // Since FEATURE_STATE_TOKEN is a multi token, we need to
50
- // flatten it [[Feature1State, Feature2State], [Feature3State]].
51
- const flattenedStates = states.reduce((total, values) => total.concat(values), []);
52
- // add stores to the state graph and return their defaults.
53
- const results = factory.addAndReturnDefaults(flattenedStates);
54
- if (results.states.length) {
55
- internalStateOperations.setStateToTheCurrentWithNew(results);
56
- // Dispatch the update action and invoke init and bootstrap functions after.
57
- lifecycleStateManager.ngxsBootstrap(new UpdateState(results.defaults), results);
58
- }
59
- }
60
- /**
61
- * InjectionToken that registers the global Store.
62
- */
63
- export const NGXS_ROOT_STORE_INITIALIZER = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_ROOT_STORE_INITIALIZER' : '');
64
- /**
65
- * InjectionToken that registers feature states.
66
- */
67
- export const NGXS_FEATURE_STORE_INITIALIZER = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_FEATURE_STORE_INITIALIZER' : '');
68
- export const NGXS_ROOT_ENVIRONMENT_INITIALIZER = [
69
- { provide: NGXS_ROOT_STORE_INITIALIZER, useFactory: rootStoreInitializer },
70
- {
71
- provide: ENVIRONMENT_INITIALIZER,
72
- multi: true,
73
- useFactory() {
74
- return () => inject(NGXS_ROOT_STORE_INITIALIZER);
75
- }
76
- }
77
- ];
78
- /**
79
- * The `NGXS_FEATURE_ENVIRONMENT_INITIALIZER` functions as an environment initializer
80
- * at the `Route` level. Angular Router creates an environment route injector for each
81
- * matched route where navigation occurs. The injector is created once, ensuring that
82
- * the feature states initialization only happens once as well.
83
- */
84
- export const NGXS_FEATURE_ENVIRONMENT_INITIALIZER = [
85
- { provide: NGXS_FEATURE_STORE_INITIALIZER, useFactory: featureStatesInitializer },
86
- {
87
- provide: ENVIRONMENT_INITIALIZER,
88
- multi: true,
89
- useFactory() {
90
- return () => inject(NGXS_FEATURE_STORE_INITIALIZER);
91
- }
92
- }
93
- ];
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"initializers.js","sourceRoot":"","sources":["../../../../../packages/store/src/standalone-features/initializers.ts"],"names":[],"mappings":"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","sourcesContent":["import { ENVIRONMENT_INITIALIZER, InjectionToken, Provider, inject } from '@angular/core';\nimport { ɵStateClassInternal } from '@ngxs/store/internals';\n\nimport { Store } from '../store';\nimport { NGXS_PREBOOT_FNS } from './preboot';\nimport { InitState, UpdateState } from '../plugin_api';\nimport { FEATURE_STATE_TOKEN, ROOT_STATE_TOKEN } from '../symbols';\nimport { StateFactory } from '../internal/state-factory';\nimport { StatesAndDefaults } from '../internal/internals';\nimport { SelectFactory } from '../decorators/select/select-factory';\nimport { InternalStateOperations } from '../internal/state-operations';\nimport { LifecycleStateManager } from '../internal/lifecycle-state-manager';\nimport { installOnUnhandhedErrorHandler } from '../internal/unhandled-rxjs-error-callback';\n\n/**\n * This function is shared by both NgModule and standalone features.\n * When using `NgxsModule.forRoot` and `provideStore`, we can depend on the\n * same initialization functionality.\n */\nexport function rootStoreInitializer(): void {\n  // Override the RxJS `config.onUnhandledError` within the root store initializer,\n  // but only after other code has already executed.\n  // If users have a custom `config.onUnhandledError`, we might overwrite it too\n  // early and capture the original `config.onUnhandledError` before it is properly set.\n  installOnUnhandhedErrorHandler();\n\n  const prebootFns = inject(NGXS_PREBOOT_FNS, { optional: true }) || [];\n  prebootFns.forEach(prebootFn => prebootFn());\n\n  const factory = inject(StateFactory);\n  const internalStateOperations = inject(InternalStateOperations);\n\n  inject(Store);\n  inject(SelectFactory);\n\n  const states = inject(ROOT_STATE_TOKEN, { optional: true }) || [];\n  const lifecycleStateManager = inject(LifecycleStateManager);\n\n  // Add stores to the state graph and return their defaults.\n  const results: StatesAndDefaults = factory.addAndReturnDefaults(states);\n\n  internalStateOperations.setStateToTheCurrentWithNew(results);\n\n  // Connect our actions stream.\n  factory.connectActionHandlers();\n\n  // Dispatch the init action and invoke init and bootstrap functions after.\n  lifecycleStateManager.ngxsBootstrap(new InitState(), results);\n}\n\n/**\n * This function is utilized by both NgModule and standalone features.\n * When using `NgxsModule.forFeature` and `provideStates`, we can depend on\n * the same initialization functionality.\n */\nexport function featureStatesInitializer(): void {\n  inject(Store);\n\n  const internalStateOperations = inject(InternalStateOperations);\n  const factory = inject(StateFactory);\n  const states = inject(FEATURE_STATE_TOKEN, { optional: true }) || [];\n  const lifecycleStateManager = inject(LifecycleStateManager);\n\n  // Since FEATURE_STATE_TOKEN is a multi token, we need to\n  // flatten it [[Feature1State, Feature2State], [Feature3State]].\n  const flattenedStates: ɵStateClassInternal[] = states.reduce(\n    (total: ɵStateClassInternal[], values: ɵStateClassInternal[]) => total.concat(values),\n    []\n  );\n\n  // add stores to the state graph and return their defaults.\n  const results: StatesAndDefaults = factory.addAndReturnDefaults(flattenedStates);\n\n  if (results.states.length) {\n    internalStateOperations.setStateToTheCurrentWithNew(results);\n\n    // Dispatch the update action and invoke init and bootstrap functions after.\n    lifecycleStateManager.ngxsBootstrap(new UpdateState(results.defaults), results);\n  }\n}\n\n/**\n * InjectionToken that registers the global Store.\n */\nexport const NGXS_ROOT_STORE_INITIALIZER = new InjectionToken<void>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_ROOT_STORE_INITIALIZER' : ''\n);\n\n/**\n * InjectionToken that registers feature states.\n */\nexport const NGXS_FEATURE_STORE_INITIALIZER = new InjectionToken<void>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_FEATURE_STORE_INITIALIZER' : ''\n);\n\nexport const NGXS_ROOT_ENVIRONMENT_INITIALIZER: Provider[] = [\n  { provide: NGXS_ROOT_STORE_INITIALIZER, useFactory: rootStoreInitializer },\n  {\n    provide: ENVIRONMENT_INITIALIZER,\n    multi: true,\n    useFactory() {\n      return () => inject(NGXS_ROOT_STORE_INITIALIZER);\n    }\n  }\n];\n\n/**\n * The `NGXS_FEATURE_ENVIRONMENT_INITIALIZER` functions as an environment initializer\n * at the `Route` level. Angular Router creates an environment route injector for each\n * matched route where navigation occurs. The injector is created once, ensuring that\n * the feature states initialization only happens once as well.\n */\nexport const NGXS_FEATURE_ENVIRONMENT_INITIALIZER: Provider[] = [\n  { provide: NGXS_FEATURE_STORE_INITIALIZER, useFactory: featureStatesInitializer },\n  {\n    provide: ENVIRONMENT_INITIALIZER,\n    multi: true,\n    useFactory() {\n      return () => inject(NGXS_FEATURE_STORE_INITIALIZER);\n    }\n  }\n];\n"]}
@@ -1,33 +0,0 @@
1
- import { ENVIRONMENT_INITIALIZER, inject, makeEnvironmentProviders } from '@angular/core';
2
- import { NGXS_PLUGINS, ɵisPluginClass } from '@ngxs/store/plugins';
3
- import { PluginManager } from '../plugin-manager';
4
- /**
5
- * This function registers a custom global plugin for the state.
6
- *
7
- * ```ts
8
- * bootstrapApplication(AppComponent, {
9
- * providers: [
10
- * provideStore(
11
- * [CountriesState],
12
- * withNgxsPlugin(LogoutPlugin)
13
- * )
14
- * ]
15
- * });
16
- * ```
17
- */
18
- export function withNgxsPlugin(plugin) {
19
- return makeEnvironmentProviders([
20
- ɵisPluginClass(plugin)
21
- ? { provide: NGXS_PLUGINS, useClass: plugin, multi: true }
22
- : { provide: NGXS_PLUGINS, useValue: plugin, multi: true },
23
- // We should inject the `PluginManager` to retrieve `NGXS_PLUGINS` and
24
- // register those plugins. The plugin can be added from inside the child
25
- // route, so the plugin manager should be re-injected.
26
- {
27
- provide: ENVIRONMENT_INITIALIZER,
28
- useValue: () => inject(PluginManager),
29
- multi: true
30
- }
31
- ]);
32
- }
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3RvcmUvc3JjL3N0YW5kYWxvbmUtZmVhdHVyZXMvcGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFHdkIsTUFBTSxFQUNOLHdCQUF3QixFQUN6QixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsWUFBWSxFQUE0QixjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUU3RixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbEQ7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQUMsTUFBdUM7SUFDcEUsT0FBTyx3QkFBd0IsQ0FBQztRQUM5QixjQUFjLENBQUMsTUFBTSxDQUFDO1lBQ3BCLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO1lBQzFELENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO1FBQzVELHNFQUFzRTtRQUN0RSx3RUFBd0U7UUFDeEUsc0RBQXNEO1FBQ3REO1lBQ0UsT0FBTyxFQUFFLHVCQUF1QjtZQUNoQyxRQUFRLEVBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQztZQUNyQyxLQUFLLEVBQUUsSUFBSTtTQUNaO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEVOVklST05NRU5UX0lOSVRJQUxJWkVSLFxuICBFbnZpcm9ubWVudFByb3ZpZGVycyxcbiAgVHlwZSxcbiAgaW5qZWN0LFxuICBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnNcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOR1hTX1BMVUdJTlMsIE5neHNQbHVnaW4sIE5neHNQbHVnaW5GbiwgybVpc1BsdWdpbkNsYXNzIH0gZnJvbSAnQG5neHMvc3RvcmUvcGx1Z2lucyc7XG5cbmltcG9ydCB7IFBsdWdpbk1hbmFnZXIgfSBmcm9tICcuLi9wbHVnaW4tbWFuYWdlcic7XG5cbi8qKlxuICogVGhpcyBmdW5jdGlvbiByZWdpc3RlcnMgYSBjdXN0b20gZ2xvYmFsIHBsdWdpbiBmb3IgdGhlIHN0YXRlLlxuICpcbiAqIGBgYHRzXG4gKiBib290c3RyYXBBcHBsaWNhdGlvbihBcHBDb21wb25lbnQsIHtcbiAqICAgcHJvdmlkZXJzOiBbXG4gKiAgICAgcHJvdmlkZVN0b3JlKFxuICogICAgICAgW0NvdW50cmllc1N0YXRlXSxcbiAqICAgICAgIHdpdGhOZ3hzUGx1Z2luKExvZ291dFBsdWdpbilcbiAqICAgICApXG4gKiAgIF1cbiAqIH0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB3aXRoTmd4c1BsdWdpbihwbHVnaW46IFR5cGU8Tmd4c1BsdWdpbj4gfCBOZ3hzUGx1Z2luRm4pOiBFbnZpcm9ubWVudFByb3ZpZGVycyB7XG4gIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICAgIMm1aXNQbHVnaW5DbGFzcyhwbHVnaW4pXG4gICAgICA/IHsgcHJvdmlkZTogTkdYU19QTFVHSU5TLCB1c2VDbGFzczogcGx1Z2luLCBtdWx0aTogdHJ1ZSB9XG4gICAgICA6IHsgcHJvdmlkZTogTkdYU19QTFVHSU5TLCB1c2VWYWx1ZTogcGx1Z2luLCBtdWx0aTogdHJ1ZSB9LFxuICAgIC8vIFdlIHNob3VsZCBpbmplY3QgdGhlIGBQbHVnaW5NYW5hZ2VyYCB0byByZXRyaWV2ZSBgTkdYU19QTFVHSU5TYCBhbmRcbiAgICAvLyByZWdpc3RlciB0aG9zZSBwbHVnaW5zLiBUaGUgcGx1Z2luIGNhbiBiZSBhZGRlZCBmcm9tIGluc2lkZSB0aGUgY2hpbGRcbiAgICAvLyByb3V0ZSwgc28gdGhlIHBsdWdpbiBtYW5hZ2VyIHNob3VsZCBiZSByZS1pbmplY3RlZC5cbiAgICB7XG4gICAgICBwcm92aWRlOiBFTlZJUk9OTUVOVF9JTklUSUFMSVpFUixcbiAgICAgIHVzZVZhbHVlOiAoKSA9PiBpbmplY3QoUGx1Z2luTWFuYWdlciksXG4gICAgICBtdWx0aTogdHJ1ZVxuICAgIH1cbiAgXSk7XG59XG4iXX0=
@@ -1,31 +0,0 @@
1
- import { InjectionToken, makeEnvironmentProviders } from '@angular/core';
2
- /**
3
- * InjectionToken that registers preboot functions (called before the root initializer).
4
- */
5
- export const NGXS_PREBOOT_FNS = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_PREBOOT_FNS' : '');
6
- /**
7
- * This function registers a preboot function which will be called before the root
8
- * store initializer is run, but after all of the NGXS features are provided and
9
- * available for injection. This is useful for registering action stream listeners
10
- * before any action is dispatched.
11
- *
12
- * ```ts
13
- * bootstrapApplication(AppComponent, {
14
- * providers: [
15
- * provideStore(
16
- * [CountriesState],
17
- * withNgxsPreboot(() => {
18
- * const actions$ = inject(Actions);
19
- * actions$.subscribe(ctx => console.log(ctx));
20
- * })
21
- * )
22
- * ]
23
- * });
24
- * ```
25
- */
26
- export function withNgxsPreboot(prebootFn) {
27
- return makeEnvironmentProviders([
28
- { provide: NGXS_PREBOOT_FNS, multi: true, useValue: prebootFn }
29
- ]);
30
- }
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlYm9vdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0b3JlL3NyYy9zdGFuZGFsb25lLWZlYXR1cmVzL3ByZWJvb3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksY0FBYyxDQUNoRCxPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUN4RSxDQUFDO0FBRUY7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQkc7QUFDSCxNQUFNLFVBQVUsZUFBZSxDQUFDLFNBQXVCO0lBQ3JELE9BQU8sd0JBQXdCLENBQUM7UUFDOUIsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFO0tBQ2hFLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogSW5qZWN0aW9uVG9rZW4gdGhhdCByZWdpc3RlcnMgcHJlYm9vdCBmdW5jdGlvbnMgKGNhbGxlZCBiZWZvcmUgdGhlIHJvb3QgaW5pdGlhbGl6ZXIpLlxuICovXG5leHBvcnQgY29uc3QgTkdYU19QUkVCT09UX0ZOUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxWb2lkRnVuY3Rpb25bXT4oXG4gIHR5cGVvZiBuZ0Rldk1vZGUgIT09ICd1bmRlZmluZWQnICYmIG5nRGV2TW9kZSA/ICdOR1hTX1BSRUJPT1RfRk5TJyA6ICcnXG4pO1xuXG4vKipcbiAqIFRoaXMgZnVuY3Rpb24gcmVnaXN0ZXJzIGEgcHJlYm9vdCBmdW5jdGlvbiB3aGljaCB3aWxsIGJlIGNhbGxlZCBiZWZvcmUgdGhlIHJvb3RcbiAqIHN0b3JlIGluaXRpYWxpemVyIGlzIHJ1biwgYnV0IGFmdGVyIGFsbCBvZiB0aGUgTkdYUyBmZWF0dXJlcyBhcmUgcHJvdmlkZWQgYW5kXG4gKiBhdmFpbGFibGUgZm9yIGluamVjdGlvbi4gVGhpcyBpcyB1c2VmdWwgZm9yIHJlZ2lzdGVyaW5nIGFjdGlvbiBzdHJlYW0gbGlzdGVuZXJzXG4gKiBiZWZvcmUgYW55IGFjdGlvbiBpcyBkaXNwYXRjaGVkLlxuICpcbiAqIGBgYHRzXG4gKiBib290c3RyYXBBcHBsaWNhdGlvbihBcHBDb21wb25lbnQsIHtcbiAqICAgcHJvdmlkZXJzOiBbXG4gKiAgICAgcHJvdmlkZVN0b3JlKFxuICogICAgICAgW0NvdW50cmllc1N0YXRlXSxcbiAqICAgICAgIHdpdGhOZ3hzUHJlYm9vdCgoKSA9PiB7XG4gKiAgICAgICAgIGNvbnN0IGFjdGlvbnMkID0gaW5qZWN0KEFjdGlvbnMpO1xuICogICAgICAgICBhY3Rpb25zJC5zdWJzY3JpYmUoY3R4ID0+IGNvbnNvbGUubG9nKGN0eCkpO1xuICogICAgICAgfSlcbiAqICAgICApXG4gKiAgIF1cbiAqIH0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB3aXRoTmd4c1ByZWJvb3QocHJlYm9vdEZuOiBWb2lkRnVuY3Rpb24pIHtcbiAgcmV0dXJuIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyhbXG4gICAgeyBwcm92aWRlOiBOR1hTX1BSRUJPT1RfRk5TLCBtdWx0aTogdHJ1ZSwgdXNlVmFsdWU6IHByZWJvb3RGbiB9XG4gIF0pO1xufVxuIl19
@@ -1,26 +0,0 @@
1
- import { makeEnvironmentProviders } from '@angular/core';
2
- import { getFeatureProviders } from './feature-providers';
3
- import { NGXS_FEATURE_ENVIRONMENT_INITIALIZER } from './initializers';
4
- /**
5
- * This version serves as a standalone alternative to `NgxsModule.forFeature`.
6
- * It can be used in a similar manner to register feature states, but at the
7
- * `Route` providers level:
8
- *
9
- * ```ts
10
- * const routes: Routes = [
11
- * {
12
- * path: 'products',
13
- * loadComponent: async () => {...},
14
- * providers: [provideStates([ProductsState])]
15
- * }
16
- * ];
17
- * ```
18
- */
19
- export function provideStates(states, ...features) {
20
- return makeEnvironmentProviders([
21
- ...getFeatureProviders(states),
22
- features,
23
- NGXS_FEATURE_ENVIRONMENT_INITIALIZER
24
- ]);
25
- }
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1zdGF0ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvc3RhbmRhbG9uZS1mZWF0dXJlcy9wcm92aWRlLXN0YXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXdCLHdCQUF3QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9FLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFELE9BQU8sRUFBRSxvQ0FBb0MsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXRFOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBQ0gsTUFBTSxVQUFVLGFBQWEsQ0FDM0IsTUFBcUIsRUFDckIsR0FBRyxRQUFnQztJQUVuQyxPQUFPLHdCQUF3QixDQUFDO1FBQzlCLEdBQUcsbUJBQW1CLENBQUMsTUFBTSxDQUFDO1FBQzlCLFFBQVE7UUFDUixvQ0FBb0M7S0FDckMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudmlyb25tZW50UHJvdmlkZXJzLCBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IMm1U3RhdGVDbGFzcyB9IGZyb20gJ0BuZ3hzL3N0b3JlL2ludGVybmFscyc7XG5cbmltcG9ydCB7IGdldEZlYXR1cmVQcm92aWRlcnMgfSBmcm9tICcuL2ZlYXR1cmUtcHJvdmlkZXJzJztcbmltcG9ydCB7IE5HWFNfRkVBVFVSRV9FTlZJUk9OTUVOVF9JTklUSUFMSVpFUiB9IGZyb20gJy4vaW5pdGlhbGl6ZXJzJztcblxuLyoqXG4gKiBUaGlzIHZlcnNpb24gc2VydmVzIGFzIGEgc3RhbmRhbG9uZSBhbHRlcm5hdGl2ZSB0byBgTmd4c01vZHVsZS5mb3JGZWF0dXJlYC5cbiAqIEl0IGNhbiBiZSB1c2VkIGluIGEgc2ltaWxhciBtYW5uZXIgdG8gcmVnaXN0ZXIgZmVhdHVyZSBzdGF0ZXMsIGJ1dCBhdCB0aGVcbiAqIGBSb3V0ZWAgcHJvdmlkZXJzIGxldmVsOlxuICpcbiAqIGBgYHRzXG4gKiBjb25zdCByb3V0ZXM6IFJvdXRlcyA9IFtcbiAqICAge1xuICogICAgIHBhdGg6ICdwcm9kdWN0cycsXG4gKiAgICAgbG9hZENvbXBvbmVudDogYXN5bmMgKCkgPT4gey4uLn0sXG4gKiAgICAgcHJvdmlkZXJzOiBbcHJvdmlkZVN0YXRlcyhbUHJvZHVjdHNTdGF0ZV0pXVxuICogICB9XG4gKiBdO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlU3RhdGVzKFxuICBzdGF0ZXM6IMm1U3RhdGVDbGFzc1tdLFxuICAuLi5mZWF0dXJlczogRW52aXJvbm1lbnRQcm92aWRlcnNbXVxuKTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xuICByZXR1cm4gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAgICAuLi5nZXRGZWF0dXJlUHJvdmlkZXJzKHN0YXRlcyksXG4gICAgZmVhdHVyZXMsXG4gICAgTkdYU19GRUFUVVJFX0VOVklST05NRU5UX0lOSVRJQUxJWkVSXG4gIF0pO1xufVxuIl19
@@ -1,26 +0,0 @@
1
- import { makeEnvironmentProviders } from '@angular/core';
2
- import { getRootProviders } from './root-providers';
3
- import { NGXS_ROOT_ENVIRONMENT_INITIALIZER } from './initializers';
4
- export function provideStore(states = [], ...optionsAndFeatures) {
5
- const features = [];
6
- // Options are empty by default (see `forRoot`).
7
- let options = {};
8
- if (optionsAndFeatures.length > 0) {
9
- if (isEnvironmentProvider(optionsAndFeatures[0])) {
10
- features.push(...optionsAndFeatures);
11
- }
12
- else {
13
- options = optionsAndFeatures[0];
14
- features.push(...optionsAndFeatures.slice(1));
15
- }
16
- }
17
- return makeEnvironmentProviders([
18
- ...getRootProviders(states, options),
19
- NGXS_ROOT_ENVIRONMENT_INITIALIZER,
20
- features
21
- ]);
22
- }
23
- function isEnvironmentProvider(target) {
24
- return !!target.ɵproviders;
25
- }
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1zdG9yZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0b3JlL3NyYy9zdGFuZGFsb25lLWZlYXR1cmVzL3Byb3ZpZGUtc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF3Qix3QkFBd0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUkvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQThCbkUsTUFBTSxVQUFVLFlBQVksQ0FDMUIsU0FBd0IsRUFBRSxFQUMxQixHQUFHLGtCQUF5QjtJQUU1QixNQUFNLFFBQVEsR0FBMkIsRUFBRSxDQUFDO0lBQzVDLGdEQUFnRDtJQUNoRCxJQUFJLE9BQU8sR0FBc0IsRUFBRSxDQUFDO0lBRXBDLElBQUksa0JBQWtCLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ2xDLElBQUkscUJBQXFCLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ2pELFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxHQUFHLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2hDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoRCxDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU8sd0JBQXdCLENBQUM7UUFDOUIsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDO1FBQ3BDLGlDQUFpQztRQUNqQyxRQUFRO0tBQ1QsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELFNBQVMscUJBQXFCLENBQUMsTUFBVztJQUN4QyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDO0FBQzdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbnZpcm9ubWVudFByb3ZpZGVycywgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyDJtVN0YXRlQ2xhc3MgfSBmcm9tICdAbmd4cy9zdG9yZS9pbnRlcm5hbHMnO1xuXG5pbXBvcnQgeyBOZ3hzTW9kdWxlT3B0aW9ucyB9IGZyb20gJy4uL3N5bWJvbHMnO1xuaW1wb3J0IHsgZ2V0Um9vdFByb3ZpZGVycyB9IGZyb20gJy4vcm9vdC1wcm92aWRlcnMnO1xuaW1wb3J0IHsgTkdYU19ST09UX0VOVklST05NRU5UX0lOSVRJQUxJWkVSIH0gZnJvbSAnLi9pbml0aWFsaXplcnMnO1xuXG4vKipcbiAqIFRoaXMgZnVuY3Rpb24gcHJvdmlkZXMgZ2xvYmFsIHN0b3JlIHByb3ZpZGVycyBhbmQgaW5pdGlhbGl6ZXMgdGhlIHN0b3JlLlxuICpcbiAqIGBgYHRzXG4gKiBib290c3RyYXBBcHBsaWNhdGlvbihBcHBDb21wb25lbnQsIHtcbiAqICAgcHJvdmlkZXJzOiBbcHJvdmlkZVN0b3JlKFtDb3VudHJpZXNTdGF0ZV0pXVxuICogfSk7XG4gKiBgYGBcbiAqXG4gKiBUaGUgYHByb3ZpZGVTdG9yZWAgbWF5IGJlIG9wdGlvbmFsbHkgY2FsbGVkIHdpdGggYSBjb25maWcgYmVmb3JlIHRoZSBsaXN0IG9mIGZlYXR1cmVzOlxuICpcbiAqIGBgYHRzXG4gKiBwcm92aWRlU3RvcmUoW0NvdW50cmllc1N0YXRlXSwge1xuICogICBkZXZlbG9wbWVudE1vZGU6ICFlbnZpcm9ubWVudC5wcm9kdWN0aW9uXG4gKiB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVN0b3JlKFxuICBzdGF0ZXM/OiDJtVN0YXRlQ2xhc3NbXSxcbiAgLi4uZmVhdHVyZXM6IEVudmlyb25tZW50UHJvdmlkZXJzW11cbik6IEVudmlyb25tZW50UHJvdmlkZXJzO1xuXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVN0b3JlKFxuICBzdGF0ZXM/OiDJtVN0YXRlQ2xhc3NbXSxcbiAgb3B0aW9ucz86IE5neHNNb2R1bGVPcHRpb25zLFxuICAuLi5mZWF0dXJlczogRW52aXJvbm1lbnRQcm92aWRlcnNbXVxuKTogRW52aXJvbm1lbnRQcm92aWRlcnM7XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlU3RvcmUoXG4gIHN0YXRlczogybVTdGF0ZUNsYXNzW10gPSBbXSxcbiAgLi4ub3B0aW9uc0FuZEZlYXR1cmVzOiBhbnlbXVxuKTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xuICBjb25zdCBmZWF0dXJlczogRW52aXJvbm1lbnRQcm92aWRlcnNbXSA9IFtdO1xuICAvLyBPcHRpb25zIGFyZSBlbXB0eSBieSBkZWZhdWx0IChzZWUgYGZvclJvb3RgKS5cbiAgbGV0IG9wdGlvbnM6IE5neHNNb2R1bGVPcHRpb25zID0ge307XG5cbiAgaWYgKG9wdGlvbnNBbmRGZWF0dXJlcy5sZW5ndGggPiAwKSB7XG4gICAgaWYgKGlzRW52aXJvbm1lbnRQcm92aWRlcihvcHRpb25zQW5kRmVhdHVyZXNbMF0pKSB7XG4gICAgICBmZWF0dXJlcy5wdXNoKC4uLm9wdGlvbnNBbmRGZWF0dXJlcyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIG9wdGlvbnMgPSBvcHRpb25zQW5kRmVhdHVyZXNbMF07XG4gICAgICBmZWF0dXJlcy5wdXNoKC4uLm9wdGlvbnNBbmRGZWF0dXJlcy5zbGljZSgxKSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyhbXG4gICAgLi4uZ2V0Um9vdFByb3ZpZGVycyhzdGF0ZXMsIG9wdGlvbnMpLFxuICAgIE5HWFNfUk9PVF9FTlZJUk9OTUVOVF9JTklUSUFMSVpFUixcbiAgICBmZWF0dXJlc1xuICBdKTtcbn1cblxuZnVuY3Rpb24gaXNFbnZpcm9ubWVudFByb3ZpZGVyKHRhcmdldDogYW55KTogdGFyZ2V0IGlzIEVudmlyb25tZW50UHJvdmlkZXJzIHtcbiAgcmV0dXJuICEhdGFyZ2V0Lsm1cHJvdmlkZXJzO1xufVxuIl19
@@ -1,34 +0,0 @@
1
- import { APP_BOOTSTRAP_LISTENER, inject } from '@angular/core';
2
- import { ɵNgxsAppBootstrappedState } from '@ngxs/store/internals';
3
- import { CUSTOM_NGXS_EXECUTION_STRATEGY } from '../execution/symbols';
4
- import { ROOT_STATE_TOKEN, NGXS_OPTIONS } from '../symbols';
5
- /**
6
- * This function provides the required providers when invoking `NgxsModule.forRoot`
7
- * or `provideStore`. It is shared between the NgModule and standalone APIs.
8
- */
9
- export function getRootProviders(states, options) {
10
- return [
11
- ...states,
12
- {
13
- provide: ROOT_STATE_TOKEN,
14
- useValue: states
15
- },
16
- {
17
- provide: APP_BOOTSTRAP_LISTENER,
18
- useFactory: () => {
19
- const appBootstrappedState = inject(ɵNgxsAppBootstrappedState);
20
- return () => appBootstrappedState.bootstrap();
21
- },
22
- multi: true
23
- },
24
- {
25
- provide: NGXS_OPTIONS,
26
- useValue: options
27
- },
28
- {
29
- provide: CUSTOM_NGXS_EXECUTION_STRATEGY,
30
- useValue: options.executionStrategy
31
- }
32
- ];
33
- }
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC1wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvc3RhbmRhbG9uZS1mZWF0dXJlcy9yb290LXByb3ZpZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQVksTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBZSx5QkFBeUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRS9FLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RFLE9BQU8sRUFBcUIsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRS9FOzs7R0FHRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FDOUIsTUFBcUIsRUFDckIsT0FBMEI7SUFFMUIsT0FBTztRQUNMLEdBQUcsTUFBTTtRQUNUO1lBQ0UsT0FBTyxFQUFFLGdCQUFnQjtZQUN6QixRQUFRLEVBQUUsTUFBTTtTQUNqQjtRQUNEO1lBQ0UsT0FBTyxFQUFFLHNCQUFzQjtZQUMvQixVQUFVLEVBQUUsR0FBRyxFQUFFO2dCQUNmLE1BQU0sb0JBQW9CLEdBQUcsTUFBTSxDQUFDLHlCQUF5QixDQUFDLENBQUM7Z0JBQy9ELE9BQU8sR0FBRyxFQUFFLENBQUMsb0JBQW9CLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDaEQsQ0FBQztZQUNELEtBQUssRUFBRSxJQUFJO1NBQ1o7UUFDRDtZQUNFLE9BQU8sRUFBRSxZQUFZO1lBQ3JCLFFBQVEsRUFBRSxPQUFPO1NBQ2xCO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsOEJBQThCO1lBQ3ZDLFFBQVEsRUFBRSxPQUFPLENBQUMsaUJBQWlCO1NBQ3BDO0tBQ0YsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUFBfQk9PVFNUUkFQX0xJU1RFTkVSLCBQcm92aWRlciwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyDJtVN0YXRlQ2xhc3MsIMm1Tmd4c0FwcEJvb3RzdHJhcHBlZFN0YXRlIH0gZnJvbSAnQG5neHMvc3RvcmUvaW50ZXJuYWxzJztcblxuaW1wb3J0IHsgQ1VTVE9NX05HWFNfRVhFQ1VUSU9OX1NUUkFURUdZIH0gZnJvbSAnLi4vZXhlY3V0aW9uL3N5bWJvbHMnO1xuaW1wb3J0IHsgTmd4c01vZHVsZU9wdGlvbnMsIFJPT1RfU1RBVEVfVE9LRU4sIE5HWFNfT1BUSU9OUyB9IGZyb20gJy4uL3N5bWJvbHMnO1xuXG4vKipcbiAqIFRoaXMgZnVuY3Rpb24gcHJvdmlkZXMgdGhlIHJlcXVpcmVkIHByb3ZpZGVycyB3aGVuIGludm9raW5nIGBOZ3hzTW9kdWxlLmZvclJvb3RgXG4gKiBvciBgcHJvdmlkZVN0b3JlYC4gSXQgaXMgc2hhcmVkIGJldHdlZW4gdGhlIE5nTW9kdWxlIGFuZCBzdGFuZGFsb25lIEFQSXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRSb290UHJvdmlkZXJzKFxuICBzdGF0ZXM6IMm1U3RhdGVDbGFzc1tdLFxuICBvcHRpb25zOiBOZ3hzTW9kdWxlT3B0aW9uc1xuKTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAgLi4uc3RhdGVzLFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFJPT1RfU1RBVEVfVE9LRU4sXG4gICAgICB1c2VWYWx1ZTogc3RhdGVzXG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBBUFBfQk9PVFNUUkFQX0xJU1RFTkVSLFxuICAgICAgdXNlRmFjdG9yeTogKCkgPT4ge1xuICAgICAgICBjb25zdCBhcHBCb290c3RyYXBwZWRTdGF0ZSA9IGluamVjdCjJtU5neHNBcHBCb290c3RyYXBwZWRTdGF0ZSk7XG4gICAgICAgIHJldHVybiAoKSA9PiBhcHBCb290c3RyYXBwZWRTdGF0ZS5ib290c3RyYXAoKTtcbiAgICAgIH0sXG4gICAgICBtdWx0aTogdHJ1ZVxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdYU19PUFRJT05TLFxuICAgICAgdXNlVmFsdWU6IG9wdGlvbnNcbiAgICB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IENVU1RPTV9OR1hTX0VYRUNVVElPTl9TVFJBVEVHWSxcbiAgICAgIHVzZVZhbHVlOiBvcHRpb25zLmV4ZWN1dGlvblN0cmF0ZWd5XG4gICAgfVxuICBdO1xufVxuIl19
@@ -1,117 +0,0 @@
1
- import { computed, inject, Injectable } from '@angular/core';
2
- import { of, throwError, catchError, distinctUntilChanged, map, shareReplay, take } from 'rxjs';
3
- import { ɵINITIAL_STATE_TOKEN, ɵStateStream } from '@ngxs/store/internals';
4
- import { InternalNgxsExecutionStrategy } from './execution/internal-ngxs-execution-strategy';
5
- import { InternalStateOperations } from './internal/state-operations';
6
- import { getRootSelectorFactory } from './selectors/selector-utils';
7
- import { leaveNgxs } from './operators/leave-ngxs';
8
- import { NgxsConfig } from './symbols';
9
- import { StateFactory } from './internal/state-factory';
10
- import * as i0 from "@angular/core";
11
- export class Store {
12
- constructor() {
13
- this._stateStream = inject(ɵStateStream);
14
- this._internalStateOperations = inject(InternalStateOperations);
15
- this._config = inject(NgxsConfig);
16
- this._internalExecutionStrategy = inject(InternalNgxsExecutionStrategy);
17
- this._stateFactory = inject(StateFactory);
18
- /**
19
- * This is a derived state stream that leaves NGXS execution strategy to emit state changes within the Angular zone,
20
- * because state is being changed actually within the `<root>` zone, see `InternalDispatcher#dispatchSingle`.
21
- * All selects would use this stream, and it would call leave only once for any state change across all active selectors.
22
- */
23
- this._selectableStateStream = this._stateStream.pipe(leaveNgxs(this._internalExecutionStrategy), shareReplay({ bufferSize: 1, refCount: true }));
24
- this.initStateStream();
25
- }
26
- /**
27
- * Dispatches action(s).
28
- */
29
- dispatch(actionOrActions) {
30
- if (typeof ngDevMode !== 'undefined' && ngDevMode) {
31
- if (
32
- // If a single action is dispatched and it's nullable.
33
- actionOrActions == null ||
34
- // If a list of actions is dispatched and any of the actions are nullable.
35
- (Array.isArray(actionOrActions) && actionOrActions.some(action => action == null))) {
36
- const error = new Error('`dispatch()` was called without providing an action.');
37
- return throwError(() => error);
38
- }
39
- }
40
- return this._internalStateOperations.getRootStateOperations().dispatch(actionOrActions);
41
- }
42
- /**
43
- * Selects a slice of data from the store.
44
- */
45
- select(selector) {
46
- const selectorFn = this.getStoreBoundSelectorFn(selector);
47
- return this._selectableStateStream.pipe(map(selectorFn), catchError((error) => {
48
- // if error is TypeError we swallow it to prevent usual errors with property access
49
- if (this._config.selectorOptions.suppressErrors && error instanceof TypeError) {
50
- return of(undefined);
51
- }
52
- // rethrow other errors
53
- return throwError(error);
54
- }), distinctUntilChanged(), leaveNgxs(this._internalExecutionStrategy));
55
- }
56
- /**
57
- * Select one slice of data from the store.
58
- */
59
- selectOnce(selector) {
60
- return this.select(selector).pipe(take(1));
61
- }
62
- /**
63
- * Select a snapshot from the state.
64
- */
65
- selectSnapshot(selector) {
66
- const selectorFn = this.getStoreBoundSelectorFn(selector);
67
- return selectorFn(this._stateStream.getValue());
68
- }
69
- /**
70
- * Select a signal from the state.
71
- */
72
- selectSignal(selector) {
73
- const selectorFn = this.getStoreBoundSelectorFn(selector);
74
- return computed(() => selectorFn(this._stateStream.state()));
75
- }
76
- /**
77
- * Allow the user to subscribe to the root of the state
78
- */
79
- subscribe(fn) {
80
- return this._selectableStateStream
81
- .pipe(leaveNgxs(this._internalExecutionStrategy))
82
- .subscribe(fn);
83
- }
84
- /**
85
- * Return the raw value of the state.
86
- */
87
- snapshot() {
88
- return this._internalStateOperations.getRootStateOperations().getState();
89
- }
90
- /**
91
- * Reset the state to a specific point in time. This method is useful
92
- * for plugin's who need to modify the state directly or unit testing.
93
- */
94
- reset(state) {
95
- this._internalStateOperations.getRootStateOperations().setState(state);
96
- }
97
- getStoreBoundSelectorFn(selector) {
98
- const makeSelectorFn = getRootSelectorFactory(selector);
99
- const runtimeContext = this._stateFactory.getRuntimeSelectorContext();
100
- return makeSelectorFn(runtimeContext);
101
- }
102
- initStateStream() {
103
- const initialStateValue = inject(ɵINITIAL_STATE_TOKEN);
104
- const value = this._stateStream.value;
105
- const storeIsEmpty = !value || Object.keys(value).length === 0;
106
- if (storeIsEmpty) {
107
- this._stateStream.next(initialStateValue);
108
- }
109
- }
110
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
111
- /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, providedIn: 'root' }); }
112
- }
113
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, decorators: [{
114
- type: Injectable,
115
- args: [{ providedIn: 'root' }]
116
- }], ctorParameters: () => [] });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../packages/store/src/store.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, inject, Injectable, Signal } from '@angular/core';\nimport {\n  Observable,\n  of,\n  Subscription,\n  throwError,\n  catchError,\n  distinctUntilChanged,\n  map,\n  shareReplay,\n  take\n} from 'rxjs';\nimport { ɵINITIAL_STATE_TOKEN, ɵStateStream } from '@ngxs/store/internals';\n\nimport { InternalNgxsExecutionStrategy } from './execution/internal-ngxs-execution-strategy';\nimport { InternalStateOperations } from './internal/state-operations';\nimport { getRootSelectorFactory } from './selectors/selector-utils';\nimport { leaveNgxs } from './operators/leave-ngxs';\nimport { NgxsConfig } from './symbols';\nimport { StateFactory } from './internal/state-factory';\nimport { TypedSelector } from './selectors';\n\n// We need to check whether the provided `T` type extends an array in order to\n// apply the `NonNullable[]` type to its elements. This is because, for\n// `const actions = [undefined]`, type inference would result in `NonNullable<unknown>`\n// rather than `NonNullable<unknown>[]`.\ntype ActionOrArrayOfActions<T> = T extends (infer U)[] ? NonNullable<U>[] : NonNullable<T>;\n\n@Injectable({ providedIn: 'root' })\nexport class Store {\n  private _stateStream = inject(ɵStateStream);\n  private _internalStateOperations = inject(InternalStateOperations);\n  private _config = inject(NgxsConfig);\n  private _internalExecutionStrategy = inject(InternalNgxsExecutionStrategy);\n  private _stateFactory = inject(StateFactory);\n\n  /**\n   * This is a derived state stream that leaves NGXS execution strategy to emit state changes within the Angular zone,\n   * because state is being changed actually within the `<root>` zone, see `InternalDispatcher#dispatchSingle`.\n   * All selects would use this stream, and it would call leave only once for any state change across all active selectors.\n   */\n  private _selectableStateStream = this._stateStream.pipe(\n    leaveNgxs(this._internalExecutionStrategy),\n    shareReplay({ bufferSize: 1, refCount: true })\n  );\n\n  constructor() {\n    this.initStateStream();\n  }\n\n  /**\n   * Dispatches action(s).\n   */\n  dispatch<T>(actionOrActions: ActionOrArrayOfActions<T>): Observable<void> {\n    if (typeof ngDevMode !== 'undefined' && ngDevMode) {\n      if (\n        // If a single action is dispatched and it's nullable.\n        actionOrActions == null ||\n        // If a list of actions is dispatched and any of the actions are nullable.\n        (Array.isArray(actionOrActions) && actionOrActions.some(action => action == null))\n      ) {\n        const error = new Error('`dispatch()` was called without providing an action.');\n        return throwError(() => error);\n      }\n    }\n\n    return this._internalStateOperations.getRootStateOperations().dispatch(actionOrActions);\n  }\n\n  /**\n   * Selects a slice of data from the store.\n   */\n  select<T>(selector: TypedSelector<T>): Observable<T> {\n    const selectorFn = this.getStoreBoundSelectorFn(selector);\n    return this._selectableStateStream.pipe(\n      map(selectorFn),\n      catchError((error: Error): Observable<never> | Observable<undefined> => {\n        // if error is TypeError we swallow it to prevent usual errors with property access\n        if (this._config.selectorOptions.suppressErrors && error instanceof TypeError) {\n          return of(undefined);\n        }\n\n        // rethrow other errors\n        return throwError(error);\n      }),\n      distinctUntilChanged(),\n      leaveNgxs(this._internalExecutionStrategy)\n    );\n  }\n\n  /**\n   * Select one slice of data from the store.\n   */\n  selectOnce<T>(selector: TypedSelector<T>): Observable<T> {\n    return this.select(selector).pipe(take(1));\n  }\n\n  /**\n   * Select a snapshot from the state.\n   */\n  selectSnapshot<T>(selector: TypedSelector<T>): T {\n    const selectorFn = this.getStoreBoundSelectorFn(selector);\n    return selectorFn(this._stateStream.getValue());\n  }\n\n  /**\n   * Select a signal from the state.\n   */\n  selectSignal<T>(selector: TypedSelector<T>): Signal<T> {\n    const selectorFn = this.getStoreBoundSelectorFn(selector);\n    return computed<T>(() => selectorFn(this._stateStream.state()));\n  }\n\n  /**\n   * Allow the user to subscribe to the root of the state\n   */\n  subscribe(fn?: (value: any) => void): Subscription {\n    return this._selectableStateStream\n      .pipe(leaveNgxs(this._internalExecutionStrategy))\n      .subscribe(fn);\n  }\n\n  /**\n   * Return the raw value of the state.\n   */\n  snapshot(): any {\n    return this._internalStateOperations.getRootStateOperations().getState();\n  }\n\n  /**\n   * Reset the state to a specific point in time. This method is useful\n   * for plugin's who need to modify the state directly or unit testing.\n   */\n  reset(state: any) {\n    this._internalStateOperations.getRootStateOperations().setState(state);\n  }\n\n  private getStoreBoundSelectorFn(selector: any) {\n    const makeSelectorFn = getRootSelectorFactory(selector);\n    const runtimeContext = this._stateFactory.getRuntimeSelectorContext();\n    return makeSelectorFn(runtimeContext);\n  }\n\n  private initStateStream(): void {\n    const initialStateValue: any = inject(ɵINITIAL_STATE_TOKEN);\n    const value = this._stateStream.value;\n    const storeIsEmpty = !value || Object.keys(value).length === 0;\n\n    if (storeIsEmpty) {\n      this._stateStream.next(initialStateValue);\n    }\n  }\n}\n"]}
@@ -1,86 +0,0 @@
1
- import { Injectable, InjectionToken, inject } from '@angular/core';
2
- import { DispatchOutsideZoneNgxsExecutionStrategy } from './execution/dispatch-outside-zone-ngxs-execution-strategy';
3
- import * as i0 from "@angular/core";
4
- // The injection token is used to resolve a list of states provided at
5
- // the root level through either `NgxsModule.forRoot` or `provideStore`.
6
- export const ROOT_STATE_TOKEN = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'ROOT_STATE_TOKEN' : '');
7
- // The injection token is used to resolve a list of states provided at
8
- // the feature level through either `NgxsModule.forFeature` or `provideStates`.
9
- // The Array<Array> is used to overload the resolved value of the token because
10
- // it is a multi-provider token.
11
- export const FEATURE_STATE_TOKEN = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'FEATURE_STATE_TOKEN' : '');
12
- // The injection token is used to resolve to options provided at the root
13
- // level through either `NgxsModule.forRoot` or `provideStore`.
14
- export const NGXS_OPTIONS = new InjectionToken(typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_OPTIONS' : '');
15
- /**
16
- * The NGXS config settings.
17
- */
18
- export class NgxsConfig {
19
- constructor() {
20
- this.compatibility = {
21
- strictContentSecurityPolicy: false
22
- };
23
- /**
24
- * Determines the execution context to perform async operations inside. An implementation can be
25
- * provided to override the default behaviour where the async operations are run
26
- * outside Angular's zone but all observable behaviours of NGXS are run back inside Angular's zone.
27
- * These observable behaviours are from:
28
- * `store.selectSignal(...)`, `store.select(...)`, `actions.subscribe(...)` or `store.dispatch(...).subscribe(...)`
29
- * Every `zone.run` causes Angular to run change detection on the whole tree (`app.tick()`) so of your
30
- * application doesn't rely on zone.js running change detection then you can switch to the
31
- * `NoopNgxsExecutionStrategy` that doesn't interact with zones.
32
- * (default: null)
33
- */
34
- this.executionStrategy = DispatchOutsideZoneNgxsExecutionStrategy;
35
- /**
36
- * Defining shared selector options
37
- */
38
- this.selectorOptions = {
39
- injectContainerState: false,
40
- suppressErrors: false
41
- };
42
- }
43
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsConfig, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
44
- /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsConfig, providedIn: 'root', useFactory: () => {
45
- const defaultConfig = new NgxsConfig();
46
- const config = inject(NGXS_OPTIONS);
47
- return {
48
- ...defaultConfig,
49
- ...config,
50
- selectorOptions: {
51
- ...defaultConfig.selectorOptions,
52
- ...config.selectorOptions
53
- }
54
- };
55
- } }); }
56
- }
57
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsConfig, decorators: [{
58
- type: Injectable,
59
- args: [{
60
- providedIn: 'root',
61
- useFactory: () => {
62
- const defaultConfig = new NgxsConfig();
63
- const config = inject(NGXS_OPTIONS);
64
- return {
65
- ...defaultConfig,
66
- ...config,
67
- selectorOptions: {
68
- ...defaultConfig.selectorOptions,
69
- ...config.selectorOptions
70
- }
71
- };
72
- }
73
- }]
74
- }] });
75
- /**
76
- * Represents a basic change from a previous to a new value for a single state instance.
77
- * Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.
78
- */
79
- export class NgxsSimpleChange {
80
- constructor(previousValue, currentValue, firstChange) {
81
- this.previousValue = previousValue;
82
- this.currentValue = currentValue;
83
- this.firstChange = firstChange;
84
- }
85
- }
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbols.js","sourceRoot":"","sources":["../../../../packages/store/src/symbols.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAQ,MAAM,EAAE,MAAM,eAAe,CAAC;AAOzE,OAAO,EAAE,wCAAwC,EAAE,MAAM,2DAA2D,CAAC;;AAErH,sEAAsE;AACtE,wEAAwE;AACxE,MAAM,CAAC,MAAM,gBAAgB,GAAG,IAAI,cAAc,CAChD,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CACxE,CAAC;AAEF,sEAAsE;AACtE,+EAA+E;AAC/E,+EAA+E;AAC/E,gCAAgC;AAChC,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,cAAc,CACnD,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAC3E,CAAC;AAEF,yEAAyE;AACzE,+DAA+D;AAC/D,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,cAAc,CAC5C,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CACpE,CAAC;AAMF;;GAEG;AAgBH,MAAM,OAAO,UAAU;IAfvB;QA0BE,kBAAa,GAOT;YACF,2BAA2B,EAAE,KAAK;SACnC,CAAC;QACF;;;;;;;;;;WAUG;QACH,sBAAiB,GAAgC,wCAAwC,CAAC;QAC1F;;WAEG;QACH,oBAAe,GAA2B;YACxC,oBAAoB,EAAE,KAAK;YAC3B,cAAc,EAAE,KAAK;SACtB,CAAC;KACH;iIAxCY,UAAU;qIAAV,UAAU,cAdT,MAAM,cACN,GAAe,EAAE;YAC3B,MAAM,aAAa,GAAG,IAAI,UAAU,EAAE,CAAC;YACvC,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;YACpC,OAAO;gBACL,GAAG,aAAa;gBAChB,GAAG,MAAM;gBACT,eAAe,EAAE;oBACf,GAAG,aAAa,CAAC,eAAe;oBAChC,GAAG,MAAM,CAAC,eAAe;iBAC1B;aACF,CAAC;QACJ,CAAC;;2FAEU,UAAU;kBAftB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;oBAClB,UAAU,EAAE,GAAe,EAAE;wBAC3B,MAAM,aAAa,GAAG,gBAAgB,CAAC;wBACvC,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;wBACpC,OAAO;4BACL,GAAG,aAAa;4BAChB,GAAG,MAAM;4BACT,eAAe,EAAE;gCACf,GAAG,aAAa,CAAC,eAAe;gCAChC,GAAG,MAAM,CAAC,eAAe;6BAC1B;yBACF,CAAC;oBACJ,CAAC;iBACF;;AAsED;;;GAGG;AACH,MAAM,OAAO,gBAAgB;IAC3B,YACkB,aAAgB,EAChB,YAAe,EACf,WAAoB;QAFpB,kBAAa,GAAb,aAAa,CAAG;QAChB,iBAAY,GAAZ,YAAY,CAAG;QACf,gBAAW,GAAX,WAAW,CAAS;IACnC,CAAC;CACL","sourcesContent":["import { Injectable, InjectionToken, Type, inject } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport { StateOperator } from '@ngxs/store/operators';\nimport { ɵSharedSelectorOptions, ɵStateClass } from '@ngxs/store/internals';\n\nimport { NgxsExecutionStrategy } from './execution/symbols';\nimport { DispatchOutsideZoneNgxsExecutionStrategy } from './execution/dispatch-outside-zone-ngxs-execution-strategy';\n\n// The injection token is used to resolve a list of states provided at\n// the root level through either `NgxsModule.forRoot` or `provideStore`.\nexport const ROOT_STATE_TOKEN = new InjectionToken<Array<ɵStateClass>>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'ROOT_STATE_TOKEN' : ''\n);\n\n// The injection token is used to resolve a list of states provided at\n// the feature level through either `NgxsModule.forFeature` or `provideStates`.\n// The Array<Array> is used to overload the resolved value of the token because\n// it is a multi-provider token.\nexport const FEATURE_STATE_TOKEN = new InjectionToken<Array<Array<ɵStateClass>>>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'FEATURE_STATE_TOKEN' : ''\n);\n\n// The injection token is used to resolve to options provided at the root\n// level through either `NgxsModule.forRoot` or `provideStore`.\nexport const NGXS_OPTIONS = new InjectionToken<NgxsModuleOptions>(\n  typeof ngDevMode !== 'undefined' && ngDevMode ? 'NGXS_OPTIONS' : ''\n);\n\nexport type NgxsLifeCycle = Partial<NgxsOnChanges> &\n  Partial<NgxsOnInit> &\n  Partial<NgxsAfterBootstrap>;\n\n/**\n * The NGXS config settings.\n */\n@Injectable({\n  providedIn: 'root',\n  useFactory: (): NgxsConfig => {\n    const defaultConfig = new NgxsConfig();\n    const config = inject(NGXS_OPTIONS);\n    return {\n      ...defaultConfig,\n      ...config,\n      selectorOptions: {\n        ...defaultConfig.selectorOptions,\n        ...config.selectorOptions\n      }\n    };\n  }\n})\nexport class NgxsConfig {\n  /**\n   * Run in development mode. This will add additional debugging features:\n   * - Object.freeze on the state and actions to guarantee immutability\n   * (default: false)\n   *\n   * Note: this property will be accounted only in development mode.\n   * It makes sense to use it only during development to ensure there're no state mutations.\n   * When building for production, the `Object.freeze` will be tree-shaken away.\n   */\n  developmentMode: boolean;\n  compatibility: {\n    /**\n     * Support a strict Content Security Policy.\n     * This will circumvent some optimisations that violate a strict CSP through the use of `new Function(...)`.\n     * (default: false)\n     */\n    strictContentSecurityPolicy: boolean;\n  } = {\n    strictContentSecurityPolicy: false\n  };\n  /**\n   * Determines the execution context to perform async operations inside. An implementation can be\n   * provided to override the default behaviour where the async operations are run\n   * outside Angular's zone but all observable behaviours of NGXS are run back inside Angular's zone.\n   * These observable behaviours are from:\n   *   `store.selectSignal(...)`, `store.select(...)`, `actions.subscribe(...)` or `store.dispatch(...).subscribe(...)`\n   * Every `zone.run` causes Angular to run change detection on the whole tree (`app.tick()`) so of your\n   * application doesn't rely on zone.js running change detection then you can switch to the\n   * `NoopNgxsExecutionStrategy` that doesn't interact with zones.\n   * (default: null)\n   */\n  executionStrategy: Type<NgxsExecutionStrategy> = DispatchOutsideZoneNgxsExecutionStrategy;\n  /**\n   * Defining shared selector options\n   */\n  selectorOptions: ɵSharedSelectorOptions = {\n    injectContainerState: false,\n    suppressErrors: false\n  };\n}\n\nexport { StateOperator };\n\n/**\n * State context provided to the actions in the state.\n */\nexport interface StateContext<T> {\n  /**\n   * Get the current state.\n   */\n  getState(): T;\n\n  /**\n   * Reset the state to a new value.\n   */\n  setState(val: T | StateOperator<T>): void;\n\n  /**\n   * Patch the existing state with the provided value.\n   */\n  patchState(val: Partial<T>): void;\n\n  /**\n   * Dispatch a new action and return the dispatched observable.\n   */\n  dispatch(actions: any | any[]): Observable<void>;\n}\n\n/**\n * Represents a basic change from a previous to a new value for a single state instance.\n * Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.\n */\nexport class NgxsSimpleChange<T = any> {\n  constructor(\n    public readonly previousValue: T,\n    public readonly currentValue: T,\n    public readonly firstChange: boolean\n  ) {}\n}\n\n/**\n * On init interface\n */\nexport interface NgxsOnInit {\n  ngxsOnInit(ctx: StateContext<any>): void;\n}\n\n/**\n * On change interface\n */\nexport interface NgxsOnChanges {\n  ngxsOnChanges(change: NgxsSimpleChange): void;\n}\n\n/**\n * After bootstrap interface\n */\nexport interface NgxsAfterBootstrap {\n  ngxsAfterBootstrap(ctx: StateContext<any>): void;\n}\n\nexport type NgxsModuleOptions = Partial<NgxsConfig>;\n\n/** @internal */\ndeclare global {\n  const ngDevMode: boolean;\n}\n"]}
@@ -1,11 +0,0 @@
1
- import { dispatch } from './dispatch';
2
- export function createDispatchMap(actionMap) {
3
- return Object.entries(actionMap).reduce((accumulator, [key, ActionType]) => {
4
- Object.defineProperty(accumulator, key, {
5
- enumerable: true,
6
- value: dispatch(ActionType)
7
- });
8
- return accumulator;
9
- }, {});
10
- }
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWRpc3BhdGNoLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0b3JlL3NyYy91dGlscy9jcmVhdGUtZGlzcGF0Y2gtbWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFNdEMsTUFBTSxVQUFVLGlCQUFpQixDQUFzQixTQUFZO0lBQ2pFLE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDLEVBQUUsRUFBRTtRQUN6RSxNQUFNLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSxHQUFHLEVBQUU7WUFDdEMsVUFBVSxFQUFFLElBQUk7WUFDaEIsS0FBSyxFQUFFLFFBQVEsQ0FBQyxVQUFVLENBQUM7U0FDNUIsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQyxFQUFFLEVBQUUsQ0FRSixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgZGlzcGF0Y2ggfSBmcm9tICcuL2Rpc3BhdGNoJztcblxuaW1wb3J0IHsgQWN0aW9uRGVmIH0gZnJvbSAnLi4vYWN0aW9ucy9zeW1ib2xzJztcblxuZXhwb3J0IHR5cGUgQWN0aW9uTWFwID0gUmVjb3JkPHN0cmluZywgQWN0aW9uRGVmPGFueT4+O1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGlzcGF0Y2hNYXA8VCBleHRlbmRzIEFjdGlvbk1hcD4oYWN0aW9uTWFwOiBUKSB7XG4gIHJldHVybiBPYmplY3QuZW50cmllcyhhY3Rpb25NYXApLnJlZHVjZSgoYWNjdW11bGF0b3IsIFtrZXksIEFjdGlvblR5cGVdKSA9PiB7XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KGFjY3VtdWxhdG9yLCBrZXksIHtcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICB2YWx1ZTogZGlzcGF0Y2goQWN0aW9uVHlwZSlcbiAgICB9KTtcbiAgICByZXR1cm4gYWNjdW11bGF0b3I7XG4gIH0sIHt9KSBhcyB7XG4gICAgLy8gVGhpcyBpcyBpbmxpbmVkIHRvIGVuaGFuY2UgZGV2ZWxvcGVyIGV4cGVyaWVuY2UuXG4gICAgLy8gSWYgd2Ugd2VyZSB0byBzd2l0Y2ggdG8gYW5vdGhlciB0eXBlLCBzdWNoIGFzXG4gICAgLy8gYHR5cGUgQWN0aW9uTWFwUmV0dXJuVHlwZTxUIGV4dGVuZHMgQWN0aW9uTWFwPiA9IHsgLi4uIH1gLCBjb2RlIGVkaXRvcnNcbiAgICAvLyB3b3VsZCBkaXNwbGF5IHRoZSByZXR1cm4gdHlwZSBzaW1wbHkgYXMgYEFjdGlvbk1hcFJldHVyblR5cGVgLCByYXRoZXJcbiAgICAvLyB0aGFuIHByZXNlbnRpbmcgaXQgYXMgYW4gb2JqZWN0IHdpdGggcHJvcGVydGllcyB0aGF0IGNvcnJlc3BvbmQgdG9cbiAgICAvLyBmdW5jdGlvbnMgcmV0dXJuaW5nIG9ic2VydmFibGVzLlxuICAgIHJlYWRvbmx5IFtLIGluIGtleW9mIFRdOiAoLi4uYXJnczogQ29uc3RydWN0b3JQYXJhbWV0ZXJzPFRbS10+KSA9PiBPYnNlcnZhYmxlPHZvaWQ+O1xuICB9O1xufVxuIl19
@@ -1,13 +0,0 @@
1
- import { inject } from '@angular/core';
2
- import { Store } from '../store';
3
- export function createSelectMap(selectorMap) {
4
- const store = inject(Store);
5
- return Object.entries(selectorMap).reduce((accumulator, [key, selector]) => {
6
- Object.defineProperty(accumulator, key, {
7
- enumerable: true,
8
- value: store.selectSignal(selector)
9
- });
10
- return accumulator;
11
- }, {});
12
- }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXNlbGVjdC1tYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvdXRpbHMvY3JlYXRlLXNlbGVjdC1tYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBS2pDLE1BQU0sVUFBVSxlQUFlLENBQXdCLFdBQWM7SUFDbkUsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRTVCLE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLEVBQUUsRUFBRTtRQUN6RSxNQUFNLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSxHQUFHLEVBQUU7WUFDdEMsVUFBVSxFQUFFLElBQUk7WUFDaEIsS0FBSyxFQUFFLEtBQUssQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO1NBQ3BDLENBQUMsQ0FBQztRQUNILE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUMsRUFBRSxFQUFFLENBUUosQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaWduYWwsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJy4uL3N0b3JlJztcbmltcG9ydCB7IFR5cGVkU2VsZWN0b3IsIMm1U2VsZWN0b3JSZXR1cm5UeXBlIH0gZnJvbSAnLi4vc2VsZWN0b3JzJztcblxuZXhwb3J0IHR5cGUgU2VsZWN0b3JNYXAgPSBSZWNvcmQ8c3RyaW5nLCBUeXBlZFNlbGVjdG9yPHVua25vd24+PjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNlbGVjdE1hcDxUIGV4dGVuZHMgU2VsZWN0b3JNYXA+KHNlbGVjdG9yTWFwOiBUKSB7XG4gIGNvbnN0IHN0b3JlID0gaW5qZWN0KFN0b3JlKTtcblxuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoc2VsZWN0b3JNYXApLnJlZHVjZSgoYWNjdW11bGF0b3IsIFtrZXksIHNlbGVjdG9yXSkgPT4ge1xuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShhY2N1bXVsYXRvciwga2V5LCB7XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlLFxuICAgICAgdmFsdWU6IHN0b3JlLnNlbGVjdFNpZ25hbChzZWxlY3RvcilcbiAgICB9KTtcbiAgICByZXR1cm4gYWNjdW11bGF0b3I7XG4gIH0sIHt9KSBhcyB7XG4gICAgLy8gVGhpcyBpcyBpbmxpbmVkIHRvIGVuaGFuY2UgZGV2ZWxvcGVyIGV4cGVyaWVuY2UuXG4gICAgLy8gSWYgd2Ugd2VyZSB0byBzd2l0Y2ggdG8gYW5vdGhlciB0eXBlLCBzdWNoIGFzXG4gICAgLy8gYHR5cGUgU2VsZWN0b3JNYXBSZXR1cm5UeXBlPFQgZXh0ZW5kcyBTZWxlY3Rvck1hcD4gPSB7IC4uLiB9YCwgY29kZSBlZGl0b3JzXG4gICAgLy8gd291bGQgZGlzcGxheSB0aGUgcmV0dXJuIHR5cGUgc2ltcGx5IGFzIGBTZWxlY3Rvck1hcFJldHVyblR5cGVgLCByYXRoZXJcbiAgICAvLyB0aGFuIHByZXNlbnRpbmcgaXQgYXMgYW4gb2JqZWN0IHdpdGggcHJvcGVydGllcyB0aGF0IGNvcnJlc3BvbmQgdG9cbiAgICAvLyBzaWduYWxzIHRoYXQga2VlcCBzdG9yZSBzZWxlY3RlZCB2YWx1ZS5cbiAgICByZWFkb25seSBbSyBpbiBrZXlvZiBUXTogU2lnbmFsPMm1U2VsZWN0b3JSZXR1cm5UeXBlPFRbS10+PjtcbiAgfTtcbn1cbiJdfQ==
@@ -1,7 +0,0 @@
1
- import { inject } from '@angular/core';
2
- import { Store } from '../store';
3
- export function dispatch(ActionType) {
4
- const store = inject(Store);
5
- return (...args) => store.dispatch(new ActionType(...args));
6
- }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGF0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdG9yZS9zcmMvdXRpbHMvZGlzcGF0Y2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBR2pDLE1BQU0sVUFBVSxRQUFRLENBQXNCLFVBQTRCO0lBQ3hFLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1QixPQUFPLENBQUMsR0FBRyxJQUFXLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxVQUFVLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQ3JFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICcuLi9zdG9yZSc7XG5pbXBvcnQgeyBBY3Rpb25EZWYgfSBmcm9tICcuLi9hY3Rpb25zL3N5bWJvbHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZGlzcGF0Y2g8VEFyZ3MgZXh0ZW5kcyBhbnlbXT4oQWN0aW9uVHlwZTogQWN0aW9uRGVmPFRBcmdzPikge1xuICBjb25zdCBzdG9yZSA9IGluamVjdChTdG9yZSk7XG4gIHJldHVybiAoLi4uYXJnczogVEFyZ3MpID0+IHN0b3JlLmRpc3BhdGNoKG5ldyBBY3Rpb25UeXBlKC4uLmFyZ3MpKTtcbn1cbiJdfQ==