@ngxs/store 3.8.1-dev.master-b3b91f8 → 3.8.1-dev.master-b132a8a
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.
- package/esm2020/src/configs/messages.config.mjs +6 -1
- package/esm2020/src/internal/lifecycle-state-manager.mjs +19 -1
- package/fesm2015/ngxs-store.mjs +34 -13
- package/fesm2015/ngxs-store.mjs.map +1 -1
- package/fesm2020/ngxs-store.mjs +34 -13
- package/fesm2020/ngxs-store.mjs.map +1 -1
- package/package.json +1 -1
- package/src/configs/messages.config.d.ts +1 -0
- package/src/internal/lifecycle-state-manager.d.ts +3 -1
|
@@ -24,6 +24,11 @@ export function getZoneWarningMessage() {
|
|
|
24
24
|
export function getUndecoratedStateInIvyWarningMessage(name) {
|
|
25
25
|
return `'${name}' class should be decorated with @Injectable() right after the @State() decorator`;
|
|
26
26
|
}
|
|
27
|
+
export function getInvalidInitializationOrderMessage() {
|
|
28
|
+
return ('You have an invalid state initialization order. This typically occurs when `NgxsModule.forFeature`\n' +
|
|
29
|
+
'or `provideStates` is called before `NgxsModule.forRoot` or `provideStore`.\n' +
|
|
30
|
+
'One example is when `NgxsRouterPluginModule.forRoot` is called before `NgxsModule.forRoot`.');
|
|
31
|
+
}
|
|
27
32
|
export function throwSelectFactoryNotConnectedError() {
|
|
28
33
|
throw new Error('You have forgotten to import the NGXS module!');
|
|
29
34
|
}
|
|
@@ -33,4 +38,4 @@ export function throwPatchingArrayError() {
|
|
|
33
38
|
export function throwPatchingPrimitiveError() {
|
|
34
39
|
throw new Error('Patching primitives is not supported.');
|
|
35
40
|
}
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZXMuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3RvcmUvc3JjL2NvbmZpZ3MvbWVzc2FnZXMuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxJQUFZO0lBQzlDLE1BQU0sSUFBSSxLQUFLLENBQ2IsR0FBRyxJQUFJLDBFQUEwRSxDQUNsRixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSwyQkFBMkI7SUFDekMsTUFBTSxJQUFJLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQyxDQUFDO0FBQzdELENBQUM7QUFFRCxNQUFNLFVBQVUscUJBQXFCLENBQ25DLE9BQWUsRUFDZixPQUFlLEVBQ2YsT0FBZTtJQUVmLE1BQU0sSUFBSSxLQUFLLENBQUMsZUFBZSxPQUFPLFVBQVUsT0FBTyxzQkFBc0IsT0FBTyxHQUFHLENBQUMsQ0FBQztBQUMzRixDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUFDLElBQVk7SUFDbkQsTUFBTSxJQUFJLEtBQUssQ0FBQywwREFBMEQsSUFBSSxVQUFVLENBQUMsQ0FBQztBQUM1RixDQUFDO0FBRUQsTUFBTSxVQUFVLHlCQUF5QjtJQUN2QyxNQUFNLElBQUksS0FBSyxDQUFDLHlEQUF5RCxDQUFDLENBQUM7QUFDN0UsQ0FBQztBQUVELE1BQU0sVUFBVSwyQkFBMkI7SUFDekMsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBQ3JELENBQUM7QUFFRCxNQUFNLFVBQVUscUJBQXFCO0lBQ25DLE9BQU8sQ0FDTCw2R0FBNkc7UUFDN0csd0ZBQXdGO1FBQ3hGLDhFQUE4RSxDQUMvRSxDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSxzQ0FBc0MsQ0FBQyxJQUFZO0lBQ2pFLE9BQU8sSUFBSSxJQUFJLG1GQUFtRixDQUFDO0FBQ3JHLENBQUM7QUFFRCxNQUFNLFVBQVUsb0NBQW9DO0lBQ2xELE9BQU8sQ0FDTCxzR0FBc0c7UUFDdEcsK0VBQStFO1FBQy9FLDZGQUE2RixDQUM5RixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSxtQ0FBbUM7SUFDakQsTUFBTSxJQUFJLEtBQUssQ0FBQywrQ0FBK0MsQ0FBQyxDQUFDO0FBQ25FLENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCO0lBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsbUNBQW1DLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBRUQsTUFBTSxVQUFVLDJCQUEyQjtJQUN6QyxNQUFNLElBQUksS0FBSyxDQUFDLHVDQUF1QyxDQUFDLENBQUM7QUFDM0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiB0aHJvd1N0YXRlTmFtZUVycm9yKG5hbWU6IHN0cmluZyk6IG5ldmVyIHtcbiAgdGhyb3cgbmV3IEVycm9yKFxuICAgIGAke25hbWV9IGlzIG5vdCBhIHZhbGlkIHN0YXRlIG5hbWUuIEl0IG5lZWRzIHRvIGJlIGEgdmFsaWQgb2JqZWN0IHByb3BlcnR5IG5hbWUuYFxuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdGhyb3dTdGF0ZU5hbWVQcm9wZXJ0eUVycm9yKCk6IG5ldmVyIHtcbiAgdGhyb3cgbmV3IEVycm9yKGBTdGF0ZXMgbXVzdCByZWdpc3RlciBhICduYW1lJyBwcm9wZXJ0eS5gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93U3RhdGVVbmlxdWVFcnJvcihcbiAgY3VycmVudDogc3RyaW5nLFxuICBuZXdOYW1lOiBzdHJpbmcsXG4gIG9sZE5hbWU6IHN0cmluZ1xuKTogbmV2ZXIge1xuICB0aHJvdyBuZXcgRXJyb3IoYFN0YXRlIG5hbWUgJyR7Y3VycmVudH0nIGZyb20gJHtuZXdOYW1lfSBhbHJlYWR5IGV4aXN0cyBpbiAke29sZE5hbWV9LmApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdGhyb3dTdGF0ZURlY29yYXRvckVycm9yKG5hbWU6IHN0cmluZyk6IG5ldmVyIHtcbiAgdGhyb3cgbmV3IEVycm9yKGBTdGF0ZXMgbXVzdCBiZSBkZWNvcmF0ZWQgd2l0aCBAU3RhdGUoKSBkZWNvcmF0b3IsIGJ1dCBcIiR7bmFtZX1cIiBpc24ndC5gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93QWN0aW9uRGVjb3JhdG9yRXJyb3IoKTogbmV2ZXIge1xuICB0aHJvdyBuZXcgRXJyb3IoJ0BBY3Rpb24oKSBkZWNvcmF0b3IgY2Fubm90IGJlIHVzZWQgd2l0aCBzdGF0aWMgbWV0aG9kcy4nKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93U2VsZWN0b3JEZWNvcmF0b3JFcnJvcigpOiBuZXZlciB7XG4gIHRocm93IG5ldyBFcnJvcignU2VsZWN0b3JzIG9ubHkgd29yayBvbiBtZXRob2RzLicpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Wm9uZVdhcm5pbmdNZXNzYWdlKCk6IHN0cmluZyB7XG4gIHJldHVybiAoXG4gICAgJ1lvdXIgYXBwbGljYXRpb24gd2FzIGJvb3RzdHJhcHBlZCB3aXRoIG5vb3BlZCB6b25lIGFuZCB5b3VyIGV4ZWN1dGlvbiBzdHJhdGVneSByZXF1aXJlcyBhbiBhY3R1YWwgTmdab25lIVxcbicgK1xuICAgICdQbGVhc2Ugc2V0IHRoZSB2YWx1ZSBvZiB0aGUgZXhlY3V0aW9uU3RyYXRlZ3kgcHJvcGVydHkgdG8gTm9vcE5neHNFeGVjdXRpb25TdHJhdGVneS5cXG4nICtcbiAgICAnTmd4c01vZHVsZS5mb3JSb290KHN0YXRlcywgeyBleGVjdXRpb25TdHJhdGVneTogTm9vcE5neHNFeGVjdXRpb25TdHJhdGVneSB9KSdcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFVuZGVjb3JhdGVkU3RhdGVJbkl2eVdhcm5pbmdNZXNzYWdlKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJyR7bmFtZX0nIGNsYXNzIHNob3VsZCBiZSBkZWNvcmF0ZWQgd2l0aCBASW5qZWN0YWJsZSgpIHJpZ2h0IGFmdGVyIHRoZSBAU3RhdGUoKSBkZWNvcmF0b3JgO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SW52YWxpZEluaXRpYWxpemF0aW9uT3JkZXJNZXNzYWdlKCkge1xuICByZXR1cm4gKFxuICAgICdZb3UgaGF2ZSBhbiBpbnZhbGlkIHN0YXRlIGluaXRpYWxpemF0aW9uIG9yZGVyLiBUaGlzIHR5cGljYWxseSBvY2N1cnMgd2hlbiBgTmd4c01vZHVsZS5mb3JGZWF0dXJlYFxcbicgK1xuICAgICdvciBgcHJvdmlkZVN0YXRlc2AgaXMgY2FsbGVkIGJlZm9yZSBgTmd4c01vZHVsZS5mb3JSb290YCBvciBgcHJvdmlkZVN0b3JlYC5cXG4nICtcbiAgICAnT25lIGV4YW1wbGUgaXMgd2hlbiBgTmd4c1JvdXRlclBsdWdpbk1vZHVsZS5mb3JSb290YCBpcyBjYWxsZWQgYmVmb3JlIGBOZ3hzTW9kdWxlLmZvclJvb3RgLidcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93U2VsZWN0RmFjdG9yeU5vdENvbm5lY3RlZEVycm9yKCk6IG5ldmVyIHtcbiAgdGhyb3cgbmV3IEVycm9yKCdZb3UgaGF2ZSBmb3Jnb3R0ZW4gdG8gaW1wb3J0IHRoZSBOR1hTIG1vZHVsZSEnKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93UGF0Y2hpbmdBcnJheUVycm9yKCk6IG5ldmVyIHtcbiAgdGhyb3cgbmV3IEVycm9yKCdQYXRjaGluZyBhcnJheXMgaXMgbm90IHN1cHBvcnRlZC4nKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRocm93UGF0Y2hpbmdQcmltaXRpdmVFcnJvcigpOiBuZXZlciB7XG4gIHRocm93IG5ldyBFcnJvcignUGF0Y2hpbmcgcHJpbWl0aXZlcyBpcyBub3Qgc3VwcG9ydGVkLicpO1xufVxuIl19
|
|
@@ -5,15 +5,18 @@ import { catchError, filter, mergeMap, pairwise, startWith, takeUntil, tap } fro
|
|
|
5
5
|
import { Store } from '../store';
|
|
6
6
|
import { getValue } from '../utils/utils';
|
|
7
7
|
import { InternalErrorReporter } from './error-handler';
|
|
8
|
+
import { InitState, UpdateState } from '../actions/actions';
|
|
8
9
|
import { StateContextFactory } from './state-context-factory';
|
|
9
10
|
import { InternalStateOperations } from './state-operations';
|
|
10
11
|
import { NgxsSimpleChange } from '../symbols';
|
|
12
|
+
import { getInvalidInitializationOrderMessage } from '../configs/messages.config';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
import * as i1 from "../store";
|
|
13
15
|
import * as i2 from "./error-handler";
|
|
14
16
|
import * as i3 from "./state-operations";
|
|
15
17
|
import * as i4 from "./state-context-factory";
|
|
16
18
|
import * as i5 from "@ngxs/store/internals";
|
|
19
|
+
const NG_DEV_MODE = typeof ngDevMode === 'undefined' || ngDevMode;
|
|
17
20
|
export class LifecycleStateManager {
|
|
18
21
|
constructor(_store, _internalErrorReporter, _internalStateOperations, _stateContextFactory, _bootstrapper) {
|
|
19
22
|
this._store = _store;
|
|
@@ -27,6 +30,21 @@ export class LifecycleStateManager {
|
|
|
27
30
|
this._destroy$.next();
|
|
28
31
|
}
|
|
29
32
|
ngxsBootstrap(action, results) {
|
|
33
|
+
if (NG_DEV_MODE) {
|
|
34
|
+
if (action instanceof InitState) {
|
|
35
|
+
this._initStateHasBeenDispatched = true;
|
|
36
|
+
}
|
|
37
|
+
else if (
|
|
38
|
+
// This is a dev mode-only check that ensures the correct order of
|
|
39
|
+
// state initialization. The `NgxsModule.forRoot` or `provideStore` should
|
|
40
|
+
// always come first, followed by `forFeature` and `provideStates`. If the
|
|
41
|
+
// `UpdateState` is dispatched before the `InitState` is dispatched, it indicates
|
|
42
|
+
// that modules or providers are in an invalid order.
|
|
43
|
+
action instanceof UpdateState &&
|
|
44
|
+
!this._initStateHasBeenDispatched) {
|
|
45
|
+
console.error(getInvalidInitializationOrderMessage());
|
|
46
|
+
}
|
|
47
|
+
}
|
|
30
48
|
this._internalStateOperations
|
|
31
49
|
.getRootStateOperations()
|
|
32
50
|
.dispatch(action)
|
|
@@ -76,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.4", ngImpor
|
|
|
76
94
|
type: Injectable,
|
|
77
95
|
args: [{ providedIn: 'root' }]
|
|
78
96
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.InternalErrorReporter }, { type: i3.InternalStateOperations }, { type: i4.StateContextFactory }, { type: i5.NgxsBootstrapper }]; } });
|
|
79
|
-
//# 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 { Injectable, OnDestroy } from '@angular/core';\nimport { NgxsBootstrapper } from '@ngxs/store/internals';\nimport { EMPTY, ReplaySubject } from 'rxjs';\nimport {\n  catchError,\n  filter,\n  mergeMap,\n  pairwise,\n  startWith,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\n\nimport { Store } from '../store';\nimport { getValue } from '../utils/utils';\nimport { InternalErrorReporter } from './error-handler';\nimport { StateContextFactory } from './state-context-factory';\nimport { InternalStateOperations } from './state-operations';\nimport { MappedStore, StatesAndDefaults } from './internals';\nimport { NgxsLifeCycle, NgxsSimpleChange, StateContext } from '../symbols';\n\n@Injectable({ providedIn: 'root' })\nexport class LifecycleStateManager implements OnDestroy {\n  private readonly _destroy$ = new ReplaySubject<void>(1);\n\n  constructor(\n    private _store: Store,\n    private _internalErrorReporter: InternalErrorReporter,\n    private _internalStateOperations: InternalStateOperations,\n    private _stateContextFactory: StateContextFactory,\n    private _bootstrapper: NgxsBootstrapper\n  ) {}\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  ngxsBootstrap<T>(action: T, results: StatesAndDefaults | undefined): void {\n    this._internalStateOperations\n      .getRootStateOperations()\n      .dispatch(action)\n      .pipe(\n        filter(() => !!results),\n        tap(() => this._invokeInitOnStates(results!.states)),\n        mergeMap(() => this._bootstrapper.appBootstrapped$),\n        filter(appBootstrapped => !!appBootstrapped),\n        catchError(error => {\n          // The `SafeSubscriber` (which is used by most RxJS operators) re-throws\n          // errors asynchronously (`setTimeout(() => { throw error })`). This might\n          // break existing user's code or unit tests. We catch the error manually to\n          // be backward compatible with the old behavior.\n          this._internalErrorReporter.reportErrorSafely(error);\n          return EMPTY;\n        }),\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);\n  }\n}\n"]}
|
|
97
|
+
//# 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 { Injectable, OnDestroy } from '@angular/core';\nimport { NgxsBootstrapper } from '@ngxs/store/internals';\nimport { EMPTY, ReplaySubject } from 'rxjs';\nimport {\n  catchError,\n  filter,\n  mergeMap,\n  pairwise,\n  startWith,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\n\nimport { Store } from '../store';\nimport { getValue } from '../utils/utils';\nimport { InternalErrorReporter } from './error-handler';\nimport { InitState, UpdateState } from '../actions/actions';\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\nconst NG_DEV_MODE = typeof ngDevMode === 'undefined' || ngDevMode;\n\n@Injectable({ providedIn: 'root' })\nexport class LifecycleStateManager implements OnDestroy {\n  private readonly _destroy$ = new ReplaySubject<void>(1);\n\n  private _initStateHasBeenDispatched?: boolean;\n\n  constructor(\n    private _store: Store,\n    private _internalErrorReporter: InternalErrorReporter,\n    private _internalStateOperations: InternalStateOperations,\n    private _stateContextFactory: StateContextFactory,\n    private _bootstrapper: NgxsBootstrapper\n  ) {}\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  ngxsBootstrap(\n    action: InitState | UpdateState,\n    results: StatesAndDefaults | undefined\n  ): void {\n    if (NG_DEV_MODE) {\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());\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._bootstrapper.appBootstrapped$),\n        filter(appBootstrapped => !!appBootstrapped),\n        catchError(error => {\n          // The `SafeSubscriber` (which is used by most RxJS operators) re-throws\n          // errors asynchronously (`setTimeout(() => { throw error })`). This might\n          // break existing user's code or unit tests. We catch the error manually to\n          // be backward compatible with the old behavior.\n          this._internalErrorReporter.reportErrorSafely(error);\n          return EMPTY;\n        }),\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);\n  }\n}\n"]}
|
package/fesm2015/ngxs-store.mjs
CHANGED
|
@@ -702,6 +702,11 @@ function getZoneWarningMessage() {
|
|
|
702
702
|
function getUndecoratedStateInIvyWarningMessage(name) {
|
|
703
703
|
return `'${name}' class should be decorated with @Injectable() right after the @State() decorator`;
|
|
704
704
|
}
|
|
705
|
+
function getInvalidInitializationOrderMessage() {
|
|
706
|
+
return ('You have an invalid state initialization order. This typically occurs when `NgxsModule.forFeature`\n' +
|
|
707
|
+
'or `provideStates` is called before `NgxsModule.forRoot` or `provideStore`.\n' +
|
|
708
|
+
'One example is when `NgxsRouterPluginModule.forRoot` is called before `NgxsModule.forRoot`.');
|
|
709
|
+
}
|
|
705
710
|
function throwSelectFactoryNotConnectedError() {
|
|
706
711
|
throw new Error('You have forgotten to import the NGXS module!');
|
|
707
712
|
}
|
|
@@ -767,18 +772,18 @@ function verifyZoneIsNotNooped(ngZone) {
|
|
|
767
772
|
console.warn(getZoneWarningMessage());
|
|
768
773
|
}
|
|
769
774
|
|
|
770
|
-
const NG_DEV_MODE$
|
|
775
|
+
const NG_DEV_MODE$4 = typeof ngDevMode === 'undefined' || ngDevMode;
|
|
771
776
|
/**
|
|
772
777
|
* Consumers have the option to utilize the execution strategy provided by
|
|
773
778
|
* `NgxsModule.forRoot({executionStrategy})` or `provideStore([], {executionStrategy})`.
|
|
774
779
|
*/
|
|
775
|
-
const CUSTOM_NGXS_EXECUTION_STRATEGY = new InjectionToken(NG_DEV_MODE$
|
|
780
|
+
const CUSTOM_NGXS_EXECUTION_STRATEGY = new InjectionToken(NG_DEV_MODE$4 ? 'CUSTOM_NGXS_EXECUTION_STRATEGY' : '');
|
|
776
781
|
/**
|
|
777
782
|
* The injection token is used internally to resolve an instance of the execution
|
|
778
783
|
* strategy. It checks whether consumers have provided their own `executionStrategy`
|
|
779
784
|
* and also verifies if we are operating in a zone-aware environment.
|
|
780
785
|
*/
|
|
781
|
-
const NGXS_EXECUTION_STRATEGY = new InjectionToken(NG_DEV_MODE$
|
|
786
|
+
const NGXS_EXECUTION_STRATEGY = new InjectionToken(NG_DEV_MODE$4 ? 'NGXS_EXECUTION_STRATEGY' : '', {
|
|
782
787
|
providedIn: 'root',
|
|
783
788
|
factory: () => {
|
|
784
789
|
const injector = inject(INJECTOR);
|
|
@@ -858,21 +863,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.4", ngImpor
|
|
|
858
863
|
args: [{ providedIn: 'root' }]
|
|
859
864
|
}], ctorParameters: function () { return [{ type: InternalActions }, { type: InternalNgxsExecutionStrategy }]; } });
|
|
860
865
|
|
|
861
|
-
const NG_DEV_MODE$
|
|
866
|
+
const NG_DEV_MODE$3 = typeof ngDevMode === 'undefined' || ngDevMode;
|
|
862
867
|
// The injection token is used to resolve a list of states provided at
|
|
863
868
|
// the root level through either `NgxsModule.forRoot` or `provideStore`.
|
|
864
|
-
const ROOT_STATE_TOKEN = new InjectionToken(NG_DEV_MODE$
|
|
869
|
+
const ROOT_STATE_TOKEN = new InjectionToken(NG_DEV_MODE$3 ? 'ROOT_STATE_TOKEN' : '');
|
|
865
870
|
// The injection token is used to resolve a list of states provided at
|
|
866
871
|
// the feature level through either `NgxsModule.forFeature` or `provideStates`.
|
|
867
872
|
// The Array<Array> is used to overload the resolved value of the token because
|
|
868
873
|
// it is a multi-provider token.
|
|
869
|
-
const FEATURE_STATE_TOKEN = new InjectionToken(NG_DEV_MODE$
|
|
874
|
+
const FEATURE_STATE_TOKEN = new InjectionToken(NG_DEV_MODE$3 ? 'FEATURE_STATE_TOKEN' : '');
|
|
870
875
|
// The injection token is used to resolve to custom NGXS plugins provided
|
|
871
876
|
// at the root level through either `{provide}` scheme or `withNgxsPlugin`.
|
|
872
|
-
const NGXS_PLUGINS = new InjectionToken(NG_DEV_MODE$
|
|
877
|
+
const NGXS_PLUGINS = new InjectionToken(NG_DEV_MODE$3 ? 'NGXS_PLUGINS' : '');
|
|
873
878
|
// The injection token is used to resolve to options provided at the root
|
|
874
879
|
// level through either `NgxsModule.forRoot` or `provideStore`.
|
|
875
|
-
const NGXS_OPTIONS = new InjectionToken(NG_DEV_MODE$
|
|
880
|
+
const NGXS_OPTIONS = new InjectionToken(NG_DEV_MODE$3 ? 'NGXS_OPTIONS' : '');
|
|
876
881
|
/**
|
|
877
882
|
* The NGXS config settings.
|
|
878
883
|
*/
|
|
@@ -1388,7 +1393,7 @@ function getState(currentAppState, path) {
|
|
|
1388
1393
|
return getValue(currentAppState, path);
|
|
1389
1394
|
}
|
|
1390
1395
|
|
|
1391
|
-
const NG_DEV_MODE$
|
|
1396
|
+
const NG_DEV_MODE$2 = typeof ngDevMode === 'undefined' || ngDevMode;
|
|
1392
1397
|
/**
|
|
1393
1398
|
* The `StateFactory` class adds root and feature states to the graph.
|
|
1394
1399
|
* This extracts state names from state classes, checks if they already
|
|
@@ -1478,7 +1483,7 @@ class StateFactory {
|
|
|
1478
1483
|
* Add a new state to the global defs.
|
|
1479
1484
|
*/
|
|
1480
1485
|
add(stateClasses) {
|
|
1481
|
-
if (NG_DEV_MODE$
|
|
1486
|
+
if (NG_DEV_MODE$2) {
|
|
1482
1487
|
ensureStatesAreDecorated(stateClasses);
|
|
1483
1488
|
}
|
|
1484
1489
|
const { newStates } = this.addToStatesMap(stateClasses);
|
|
@@ -1498,7 +1503,7 @@ class StateFactory {
|
|
|
1498
1503
|
// `State` decorator. This check is moved here because the `ɵprov` property
|
|
1499
1504
|
// will not exist on the class in JIT mode (because it's set asynchronously
|
|
1500
1505
|
// during JIT compilation through `Object.defineProperty`).
|
|
1501
|
-
if (NG_DEV_MODE$
|
|
1506
|
+
if (NG_DEV_MODE$2) {
|
|
1502
1507
|
ensureStateClassIsInjectable(stateClass);
|
|
1503
1508
|
}
|
|
1504
1509
|
const stateMap = {
|
|
@@ -1600,7 +1605,7 @@ class StateFactory {
|
|
|
1600
1605
|
}
|
|
1601
1606
|
// The `NgxsUnhandledActionsLogger` is a tree-shakable class which functions
|
|
1602
1607
|
// only during development.
|
|
1603
|
-
if (NG_DEV_MODE$
|
|
1608
|
+
if (NG_DEV_MODE$2 && !actionHasBeenHandled) {
|
|
1604
1609
|
const unhandledActionsLogger = this._injector.get(NgxsUnhandledActionsLogger, null);
|
|
1605
1610
|
// The `NgxsUnhandledActionsLogger` will not be resolved by the injector if the
|
|
1606
1611
|
// `NgxsDevelopmentModule` is not provided. It's enough to check whether the `injector.get`
|
|
@@ -1619,7 +1624,7 @@ class StateFactory {
|
|
|
1619
1624
|
const statesMap = this.statesByName;
|
|
1620
1625
|
for (const stateClass of stateClasses) {
|
|
1621
1626
|
const stateName = getStoreMetadata$1(stateClass).name;
|
|
1622
|
-
if (NG_DEV_MODE$
|
|
1627
|
+
if (NG_DEV_MODE$2) {
|
|
1623
1628
|
ensureStateNameIsUnique(stateName, stateClass, statesMap);
|
|
1624
1629
|
}
|
|
1625
1630
|
const unmountedState = !statesMap[stateName];
|
|
@@ -1776,6 +1781,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.4", ngImpor
|
|
|
1776
1781
|
args: [{ providedIn: 'root' }]
|
|
1777
1782
|
}], ctorParameters: function () { return [{ type: Store }, { type: NgxsConfig }]; } });
|
|
1778
1783
|
|
|
1784
|
+
const NG_DEV_MODE$1 = typeof ngDevMode === 'undefined' || ngDevMode;
|
|
1779
1785
|
class LifecycleStateManager {
|
|
1780
1786
|
constructor(_store, _internalErrorReporter, _internalStateOperations, _stateContextFactory, _bootstrapper) {
|
|
1781
1787
|
this._store = _store;
|
|
@@ -1789,6 +1795,21 @@ class LifecycleStateManager {
|
|
|
1789
1795
|
this._destroy$.next();
|
|
1790
1796
|
}
|
|
1791
1797
|
ngxsBootstrap(action, results) {
|
|
1798
|
+
if (NG_DEV_MODE$1) {
|
|
1799
|
+
if (action instanceof InitState) {
|
|
1800
|
+
this._initStateHasBeenDispatched = true;
|
|
1801
|
+
}
|
|
1802
|
+
else if (
|
|
1803
|
+
// This is a dev mode-only check that ensures the correct order of
|
|
1804
|
+
// state initialization. The `NgxsModule.forRoot` or `provideStore` should
|
|
1805
|
+
// always come first, followed by `forFeature` and `provideStates`. If the
|
|
1806
|
+
// `UpdateState` is dispatched before the `InitState` is dispatched, it indicates
|
|
1807
|
+
// that modules or providers are in an invalid order.
|
|
1808
|
+
action instanceof UpdateState &&
|
|
1809
|
+
!this._initStateHasBeenDispatched) {
|
|
1810
|
+
console.error(getInvalidInitializationOrderMessage());
|
|
1811
|
+
}
|
|
1812
|
+
}
|
|
1792
1813
|
this._internalStateOperations
|
|
1793
1814
|
.getRootStateOperations()
|
|
1794
1815
|
.dispatch(action)
|