UNPKG

@ngxs/store

Version:
565 lines (526 loc) • 22.8 kB
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : typeof define === 'function' && define.amd ? define('@ngxs/store/operators', ['exports'], factory) : (global = global || self, factory((global.ngxs = global.ngxs || {}, global.ngxs.store = global.ngxs.store || {}, global.ngxs.store.operators = {}))); }(this, function (exports) { '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; } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} items - Specific items to append to the end of an array * @return {?} */ function append(items) { return (/** * @param {?} existing * @return {?} */ function appendOperator(existing) { // If `items` is `undefined` or `null` or `[]` but `existing` is provided // just return `existing` /** @type {?} */ var itemsNotProvidedButExistingIs = (!items || !items.length) && existing; if (itemsNotProvidedButExistingIs) { return (/** @type {?} */ (existing)); } if (Array.isArray(existing)) { return existing.concat((/** @type {?} */ (items))); } // For example if some property is added dynamically // and didn't exist before thus it's not `ArrayLike` return (/** @type {?} */ (items)); }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {...?} operators * @return {?} */ function compose() { var operators = []; for (var _i = 0; _i < arguments.length; _i++) { operators[_i] = arguments[_i]; } return (/** * @param {?} existing * @return {?} */ function composeOperator(existing) { return operators.reduce((/** * @param {?} accumulator * @param {?} operator * @return {?} */ function (accumulator, operator) { return operator(accumulator); }), existing); }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} value * @return {?} */ function isStateOperator(value) { return typeof value === 'function'; } /** * @param {?} value * @return {?} */ function isUndefined(value) { return typeof value === 'undefined'; } /** * @template T * @param {?} value * @return {?} */ function isPredicate(value) { return typeof value === 'function'; } /** * @param {?} value * @return {?} */ function isNumber(value) { return typeof value === 'number'; } /** * @param {?} index * @return {?} */ function invalidIndex(index) { return Number.isNaN(index) || index === -1; } /** * @template T * @param {?} value * @return {?} */ function isNil(value) { return value === null || isUndefined(value); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} operatorOrValue * @param {?=} existing * @return {?} */ function retrieveValue(operatorOrValue, existing) { // If state operator is a function // then call it with an original value if (isStateOperator(operatorOrValue)) { /** @type {?} */ var value = operatorOrValue((/** @type {?} */ ((/** @type {?} */ (existing))))); return (/** @type {?} */ (value)); } // If operator or value was not provided // e.g. `elseOperatorOrValue` is `undefined` // then we just return an original value if (isUndefined(operatorOrValue)) { return (/** @type {?} */ ((/** @type {?} */ (((/** @type {?} */ (existing))))))); } return (/** @type {?} */ (operatorOrValue)); } /** * @template T * @param {?} condition - Condition can be a plain boolean value or a function, * that returns boolean, also this function can take a value as an argument * to which this state operator applies * @param {?} trueOperatorOrValue - Any value or a state operator * @param {?=} elseOperatorOrValue - Any value or a state operator * @return {?} */ function iif(condition, trueOperatorOrValue, elseOperatorOrValue) { return (/** * @param {?} existing * @return {?} */ function iifOperator(existing) { // Convert the value to a boolean /** @type {?} */ var result = !!condition; // but if it is a function then run it to get the result if (isPredicate(condition)) { result = condition(existing); } if (result) { return retrieveValue(trueOperatorOrValue, (/** @type {?} */ (existing))); } return retrieveValue((/** @type {?} */ (elseOperatorOrValue)), (/** @type {?} */ (existing))); }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} value - Value to insert * @param {?=} beforePosition * @return {?} */ function insertItem(value, beforePosition) { return (/** * @param {?} existing * @return {?} */ function insertItemOperator(existing) { // Have to check explicitly for `null` and `undefined` // because `value` can be `0`, thus `!value` will return `true` if (isNil(value) && existing) { return (/** @type {?} */ (existing)); } // Property may be dynamic and might not existed before if (!Array.isArray(existing)) { return [(/** @type {?} */ (value))]; } /** @type {?} */ var clone = existing.slice(); /** @type {?} */ var index = 0; // No need to call `isNumber` // as we are checking `> 0` not `>= 0` // everything except number will return false here if ((/** @type {?} */ (beforePosition)) > 0) { index = (/** @type {?} */ (beforePosition)); } clone.splice(index, 0, (/** @type {?} */ (value))); return clone; }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} patchObject * @return {?} */ function patch(patchObject) { return (/** * @template U * @param {?} existing * @return {?} */ function patchStateOperator(existing) { /** @type {?} */ var clone = null; for (var k in patchObject) { /** @type {?} */ var newValue = patchObject[k]; /** @type {?} */ var existingPropValue = existing[k]; /** @type {?} */ var newPropValue = isStateOperator(newValue) ? newValue((/** @type {?} */ (existingPropValue))) : newValue; if (newPropValue !== existingPropValue) { if (!clone) { clone = __assign({}, ((/** @type {?} */ (existing)))); } clone[k] = newPropValue; } } return clone || existing; }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} selector - Index of item in the array or a predicate function * that can be provided in `Array.prototype.findIndex` * @param {?} operatorOrValue - New value under the `selector` index or a * function that can be applied to an existing value * @return {?} */ function updateItem(selector, operatorOrValue) { return (/** * @param {?} existing * @return {?} */ function updateItemOperator(existing) { /** @type {?} */ var index = -1; if (isPredicate(selector)) { index = existing.findIndex(selector); } else if (isNumber(selector)) { index = selector; } if (invalidIndex(index)) { return (/** @type {?} */ (existing)); } /** @type {?} */ var value = (/** @type {?} */ (null)); // Need to check if the new item value will change the existing item value // then, only if it will change it then clone the array and set the item if (isStateOperator(operatorOrValue)) { value = operatorOrValue((/** @type {?} */ (existing[index]))); } else { value = operatorOrValue; } // If the value hasn't been mutated // then we just return `existing` array if (value === existing[index]) { return (/** @type {?} */ (existing)); } /** @type {?} */ var clone = existing.slice(); clone[index] = (/** @type {?} */ (value)); return clone; }); } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @template T * @param {?} selector - index or predicate to remove an item from an array by * @return {?} */ function removeItem(selector) { return (/** * @param {?} existing * @return {?} */ function removeItemOperator(existing) { /** @type {?} */ var index = -1; if (isPredicate(selector)) { index = existing.findIndex(selector); } else if (isNumber(selector)) { index = selector; } if (invalidIndex(index)) { return (/** @type {?} */ (existing)); } /** @type {?} */ var clone = existing.slice(); clone.splice(index, 1); return clone; }); } exports.append = append; exports.compose = compose; exports.iif = iif; exports.insertItem = insertItem; exports.isStateOperator = isStateOperator; exports.patch = patch; exports.removeItem = removeItem; exports.updateItem = updateItem; Object.defineProperty(exports, '__esModule', { value: true }); })); //# sourceMappingURL=ngxs-store-operators.umd.js.map