@ngrx/store-devtools 15.4.0 → 16.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/src/config.mjs +68 -0
- package/esm2022/src/devtools-dispatcher.mjs +12 -0
- package/esm2022/src/devtools.mjs +109 -0
- package/esm2022/src/extension.mjs +164 -0
- package/esm2022/src/instrument.mjs +23 -0
- package/{fesm2020 → fesm2022}/ngrx-store-devtools.mjs +19 -15
- package/fesm2022/ngrx-store-devtools.mjs.map +1 -0
- package/migrations/6_0_0/index.js +2 -2
- package/migrations/6_0_0/index.js.map +1 -1
- package/package.json +6 -12
- package/schematics/ng-add/index.js +4 -4
- package/schematics/ng-add/index.js.map +1 -1
- package/schematics/ng-add/schema.js +1 -1
- package/schematics-core/index.js +50 -61
- package/schematics-core/index.js.map +1 -1
- package/schematics-core/utility/ast-utils.js +3 -3
- package/schematics-core/utility/change.js +2 -2
- package/schematics-core/utility/config.js +1 -1
- package/schematics-core/utility/find-component.js +2 -2
- package/schematics-core/utility/find-module.js +2 -2
- package/schematics-core/utility/json-utilts.js +2 -2
- package/schematics-core/utility/libs-version.js +2 -2
- package/schematics-core/utility/libs-version.js.map +1 -1
- package/schematics-core/utility/ngrx-utils.js +3 -3
- package/schematics-core/utility/package.js +1 -1
- package/schematics-core/utility/parse-name.js +2 -2
- package/schematics-core/utility/project.js +1 -1
- package/schematics-core/utility/strings.js +1 -1
- package/schematics-core/utility/update.js +1 -1
- package/schematics-core/utility/visitors.js +7 -7
- package/src/actions.d.ts +1 -1
- package/src/config.d.ts +5 -5
- package/src/reducer.d.ts +4 -4
- package/esm2020/src/config.mjs +0 -63
- package/esm2020/src/devtools-dispatcher.mjs +0 -11
- package/esm2020/src/devtools.mjs +0 -108
- package/esm2020/src/extension.mjs +0 -163
- package/esm2020/src/instrument.mjs +0 -22
- package/fesm2015/ngrx-store-devtools.mjs +0 -984
- package/fesm2015/ngrx-store-devtools.mjs.map +0 -1
- package/fesm2020/ngrx-store-devtools.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/ngrx-store-devtools.mjs +0 -0
- /package/{esm2020 → esm2022}/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/src/actions.mjs +0 -0
- /package/{esm2020 → esm2022}/src/index.mjs +0 -0
- /package/{esm2020 → esm2022}/src/provide-store-devtools.mjs +0 -0
- /package/{esm2020 → esm2022}/src/reducer.mjs +0 -0
- /package/{esm2020 → esm2022}/src/utils.mjs +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
exports
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.platformVersion = void 0;
|
|
4
|
-
exports.platformVersion = '^
|
|
4
|
+
exports.platformVersion = '^16.0.0-beta.0';
|
|
5
5
|
//# sourceMappingURL=libs-version.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"libs-version.js","sourceRoot":"","sources":["../../../../../modules/store-devtools/schematics-core/utility/libs-version.ts"],"names":[],"mappings":";;;AAAa,QAAA,eAAe,GAAG,
|
|
1
|
+
{"version":3,"file":"libs-version.js","sourceRoot":"","sources":["../../../../../modules/store-devtools/schematics-core/utility/libs-version.ts"],"names":[],"mappings":";;;AAAa,QAAA,eAAe,GAAG,gBAAgB,CAAC","sourcesContent":["export const platformVersion = '^16.0.0-beta.0';\n"]}
|
|
@@ -35,7 +35,7 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
35
35
|
}
|
|
36
36
|
return to.concat(ar || Array.prototype.slice.call(from));
|
|
37
37
|
};
|
|
38
|
-
exports
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
39
|
exports.getPrefix = exports.omit = exports.addReducerImportToNgModule = exports.addReducerToActionReducerMap = exports.addReducerToStateInterface = exports.addReducerToState = void 0;
|
|
40
40
|
var ts = require("typescript");
|
|
41
41
|
var stringUtils = require("./strings");
|
|
@@ -82,7 +82,7 @@ function addReducerToState(options) {
|
|
|
82
82
|
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
83
83
|
finally {
|
|
84
84
|
try {
|
|
85
|
-
if (changes_1_1 && !changes_1_1.done && (_a = changes_1
|
|
85
|
+
if (changes_1_1 && !changes_1_1.done && (_a = changes_1.return)) _a.call(changes_1);
|
|
86
86
|
}
|
|
87
87
|
finally { if (e_1) throw e_1.error; }
|
|
88
88
|
}
|
|
@@ -223,7 +223,7 @@ function addReducerImportToNgModule(options) {
|
|
|
223
223
|
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
224
224
|
finally {
|
|
225
225
|
try {
|
|
226
|
-
if (changes_2_1 && !changes_2_1.done && (_a = changes_2
|
|
226
|
+
if (changes_2_1 && !changes_2_1.done && (_a = changes_2.return)) _a.call(changes_2);
|
|
227
227
|
}
|
|
228
228
|
finally { if (e_2) throw e_2.error; }
|
|
229
229
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
exports
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.parseName = void 0;
|
|
4
4
|
var core_1 = require("@angular-devkit/core");
|
|
5
5
|
function parseName(path, name) {
|
|
@@ -7,7 +7,7 @@ function parseName(path, name) {
|
|
|
7
7
|
var namePath = (0, core_1.dirname)((path + '/' + name));
|
|
8
8
|
return {
|
|
9
9
|
name: nameWithoutPath,
|
|
10
|
-
path: (0, core_1.normalize)('/' + namePath)
|
|
10
|
+
path: (0, core_1.normalize)('/' + namePath),
|
|
11
11
|
};
|
|
12
12
|
}
|
|
13
13
|
exports.parseName = parseName;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
exports
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.featurePath = exports.group = exports.pluralize = exports.capitalize = exports.underscore = exports.classify = exports.camelize = exports.dasherize = exports.decamelize = void 0;
|
|
4
4
|
/**
|
|
5
5
|
* @license
|
|
@@ -5,7 +5,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
5
5
|
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
6
6
|
function step(op) {
|
|
7
7
|
if (f) throw new TypeError("Generator is already executing.");
|
|
8
|
-
while (_) try {
|
|
8
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
9
9
|
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;
|
|
10
10
|
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
11
11
|
switch (op[0]) {
|
|
@@ -53,7 +53,7 @@ var __read = (this && this.__read) || function (o, n) {
|
|
|
53
53
|
}
|
|
54
54
|
return ar;
|
|
55
55
|
};
|
|
56
|
-
exports
|
|
56
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
57
57
|
exports.visitDecorator = exports.visitNgModules = exports.visitComponents = exports.visitNgModuleExports = exports.visitNgModuleImports = exports.visitTemplates = exports.visitTSSourceFiles = void 0;
|
|
58
58
|
var ts = require("typescript");
|
|
59
59
|
var core_1 = require("@angular-devkit/core");
|
|
@@ -69,7 +69,7 @@ function visitTSSourceFiles(tree, visitor) {
|
|
|
69
69
|
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
70
70
|
finally {
|
|
71
71
|
try {
|
|
72
|
-
if (_c && !_c.done && (_a = _b
|
|
72
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
73
73
|
}
|
|
74
74
|
finally { if (e_1) throw e_1.error; }
|
|
75
75
|
}
|
|
@@ -90,7 +90,7 @@ function visitTemplates(tree, visitor) {
|
|
|
90
90
|
fileName: source.fileName,
|
|
91
91
|
content: n.initializer.text,
|
|
92
92
|
inline: true,
|
|
93
|
-
start: templateStartIdx
|
|
93
|
+
start: templateStartIdx,
|
|
94
94
|
}, tree);
|
|
95
95
|
return;
|
|
96
96
|
}
|
|
@@ -109,7 +109,7 @@ function visitTemplates(tree, visitor) {
|
|
|
109
109
|
fileName: templatePath,
|
|
110
110
|
content: fileContent.toString(),
|
|
111
111
|
inline: false,
|
|
112
|
-
start: 0
|
|
112
|
+
start: 0,
|
|
113
113
|
}, tree);
|
|
114
114
|
return;
|
|
115
115
|
}
|
|
@@ -211,7 +211,7 @@ function visit(directory) {
|
|
|
211
211
|
return [3 /*break*/, 7];
|
|
212
212
|
case 6:
|
|
213
213
|
try {
|
|
214
|
-
if (_b && !_b.done && (_e = _a
|
|
214
|
+
if (_b && !_b.done && (_e = _a.return)) _e.call(_a);
|
|
215
215
|
}
|
|
216
216
|
finally { if (e_2) throw e_2.error; }
|
|
217
217
|
return [7 /*endfinally*/];
|
|
@@ -239,7 +239,7 @@ function visit(directory) {
|
|
|
239
239
|
return [3 /*break*/, 14];
|
|
240
240
|
case 13:
|
|
241
241
|
try {
|
|
242
|
-
if (_d && !_d.done && (_f = _c
|
|
242
|
+
if (_d && !_d.done && (_f = _c.return)) _f.call(_c);
|
|
243
243
|
}
|
|
244
244
|
finally { if (e_3) throw e_3.error; }
|
|
245
245
|
return [7 /*endfinally*/];
|
package/src/actions.d.ts
CHANGED
|
@@ -76,4 +76,4 @@ export declare class PauseRecording implements Action {
|
|
|
76
76
|
readonly type = "PAUSE_RECORDING";
|
|
77
77
|
constructor(status: boolean);
|
|
78
78
|
}
|
|
79
|
-
export
|
|
79
|
+
export type All = PerformAction | Refresh | Reset | Rollback | Commit | Sweep | ToggleAction | SetActionsActive | JumpToState | JumpToAction | ImportState | LockChanges | PauseRecording;
|
package/src/config.d.ts
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { ActionReducer, Action } from '@ngrx/store';
|
|
2
2
|
import { InjectionToken } from '@angular/core';
|
|
3
|
-
export
|
|
4
|
-
export
|
|
5
|
-
export
|
|
3
|
+
export type ActionSanitizer = (action: Action, id: number) => Action;
|
|
4
|
+
export type StateSanitizer = (state: any, index: number) => any;
|
|
5
|
+
export type SerializationOptions = {
|
|
6
6
|
options?: boolean | any;
|
|
7
7
|
replacer?: (key: any, value: any) => {};
|
|
8
8
|
reviver?: (key: any, value: any) => {};
|
|
9
9
|
immutable?: any;
|
|
10
10
|
refs?: Array<any>;
|
|
11
11
|
};
|
|
12
|
-
export
|
|
12
|
+
export type Predicate = (state: any, action: Action) => boolean;
|
|
13
13
|
/**
|
|
14
14
|
* Chrome extension documentation
|
|
15
15
|
* @see https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md#features
|
|
@@ -115,7 +115,7 @@ export declare const STORE_DEVTOOLS_CONFIG: InjectionToken<StoreDevtoolsConfig>;
|
|
|
115
115
|
* Used to provide a `StoreDevtoolsConfig` for the store-devtools.
|
|
116
116
|
*/
|
|
117
117
|
export declare const INITIAL_OPTIONS: InjectionToken<StoreDevtoolsConfig>;
|
|
118
|
-
export
|
|
118
|
+
export type StoreDevtoolsOptions = Partial<StoreDevtoolsConfig> | (() => Partial<StoreDevtoolsConfig>);
|
|
119
119
|
export declare function noMonitor(): null;
|
|
120
120
|
export declare const DEFAULT_NAME = "NgRx Store DevTools";
|
|
121
121
|
export declare function createConfig(optionsInput: StoreDevtoolsOptions): StoreDevtoolsConfig;
|
package/src/reducer.d.ts
CHANGED
|
@@ -2,14 +2,14 @@ import { ErrorHandler } from '@angular/core';
|
|
|
2
2
|
import { Action, ActionReducer, UPDATE, INIT } from '@ngrx/store';
|
|
3
3
|
import * as DevtoolsActions from './actions';
|
|
4
4
|
import { StoreDevtoolsConfig } from './config';
|
|
5
|
-
export
|
|
5
|
+
export type InitAction = {
|
|
6
6
|
readonly type: typeof INIT;
|
|
7
7
|
};
|
|
8
|
-
export
|
|
8
|
+
export type UpdateReducerAction = {
|
|
9
9
|
readonly type: typeof UPDATE;
|
|
10
10
|
};
|
|
11
|
-
export
|
|
12
|
-
export
|
|
11
|
+
export type CoreActions = InitAction | UpdateReducerAction;
|
|
12
|
+
export type Actions = DevtoolsActions.All | CoreActions;
|
|
13
13
|
export declare const INIT_ACTION: {
|
|
14
14
|
type: "@ngrx/store/init";
|
|
15
15
|
};
|
package/esm2020/src/config.mjs
DELETED
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
2
|
-
/**
|
|
3
|
-
* Chrome extension documentation
|
|
4
|
-
* @see https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md
|
|
5
|
-
* Firefox extension documentation
|
|
6
|
-
* @see https://github.com/zalmoxisus/redux-devtools-extension/blob/master/docs/API/Arguments.md
|
|
7
|
-
*/
|
|
8
|
-
export class StoreDevtoolsConfig {
|
|
9
|
-
constructor() {
|
|
10
|
-
/**
|
|
11
|
-
* Maximum allowed actions to be stored in the history tree (default: `false`)
|
|
12
|
-
*/
|
|
13
|
-
this.maxAge = false;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
export const STORE_DEVTOOLS_CONFIG = new InjectionToken('@ngrx/store-devtools Options');
|
|
17
|
-
/**
|
|
18
|
-
* Used to provide a `StoreDevtoolsConfig` for the store-devtools.
|
|
19
|
-
*/
|
|
20
|
-
export const INITIAL_OPTIONS = new InjectionToken('@ngrx/store-devtools Initial Config');
|
|
21
|
-
export function noMonitor() {
|
|
22
|
-
return null;
|
|
23
|
-
}
|
|
24
|
-
export const DEFAULT_NAME = 'NgRx Store DevTools';
|
|
25
|
-
export function createConfig(optionsInput) {
|
|
26
|
-
const DEFAULT_OPTIONS = {
|
|
27
|
-
maxAge: false,
|
|
28
|
-
monitor: noMonitor,
|
|
29
|
-
actionSanitizer: undefined,
|
|
30
|
-
stateSanitizer: undefined,
|
|
31
|
-
name: DEFAULT_NAME,
|
|
32
|
-
serialize: false,
|
|
33
|
-
logOnly: false,
|
|
34
|
-
autoPause: false,
|
|
35
|
-
trace: false,
|
|
36
|
-
traceLimit: 75,
|
|
37
|
-
// Add all features explicitly. This prevent buggy behavior for
|
|
38
|
-
// options like "lock" which might otherwise not show up.
|
|
39
|
-
features: {
|
|
40
|
-
pause: true,
|
|
41
|
-
lock: true,
|
|
42
|
-
persist: true,
|
|
43
|
-
export: true,
|
|
44
|
-
import: 'custom',
|
|
45
|
-
jump: true,
|
|
46
|
-
skip: true,
|
|
47
|
-
reorder: true,
|
|
48
|
-
dispatch: true,
|
|
49
|
-
test: true, // Generate tests for the selected actions
|
|
50
|
-
},
|
|
51
|
-
};
|
|
52
|
-
const options = typeof optionsInput === 'function' ? optionsInput() : optionsInput;
|
|
53
|
-
const logOnly = options.logOnly
|
|
54
|
-
? { pause: true, export: true, test: true }
|
|
55
|
-
: false;
|
|
56
|
-
const features = options.features || logOnly || DEFAULT_OPTIONS.features;
|
|
57
|
-
const config = Object.assign({}, DEFAULT_OPTIONS, { features }, options);
|
|
58
|
-
if (config.maxAge && config.maxAge < 2) {
|
|
59
|
-
throw new Error(`Devtools 'maxAge' cannot be less than 2, got ${config.maxAge}`);
|
|
60
|
-
}
|
|
61
|
-
return config;
|
|
62
|
-
}
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../../modules/store-devtools/src/config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AA8D/C;;;;;GAKG;AACH,MAAM,OAAO,mBAAmB;IAAhC;QACE;;WAEG;QACH,WAAM,GAAmB,KAAK,CAAC;IA2CjC,CAAC;CAAA;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,IAAI,cAAc,CACrD,8BAA8B,CAC/B,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,cAAc,CAC/C,qCAAqC,CACtC,CAAC;AAMF,MAAM,UAAU,SAAS;IACvB,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,qBAAqB,CAAC;AAElD,MAAM,UAAU,YAAY,CAC1B,YAAkC;IAElC,MAAM,eAAe,GAAwB;QAC3C,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,SAAS;QAClB,eAAe,EAAE,SAAS;QAC1B,cAAc,EAAE,SAAS;QACzB,IAAI,EAAE,YAAY;QAClB,SAAS,EAAE,KAAK;QAChB,OAAO,EAAE,KAAK;QACd,SAAS,EAAE,KAAK;QAChB,KAAK,EAAE,KAAK;QACZ,UAAU,EAAE,EAAE;QACd,+DAA+D;QAC/D,yDAAyD;QACzD,QAAQ,EAAE;YACR,KAAK,EAAE,IAAI;YACX,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,QAAQ;YAChB,IAAI,EAAE,IAAI;YACV,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI,EAAE,0CAA0C;SACvD;KACF,CAAC;IAEF,MAAM,OAAO,GACX,OAAO,YAAY,KAAK,UAAU,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC;IACrE,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO;QAC7B,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;QAC3C,CAAC,CAAC,KAAK,CAAC;IACV,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,OAAO,IAAI,eAAe,CAAC,QAAQ,CAAC;IACzE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,EAAE,EAAE,QAAQ,EAAE,EAAE,OAAO,CAAC,CAAC;IAEzE,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;QACtC,MAAM,IAAI,KAAK,CACb,gDAAgD,MAAM,CAAC,MAAM,EAAE,CAChE,CAAC;KACH;IAED,OAAO,MAAM,CAAC;AAChB,CAAC","sourcesContent":["import { ActionReducer, Action } from '@ngrx/store';\nimport { InjectionToken } from '@angular/core';\n\nexport type ActionSanitizer = (action: Action, id: number) => Action;\nexport type StateSanitizer = (state: any, index: number) => any;\nexport type SerializationOptions = {\n  options?: boolean | any;\n  replacer?: (key: any, value: any) => {};\n  reviver?: (key: any, value: any) => {};\n  immutable?: any;\n  refs?: Array<any>;\n};\nexport type Predicate = (state: any, action: Action) => boolean;\n\n/**\n * Chrome extension documentation\n * @see https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md#features\n * Firefox extension documentation\n * @see https://github.com/zalmoxisus/redux-devtools-extension/blob/master/docs/API/Arguments.md#features\n */\nexport interface DevToolsFeatureOptions {\n  /**\n   * Start/pause recording of dispatched actions\n   */\n  pause?: boolean;\n  /**\n   * Lock/unlock dispatching actions and side effects\n   */\n  lock?: boolean;\n  /**\n   * Persist states on page reloading\n   */\n  persist?: boolean;\n  /**\n   * Export history of actions in a file\n   */\n  export?: boolean;\n  /**\n   * Import history of actions from a file\n   */\n  import?: 'custom' | boolean;\n  /**\n   * Jump back and forth (time travelling)\n   */\n  jump?: boolean;\n  /**\n   * Skip (cancel) actions\n   */\n  skip?: boolean;\n  /**\n   * Drag and drop actions in the history list\n   */\n  reorder?: boolean;\n  /**\n   * Dispatch custom actions or action creators\n   */\n  dispatch?: boolean;\n  /**\n   * Generate tests for the selected actions\n   */\n  test?: boolean;\n}\n\n/**\n * Chrome extension documentation\n * @see https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n * Firefox extension documentation\n * @see https://github.com/zalmoxisus/redux-devtools-extension/blob/master/docs/API/Arguments.md\n */\nexport class StoreDevtoolsConfig {\n  /**\n   * Maximum allowed actions to be stored in the history tree (default: `false`)\n   */\n  maxAge: number | false = false;\n  monitor?: ActionReducer<any, any>;\n  /**\n   * Function which takes `action` object and id number as arguments, and should return `action` object back.\n   */\n  actionSanitizer?: ActionSanitizer;\n  /**\n   * Function which takes `state` object and index as arguments, and should return `state` object back.\n   */\n  stateSanitizer?: StateSanitizer;\n  /**\n   * The instance name to be shown on the monitor page (default: `document.title`)\n   */\n  name?: string;\n  serialize?: boolean | SerializationOptions;\n  logOnly?: boolean;\n  features?: DevToolsFeatureOptions;\n  /**\n   * Action types to be hidden in the monitors. If `actionsSafelist` specified, `actionsBlocklist` is ignored.\n   */\n  actionsBlocklist?: string[];\n  /**\n   * Action types to be shown in the monitors\n   */\n  actionsSafelist?: string[];\n  /**\n   * Called for every action before sending, takes state and action object, and returns true in case it allows sending the current data to the monitor.\n   */\n  predicate?: Predicate;\n  /**\n   * Auto pauses when the extension’s window is not opened, and so has zero impact on your app when not in use.\n   */\n  autoPause?: boolean;\n\n  /**\n   * If set to true, will include stack trace for every dispatched action\n   */\n  trace?: boolean | (() => string);\n\n  /**\n   * Maximum stack trace frames to be stored (in case trace option was provided as true).\n   */\n  traceLimit?: number;\n}\n\nexport const STORE_DEVTOOLS_CONFIG = new InjectionToken<StoreDevtoolsConfig>(\n  '@ngrx/store-devtools Options'\n);\n\n/**\n * Used to provide a `StoreDevtoolsConfig` for the store-devtools.\n */\nexport const INITIAL_OPTIONS = new InjectionToken<StoreDevtoolsConfig>(\n  '@ngrx/store-devtools Initial Config'\n);\n\nexport type StoreDevtoolsOptions =\n  | Partial<StoreDevtoolsConfig>\n  | (() => Partial<StoreDevtoolsConfig>);\n\nexport function noMonitor(): null {\n  return null;\n}\n\nexport const DEFAULT_NAME = 'NgRx Store DevTools';\n\nexport function createConfig(\n  optionsInput: StoreDevtoolsOptions\n): StoreDevtoolsConfig {\n  const DEFAULT_OPTIONS: StoreDevtoolsConfig = {\n    maxAge: false,\n    monitor: noMonitor,\n    actionSanitizer: undefined,\n    stateSanitizer: undefined,\n    name: DEFAULT_NAME,\n    serialize: false,\n    logOnly: false,\n    autoPause: false,\n    trace: false,\n    traceLimit: 75,\n    // Add all features explicitly. This prevent buggy behavior for\n    // options like \"lock\" which might otherwise not show up.\n    features: {\n      pause: true, // Start/pause recording of dispatched actions\n      lock: true, // Lock/unlock dispatching actions and side effects\n      persist: true, // Persist states on page reloading\n      export: true, // Export history of actions in a file\n      import: 'custom', // Import history of actions from a file\n      jump: true, // Jump back and forth (time travelling)\n      skip: true, // Skip (cancel) actions\n      reorder: true, // Drag and drop actions in the history list\n      dispatch: true, // Dispatch custom actions or action creators\n      test: true, // Generate tests for the selected actions\n    },\n  };\n\n  const options =\n    typeof optionsInput === 'function' ? optionsInput() : optionsInput;\n  const logOnly = options.logOnly\n    ? { pause: true, export: true, test: true }\n    : false;\n  const features = options.features || logOnly || DEFAULT_OPTIONS.features;\n  const config = Object.assign({}, DEFAULT_OPTIONS, { features }, options);\n\n  if (config.maxAge && config.maxAge < 2) {\n    throw new Error(\n      `Devtools 'maxAge' cannot be less than 2, got ${config.maxAge}`\n    );\n  }\n\n  return config;\n}\n"]}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { ActionsSubject } from '@ngrx/store';
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class DevtoolsDispatcher extends ActionsSubject {
|
|
5
|
-
}
|
|
6
|
-
/** @nocollapse */ DevtoolsDispatcher.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: DevtoolsDispatcher, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
7
|
-
/** @nocollapse */ DevtoolsDispatcher.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: DevtoolsDispatcher });
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: DevtoolsDispatcher, decorators: [{
|
|
9
|
-
type: Injectable
|
|
10
|
-
}] });
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV2dG9vbHMtZGlzcGF0Y2hlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL21vZHVsZXMvc3RvcmUtZGV2dG9vbHMvc3JjL2RldnRvb2xzLWRpc3BhdGNoZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUczQyxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsY0FBYzs7a0lBQXpDLGtCQUFrQjtzSUFBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBY3Rpb25zU3ViamVjdCB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIERldnRvb2xzRGlzcGF0Y2hlciBleHRlbmRzIEFjdGlvbnNTdWJqZWN0IHt9XG4iXX0=
|
package/esm2020/src/devtools.mjs
DELETED
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { Injectable, Inject } from '@angular/core';
|
|
2
|
-
import { INITIAL_STATE, } from '@ngrx/store';
|
|
3
|
-
import { merge, queueScheduler, ReplaySubject, } from 'rxjs';
|
|
4
|
-
import { map, observeOn, scan, skip, withLatestFrom } from 'rxjs/operators';
|
|
5
|
-
import * as Actions from './actions';
|
|
6
|
-
import { STORE_DEVTOOLS_CONFIG } from './config';
|
|
7
|
-
import { liftInitialState, liftReducerWith } from './reducer';
|
|
8
|
-
import { liftAction, unliftState, shouldFilterActions, filterLiftedState, } from './utils';
|
|
9
|
-
import { PERFORM_ACTION } from './actions';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "./devtools-dispatcher";
|
|
12
|
-
import * as i2 from "@ngrx/store";
|
|
13
|
-
import * as i3 from "./extension";
|
|
14
|
-
import * as i4 from "./config";
|
|
15
|
-
export class StoreDevtools {
|
|
16
|
-
constructor(dispatcher, actions$, reducers$, extension, scannedActions, errorHandler, initialState, config) {
|
|
17
|
-
const liftedInitialState = liftInitialState(initialState, config.monitor);
|
|
18
|
-
const liftReducer = liftReducerWith(initialState, liftedInitialState, errorHandler, config.monitor, config);
|
|
19
|
-
const liftedAction$ = merge(merge(actions$.asObservable().pipe(skip(1)), extension.actions$).pipe(map(liftAction)), dispatcher, extension.liftedActions$).pipe(observeOn(queueScheduler));
|
|
20
|
-
const liftedReducer$ = reducers$.pipe(map(liftReducer));
|
|
21
|
-
const liftedStateSubject = new ReplaySubject(1);
|
|
22
|
-
const liftedStateSubscription = liftedAction$
|
|
23
|
-
.pipe(withLatestFrom(liftedReducer$), scan(({ state: liftedState }, [action, reducer]) => {
|
|
24
|
-
let reducedLiftedState = reducer(liftedState, action);
|
|
25
|
-
// On full state update
|
|
26
|
-
// If we have actions filters, we must filter completely our lifted state to be sync with the extension
|
|
27
|
-
if (action.type !== PERFORM_ACTION && shouldFilterActions(config)) {
|
|
28
|
-
reducedLiftedState = filterLiftedState(reducedLiftedState, config.predicate, config.actionsSafelist, config.actionsBlocklist);
|
|
29
|
-
}
|
|
30
|
-
// Extension should be sent the sanitized lifted state
|
|
31
|
-
extension.notify(action, reducedLiftedState);
|
|
32
|
-
return { state: reducedLiftedState, action };
|
|
33
|
-
}, { state: liftedInitialState, action: null }))
|
|
34
|
-
.subscribe(({ state, action }) => {
|
|
35
|
-
liftedStateSubject.next(state);
|
|
36
|
-
if (action.type === Actions.PERFORM_ACTION) {
|
|
37
|
-
const unliftedAction = action.action;
|
|
38
|
-
scannedActions.next(unliftedAction);
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
const extensionStartSubscription = extension.start$.subscribe(() => {
|
|
42
|
-
this.refresh();
|
|
43
|
-
});
|
|
44
|
-
const liftedState$ = liftedStateSubject.asObservable();
|
|
45
|
-
const state$ = liftedState$.pipe(map(unliftState));
|
|
46
|
-
this.extensionStartSubscription = extensionStartSubscription;
|
|
47
|
-
this.stateSubscription = liftedStateSubscription;
|
|
48
|
-
this.dispatcher = dispatcher;
|
|
49
|
-
this.liftedState = liftedState$;
|
|
50
|
-
this.state = state$;
|
|
51
|
-
}
|
|
52
|
-
dispatch(action) {
|
|
53
|
-
this.dispatcher.next(action);
|
|
54
|
-
}
|
|
55
|
-
next(action) {
|
|
56
|
-
this.dispatcher.next(action);
|
|
57
|
-
}
|
|
58
|
-
error(error) { }
|
|
59
|
-
complete() { }
|
|
60
|
-
performAction(action) {
|
|
61
|
-
this.dispatch(new Actions.PerformAction(action, +Date.now()));
|
|
62
|
-
}
|
|
63
|
-
refresh() {
|
|
64
|
-
this.dispatch(new Actions.Refresh());
|
|
65
|
-
}
|
|
66
|
-
reset() {
|
|
67
|
-
this.dispatch(new Actions.Reset(+Date.now()));
|
|
68
|
-
}
|
|
69
|
-
rollback() {
|
|
70
|
-
this.dispatch(new Actions.Rollback(+Date.now()));
|
|
71
|
-
}
|
|
72
|
-
commit() {
|
|
73
|
-
this.dispatch(new Actions.Commit(+Date.now()));
|
|
74
|
-
}
|
|
75
|
-
sweep() {
|
|
76
|
-
this.dispatch(new Actions.Sweep());
|
|
77
|
-
}
|
|
78
|
-
toggleAction(id) {
|
|
79
|
-
this.dispatch(new Actions.ToggleAction(id));
|
|
80
|
-
}
|
|
81
|
-
jumpToAction(actionId) {
|
|
82
|
-
this.dispatch(new Actions.JumpToAction(actionId));
|
|
83
|
-
}
|
|
84
|
-
jumpToState(index) {
|
|
85
|
-
this.dispatch(new Actions.JumpToState(index));
|
|
86
|
-
}
|
|
87
|
-
importState(nextLiftedState) {
|
|
88
|
-
this.dispatch(new Actions.ImportState(nextLiftedState));
|
|
89
|
-
}
|
|
90
|
-
lockChanges(status) {
|
|
91
|
-
this.dispatch(new Actions.LockChanges(status));
|
|
92
|
-
}
|
|
93
|
-
pauseRecording(status) {
|
|
94
|
-
this.dispatch(new Actions.PauseRecording(status));
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
/** @nocollapse */ StoreDevtools.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: StoreDevtools, deps: [{ token: i1.DevtoolsDispatcher }, { token: i2.ActionsSubject }, { token: i2.ReducerObservable }, { token: i3.DevtoolsExtension }, { token: i2.ScannedActionsSubject }, { token: i0.ErrorHandler }, { token: INITIAL_STATE }, { token: STORE_DEVTOOLS_CONFIG }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
98
|
-
/** @nocollapse */ StoreDevtools.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: StoreDevtools });
|
|
99
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: StoreDevtools, decorators: [{
|
|
100
|
-
type: Injectable
|
|
101
|
-
}], ctorParameters: function () { return [{ type: i1.DevtoolsDispatcher }, { type: i2.ActionsSubject }, { type: i2.ReducerObservable }, { type: i3.DevtoolsExtension }, { type: i2.ScannedActionsSubject }, { type: i0.ErrorHandler }, { type: undefined, decorators: [{
|
|
102
|
-
type: Inject,
|
|
103
|
-
args: [INITIAL_STATE]
|
|
104
|
-
}] }, { type: i4.StoreDevtoolsConfig, decorators: [{
|
|
105
|
-
type: Inject,
|
|
106
|
-
args: [STORE_DEVTOOLS_CONFIG]
|
|
107
|
-
}] }]; } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devtools.js","sourceRoot":"","sources":["../../../../../modules/store-devtools/src/devtools.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, ErrorHandler } from '@angular/core';\nimport {\n  Action,\n  ActionReducer,\n  ActionsSubject,\n  INITIAL_STATE,\n  ReducerObservable,\n  ScannedActionsSubject,\n} from '@ngrx/store';\nimport {\n  merge,\n  Observable,\n  Observer,\n  queueScheduler,\n  ReplaySubject,\n  Subscription,\n} from 'rxjs';\nimport { map, observeOn, scan, skip, withLatestFrom } from 'rxjs/operators';\n\nimport * as Actions from './actions';\nimport { STORE_DEVTOOLS_CONFIG, StoreDevtoolsConfig } from './config';\nimport { DevtoolsExtension } from './extension';\nimport { LiftedState, liftInitialState, liftReducerWith } from './reducer';\nimport {\n  liftAction,\n  unliftState,\n  shouldFilterActions,\n  filterLiftedState,\n} from './utils';\nimport { DevtoolsDispatcher } from './devtools-dispatcher';\nimport { PERFORM_ACTION } from './actions';\n\n@Injectable()\nexport class StoreDevtools implements Observer<any> {\n  private stateSubscription: Subscription;\n  private extensionStartSubscription: Subscription;\n  public dispatcher: ActionsSubject;\n  public liftedState: Observable<LiftedState>;\n  public state: Observable<any>;\n\n  constructor(\n    dispatcher: DevtoolsDispatcher,\n    actions$: ActionsSubject,\n    reducers$: ReducerObservable,\n    extension: DevtoolsExtension,\n    scannedActions: ScannedActionsSubject,\n    errorHandler: ErrorHandler,\n    @Inject(INITIAL_STATE) initialState: any,\n    @Inject(STORE_DEVTOOLS_CONFIG) config: StoreDevtoolsConfig\n  ) {\n    const liftedInitialState = liftInitialState(initialState, config.monitor);\n    const liftReducer = liftReducerWith(\n      initialState,\n      liftedInitialState,\n      errorHandler,\n      config.monitor,\n      config\n    );\n\n    const liftedAction$ = merge(\n      merge(actions$.asObservable().pipe(skip(1)), extension.actions$).pipe(\n        map(liftAction)\n      ),\n      dispatcher,\n      extension.liftedActions$\n    ).pipe(observeOn(queueScheduler));\n\n    const liftedReducer$ = reducers$.pipe(map(liftReducer));\n\n    const liftedStateSubject = new ReplaySubject<LiftedState>(1);\n\n    const liftedStateSubscription = liftedAction$\n      .pipe(\n        withLatestFrom(liftedReducer$),\n        scan<\n          [any, ActionReducer<LiftedState, Actions.All>],\n          {\n            state: LiftedState;\n            action: any;\n          }\n        >(\n          ({ state: liftedState }, [action, reducer]) => {\n            let reducedLiftedState = reducer(liftedState, action);\n            // On full state update\n            // If we have actions filters, we must filter completely our lifted state to be sync with the extension\n            if (action.type !== PERFORM_ACTION && shouldFilterActions(config)) {\n              reducedLiftedState = filterLiftedState(\n                reducedLiftedState,\n                config.predicate,\n                config.actionsSafelist,\n                config.actionsBlocklist\n              );\n            }\n            // Extension should be sent the sanitized lifted state\n            extension.notify(action, reducedLiftedState);\n            return { state: reducedLiftedState, action };\n          },\n          { state: liftedInitialState, action: null as any }\n        )\n      )\n      .subscribe(({ state, action }) => {\n        liftedStateSubject.next(state);\n\n        if (action.type === Actions.PERFORM_ACTION) {\n          const unliftedAction = (action as Actions.PerformAction).action;\n\n          scannedActions.next(unliftedAction);\n        }\n      });\n\n    const extensionStartSubscription = extension.start$.subscribe(() => {\n      this.refresh();\n    });\n\n    const liftedState$ =\n      liftedStateSubject.asObservable() as Observable<LiftedState>;\n    const state$ = liftedState$.pipe(map(unliftState));\n\n    this.extensionStartSubscription = extensionStartSubscription;\n    this.stateSubscription = liftedStateSubscription;\n    this.dispatcher = dispatcher;\n    this.liftedState = liftedState$;\n    this.state = state$;\n  }\n\n  dispatch(action: Action) {\n    this.dispatcher.next(action);\n  }\n\n  next(action: any) {\n    this.dispatcher.next(action);\n  }\n\n  error(error: any) {}\n\n  complete() {}\n\n  performAction(action: any) {\n    this.dispatch(new Actions.PerformAction(action, +Date.now()));\n  }\n\n  refresh() {\n    this.dispatch(new Actions.Refresh());\n  }\n\n  reset() {\n    this.dispatch(new Actions.Reset(+Date.now()));\n  }\n\n  rollback() {\n    this.dispatch(new Actions.Rollback(+Date.now()));\n  }\n\n  commit() {\n    this.dispatch(new Actions.Commit(+Date.now()));\n  }\n\n  sweep() {\n    this.dispatch(new Actions.Sweep());\n  }\n\n  toggleAction(id: number) {\n    this.dispatch(new Actions.ToggleAction(id));\n  }\n\n  jumpToAction(actionId: number) {\n    this.dispatch(new Actions.JumpToAction(actionId));\n  }\n\n  jumpToState(index: number) {\n    this.dispatch(new Actions.JumpToState(index));\n  }\n\n  importState(nextLiftedState: any) {\n    this.dispatch(new Actions.ImportState(nextLiftedState));\n  }\n\n  lockChanges(status: boolean) {\n    this.dispatch(new Actions.LockChanges(status));\n  }\n\n  pauseRecording(status: boolean) {\n    this.dispatch(new Actions.PauseRecording(status));\n  }\n}\n"]}
|