@ngxs/storage-plugin 3.7.6-dev.master-fb318b1 → 3.7.6-dev.master-40a2210

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.
@@ -1,565 +0,0 @@
1
- import { InjectionToken, Injectable, Inject, PLATFORM_ID, Injector, NgModule } from '@angular/core';
2
- import { StateToken, actionMatcher, InitState, UpdateState, getValue, setValue, NGXS_PLUGINS } from '@ngxs/store';
3
- import { __assign, __values } from 'tslib';
4
- import { isPlatformServer } from '@angular/common';
5
- import { tap } from 'rxjs/operators';
6
-
7
- /**
8
- * @fileoverview added by tsickle
9
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
10
- */
11
- /** @enum {number} */
12
- var StorageOption = {
13
- LocalStorage: 0,
14
- SessionStorage: 1,
15
- };
16
- /**
17
- * @record
18
- */
19
- function NgxsStoragePluginOptions() { }
20
- if (false) {
21
- /**
22
- * Key for the state slice to store in the storage engine.
23
- * @type {?|undefined}
24
- */
25
- NgxsStoragePluginOptions.prototype.key;
26
- /**
27
- * The namespace is used to prefix the key for the state slice. This is
28
- * necessary when running micro frontend applications which use storage plugin.
29
- * The namespace will eliminate the conflict between keys that might overlap.
30
- * @type {?|undefined}
31
- */
32
- NgxsStoragePluginOptions.prototype.namespace;
33
- /**
34
- * Storage engine to use. Deaults to localStorage but can provide
35
- *
36
- * sessionStorage or custom implementation of the StorageEngine interface
37
- * @type {?|undefined}
38
- */
39
- NgxsStoragePluginOptions.prototype.storage;
40
- /**
41
- * Migration strategies.
42
- * @type {?|undefined}
43
- */
44
- NgxsStoragePluginOptions.prototype.migrations;
45
- /**
46
- * Serailizer for the object before its pushed into the engine.
47
- * @param {?} obj
48
- * @return {?}
49
- */
50
- NgxsStoragePluginOptions.prototype.serialize = function (obj) { };
51
- /**
52
- * Deserializer for the object before its pulled out of the engine.
53
- * @param {?} obj
54
- * @return {?}
55
- */
56
- NgxsStoragePluginOptions.prototype.deserialize = function (obj) { };
57
- /**
58
- * Method to alter object before serialization.
59
- * @param {?} obj
60
- * @param {?} key
61
- * @return {?}
62
- */
63
- NgxsStoragePluginOptions.prototype.beforeSerialize = function (obj, key) { };
64
- /**
65
- * Method to alter object after deserialization.
66
- * @param {?} obj
67
- * @param {?} key
68
- * @return {?}
69
- */
70
- NgxsStoragePluginOptions.prototype.afterDeserialize = function (obj, key) { };
71
- }
72
- /** @type {?} */
73
- var NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTIONS');
74
- /** @type {?} */
75
- var STORAGE_ENGINE = new InjectionToken('STORAGE_ENGINE');
76
- /**
77
- * @record
78
- */
79
- function StorageEngine() { }
80
- if (false) {
81
- /** @type {?} */
82
- StorageEngine.prototype.length;
83
- /**
84
- * @param {?} key
85
- * @return {?}
86
- */
87
- StorageEngine.prototype.getItem = function (key) { };
88
- /**
89
- * @param {?} key
90
- * @param {?} val
91
- * @return {?}
92
- */
93
- StorageEngine.prototype.setItem = function (key, val) { };
94
- /**
95
- * @param {?} key
96
- * @return {?}
97
- */
98
- StorageEngine.prototype.removeItem = function (key) { };
99
- /**
100
- * @return {?}
101
- */
102
- StorageEngine.prototype.clear = function () { };
103
- }
104
-
105
- /**
106
- * @fileoverview added by tsickle
107
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
108
- */
109
- /**
110
- * The following key is used to store the entire serialized
111
- * state when there's no specific state provided.
112
- * @type {?}
113
- */
114
- var DEFAULT_STATE_KEY = '@@STATE';
115
- /**
116
- * @param {?} options
117
- * @return {?}
118
- */
119
- function storageOptionsFactory(options) {
120
- return __assign({ key: [DEFAULT_STATE_KEY], storage: 0 /* LocalStorage */, serialize: JSON.stringify, deserialize: JSON.parse, beforeSerialize: (/**
121
- * @param {?} obj
122
- * @return {?}
123
- */
124
- function (obj) { return obj; }), afterDeserialize: (/**
125
- * @param {?} obj
126
- * @return {?}
127
- */
128
- function (obj) { return obj; }) }, options);
129
- }
130
- /**
131
- * @param {?} options
132
- * @param {?} platformId
133
- * @return {?}
134
- */
135
- function engineFactory(options, platformId) {
136
- if (isPlatformServer(platformId)) {
137
- return null;
138
- }
139
- if (options.storage === 0 /* LocalStorage */) {
140
- return localStorage;
141
- }
142
- else if (options.storage === 1 /* SessionStorage */) {
143
- return sessionStorage;
144
- }
145
- return null;
146
- }
147
- /**
148
- * @param {?} key
149
- * @param {?=} options
150
- * @return {?}
151
- */
152
- function getStorageKey(key, options) {
153
- // Prepends the `namespace` option to any key if it's been provided by a user.
154
- // So `@@STATE` becomes `my-app:@@STATE`.
155
- return options && options.namespace ? options.namespace + ":" + key : key;
156
- }
157
-
158
- /**
159
- * @fileoverview added by tsickle
160
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
161
- */
162
- /**
163
- * This enables the user to provide a storage engine per individual key.
164
- * @record
165
- */
166
- function KeyWithExplicitEngine() { }
167
- if (false) {
168
- /** @type {?} */
169
- KeyWithExplicitEngine.prototype.key;
170
- /** @type {?} */
171
- KeyWithExplicitEngine.prototype.engine;
172
- }
173
- /**
174
- * Determines whether the provided key has the following structure.
175
- * @param {?} key
176
- * @return {?}
177
- */
178
- function isKeyWithExplicitEngine(key) {
179
- return key != null && !!key.engine;
180
- }
181
- /**
182
- * This symbol is used to store the metadata on state classes.
183
- * @type {?}
184
- */
185
- var META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
186
- /**
187
- * @param {?} storageKey
188
- * @return {?}
189
- */
190
- function exctractStringKey(storageKey) {
191
- // Extract the actual key out of the `{ key, engine }` structure.
192
- if (isKeyWithExplicitEngine(storageKey)) {
193
- storageKey = storageKey.key;
194
- }
195
- // Given the `storageKey` is a class, for instance, `AuthState`.
196
- // We should retrieve its metadata and the `name` property.
197
- // The `name` property might be a string (state name) or a state token.
198
- if (storageKey.hasOwnProperty(META_OPTIONS_KEY)) {
199
- storageKey = ((/** @type {?} */ (storageKey)))[META_OPTIONS_KEY].name;
200
- }
201
- return storageKey instanceof StateToken ? storageKey.getName() : (/** @type {?} */ (storageKey));
202
- }
203
-
204
- /**
205
- * @fileoverview added by tsickle
206
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
207
- */
208
- /**
209
- * @record
210
- */
211
- function FinalNgxsStoragePluginOptions() { }
212
- if (false) {
213
- /** @type {?} */
214
- FinalNgxsStoragePluginOptions.prototype.keysWithEngines;
215
- }
216
- /** @type {?} */
217
- var FINAL_NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('FINAL_NGXS_STORAGE_PLUGIN_OPTIONS');
218
- /**
219
- * @param {?} injector
220
- * @param {?} options
221
- * @return {?}
222
- */
223
- function createFinalStoragePluginOptions(injector, options) {
224
- /** @type {?} */
225
- var storageKeys = Array.isArray(options.key) ? options.key : [(/** @type {?} */ (options.key))];
226
- /** @type {?} */
227
- var keysWithEngines = storageKeys.map((/**
228
- * @param {?} storageKey
229
- * @return {?}
230
- */
231
- function (storageKey) {
232
- /** @type {?} */
233
- var key = exctractStringKey(storageKey);
234
- /** @type {?} */
235
- var engine = isKeyWithExplicitEngine(storageKey)
236
- ? injector.get(storageKey.engine)
237
- : injector.get(STORAGE_ENGINE);
238
- return { key: key, engine: engine };
239
- }));
240
- return __assign({}, options, { keysWithEngines: keysWithEngines });
241
- }
242
-
243
- /**
244
- * @fileoverview added by tsickle
245
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
246
- */
247
- var NgxsStoragePlugin = /** @class */ (function () {
248
- function NgxsStoragePlugin(_options, _platformId) {
249
- this._options = _options;
250
- this._platformId = _platformId;
251
- this._keysWithEngines = this._options.keysWithEngines;
252
- // We default to `[DEFAULT_STATE_KEY]` if the user explicitly does not provide the `key` option.
253
- this._usesDefaultStateKey = this._keysWithEngines.length === 1 && this._keysWithEngines[0].key === DEFAULT_STATE_KEY;
254
- }
255
- /**
256
- * @param {?} state
257
- * @param {?} event
258
- * @param {?} next
259
- * @return {?}
260
- */
261
- NgxsStoragePlugin.prototype.handle = /**
262
- * @param {?} state
263
- * @param {?} event
264
- * @param {?} next
265
- * @return {?}
266
- */
267
- function (state, event, next) {
268
- var _this = this;
269
- var e_1, _a;
270
- if (isPlatformServer(this._platformId)) {
271
- return next(state, event);
272
- }
273
- /** @type {?} */
274
- var matches = actionMatcher(event);
275
- /** @type {?} */
276
- var isInitAction = matches(InitState);
277
- /** @type {?} */
278
- var isUpdateAction = matches(UpdateState);
279
- /** @type {?} */
280
- var isInitOrUpdateAction = isInitAction || isUpdateAction;
281
- /** @type {?} */
282
- var hasMigration = false;
283
- if (isInitOrUpdateAction) {
284
- /** @type {?} */
285
- var addedStates = isUpdateAction && event.addedStates;
286
- var _loop_1 = function (key, engine) {
287
- // We're checking what states have been added by NGXS and if any of these states should be handled by
288
- // the storage plugin. For instance, we only want to deserialize the `auth` state, NGXS has added
289
- // the `user` state, the storage plugin will be rerun and will do redundant deserialization.
290
- // `usesDefaultStateKey` is necessary to check since `event.addedStates` never contains `@@STATE`.
291
- if (!this_1._usesDefaultStateKey && addedStates) {
292
- // We support providing keys that can be deeply nested via dot notation, for instance,
293
- // `keys: ['myState.myProperty']` is a valid key.
294
- // The state name should always go first. The below code checks if the `key` includes dot
295
- // notation and extracts the state name out of the key.
296
- // Given the `key` is `myState.myProperty`, the `addedStates` will only contain `myState`.
297
- /** @type {?} */
298
- var dotNotationIndex = key.indexOf(DOT);
299
- /** @type {?} */
300
- var stateName = dotNotationIndex > -1 ? key.slice(0, dotNotationIndex) : key;
301
- if (!addedStates.hasOwnProperty(stateName)) {
302
- return "continue";
303
- }
304
- }
305
- /** @type {?} */
306
- var storageKey = getStorageKey(key, this_1._options);
307
- /** @type {?} */
308
- var storedValue = engine.getItem(storageKey);
309
- if (storedValue !== 'undefined' && storedValue != null) {
310
- try {
311
- /** @type {?} */
312
- var newVal = (/** @type {?} */ (this_1._options.deserialize))(storedValue);
313
- storedValue = (/** @type {?} */ (this_1._options.afterDeserialize))(newVal, key);
314
- }
315
- catch (_a) {
316
- // Caretaker note: we have still left the `typeof` condition in order to avoid
317
- // creating a breaking change for projects that still use the View Engine.
318
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
319
- console.error("Error ocurred while deserializing the " + storageKey + " store value, falling back to empty object, the value obtained from the store: ", storedValue);
320
- }
321
- storedValue = {};
322
- }
323
- if (this_1._options.migrations) {
324
- this_1._options.migrations.forEach((/**
325
- * @param {?} strategy
326
- * @return {?}
327
- */
328
- function (strategy) {
329
- /** @type {?} */
330
- var versionMatch = strategy.version === getValue(storedValue, strategy.versionKey || 'version');
331
- /** @type {?} */
332
- var keyMatch = (!strategy.key && _this._usesDefaultStateKey) || strategy.key === key;
333
- if (versionMatch && keyMatch) {
334
- storedValue = strategy.migrate(storedValue);
335
- hasMigration = true;
336
- }
337
- }));
338
- }
339
- if (!this_1._usesDefaultStateKey) {
340
- state = setValue(state, key, storedValue);
341
- }
342
- else {
343
- // The `UpdateState` action is dispatched whenever the feature state is added.
344
- // The below condition is met only when the `UpdateState` is dispatched.
345
- // Let's assume that we have 2 states `counter` and `@ngxs/router-plugin` state.
346
- // `CounterState` is provided on the root level when calling `NgxsModule.forRoot()`
347
- // and `@ngxs/router-plugin` is provided as a feature state.
348
- // The storage plugin may save the `counter` state value as `10` before.
349
- // The `CounterState` may implement the `ngxsOnInit` hook and call `ctx.setState(999)`.
350
- // The storage plugin will re-hydrate the whole state when the `RouterState` is registered,
351
- // and the `counter` state will again equal `10` (not `999`).
352
- if (storedValue && addedStates && Object.keys(addedStates).length > 0) {
353
- storedValue = Object.keys(addedStates).reduce((/**
354
- * @param {?} accumulator
355
- * @param {?} addedState
356
- * @return {?}
357
- */
358
- function (accumulator, addedState) {
359
- // The `storedValue` may equal the whole state (when the default state key is used).
360
- // If `addedStates` contains only `router` then we want to merge the state only
361
- // with the `router` value.
362
- // Let's assume that the `storedValue` is an object:
363
- // `{ counter: 10, router: {...} }`
364
- // This will pick only the `router` object from the `storedValue` and `counter`
365
- // state will not be re-hydrated unnecessary.
366
- if (storedValue.hasOwnProperty(addedState)) {
367
- accumulator[addedState] = storedValue[addedState];
368
- }
369
- return accumulator;
370
- }), (/** @type {?} */ ({})));
371
- }
372
- state = __assign({}, state, storedValue);
373
- }
374
- }
375
- };
376
- var this_1 = this;
377
- try {
378
- for (var _b = __values(this._keysWithEngines), _c = _b.next(); !_c.done; _c = _b.next()) {
379
- var _d = _c.value, key = _d.key, engine = _d.engine;
380
- _loop_1(key, engine);
381
- }
382
- }
383
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
384
- finally {
385
- try {
386
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
387
- }
388
- finally { if (e_1) throw e_1.error; }
389
- }
390
- }
391
- return next(state, event).pipe(tap((/**
392
- * @param {?} nextState
393
- * @return {?}
394
- */
395
- function (nextState) {
396
- var e_2, _a;
397
- if (!isInitOrUpdateAction || (isInitOrUpdateAction && hasMigration)) {
398
- try {
399
- for (var _b = __values(_this._keysWithEngines), _c = _b.next(); !_c.done; _c = _b.next()) {
400
- var _d = _c.value, key = _d.key, engine = _d.engine;
401
- /** @type {?} */
402
- var storedValue = nextState;
403
- /** @type {?} */
404
- var storageKey = getStorageKey(key, _this._options);
405
- if (key !== DEFAULT_STATE_KEY) {
406
- storedValue = getValue(nextState, key);
407
- }
408
- try {
409
- /** @type {?} */
410
- var newStoredValue = (/** @type {?} */ (_this._options.beforeSerialize))(storedValue, key);
411
- engine.setItem(storageKey, (/** @type {?} */ (_this._options.serialize))(newStoredValue));
412
- }
413
- catch (error) {
414
- // Caretaker note: we have still left the `typeof` condition in order to avoid
415
- // creating a breaking change for projects that still use the View Engine.
416
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
417
- if (error &&
418
- (error.name === 'QuotaExceededError' ||
419
- error.name === 'NS_ERROR_DOM_QUOTA_REACHED')) {
420
- console.error("The " + storageKey + " store value exceeds the browser storage quota: ", storedValue);
421
- }
422
- else {
423
- console.error("Error ocurred while serializing the " + storageKey + " store value, value not updated, the value obtained from the store: ", storedValue);
424
- }
425
- }
426
- }
427
- }
428
- }
429
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
430
- finally {
431
- try {
432
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
433
- }
434
- finally { if (e_2) throw e_2.error; }
435
- }
436
- }
437
- })));
438
- };
439
- NgxsStoragePlugin.decorators = [
440
- { type: Injectable }
441
- ];
442
- /** @nocollapse */
443
- NgxsStoragePlugin.ctorParameters = function () { return [
444
- { type: undefined, decorators: [{ type: Inject, args: [FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
445
- { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
446
- ]; };
447
- return NgxsStoragePlugin;
448
- }());
449
- if (false) {
450
- /**
451
- * @type {?}
452
- * @private
453
- */
454
- NgxsStoragePlugin.prototype._keysWithEngines;
455
- /**
456
- * @type {?}
457
- * @private
458
- */
459
- NgxsStoragePlugin.prototype._usesDefaultStateKey;
460
- /**
461
- * @type {?}
462
- * @private
463
- */
464
- NgxsStoragePlugin.prototype._options;
465
- /**
466
- * @type {?}
467
- * @private
468
- */
469
- NgxsStoragePlugin.prototype._platformId;
470
- }
471
- /** @type {?} */
472
- var DOT = '.';
473
-
474
- /**
475
- * @fileoverview added by tsickle
476
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
477
- */
478
- /** @type {?} */
479
- var USER_OPTIONS = new InjectionToken('USER_OPTIONS');
480
- var NgxsStoragePluginModule = /** @class */ (function () {
481
- function NgxsStoragePluginModule() {
482
- }
483
- /**
484
- * @param {?=} options
485
- * @return {?}
486
- */
487
- NgxsStoragePluginModule.forRoot = /**
488
- * @param {?=} options
489
- * @return {?}
490
- */
491
- function (options) {
492
- return {
493
- ngModule: NgxsStoragePluginModule,
494
- providers: [
495
- {
496
- provide: NGXS_PLUGINS,
497
- useClass: NgxsStoragePlugin,
498
- multi: true
499
- },
500
- {
501
- provide: USER_OPTIONS,
502
- useValue: options
503
- },
504
- {
505
- provide: NGXS_STORAGE_PLUGIN_OPTIONS,
506
- useFactory: storageOptionsFactory,
507
- deps: [USER_OPTIONS]
508
- },
509
- {
510
- provide: STORAGE_ENGINE,
511
- useFactory: engineFactory,
512
- deps: [NGXS_STORAGE_PLUGIN_OPTIONS, PLATFORM_ID]
513
- },
514
- {
515
- provide: FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,
516
- useFactory: createFinalStoragePluginOptions,
517
- deps: [Injector, NGXS_STORAGE_PLUGIN_OPTIONS]
518
- }
519
- ]
520
- };
521
- };
522
- NgxsStoragePluginModule.decorators = [
523
- { type: NgModule }
524
- ];
525
- return NgxsStoragePluginModule;
526
- }());
527
-
528
- /**
529
- * @fileoverview added by tsickle
530
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
531
- */
532
- /** @type {?} */
533
- var LOCAL_STORAGE_ENGINE = new InjectionToken('LOCAL_STORAGE_ENGINE', {
534
- providedIn: 'root',
535
- factory: (/**
536
- * @return {?}
537
- */
538
- function () { return localStorage; })
539
- });
540
- /** @type {?} */
541
- var SESSION_STORAGE_ENGINE = new InjectionToken('SESSION_STORAGE_ENGINE', {
542
- providedIn: 'root',
543
- factory: (/**
544
- * @return {?}
545
- */
546
- function () { return sessionStorage; })
547
- });
548
-
549
- /**
550
- * @fileoverview added by tsickle
551
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
552
- */
553
-
554
- /**
555
- * @fileoverview added by tsickle
556
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
557
- */
558
-
559
- /**
560
- * @fileoverview added by tsickle
561
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
562
- */
563
-
564
- export { LOCAL_STORAGE_ENGINE, NGXS_STORAGE_PLUGIN_OPTIONS, NgxsStoragePlugin, NgxsStoragePluginModule, SESSION_STORAGE_ENGINE, STORAGE_ENGINE, USER_OPTIONS as ɵa, FINAL_NGXS_STORAGE_PLUGIN_OPTIONS as ɵc, createFinalStoragePluginOptions as ɵd, storageOptionsFactory as ɵe, engineFactory as ɵf };
565
- //# sourceMappingURL=ngxs-storage-plugin.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ngxs-storage-plugin.js","sources":["ng://@ngxs/storage-plugin/src/symbols.ts","ng://@ngxs/storage-plugin/src/internals.ts","ng://@ngxs/storage-plugin/src/internals/storage-key.ts","ng://@ngxs/storage-plugin/src/internals/final-options.ts","ng://@ngxs/storage-plugin/src/storage.plugin.ts","ng://@ngxs/storage-plugin/src/storage.module.ts","ng://@ngxs/storage-plugin/src/engines.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport { StorageKey } from './internals/storage-key';\n\nexport const enum StorageOption {\n LocalStorage,\n SessionStorage\n}\n\nexport interface NgxsStoragePluginOptions {\n /**\n * Key for the state slice to store in the storage engine.\n */\n key?: undefined | StorageKey | StorageKey[];\n\n /**\n * The namespace is used to prefix the key for the state slice. This is\n * necessary when running micro frontend applications which use storage plugin.\n * The namespace will eliminate the conflict between keys that might overlap.\n */\n namespace?: string;\n\n /**\n * Storage engine to use. Deaults to localStorage but can provide\n *\n * sessionStorage or custom implementation of the StorageEngine interface\n */\n storage?: StorageOption;\n\n /**\n * Migration strategies.\n */\n migrations?: {\n /**\n * Version to key off.\n */\n version: number | string;\n\n /**\n * Method to migrate the previous state.\n */\n migrate: (state: any) => any;\n\n /**\n * Key to migrate.\n */\n key?: string;\n\n /**\n * Key for the version. Defaults to 'version'.\n */\n versionKey?: string;\n }[];\n\n /**\n * Serailizer for the object before its pushed into the engine.\n */\n serialize?(obj: any): string;\n\n /**\n * Deserializer for the object before its pulled out of the engine.\n */\n deserialize?(obj: any): any;\n\n /**\n * Method to alter object before serialization.\n */\n beforeSerialize?(obj: any, key: string): any;\n\n /**\n * Method to alter object after deserialization.\n */\n afterDeserialize?(obj: any, key: string): any;\n}\n\nexport const NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTIONS');\n\nexport const STORAGE_ENGINE = new InjectionToken<StorageEngine>('STORAGE_ENGINE');\n\nexport interface StorageEngine {\n readonly length: number;\n getItem(key: string): any;\n setItem(key: string, val: any): void;\n removeItem(key: string): void;\n clear(): void;\n}\n","import { isPlatformServer } from '@angular/common';\n\nimport { StorageOption, StorageEngine, NgxsStoragePluginOptions } from './symbols';\n\n/**\n * The following key is used to store the entire serialized\n * state when there's no specific state provided.\n */\nexport const DEFAULT_STATE_KEY = '@@STATE';\n\nexport function storageOptionsFactory(\n options: NgxsStoragePluginOptions | undefined\n): NgxsStoragePluginOptions {\n return {\n key: [DEFAULT_STATE_KEY],\n storage: StorageOption.LocalStorage,\n serialize: JSON.stringify,\n deserialize: JSON.parse,\n beforeSerialize: obj => obj,\n afterDeserialize: obj => obj,\n ...options\n };\n}\n\nexport function engineFactory(\n options: NgxsStoragePluginOptions,\n platformId: string\n): StorageEngine | null {\n if (isPlatformServer(platformId)) {\n return null;\n }\n\n if (options.storage === StorageOption.LocalStorage) {\n return localStorage;\n } else if (options.storage === StorageOption.SessionStorage) {\n return sessionStorage;\n }\n\n return null;\n}\n\nexport function getStorageKey(key: string, options?: NgxsStoragePluginOptions): string {\n // Prepends the `namespace` option to any key if it's been provided by a user.\n // So `@@STATE` becomes `my-app:@@STATE`.\n return options && options.namespace ? `${options.namespace}:${key}` : key;\n}\n","import { InjectionToken, Type } from '@angular/core';\nimport { StateToken } from '@ngxs/store';\nimport { StateClass } from '@ngxs/store/internals';\n\nimport { StorageEngine } from '../symbols';\n\n/** This enables the user to provide a storage engine per individual key. */\nexport interface KeyWithExplicitEngine {\n key: string | StateClass | StateToken<any>;\n engine: Type<StorageEngine> | InjectionToken<StorageEngine>;\n}\n\n/** Determines whether the provided key has the following structure. */\nexport function isKeyWithExplicitEngine(key: any): key is KeyWithExplicitEngine {\n return key != null && !!key.engine;\n}\n\n/**\n * This tuples all of the possible types allowed in the `key` property.\n * This is not exposed publicly and used internally only.\n */\nexport type StorageKey = string | StateClass | StateToken<any> | KeyWithExplicitEngine;\n\n/** This symbol is used to store the metadata on state classes. */\nconst META_OPTIONS_KEY = 'NGXS_OPTIONS_META';\nexport function exctractStringKey(storageKey: StorageKey): string {\n // Extract the actual key out of the `{ key, engine }` structure.\n if (isKeyWithExplicitEngine(storageKey)) {\n storageKey = storageKey.key;\n }\n\n // Given the `storageKey` is a class, for instance, `AuthState`.\n // We should retrieve its metadata and the `name` property.\n // The `name` property might be a string (state name) or a state token.\n if (storageKey.hasOwnProperty(META_OPTIONS_KEY)) {\n storageKey = (storageKey as any)[META_OPTIONS_KEY].name;\n }\n\n return storageKey instanceof StateToken ? storageKey.getName() : <string>storageKey;\n}\n","import { InjectionToken, Injector } from '@angular/core';\n\nimport { exctractStringKey, isKeyWithExplicitEngine, StorageKey } from './storage-key';\nimport { NgxsStoragePluginOptions, StorageEngine, STORAGE_ENGINE } from '../symbols';\n\nexport interface FinalNgxsStoragePluginOptions extends NgxsStoragePluginOptions {\n keysWithEngines: {\n key: string;\n engine: StorageEngine;\n }[];\n}\n\nexport const FINAL_NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken<\n FinalNgxsStoragePluginOptions\n>('FINAL_NGXS_STORAGE_PLUGIN_OPTIONS');\n\nexport function createFinalStoragePluginOptions(\n injector: Injector,\n options: NgxsStoragePluginOptions\n): FinalNgxsStoragePluginOptions {\n const storageKeys: StorageKey[] = Array.isArray(options.key) ? options.key : [options.key!];\n\n const keysWithEngines = storageKeys.map((storageKey: StorageKey) => {\n const key = exctractStringKey(storageKey);\n const engine = isKeyWithExplicitEngine(storageKey)\n ? injector.get(storageKey.engine)\n : injector.get(STORAGE_ENGINE);\n return { key, engine };\n });\n\n return {\n ...options,\n keysWithEngines\n };\n}\n","import { PLATFORM_ID, Inject, Injectable } from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport { PlainObject } from '@ngxs/store/internals';\nimport {\n NgxsPlugin,\n setValue,\n getValue,\n InitState,\n UpdateState,\n actionMatcher,\n NgxsNextPluginFn\n} from '@ngxs/store';\nimport { tap } from 'rxjs/operators';\n\nimport { DEFAULT_STATE_KEY, getStorageKey } from './internals';\nimport {\n FinalNgxsStoragePluginOptions,\n FINAL_NGXS_STORAGE_PLUGIN_OPTIONS\n} from './internals/final-options';\n\n/**\n * @description Will be provided through Terser global definitions by Angular CLI\n * during the production build. This is how Angular does tree-shaking internally.\n */\ndeclare const ngDevMode: boolean;\n\n@Injectable()\nexport class NgxsStoragePlugin implements NgxsPlugin {\n private _keysWithEngines = this._options.keysWithEngines;\n // We default to `[DEFAULT_STATE_KEY]` if the user explicitly does not provide the `key` option.\n private _usesDefaultStateKey =\n this._keysWithEngines.length === 1 && this._keysWithEngines[0].key === DEFAULT_STATE_KEY;\n\n constructor(\n @Inject(FINAL_NGXS_STORAGE_PLUGIN_OPTIONS) private _options: FinalNgxsStoragePluginOptions,\n @Inject(PLATFORM_ID) private _platformId: string\n ) {}\n\n handle(state: any, event: any, next: NgxsNextPluginFn) {\n if (isPlatformServer(this._platformId)) {\n return next(state, event);\n }\n\n const matches = actionMatcher(event);\n const isInitAction = matches(InitState);\n const isUpdateAction = matches(UpdateState);\n const isInitOrUpdateAction = isInitAction || isUpdateAction;\n let hasMigration = false;\n\n if (isInitOrUpdateAction) {\n const addedStates = isUpdateAction && event.addedStates;\n\n for (const { key, engine } of this._keysWithEngines) {\n // We're checking what states have been added by NGXS and if any of these states should be handled by\n // the storage plugin. For instance, we only want to deserialize the `auth` state, NGXS has added\n // the `user` state, the storage plugin will be rerun and will do redundant deserialization.\n // `usesDefaultStateKey` is necessary to check since `event.addedStates` never contains `@@STATE`.\n if (!this._usesDefaultStateKey && addedStates) {\n // We support providing keys that can be deeply nested via dot notation, for instance,\n // `keys: ['myState.myProperty']` is a valid key.\n // The state name should always go first. The below code checks if the `key` includes dot\n // notation and extracts the state name out of the key.\n // Given the `key` is `myState.myProperty`, the `addedStates` will only contain `myState`.\n const dotNotationIndex = key.indexOf(DOT);\n const stateName = dotNotationIndex > -1 ? key.slice(0, dotNotationIndex) : key;\n if (!addedStates.hasOwnProperty(stateName)) {\n continue;\n }\n }\n\n const storageKey = getStorageKey(key, this._options);\n let storedValue: any = engine.getItem(storageKey);\n\n if (storedValue !== 'undefined' && storedValue != null) {\n try {\n const newVal = this._options.deserialize!(storedValue);\n storedValue = this._options.afterDeserialize!(newVal, key);\n } catch {\n // Caretaker note: we have still left the `typeof` condition in order to avoid\n // creating a breaking change for projects that still use the View Engine.\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n console.error(\n `Error ocurred while deserializing the ${storageKey} store value, falling back to empty object, the value obtained from the store: `,\n storedValue\n );\n }\n storedValue = {};\n }\n\n if (this._options.migrations) {\n this._options.migrations.forEach(strategy => {\n const versionMatch =\n strategy.version === getValue(storedValue, strategy.versionKey || 'version');\n const keyMatch =\n (!strategy.key && this._usesDefaultStateKey) || strategy.key === key;\n if (versionMatch && keyMatch) {\n storedValue = strategy.migrate(storedValue);\n hasMigration = true;\n }\n });\n }\n\n if (!this._usesDefaultStateKey) {\n state = setValue(state, key, storedValue);\n } else {\n // The `UpdateState` action is dispatched whenever the feature state is added.\n // The below condition is met only when the `UpdateState` is dispatched.\n // Let's assume that we have 2 states `counter` and `@ngxs/router-plugin` state.\n // `CounterState` is provided on the root level when calling `NgxsModule.forRoot()`\n // and `@ngxs/router-plugin` is provided as a feature state.\n // The storage plugin may save the `counter` state value as `10` before.\n // The `CounterState` may implement the `ngxsOnInit` hook and call `ctx.setState(999)`.\n // The storage plugin will re-hydrate the whole state when the `RouterState` is registered,\n // and the `counter` state will again equal `10` (not `999`).\n if (storedValue && addedStates && Object.keys(addedStates).length > 0) {\n storedValue = Object.keys(addedStates).reduce((accumulator, addedState) => {\n // The `storedValue` may equal the whole state (when the default state key is used).\n // If `addedStates` contains only `router` then we want to merge the state only\n // with the `router` value.\n // Let's assume that the `storedValue` is an object:\n // `{ counter: 10, router: {...} }`\n // This will pick only the `router` object from the `storedValue` and `counter`\n // state will not be re-hydrated unnecessary.\n if (storedValue.hasOwnProperty(addedState)) {\n accumulator[addedState] = storedValue[addedState];\n }\n return accumulator;\n }, <PlainObject>{});\n }\n\n state = { ...state, ...storedValue };\n }\n }\n }\n }\n\n return next(state, event).pipe(\n tap(nextState => {\n if (!isInitOrUpdateAction || (isInitOrUpdateAction && hasMigration)) {\n for (const { key, engine } of this._keysWithEngines) {\n let storedValue = nextState;\n\n const storageKey = getStorageKey(key, this._options);\n\n if (key !== DEFAULT_STATE_KEY) {\n storedValue = getValue(nextState, key);\n }\n\n try {\n const newStoredValue = this._options.beforeSerialize!(storedValue, key);\n engine.setItem(storageKey, this._options.serialize!(newStoredValue));\n } catch (error) {\n // Caretaker note: we have still left the `typeof` condition in order to avoid\n // creating a breaking change for projects that still use the View Engine.\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n if (\n error &&\n (error.name === 'QuotaExceededError' ||\n error.name === 'NS_ERROR_DOM_QUOTA_REACHED')\n ) {\n console.error(\n `The ${storageKey} store value exceeds the browser storage quota: `,\n storedValue\n );\n } else {\n console.error(\n `Error ocurred while serializing the ${storageKey} store value, value not updated, the value obtained from the store: `,\n storedValue\n );\n }\n }\n }\n }\n }\n })\n );\n }\n}\n\nconst DOT = '.';\n","import {\n NgModule,\n ModuleWithProviders,\n PLATFORM_ID,\n InjectionToken,\n Injector\n} from '@angular/core';\nimport { NGXS_PLUGINS } from '@ngxs/store';\n\nimport {\n NgxsStoragePluginOptions,\n STORAGE_ENGINE,\n NGXS_STORAGE_PLUGIN_OPTIONS\n} from './symbols';\nimport { NgxsStoragePlugin } from './storage.plugin';\nimport { engineFactory, storageOptionsFactory } from './internals';\nimport {\n createFinalStoragePluginOptions,\n FINAL_NGXS_STORAGE_PLUGIN_OPTIONS\n} from './internals/final-options';\n\nexport const USER_OPTIONS = new InjectionToken('USER_OPTIONS');\n\n@NgModule()\nexport class NgxsStoragePluginModule {\n static forRoot(\n options?: NgxsStoragePluginOptions\n ): ModuleWithProviders<NgxsStoragePluginModule> {\n return {\n ngModule: NgxsStoragePluginModule,\n providers: [\n {\n provide: NGXS_PLUGINS,\n useClass: NgxsStoragePlugin,\n multi: true\n },\n {\n provide: USER_OPTIONS,\n useValue: options\n },\n {\n provide: NGXS_STORAGE_PLUGIN_OPTIONS,\n useFactory: storageOptionsFactory,\n deps: [USER_OPTIONS]\n },\n {\n provide: STORAGE_ENGINE,\n useFactory: engineFactory,\n deps: [NGXS_STORAGE_PLUGIN_OPTIONS, PLATFORM_ID]\n },\n {\n provide: FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,\n useFactory: createFinalStoragePluginOptions,\n deps: [Injector, NGXS_STORAGE_PLUGIN_OPTIONS]\n }\n ]\n };\n }\n}\n","import { InjectionToken } from '@angular/core';\n\nimport { StorageEngine } from './symbols';\n\nexport const LOCAL_STORAGE_ENGINE = new InjectionToken<StorageEngine>('LOCAL_STORAGE_ENGINE', {\n providedIn: 'root',\n factory: () => localStorage\n});\n\nexport const SESSION_STORAGE_ENGINE = new InjectionToken<StorageEngine>(\n 'SESSION_STORAGE_ENGINE',\n {\n providedIn: 'root',\n factory: () => sessionStorage\n }\n);\n"],"names":["tslib_1.__values"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":21,"character":32},"arguments":["USER_OPTIONS"]},"NgxsStoragePluginModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":23,"character":1}}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["options"],"value":{"ngModule":{"__symbolic":"reference","name":"NgxsStoragePluginModule"},"providers":[{"provide":{"__symbolic":"reference","module":"@ngxs/store","name":"NGXS_PLUGINS","line":32,"character":19},"useClass":{"__symbolic":"reference","name":"NgxsStoragePlugin"},"multi":true},{"provide":{"__symbolic":"reference","name":"ɵa"},"useValue":{"__symbolic":"reference","name":"options"}},{"provide":{"__symbolic":"reference","name":"NGXS_STORAGE_PLUGIN_OPTIONS"},"useFactory":{"__symbolic":"reference","name":"ɵe"},"deps":[{"__symbolic":"reference","name":"ɵa"}]},{"provide":{"__symbolic":"reference","name":"STORAGE_ENGINE"},"useFactory":{"__symbolic":"reference","name":"ɵf"},"deps":[{"__symbolic":"reference","name":"NGXS_STORAGE_PLUGIN_OPTIONS"},{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":48,"character":46}]},{"provide":{"__symbolic":"reference","name":"ɵc"},"useFactory":{"__symbolic":"reference","name":"ɵd"},"deps":[{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":53,"character":17},{"__symbolic":"reference","name":"NGXS_STORAGE_PLUGIN_OPTIONS"}]}]}}}},"NgxsStoragePlugin":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":26,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":34,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵc"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":35,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":35,"character":12}]}]],"parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"string"}]}],"handle":[{"__symbolic":"method"}]}},"StorageOption":{"LocalStorage":0,"SessionStorage":1},"NgxsStoragePluginOptions":{"__symbolic":"interface"},"NGXS_STORAGE_PLUGIN_OPTIONS":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":75,"character":47},"arguments":["NGXS_STORAGE_PLUGIN_OPTIONS"]},"STORAGE_ENGINE":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":77,"character":34},"arguments":["STORAGE_ENGINE"]},"StorageEngine":{"__symbolic":"interface"},"LOCAL_STORAGE_ENGINE":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":4,"character":40},"arguments":["LOCAL_STORAGE_ENGINE",{"__symbolic":"error","message":"Lambda not supported","line":6,"character":11,"module":"./src/engines"}]},"SESSION_STORAGE_ENGINE":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":9,"character":42},"arguments":["SESSION_STORAGE_ENGINE",{"__symbolic":"error","message":"Lambda not supported","line":13,"character":13,"module":"./src/engines"}]},"ɵb":{"__symbolic":"interface"},"ɵc":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":12,"character":53},"arguments":["FINAL_NGXS_STORAGE_PLUGIN_OPTIONS"]},"ɵd":{"__symbolic":"function"},"ɵe":{"__symbolic":"function","parameters":["options"],"value":{"__symbolic":"error","message":"Lambda not supported","line":18,"character":21,"module":"./src/internals"}},"ɵf":{"__symbolic":"function"}},"origins":{"ɵa":"./src/storage.module","NgxsStoragePluginModule":"./src/storage.module","NgxsStoragePlugin":"./src/storage.plugin","StorageOption":"./src/symbols","NgxsStoragePluginOptions":"./src/symbols","NGXS_STORAGE_PLUGIN_OPTIONS":"./src/symbols","STORAGE_ENGINE":"./src/symbols","StorageEngine":"./src/symbols","LOCAL_STORAGE_ENGINE":"./src/engines","SESSION_STORAGE_ENGINE":"./src/engines","ɵb":"./src/internals/final-options","ɵc":"./src/internals/final-options","ɵd":"./src/internals/final-options","ɵe":"./src/internals","ɵf":"./src/internals"},"importAs":"@ngxs/storage-plugin"}