@ngxs/store 18.1.5-dev.master-4720c7c → 18.1.5-dev.master-c73c22f
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/esm2022/src/actions-stream.mjs +7 -6
- package/esm2022/src/dev-features/ngxs-unhandled-actions-logger.mjs +6 -8
- package/esm2022/src/execution/dispatch-outside-zone-ngxs-execution-strategy.mjs +9 -12
- package/esm2022/src/execution/internal-ngxs-execution-strategy.mjs +6 -9
- package/esm2022/src/internal/dispatcher.mjs +11 -15
- package/esm2022/src/internal/lifecycle-state-manager.mjs +9 -13
- package/esm2022/src/internal/state-context-factory.mjs +6 -7
- package/esm2022/src/internal/state-operations.mjs +8 -11
- package/esm2022/src/store.mjs +13 -22
- package/fesm2022/ngxs-store.mjs +59 -70
- package/fesm2022/ngxs-store.mjs.map +1 -1
- package/index.d.ts +32 -183
- package/package.json +7 -7
package/esm2022/src/store.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { computed,
|
|
1
|
+
import { computed, inject, Injectable } from '@angular/core';
|
|
2
2
|
import { of, throwError, catchError, distinctUntilChanged, map, shareReplay, take } from 'rxjs';
|
|
3
3
|
import { ɵINITIAL_STATE_TOKEN, ɵStateStream } from '@ngxs/store/internals';
|
|
4
4
|
import { InternalNgxsExecutionStrategy } from './execution/internal-ngxs-execution-strategy';
|
|
@@ -8,26 +8,21 @@ import { leaveNgxs } from './operators/leave-ngxs';
|
|
|
8
8
|
import { NgxsConfig } from './symbols';
|
|
9
9
|
import { StateFactory } from './internal/state-factory';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "@ngxs/store/internals";
|
|
12
|
-
import * as i2 from "./internal/state-operations";
|
|
13
|
-
import * as i3 from "./symbols";
|
|
14
|
-
import * as i4 from "./execution/internal-ngxs-execution-strategy";
|
|
15
|
-
import * as i5 from "./internal/state-factory";
|
|
16
11
|
const NG_DEV_MODE = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
17
12
|
export class Store {
|
|
18
|
-
constructor(
|
|
19
|
-
this._stateStream =
|
|
20
|
-
this._internalStateOperations =
|
|
21
|
-
this._config =
|
|
22
|
-
this._internalExecutionStrategy =
|
|
23
|
-
this._stateFactory =
|
|
13
|
+
constructor() {
|
|
14
|
+
this._stateStream = inject(ɵStateStream);
|
|
15
|
+
this._internalStateOperations = inject(InternalStateOperations);
|
|
16
|
+
this._config = inject(NgxsConfig);
|
|
17
|
+
this._internalExecutionStrategy = inject(InternalNgxsExecutionStrategy);
|
|
18
|
+
this._stateFactory = inject(StateFactory);
|
|
24
19
|
/**
|
|
25
20
|
* This is a derived state stream that leaves NGXS execution strategy to emit state changes within the Angular zone,
|
|
26
21
|
* because state is being changed actually within the `<root>` zone, see `InternalDispatcher#dispatchSingle`.
|
|
27
22
|
* All selects would use this stream, and it would call leave only once for any state change across all active selectors.
|
|
28
23
|
*/
|
|
29
24
|
this._selectableStateStream = this._stateStream.pipe(leaveNgxs(this._internalExecutionStrategy), shareReplay({ bufferSize: 1, refCount: true }));
|
|
30
|
-
this.initStateStream(
|
|
25
|
+
this.initStateStream();
|
|
31
26
|
}
|
|
32
27
|
/**
|
|
33
28
|
* Dispatches action(s).
|
|
@@ -105,23 +100,19 @@ export class Store {
|
|
|
105
100
|
const runtimeContext = this._stateFactory.getRuntimeSelectorContext();
|
|
106
101
|
return makeSelectorFn(runtimeContext);
|
|
107
102
|
}
|
|
108
|
-
initStateStream(
|
|
103
|
+
initStateStream() {
|
|
104
|
+
const initialStateValue = inject(ɵINITIAL_STATE_TOKEN);
|
|
109
105
|
const value = this._stateStream.value;
|
|
110
106
|
const storeIsEmpty = !value || Object.keys(value).length === 0;
|
|
111
107
|
if (storeIsEmpty) {
|
|
112
108
|
this._stateStream.next(initialStateValue);
|
|
113
109
|
}
|
|
114
110
|
}
|
|
115
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, deps: [
|
|
111
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
116
112
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, providedIn: 'root' }); }
|
|
117
113
|
}
|
|
118
114
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, decorators: [{
|
|
119
115
|
type: Injectable,
|
|
120
116
|
args: [{ providedIn: 'root' }]
|
|
121
|
-
}], ctorParameters: () => [
|
|
122
|
-
type: Optional
|
|
123
|
-
}, {
|
|
124
|
-
type: Inject,
|
|
125
|
-
args: [ɵINITIAL_STATE_TOKEN]
|
|
126
|
-
}] }] });
|
|
127
|
-
//# 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, Optional, 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\nconst NG_DEV_MODE = typeof ngDevMode !== 'undefined' && ngDevMode;\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  /**\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    private _stateStream: ɵStateStream,\n    private _internalStateOperations: InternalStateOperations,\n    private _config: NgxsConfig,\n    private _internalExecutionStrategy: InternalNgxsExecutionStrategy,\n    private _stateFactory: StateFactory,\n    @Optional()\n    @Inject(ɵINITIAL_STATE_TOKEN)\n    initialStateValue: any\n  ) {\n    this.initStateStream(initialStateValue);\n  }\n\n  /**\n   * Dispatches action(s).\n   */\n  dispatch<T>(actionOrActions: ActionOrArrayOfActions<T>): Observable<void> {\n    if (NG_DEV_MODE) {\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(initialStateValue: any): void {\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"]}
|
|
117
|
+
}], ctorParameters: () => [] });
|
|
118
|
+
//# 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\nconst NG_DEV_MODE = typeof ngDevMode !== 'undefined' && ngDevMode;\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 (NG_DEV_MODE) {\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"]}
|
package/fesm2022/ngxs-store.mjs
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, NgZone, PLATFORM_ID,
|
|
2
|
+
import { Injectable, inject, NgZone, PLATFORM_ID, InjectionToken, INJECTOR, ErrorHandler, Injector, ɵisPromise as _isPromise, computed, makeEnvironmentProviders, ENVIRONMENT_INITIALIZER, NgModule, APP_BOOTSTRAP_LISTENER } from '@angular/core';
|
|
3
3
|
import { Subject, filter, Observable, share, config, of, forkJoin, throwError, EMPTY, mergeMap, map as map$1, defaultIfEmpty, catchError, from, isObservable, takeUntil, finalize, shareReplay as shareReplay$1, distinctUntilChanged, take as take$1, ReplaySubject } from 'rxjs';
|
|
4
|
-
import
|
|
5
|
-
import { ɵwrapObserverCalls as _wrapObserverCalls, ɵOrderedSubject as _OrderedSubject, ɵmemoize as _memoize, ɵgetStoreMetadata as _getStoreMetadata, ɵgetSelectorMetadata as _getSelectorMetadata, ɵMETA_KEY as _META_KEY, ɵINITIAL_STATE_TOKEN as _INITIAL_STATE_TOKEN, ɵNgxsAppBootstrappedState as _NgxsAppBootstrappedState, ɵensureStoreMetadata as _ensureStoreMetadata, ɵMETA_OPTIONS_KEY as _META_OPTIONS_KEY, ɵensureSelectorMetadata as _ensureSelectorMetadata, ɵNGXS_STATE_CONTEXT_FACTORY as _NGXS_STATE_CONTEXT_FACTORY, ɵNGXS_STATE_FACTORY as _NGXS_STATE_FACTORY } from '@ngxs/store/internals';
|
|
4
|
+
import { ɵwrapObserverCalls as _wrapObserverCalls, ɵOrderedSubject as _OrderedSubject, ɵStateStream as _StateStream, ɵmemoize as _memoize, ɵgetStoreMetadata as _getStoreMetadata, ɵgetSelectorMetadata as _getSelectorMetadata, ɵMETA_KEY as _META_KEY, ɵINITIAL_STATE_TOKEN as _INITIAL_STATE_TOKEN, ɵNgxsAppBootstrappedState as _NgxsAppBootstrappedState, ɵensureStoreMetadata as _ensureStoreMetadata, ɵMETA_OPTIONS_KEY as _META_OPTIONS_KEY, ɵensureSelectorMetadata as _ensureSelectorMetadata, ɵNGXS_STATE_CONTEXT_FACTORY as _NGXS_STATE_CONTEXT_FACTORY, ɵNGXS_STATE_FACTORY as _NGXS_STATE_FACTORY } from '@ngxs/store/internals';
|
|
6
5
|
export { StateToken } from '@ngxs/store/internals';
|
|
7
6
|
import { isPlatformServer } from '@angular/common';
|
|
8
7
|
import { map, shareReplay, filter as filter$1, take, exhaustMap, tap, mergeMap as mergeMap$1, takeUntil as takeUntil$1, startWith, pairwise } from 'rxjs/operators';
|
|
@@ -74,15 +73,15 @@ function throwPatchingPrimitiveError() {
|
|
|
74
73
|
}
|
|
75
74
|
|
|
76
75
|
class DispatchOutsideZoneNgxsExecutionStrategy {
|
|
77
|
-
constructor(
|
|
78
|
-
this._ngZone =
|
|
79
|
-
this.
|
|
76
|
+
constructor() {
|
|
77
|
+
this._ngZone = inject(NgZone);
|
|
78
|
+
this._isServer = isPlatformServer(inject(PLATFORM_ID));
|
|
80
79
|
if (typeof ngDevMode !== 'undefined' && ngDevMode) {
|
|
81
|
-
verifyZoneIsNotNooped(_ngZone);
|
|
80
|
+
verifyZoneIsNotNooped(this._ngZone);
|
|
82
81
|
}
|
|
83
82
|
}
|
|
84
83
|
enter(func) {
|
|
85
|
-
if (
|
|
84
|
+
if (this._isServer) {
|
|
86
85
|
return this.runInsideAngular(func);
|
|
87
86
|
}
|
|
88
87
|
return this.runOutsideAngular(func);
|
|
@@ -102,16 +101,13 @@ class DispatchOutsideZoneNgxsExecutionStrategy {
|
|
|
102
101
|
}
|
|
103
102
|
return func();
|
|
104
103
|
}
|
|
105
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: DispatchOutsideZoneNgxsExecutionStrategy, deps: [
|
|
104
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: DispatchOutsideZoneNgxsExecutionStrategy, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
106
105
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: DispatchOutsideZoneNgxsExecutionStrategy, providedIn: 'root' }); }
|
|
107
106
|
}
|
|
108
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: DispatchOutsideZoneNgxsExecutionStrategy, decorators: [{
|
|
109
108
|
type: Injectable,
|
|
110
109
|
args: [{ providedIn: 'root' }]
|
|
111
|
-
}], ctorParameters: () => [
|
|
112
|
-
type: Inject,
|
|
113
|
-
args: [PLATFORM_ID]
|
|
114
|
-
}] }] });
|
|
110
|
+
}], ctorParameters: () => [] });
|
|
115
111
|
// Caretaker note: this should exist as a separate function and not a class method,
|
|
116
112
|
// since class methods are not tree-shakable.
|
|
117
113
|
function verifyZoneIsNotNooped(ngZone) {
|
|
@@ -151,8 +147,8 @@ const NGXS_EXECUTION_STRATEGY = new InjectionToken(NG_DEV_MODE$9 ? 'NGXS_EXECUTI
|
|
|
151
147
|
});
|
|
152
148
|
|
|
153
149
|
class InternalNgxsExecutionStrategy {
|
|
154
|
-
constructor(
|
|
155
|
-
this._executionStrategy =
|
|
150
|
+
constructor() {
|
|
151
|
+
this._executionStrategy = inject(NGXS_EXECUTION_STRATEGY);
|
|
156
152
|
}
|
|
157
153
|
enter(func) {
|
|
158
154
|
return this._executionStrategy.enter(func);
|
|
@@ -160,16 +156,13 @@ class InternalNgxsExecutionStrategy {
|
|
|
160
156
|
leave(func) {
|
|
161
157
|
return this._executionStrategy.leave(func);
|
|
162
158
|
}
|
|
163
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalNgxsExecutionStrategy, deps: [
|
|
159
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalNgxsExecutionStrategy, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
164
160
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalNgxsExecutionStrategy, providedIn: 'root' }); }
|
|
165
161
|
}
|
|
166
162
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalNgxsExecutionStrategy, decorators: [{
|
|
167
163
|
type: Injectable,
|
|
168
164
|
args: [{ providedIn: 'root' }]
|
|
169
|
-
}]
|
|
170
|
-
type: Inject,
|
|
171
|
-
args: [NGXS_EXECUTION_STRATEGY]
|
|
172
|
-
}] }] });
|
|
165
|
+
}] });
|
|
173
166
|
|
|
174
167
|
/**
|
|
175
168
|
* Composes a array of functions from left to right. Example:
|
|
@@ -234,7 +227,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
234
227
|
* You can listen to this in services to react without stores.
|
|
235
228
|
*/
|
|
236
229
|
class Actions extends Observable {
|
|
237
|
-
constructor(
|
|
230
|
+
constructor() {
|
|
231
|
+
const internalActions$ = inject(InternalActions);
|
|
232
|
+
const internalExecutionStrategy = inject(InternalNgxsExecutionStrategy);
|
|
238
233
|
const sharedInternalActions$ = internalActions$.pipe(leaveNgxs(internalExecutionStrategy),
|
|
239
234
|
// The `InternalActions` subject emits outside of the Angular zone.
|
|
240
235
|
// We have to re-enter the Angular zone for any incoming consumer.
|
|
@@ -250,13 +245,13 @@ class Actions extends Observable {
|
|
|
250
245
|
observer.add(childSubscription);
|
|
251
246
|
});
|
|
252
247
|
}
|
|
253
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Actions, deps: [
|
|
248
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Actions, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
254
249
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Actions, providedIn: 'root' }); }
|
|
255
250
|
}
|
|
256
251
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Actions, decorators: [{
|
|
257
252
|
type: Injectable,
|
|
258
253
|
args: [{ providedIn: 'root' }]
|
|
259
|
-
}], ctorParameters: () => [
|
|
254
|
+
}], ctorParameters: () => [] });
|
|
260
255
|
|
|
261
256
|
class PluginManager {
|
|
262
257
|
constructor() {
|
|
@@ -368,13 +363,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
368
363
|
args: [{ providedIn: 'root' }]
|
|
369
364
|
}] });
|
|
370
365
|
class InternalDispatcher {
|
|
371
|
-
constructor(
|
|
372
|
-
this._ngZone =
|
|
373
|
-
this._actions =
|
|
374
|
-
this._actionResults =
|
|
375
|
-
this._pluginManager =
|
|
376
|
-
this._stateStream =
|
|
377
|
-
this._ngxsExecutionStrategy =
|
|
366
|
+
constructor() {
|
|
367
|
+
this._ngZone = inject(NgZone);
|
|
368
|
+
this._actions = inject(InternalActions);
|
|
369
|
+
this._actionResults = inject(InternalDispatchedActionResults);
|
|
370
|
+
this._pluginManager = inject(PluginManager);
|
|
371
|
+
this._stateStream = inject(_StateStream);
|
|
372
|
+
this._ngxsExecutionStrategy = inject(InternalNgxsExecutionStrategy);
|
|
378
373
|
}
|
|
379
374
|
/**
|
|
380
375
|
* Dispatches event(s).
|
|
@@ -435,13 +430,13 @@ class InternalDispatcher {
|
|
|
435
430
|
}))
|
|
436
431
|
.pipe(shareReplay());
|
|
437
432
|
}
|
|
438
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalDispatcher, deps: [
|
|
433
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalDispatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
439
434
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalDispatcher, providedIn: 'root' }); }
|
|
440
435
|
}
|
|
441
436
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalDispatcher, decorators: [{
|
|
442
437
|
type: Injectable,
|
|
443
438
|
args: [{ providedIn: 'root' }]
|
|
444
|
-
}]
|
|
439
|
+
}] });
|
|
445
440
|
|
|
446
441
|
const NG_DEV_MODE$8 = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
447
442
|
// The injection token is used to resolve a list of states provided at
|
|
@@ -551,10 +546,10 @@ const deepFreeze = (o) => {
|
|
|
551
546
|
* @ignore
|
|
552
547
|
*/
|
|
553
548
|
class InternalStateOperations {
|
|
554
|
-
constructor(
|
|
555
|
-
this._stateStream =
|
|
556
|
-
this._dispatcher =
|
|
557
|
-
this._config =
|
|
549
|
+
constructor() {
|
|
550
|
+
this._stateStream = inject(_StateStream);
|
|
551
|
+
this._dispatcher = inject(InternalDispatcher);
|
|
552
|
+
this._config = inject(NgxsConfig);
|
|
558
553
|
}
|
|
559
554
|
/**
|
|
560
555
|
* Returns the root state operators.
|
|
@@ -581,13 +576,13 @@ class InternalStateOperations {
|
|
|
581
576
|
// Set the state to the current + new
|
|
582
577
|
stateOperations.setState({ ...currentState, ...results.defaults });
|
|
583
578
|
}
|
|
584
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalStateOperations, deps: [
|
|
579
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalStateOperations, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
585
580
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalStateOperations, providedIn: 'root' }); }
|
|
586
581
|
}
|
|
587
582
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: InternalStateOperations, decorators: [{
|
|
588
583
|
type: Injectable,
|
|
589
584
|
args: [{ providedIn: 'root' }]
|
|
590
|
-
}]
|
|
585
|
+
}] });
|
|
591
586
|
function ensureStateAndActionsAreImmutable(root) {
|
|
592
587
|
return {
|
|
593
588
|
getState: () => root.getState(),
|
|
@@ -985,12 +980,13 @@ const NGXS_DEVELOPMENT_OPTIONS = new InjectionToken(NG_DEV_MODE$5 ? 'NGXS_DEVELO
|
|
|
985
980
|
});
|
|
986
981
|
|
|
987
982
|
class NgxsUnhandledActionsLogger {
|
|
988
|
-
constructor(
|
|
983
|
+
constructor() {
|
|
989
984
|
/**
|
|
990
985
|
* These actions should be ignored by default; the user can increase this
|
|
991
986
|
* list in the future via the `ignoreActions` method.
|
|
992
987
|
*/
|
|
993
988
|
this._ignoredActions = new Set([InitState.type, UpdateState.type]);
|
|
989
|
+
const options = inject(NGXS_DEVELOPMENT_OPTIONS);
|
|
994
990
|
if (typeof options.warnOnUnhandledActions === 'object') {
|
|
995
991
|
this.ignoreActions(...options.warnOnUnhandledActions.ignore);
|
|
996
992
|
}
|
|
@@ -1015,15 +1011,12 @@ class NgxsUnhandledActionsLogger {
|
|
|
1015
1011
|
: action.type;
|
|
1016
1012
|
console.warn(`The ${action} action has been dispatched but hasn't been handled. This may happen if the state with an action handler for this action is not registered.`);
|
|
1017
1013
|
}
|
|
1018
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsUnhandledActionsLogger, deps: [
|
|
1014
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsUnhandledActionsLogger, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1019
1015
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsUnhandledActionsLogger }); }
|
|
1020
1016
|
}
|
|
1021
1017
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgxsUnhandledActionsLogger, decorators: [{
|
|
1022
1018
|
type: Injectable
|
|
1023
|
-
}], ctorParameters: () => [
|
|
1024
|
-
type: Inject,
|
|
1025
|
-
args: [NGXS_DEVELOPMENT_OPTIONS]
|
|
1026
|
-
}] }] });
|
|
1019
|
+
}], ctorParameters: () => [] });
|
|
1027
1020
|
|
|
1028
1021
|
class NgxsUnhandledErrorHandler {
|
|
1029
1022
|
constructor() {
|
|
@@ -1076,8 +1069,8 @@ function simplePatch(value) {
|
|
|
1076
1069
|
* @ignore
|
|
1077
1070
|
*/
|
|
1078
1071
|
class StateContextFactory {
|
|
1079
|
-
constructor(
|
|
1080
|
-
this._internalStateOperations =
|
|
1072
|
+
constructor() {
|
|
1073
|
+
this._internalStateOperations = inject(InternalStateOperations);
|
|
1081
1074
|
}
|
|
1082
1075
|
/**
|
|
1083
1076
|
* Create the state context
|
|
@@ -1108,13 +1101,13 @@ class StateContextFactory {
|
|
|
1108
1101
|
}
|
|
1109
1102
|
};
|
|
1110
1103
|
}
|
|
1111
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, deps: [
|
|
1104
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1112
1105
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, providedIn: 'root' }); }
|
|
1113
1106
|
}
|
|
1114
1107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: StateContextFactory, decorators: [{
|
|
1115
1108
|
type: Injectable,
|
|
1116
1109
|
args: [{ providedIn: 'root' }]
|
|
1117
|
-
}]
|
|
1110
|
+
}] });
|
|
1118
1111
|
function setStateValue(root, currentAppState, newValue, path) {
|
|
1119
1112
|
const newAppState = setValue(currentAppState, path, newValue);
|
|
1120
1113
|
root.setState(newAppState);
|
|
@@ -1553,19 +1546,19 @@ function noop() { }
|
|
|
1553
1546
|
|
|
1554
1547
|
const NG_DEV_MODE$3 = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
1555
1548
|
class Store {
|
|
1556
|
-
constructor(
|
|
1557
|
-
this._stateStream =
|
|
1558
|
-
this._internalStateOperations =
|
|
1559
|
-
this._config =
|
|
1560
|
-
this._internalExecutionStrategy =
|
|
1561
|
-
this._stateFactory =
|
|
1549
|
+
constructor() {
|
|
1550
|
+
this._stateStream = inject(_StateStream);
|
|
1551
|
+
this._internalStateOperations = inject(InternalStateOperations);
|
|
1552
|
+
this._config = inject(NgxsConfig);
|
|
1553
|
+
this._internalExecutionStrategy = inject(InternalNgxsExecutionStrategy);
|
|
1554
|
+
this._stateFactory = inject(StateFactory);
|
|
1562
1555
|
/**
|
|
1563
1556
|
* This is a derived state stream that leaves NGXS execution strategy to emit state changes within the Angular zone,
|
|
1564
1557
|
* because state is being changed actually within the `<root>` zone, see `InternalDispatcher#dispatchSingle`.
|
|
1565
1558
|
* All selects would use this stream, and it would call leave only once for any state change across all active selectors.
|
|
1566
1559
|
*/
|
|
1567
1560
|
this._selectableStateStream = this._stateStream.pipe(leaveNgxs(this._internalExecutionStrategy), shareReplay$1({ bufferSize: 1, refCount: true }));
|
|
1568
|
-
this.initStateStream(
|
|
1561
|
+
this.initStateStream();
|
|
1569
1562
|
}
|
|
1570
1563
|
/**
|
|
1571
1564
|
* Dispatches action(s).
|
|
@@ -1643,25 +1636,21 @@ class Store {
|
|
|
1643
1636
|
const runtimeContext = this._stateFactory.getRuntimeSelectorContext();
|
|
1644
1637
|
return makeSelectorFn(runtimeContext);
|
|
1645
1638
|
}
|
|
1646
|
-
initStateStream(
|
|
1639
|
+
initStateStream() {
|
|
1640
|
+
const initialStateValue = inject(_INITIAL_STATE_TOKEN);
|
|
1647
1641
|
const value = this._stateStream.value;
|
|
1648
1642
|
const storeIsEmpty = !value || Object.keys(value).length === 0;
|
|
1649
1643
|
if (storeIsEmpty) {
|
|
1650
1644
|
this._stateStream.next(initialStateValue);
|
|
1651
1645
|
}
|
|
1652
1646
|
}
|
|
1653
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, deps: [
|
|
1647
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1654
1648
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, providedIn: 'root' }); }
|
|
1655
1649
|
}
|
|
1656
1650
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: Store, decorators: [{
|
|
1657
1651
|
type: Injectable,
|
|
1658
1652
|
args: [{ providedIn: 'root' }]
|
|
1659
|
-
}], ctorParameters: () => [
|
|
1660
|
-
type: Optional
|
|
1661
|
-
}, {
|
|
1662
|
-
type: Inject,
|
|
1663
|
-
args: [_INITIAL_STATE_TOKEN]
|
|
1664
|
-
}] }] });
|
|
1653
|
+
}], ctorParameters: () => [] });
|
|
1665
1654
|
|
|
1666
1655
|
const NG_DEV_MODE$2 = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
1667
1656
|
/**
|
|
@@ -1719,11 +1708,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
1719
1708
|
|
|
1720
1709
|
const NG_DEV_MODE$1 = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
1721
1710
|
class LifecycleStateManager {
|
|
1722
|
-
constructor(
|
|
1723
|
-
this._store =
|
|
1724
|
-
this._internalStateOperations =
|
|
1725
|
-
this._stateContextFactory =
|
|
1726
|
-
this._appBootstrappedState =
|
|
1711
|
+
constructor() {
|
|
1712
|
+
this._store = inject(Store);
|
|
1713
|
+
this._internalStateOperations = inject(InternalStateOperations);
|
|
1714
|
+
this._stateContextFactory = inject(StateContextFactory);
|
|
1715
|
+
this._appBootstrappedState = inject(_NgxsAppBootstrappedState);
|
|
1727
1716
|
this._destroy$ = new ReplaySubject(1);
|
|
1728
1717
|
}
|
|
1729
1718
|
ngOnDestroy() {
|
|
@@ -1780,13 +1769,13 @@ class LifecycleStateManager {
|
|
|
1780
1769
|
_getStateContext(mappedStore) {
|
|
1781
1770
|
return this._stateContextFactory.createStateContext(mappedStore.path);
|
|
1782
1771
|
}
|
|
1783
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, deps: [
|
|
1772
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1784
1773
|
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, providedIn: 'root' }); }
|
|
1785
1774
|
}
|
|
1786
1775
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: LifecycleStateManager, decorators: [{
|
|
1787
1776
|
type: Injectable,
|
|
1788
1777
|
args: [{ providedIn: 'root' }]
|
|
1789
|
-
}]
|
|
1778
|
+
}] });
|
|
1790
1779
|
|
|
1791
1780
|
const NG_DEV_MODE = typeof ngDevMode !== 'undefined' && ngDevMode;
|
|
1792
1781
|
/**
|