@ngxs/store
Version:
1,440 lines (1,406 loc) • 172 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@ngxs/store/internals'), require('@angular/common'), require('rxjs'), require('rxjs/operators')) :
typeof define === 'function' && define.amd ? define('@ngxs/store', ['exports', '@angular/core', '@ngxs/store/internals', '@angular/common', 'rxjs', 'rxjs/operators'], factory) :
(global = global || self, factory((global.ngxs = global.ngxs || {}, global.ngxs.store = {}), global.ng.core, global.ngxs.store.internals, global.ng.common, global.rxjs, global.rxjs.operators));
}(this, function (exports, core, internals, common, rxjs, operators) { 'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function() {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __rest(s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
}
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
}
function __createBinding(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}
function __exportStar(m, exports) {
for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) exports[p] = m[p];
}
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
}
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
function __spreadArrays() {
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
};
function __await(v) {
return this instanceof __await ? (this.v = v, this) : new __await(v);
}
function __asyncGenerator(thisArg, _arguments, generator) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
}
function __asyncDelegator(o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
}
function __asyncValues(o) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
}
function __makeTemplateObject(cooked, raw) {
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
return cooked;
};
function __importStar(mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result.default = mod;
return result;
}
function __importDefault(mod) {
return (mod && mod.__esModule) ? mod : { default: mod };
}
function __classPrivateFieldGet(receiver, privateMap) {
if (!privateMap.has(receiver)) {
throw new TypeError("attempted to get private field on non-instance");
}
return privateMap.get(receiver);
}
function __classPrivateFieldSet(receiver, privateMap, value) {
if (!privateMap.has(receiver)) {
throw new TypeError("attempted to set private field on non-instance");
}
privateMap.set(receiver, value);
return value;
}
var _a;
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @enum {string} */
var VALIDATION_CODE = {
STATE_NAME: 'STATE_NAME',
STATE_UNIQUE: 'STATE_UNIQUE',
STATE_NAME_PROPERTY: 'STATE_NAME_PROPERTY',
STATE_DECORATOR: 'STATE_DECORATOR',
INCORRECT_PRODUCTION: 'INCORRECT_PRODUCTION',
INCORRECT_DEVELOPMENT: 'INCORRECT_DEVELOPMENT',
SELECT_FACTORY_NOT_CONNECTED: 'SELECT_FACTORY_NOT_CONNECTED',
ACTION_DECORATOR: 'ACTION_DECORATOR',
SELECTOR_DECORATOR: 'SELECTOR_DECORATOR',
ZONE_WARNING: 'ZONE_WARNING',
PATCHING_ARRAY: 'PATCHING_ARRAY',
PATCHING_PRIMITIVE: 'PATCHING_PRIMITIVE',
UNDECORATED_STATE_IN_IVY: 'UNDECORATED_STATE_IN_IVY',
};
/** @type {?} */
var CONFIG_MESSAGES = (_a = {},
_a[VALIDATION_CODE.STATE_NAME] = (/**
* @param {?} name
* @return {?}
*/
function (name) {
return name + " is not a valid state name. It needs to be a valid object property name.";
}),
_a[VALIDATION_CODE.STATE_NAME_PROPERTY] = (/**
* @return {?}
*/
function () { return "States must register a 'name' property"; }),
_a[VALIDATION_CODE.STATE_UNIQUE] = (/**
* @param {?} current
* @param {?} newName
* @param {?} oldName
* @return {?}
*/
function (current, newName, oldName) {
return "State name '" + current + "' from " + newName + " already exists in " + oldName;
}),
_a[VALIDATION_CODE.STATE_DECORATOR] = (/**
* @return {?}
*/
function () { return 'States must be decorated with @State() decorator'; }),
_a[VALIDATION_CODE.INCORRECT_PRODUCTION] = (/**
* @return {?}
*/
function () {
return 'Angular is running in production mode but NGXS is still running in the development mode!\n' +
'Please set developmentMode to false on the NgxsModule options when in production mode.\n' +
'NgxsModule.forRoot(states, { developmentMode: !environment.production })';
}),
_a[VALIDATION_CODE.INCORRECT_DEVELOPMENT] = (/**
* @return {?}
*/
function () {
return 'RECOMMENDATION: Set developmentMode to true on the NgxsModule when Angular is running in development mode.\n' +
'NgxsModule.forRoot(states, { developmentMode: !environment.production })';
}),
_a[VALIDATION_CODE.SELECT_FACTORY_NOT_CONNECTED] = (/**
* @return {?}
*/
function () {
return 'You have forgotten to import the NGXS module!';
}),
_a[VALIDATION_CODE.ACTION_DECORATOR] = (/**
* @return {?}
*/
function () {
return '@Action() decorator cannot be used with static methods';
}),
_a[VALIDATION_CODE.SELECTOR_DECORATOR] = (/**
* @return {?}
*/
function () { return 'Selectors only work on methods'; }),
_a[VALIDATION_CODE.ZONE_WARNING] = (/**
* @return {?}
*/
function () {
return 'Your application was bootstrapped with nooped zone and your execution strategy requires an actual NgZone!\n' +
'Please set the value of the executionStrategy property to NoopNgxsExecutionStrategy.\n' +
'NgxsModule.forRoot(states, { executionStrategy: NoopNgxsExecutionStrategy })';
}),
_a[VALIDATION_CODE.PATCHING_ARRAY] = (/**
* @return {?}
*/
function () { return 'Patching arrays is not supported.'; }),
_a[VALIDATION_CODE.PATCHING_PRIMITIVE] = (/**
* @return {?}
*/
function () { return 'Patching primitives is not supported.'; }),
_a[VALIDATION_CODE.UNDECORATED_STATE_IN_IVY] = (/**
* @param {?} name
* @return {?}
*/
function (name) {
return "'" + name + "' class should be decorated with @Injectable() right after the @State() decorator";
}),
_a);
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var DispatchOutsideZoneNgxsExecutionStrategy = /** @class */ (function () {
function DispatchOutsideZoneNgxsExecutionStrategy(_ngZone, _platformId) {
this._ngZone = _ngZone;
this._platformId = _platformId;
this.verifyZoneIsNotNooped(this._ngZone);
}
/**
* @template T
* @param {?} func
* @return {?}
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype.enter = /**
* @template T
* @param {?} func
* @return {?}
*/
function (func) {
if (common.isPlatformServer(this._platformId)) {
return this.runInsideAngular(func);
}
return this.runOutsideAngular(func);
};
/**
* @template T
* @param {?} func
* @return {?}
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype.leave = /**
* @template T
* @param {?} func
* @return {?}
*/
function (func) {
return this.runInsideAngular(func);
};
/**
* @private
* @template T
* @param {?} func
* @return {?}
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype.runInsideAngular = /**
* @private
* @template T
* @param {?} func
* @return {?}
*/
function (func) {
if (core.NgZone.isInAngularZone()) {
return func();
}
return this._ngZone.run(func);
};
/**
* @private
* @template T
* @param {?} func
* @return {?}
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype.runOutsideAngular = /**
* @private
* @template T
* @param {?} func
* @return {?}
*/
function (func) {
if (core.NgZone.isInAngularZone()) {
return this._ngZone.runOutsideAngular(func);
}
return func();
};
/**
* @private
* @param {?} ngZone
* @return {?}
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype.verifyZoneIsNotNooped = /**
* @private
* @param {?} ngZone
* @return {?}
*/
function (ngZone) {
// `NoopNgZone` is not exposed publicly as it doesn't expect
// to be used outside of the core Angular code, thus we just have
// to check if the zone doesn't extend or instanceof `NgZone`
if (ngZone instanceof core.NgZone) {
return;
}
console.warn(CONFIG_MESSAGES[VALIDATION_CODE.ZONE_WARNING]());
};
DispatchOutsideZoneNgxsExecutionStrategy.decorators = [
{ type: core.Injectable }
];
/** @nocollapse */
DispatchOutsideZoneNgxsExecutionStrategy.ctorParameters = function () { return [
{ type: core.NgZone },
{ type: String, decorators: [{ type: core.Inject, args: [core.PLATFORM_ID,] }] }
]; };
return DispatchOutsideZoneNgxsExecutionStrategy;
}());
if (false) {
/**
* @type {?}
* @private
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype._ngZone;
/**
* @type {?}
* @private
*/
DispatchOutsideZoneNgxsExecutionStrategy.prototype._platformId;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
var ROOT_STATE_TOKEN = new core.InjectionToken('ROOT_STATE_TOKEN');
/** @type {?} */
var FEATURE_STATE_TOKEN = new core.InjectionToken('FEATURE_STATE_TOKEN');
/** @type {?} */
var NGXS_PLUGINS = new core.InjectionToken('NGXS_PLUGINS');
/** @type {?} */
var NG_TEST_MODE = new core.InjectionToken('NG_TEST_MODE');
/** @type {?} */
var NG_DEV_MODE = new core.InjectionToken('NG_DEV_MODE');
/** @type {?} */
var META_KEY = 'NGXS_META';
/** @type {?} */
var META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
/** @type {?} */
var SELECTOR_META_KEY = 'NGXS_SELECTOR_META';
/**
* The NGXS config settings.
*/
var NgxsConfig = /** @class */ (function () {
function NgxsConfig() {
/**
* Defining the default state before module initialization
* This is convenient if we need to create a define our own set of states.
* @deprecated will be removed after v4
* (default: {})
*/
this.defaultsState = {};
/**
* Defining shared selector options
*/
this.selectorOptions = {
injectContainerState: true,
// TODO: default is true in v3, will change in v4
suppressErrors: true // TODO: default is true in v3, will change in v4
};
this.compatibility = {
strictContentSecurityPolicy: false
};
this.executionStrategy = DispatchOutsideZoneNgxsExecutionStrategy;
}
NgxsConfig.decorators = [
{ type: core.Injectable }
];
/** @nocollapse */
NgxsConfig.ctorParameters = function () { return []; };
return NgxsConfig;
}());
if (false) {
/**
* Run in development mode. This will add additional debugging features:
* - Object.freeze on the state and actions to guarantee immutability
* (default: false)
* @type {?}
*/
NgxsConfig.prototype.developmentMode;
/** @type {?} */
NgxsConfig.prototype.compatibility;
/**
* Determines the execution context to perform async operations inside. An implementation can be
* provided to override the default behaviour where the async operations are run
* outside Angular's zone but all observable behaviours of NGXS are run back inside Angular's zone.
* These observable behaviours are from:
* `\@Select(...)`, `store.select(...)`, `actions.subscribe(...)` or `store.dispatch(...).subscribe(...)`
* Every `zone.run` causes Angular to run change detection on the whole tree (`app.tick()`) so of your
* application doesn't rely on zone.js running change detection then you can switch to the
* `NoopNgxsExecutionStrategy` that doesn't interact with zones.
* (default: null)
* @type {?}
*/
NgxsConfig.prototype.executionStrategy;
/**
* Defining the default state before module initialization
* This is convenient if we need to create a define our own set of states.
* @deprecated will be removed after v4
* (default: {})
* @type {?}
*/
NgxsConfig.prototype.defaultsState;
/**
* Defining shared selector options
* @type {?}
*/
NgxsConfig.prototype.selectorOptions;
}
/**
* State context provided to the actions in the state.
* @record
* @template T
*/
function StateContext() { }
if (false) {
/**
* Get the current state.
* @return {?}
*/
StateContext.prototype.getState = function () { };
/**
* Reset the state to a new value.
* @param {?} val
* @return {?}
*/
StateContext.prototype.setState = function (val) { };
/**
* Patch the existing state with the provided value.
* @param {?} val
* @return {?}
*/
StateContext.prototype.patchState = function (val) { };
/**
* Dispatch a new action and return the dispatched observable.
* @param {?} actions
* @return {?}
*/
StateContext.prototype.dispatch = function (actions) { };
}
/**
* Plugin interface
* @record
*/
function NgxsPlugin() { }
if (false) {
/**
* Handle the state/action before its submitted to the state handlers.
* @param {?} state
* @param {?} action
* @param {?} next
* @return {?}
*/
NgxsPlugin.prototype.handle = function (state, action, next) { };
}
/**
* Options that can be provided to the store.
* @record
* @template T
*/
function StoreOptions() { }
if (false) {
/**
* Name of the state. Required.
* @type {?}
*/
StoreOptions.prototype.name;
/**
* Default values for the state. If not provided, uses empty object.
* @type {?|undefined}
*/
StoreOptions.prototype.defaults;
/**
* Sub states for the given state.
* @type {?|undefined}
*/
StoreOptions.prototype.children;
}
/**
* Represents a basic change from a previous to a new value for a single state instance.
* Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.
* @template T
*/
var /**
* Represents a basic change from a previous to a new value for a single state instance.
* Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.
* @template T
*/
NgxsSimpleChange = /** @class */ (function () {
function NgxsSimpleChange(previousValue, currentValue, firstChange) {
this.previousValue = previousValue;
this.currentValue = currentValue;
this.firstChange = firstChange;
}
return NgxsSimpleChange;
}());
if (false) {
/** @type {?} */
NgxsSimpleChange.prototype.previousValue;
/** @type {?} */
NgxsSimpleChange.prototype.currentValue;
/** @type {?} */
NgxsSimpleChange.prototype.firstChange;
}
/**
* On init interface
* @record
*/
function NgxsOnInit() { }
if (false) {
/**
* @param {?=} ctx
* @return {?}
*/
NgxsOnInit.prototype.ngxsOnInit = function (ctx) { };
}
/**
* On change interface
* @record
*/
function NgxsOnChanges() { }
if (false) {
/**
* @param {?} change
* @return {?}
*/
NgxsOnChanges.prototype.ngxsOnChanges = function (change) { };
}
/**
* After bootstrap interface
* @record
*/
function NgxsAfterBootstrap() { }
if (false) {
/**
* @param {?=} ctx
* @return {?}
*/
NgxsAfterBootstrap.prototype.ngxsAfterBootstrap = function (ctx) { };
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* Internal execution strategy injection token
*/
/** @type {?} */
var NGXS_EXECUTION_STRATEGY = new core.InjectionToken('NGXS_EXECUTION_STRATEGY');
/**
* @record
*/
function NgxsExecutionStrategy() { }
if (false) {
/**
* @template T
* @param {?} func
* @return {?}
*/
NgxsExecutionStrategy.prototype.enter = function (func) { };
/**
* @template T
* @param {?} func
* @return {?}
*/
NgxsExecutionStrategy.prototype.leave = function (func) { };
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* Returns the type from an action instance/class.
* @ignore
* @param {?} action
* @return {?}
*/
function getActionTypeFromInstance(action) {
if (action.constructor && action.constructor.type) {
return action.constructor.type;
}
else {
return action.type;
}
}
/**
* Matches a action
* @ignore
* @param {?} action1
* @return {?}
*/
function actionMatcher(action1) {
/** @type {?} */
var type1 = getActionTypeFromInstance(action1);
return (/**
* @param {?} action2
* @return {?}
*/
function (action2) {
return type1 === getActionTypeFromInstance(action2);
});
}
/**
* Set a deeply nested value. Example:
*
* setValue({ foo: { bar: { eat: false } } },
* 'foo.bar.eat', true) //=> { foo: { bar: { eat: true } } }
*
* While it traverses it also creates new objects from top down.
*
* @ignore
* @type {?}
*/
var setValue = (/**
* @param {?} obj
* @param {?} prop
* @param {?} val
* @return {?}
*/
function (obj, prop, val) {
obj = __assign({}, obj);
/** @type {?} */
var split = prop.split('.');
/** @type {?} */
var lastIndex = split.length - 1;
split.reduce((/**
* @param {?} acc
* @param {?} part
* @param {?} index
* @return {?}
*/
function (acc, part, index) {
if (index === lastIndex) {
acc[part] = val;
}
else {
acc[part] = Array.isArray(acc[part]) ? acc[part].slice() : __assign({}, acc[part]);
}
return acc && acc[part];
}), obj);
return obj;
});
/**
* Get a deeply nested value. Example:
*
* getValue({ foo: bar: [] }, 'foo.bar') //=> []
*
* @ignore
* @type {?}
*/
var getValue = (/**
* @param {?} obj
* @param {?} prop
* @return {?}
*/
function (obj, prop) {
return prop.split('.').reduce((/**
* @param {?} acc
* @param {?} part
* @return {?}
*/
function (acc, part) { return acc && acc[part]; }), obj);
});
/**
* Simple object check.
*
* isObject({a:1}) //=> true
* isObject(1) //=> false
*
* @ignore
* @type {?}
*/
var isObject = (/**
* @param {?} item
* @return {?}
*/
function (item) {
return item && typeof item === 'object' && !Array.isArray(item);
});
/**
* Deep merge two objects.
*
* mergeDeep({a:1, b:{x: 1, y:2}}, {b:{x: 3}, c:4}) //=> {a:1, b:{x:3, y:2}, c:4}
*
* \@param base base object onto which `sources` will be applied
* @type {?}
*/
var mergeDeep = (/**
* @param {?} base
* @param {...?} sources
* @return {?}
*/
function (base) {
var sources = [];
for (var _i = 1; _i < arguments.length; _i++) {
sources[_i - 1] = arguments[_i];
}
var _a, _b;
if (!sources.length)
return base;
/** @type {?} */
var source = sources.shift();
if (isObject(base) && isObject(source)) {
for (var key in source) {
if (isObject(source[key])) {
if (!base[key])
Object.assign(base, (_a = {}, _a[key] = {}, _a));
mergeDeep(base[key], source[key]);
}
else {
Object.assign(base, (_b = {}, _b[key] = source[key], _b));
}
}
}
return mergeDeep.apply(void 0, __spread([base], sources));
});
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
* @template T, U
*/
function StateClassInternal() { }
if (false) {
/* Skipping unnamed member:
[META_KEY]?: MetaDataModel;*/
/* Skipping unnamed member:
[META_OPTIONS_KEY]?: StoreOptions<U>;*/
}
/**
* @record
* @template T
*/
function StateOperations() { }
if (false) {
/**
* @return {?}
*/
StateOperations.prototype.getState = function () { };
/**
* @param {?} val
* @return {?}
*/
StateOperations.prototype.setState = function (val) { };
/**
* @param {?} actionOrActions
* @return {?}
*/
StateOperations.prototype.dispatch = function (actionOrActions) { };
}
/**
* @record
*/
function MetaDataModel() { }
if (false) {
/** @type {?} */
MetaDataModel.prototype.name;
/** @type {?} */
MetaDataModel.prototype.actions;
/** @type {?} */
MetaDataModel.prototype.defaults;
/** @type {?} */
MetaDataModel.prototype.path;
/** @type {?} */
MetaDataModel.prototype.makeRootSelector;
/** @type {?|undefined} */
MetaDataModel.prototype.children;
}
/**
* @record
*/
function RuntimeSelectorContext() { }
if (false) {
/**
* @param {?} key
* @return {?}
*/
RuntimeSelectorContext.prototype.getStateGetter = function (key) { };
/**
* @param {?=} localOptions
* @return {?}
*/
RuntimeSelectorContext.prototype.getSelectorOptions = function (localOptions) { };
}
/**
* @record
*/
function SharedSelectorOptions() { }
if (false) {
/** @type {?|undefined} */
SharedSelectorOptions.prototype.injectContainerState;
/** @type {?|undefined} */
SharedSelectorOptions.prototype.suppressErrors;
}
/**
* @record
*/
function SelectorMetaDataModel() { }
if (false) {
/** @type {?} */
SelectorMetaDataModel.prototype.makeRootSelector;
/** @type {?} */
SelectorMetaDataModel.prototype.originalFn;
/** @type {?} */
SelectorMetaDataModel.prototype.containerClass;
/** @type {?} */
SelectorMetaDataModel.prototype.selectorName;
/** @type {?} */
SelectorMetaDataModel.prototype.getSelectorOptions;
}
/**
* @record
*/
function MappedStore() { }
if (false) {
/** @type {?} */
MappedStore.prototype.name;
/** @type {?} */
MappedStore.prototype.isInitialised;
/** @type {?} */
MappedStore.prototype.actions;
/** @type {?} */
MappedStore.prototype.defaults;
/** @type {?} */
MappedStore.prototype.instance;
/** @type {?} */
MappedStore.prototype.path;
}
/**
* @record
*/
function StatesAndDefaults() { }
if (false) {
/** @type {?} */
StatesAndDefaults.prototype.defaults;
/** @type {?} */
StatesAndDefaults.prototype.states;
}
/**
* @record
* @template T
*/
function RootStateDiff() { }
if (false) {
/** @type {?} */
RootStateDiff.prototype.currentAppState;
/** @type {?} */
RootStateDiff.prototype.newAppState;
}
/**
* Ensures metadata is attached to the class and returns it.
*
* @ignore
* @param {?} target
* @return {?}
*/
function ensureStoreMetadata(target) {
if (!target.hasOwnProperty(META_KEY)) {
/** @type {?} */
var defaultMetadata_1 = {
name: null,
actions: {},
defaults: {},
path: null,
makeRootSelector: /**
* @param {?} context
* @return {?}
*/
function (context) {
return context.getStateGetter(defaultMetadata_1.name);
},
children: []
};
Object.defineProperty(target, META_KEY, { value: defaultMetadata_1 });
}
return getStoreMetadata(target);
}
/**
* Get the metadata attached to the state class if it exists.
*
* @ignore
* @param {?} target
* @return {?}
*/
function getStoreMetadata(target) {
return (/** @type {?} */ (target[META_KEY]));
}
/**
* Ensures metadata is attached to the selector and returns it.
*
* @ignore
* @param {?} target
* @return {?}
*/
function ensureSelectorMetadata(target) {
if (!target.hasOwnProperty(SELECTOR_META_KEY)) {
/** @type {?} */
var defaultMetadata = {
makeRootSelector: null,
originalFn: null,
containerClass: null,
selectorName: null,
getSelectorOptions: (/**
* @return {?}
*/
function () { return ({}); })
};
Object.defineProperty(target, SELECTOR_META_KEY, { value: defaultMetadata });
}
return getSelectorMetadata(target);
}
/**
* Get the metadata attached to the selector if it exists.
*
* @ignore
* @param {?} target
* @return {?}
*/
function getSelectorMetadata(target) {
return target[SELECTOR_META_KEY];
}
/**
* Get a deeply nested value. Example:
*
* getValue({ foo: bar: [] }, 'foo.bar') //=> []
*
* Note: This is not as fast as the `fastPropGetter` but is strict Content Security Policy compliant.
* See perf hit: https://jsperf.com/fast-value-getter-given-path/1
*
* @ignore
* @param {?} paths
* @return {?}
*/
function compliantPropGetter(paths) {
/** @type {?} */
var copyOfPaths = paths.slice();
return (/**
* @param {?} obj
* @return {?}
*/
function (obj) { return copyOfPaths.reduce((/**
* @param {?} acc
* @param {?} part
* @return {?}
*/
function (acc, part) { return acc && acc[part]; }), obj); });
}
/**
* The generated function is faster than:
* - pluck (Observable operator)
* - memoize
*
* @ignore
* @param {?} paths
* @return {?}
*/
function fastPropGetter(paths) {
/** @type {?} */
var segments = paths;
/** @type {?} */
var seg = 'store.' + segments[0];
/** @type {?} */
var i = 0;
/** @type {?} */
var l = segments.length;
/** @type {?} */
var expr = seg;
while (++i < l) {
expr = expr + ' && ' + (seg = seg + '.' + segments[i]);
}
/** @type {?} */
var fn = new Function('store', 'return ' + expr + ';');
return (/** @type {?} */ (fn));
}
/**
* Get a deeply nested value. Example:
*
* getValue({ foo: bar: [] }, 'foo.bar') //=> []
*
* @ignore
* @param {?} paths
* @param {?} config
* @return {?}
*/
function propGetter(paths, config) {
if (config && config.compatibility && config.compatibility.strictContentSecurityPolicy) {
return compliantPropGetter(paths);
}
else {
return fastPropGetter(paths);
}
}
/**
* Given an array of states, it will return a object graph. Example:
* const states = [
* Cart,
* CartSaved,
* CartSavedItems
* ]
*
* would return:
*
* const graph = {
* cart: ['saved'],
* saved: ['items'],
* items: []
* };
*
* @ignore
* @param {?} stateClasses
* @return {?}
*/
function buildGraph(stateClasses) {
/** @type {?} */
var findName = (/**
* @param {?} stateClass
* @return {?}
*/
function (stateClass) {
/** @type {?} */
var meta = stateClasses.find((/**
* @param {?} g
* @return {?}
*/
function (g) { return g === stateClass; }));
if (!meta) {
throw new Error("Child state not found: " + stateClass + ". \r\nYou may have forgotten to add states to module");
}
return (/** @type {?} */ ((/** @type {?} */ (meta[META_KEY])).name));
});
return stateClasses.reduce((/**
* @param {?} result
* @param {?} stateClass
* @return {?}
*/
function (result, stateClass) {
var _a = (/** @type {?} */ (stateClass[META_KEY])), name = _a.name, children = _a.children;
result[(/** @type {?} */ (name))] = (children || []).map(findName);
return result;
}), {});
}
/**
* Given a states array, returns object graph
* returning the name and state metadata. Example:
*
* const graph = {
* cart: { metadata }
* };
*
* @ignore
* @param {?} states
* @return {?}
*/
function nameToState(states) {
return states.reduce((/**
* @param {?} result
* @param {?} stateClass
* @return {?}
*/
function (result, stateClass) {
/** @type {?} */
var meta = (/** @type {?} */ (stateClass[META_KEY]));
result[(/** @type {?} */ (meta.name))] = stateClass;
return result;
}), {});
}
/**
* Given a object relationship graph will return the full path
* for the child items. Example:
*
* const graph = {
* cart: ['saved'],
* saved: ['items'],
* items: []
* };
*
* would return:
*
* const r = {
* cart: 'cart',
* saved: 'cart.saved',
* items: 'cart.saved.items'
* };
*
* @ignore
* @param {?} obj
* @param {?=} newObj
* @return {?}
*/
function findFullParentPath(obj, newObj) {
if (newObj === void 0) { newObj = {}; }
/** @type {?} */
var visit = (/**
* @param {?} child
* @param {?} keyToFind
* @return {?}
*/
function (child, keyToFind) {
for (var key in child) {
if (child.hasOwnProperty(key) && child[key].indexOf(keyToFind) >= 0) {
/** @type {?} */
var parent_1 = visit(child, key);
return parent_1 !== null ? parent_1 + "." + key : key;
}
}
return null;
});
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
/** @type {?} */
var parent_2 = visit(obj, key);
newObj[key] = parent_2 ? parent_2 + "." + key : key;
}
}
return newObj;
}
/**
* Given a object graph, it will return the items topologically sorted Example:
*
* const graph = {
* cart: ['saved'],
* saved: ['items'],
* items: []
* };
*
* would return:
*
* const results = [
* 'items',
* 'saved',
* 'cart'
* ];
*
* @ignore
* @param {?} graph
* @return {?}
*/
function topologicalSort(graph) {
/** @type {?} */
var sorted = [];
/** @type {?} */
var visited = {};
/** @type {?} */
var visit = (/**
* @param {?} name
* @param {?=} ancestors
* @return {?}
*/
function (name, ancestors) {
if (ancestors === void 0) { ancestors = []; }
if (!Array.isArray(ancestors)) {
ancestors = [];
}
ancestors.push(name);
visited[name] = true;
graph[name].forEach((/**
* @param {?} dep
* @return {?}
*/
function (dep) {
if (ancestors.indexOf(dep) >= 0) {
throw new Error("Circular dependency '" + dep + "' is required by '" + name + "': " + ancestors.join(' -> '));
}
if (visited[dep]) {
return;
}
visit(dep, ancestors.slice(0));
}));
if (sorted.indexOf(name) < 0) {
sorted.push(name);
}
});
Object.keys(graph).forEach((/**
* @param {?} k
* @return {?}
*/
function (k) { return visit(k); }));
return sorted.reverse();
}
/**
* Returns if the parameter is a object or not.
*
* @ignore
* @param {?} obj
* @return {?}
*/
function isObject$1(obj) {
return (typeof obj === 'object' && obj !== null) || typeof obj === 'function';
}
/**
* @template T
* @param {?} mappedStore
* @param {?} diff
* @return {?}
*/
function getStateDiffChanges(mappedStore, diff) {
/** @type {?} */
var previousValue = getValue(diff.currentAppState, mappedStore.path);
/** @type {?} */
var currentValue = getValue(diff.newAppState, mappedStore.path);
return new NgxsSimpleChange(previousValue, currentValue, !mappedStore.isInitialised);
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
* @template T, E
*/
function ActionCompletion() { }
if (false) {
/** @type {?} */
ActionCompletion.prototype.action;
/** @type {?} */
ActionCompletion.prototype.result;
}
/**
* RxJS operator for selecting out specific actions.
*
* This will grab actions that have just been dispatched as well as actions that have completed
* @param {...?} allowedTypes
* @return {?}
*/
function ofAction() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
return ofActionOperator(allowedTypes);
}
/**
* RxJS operator for selecting out specific actions.
*
* This will ONLY grab actions that have just been dispatched
* @param {...?} allowedTypes
* @return {?}
*/
function ofActionDispatched() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
return ofActionOperator(allowedTypes, ["DISPATCHED" /* Dispatched */]);
}
/**
* RxJS operator for selecting out specific actions.
*
* This will ONLY grab actions that have just been successfully completed
* @param {...?} allowedTypes
* @return {?}
*/
function ofActionSuccessful() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
return ofActionOperator(allowedTypes, ["SUCCESSFUL" /* Successful */]);
}
/**
* RxJS operator for selecting out specific actions.
*
* This will ONLY grab actions that have just been canceled
* @param {...?} allowedTypes
* @return {?}
*/
function ofActionCanceled() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
return ofActionOperator(allowedTypes, ["CANCELED" /* Canceled */]);
}
/**
* RxJS operator for selecting out specific actions.
*
* This will ONLY grab actions that have just been completed
* @param {...?} allowedTypes
* @return {?}
*/
function ofActionCompleted() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
/** @type {?} */
var allowedStatuses = [
"SUCCESSFUL" /* Successful */,
"CANCELED" /* Canceled */,
"ERRORED" /* Errored */
];
return ofActionOperator(allowedTypes, allowedStatuses, mapActionResult);
}
/**
* RxJS operator for selecting out specific actions.
*
* This will ONLY grab actions that have just thrown an error
* @param {...?} allowedTypes
* @return {?}
*/
function ofActionErrored() {
var allowedTypes = [];
for (var _i = 0; _i < arguments.length; _i++) {
allowedTypes[_i] = arguments[_i];
}
return ofActionOperator(allowedTypes, ["ERRORED" /* Errored */]);
}
/**
* @param {?