@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.
Files changed (49) hide show
  1. package/esm2022/src/config.mjs +68 -0
  2. package/esm2022/src/devtools-dispatcher.mjs +12 -0
  3. package/esm2022/src/devtools.mjs +109 -0
  4. package/esm2022/src/extension.mjs +164 -0
  5. package/esm2022/src/instrument.mjs +23 -0
  6. package/{fesm2020 → fesm2022}/ngrx-store-devtools.mjs +19 -15
  7. package/fesm2022/ngrx-store-devtools.mjs.map +1 -0
  8. package/migrations/6_0_0/index.js +2 -2
  9. package/migrations/6_0_0/index.js.map +1 -1
  10. package/package.json +6 -12
  11. package/schematics/ng-add/index.js +4 -4
  12. package/schematics/ng-add/index.js.map +1 -1
  13. package/schematics/ng-add/schema.js +1 -1
  14. package/schematics-core/index.js +50 -61
  15. package/schematics-core/index.js.map +1 -1
  16. package/schematics-core/utility/ast-utils.js +3 -3
  17. package/schematics-core/utility/change.js +2 -2
  18. package/schematics-core/utility/config.js +1 -1
  19. package/schematics-core/utility/find-component.js +2 -2
  20. package/schematics-core/utility/find-module.js +2 -2
  21. package/schematics-core/utility/json-utilts.js +2 -2
  22. package/schematics-core/utility/libs-version.js +2 -2
  23. package/schematics-core/utility/libs-version.js.map +1 -1
  24. package/schematics-core/utility/ngrx-utils.js +3 -3
  25. package/schematics-core/utility/package.js +1 -1
  26. package/schematics-core/utility/parse-name.js +2 -2
  27. package/schematics-core/utility/project.js +1 -1
  28. package/schematics-core/utility/strings.js +1 -1
  29. package/schematics-core/utility/update.js +1 -1
  30. package/schematics-core/utility/visitors.js +7 -7
  31. package/src/actions.d.ts +1 -1
  32. package/src/config.d.ts +5 -5
  33. package/src/reducer.d.ts +4 -4
  34. package/esm2020/src/config.mjs +0 -63
  35. package/esm2020/src/devtools-dispatcher.mjs +0 -11
  36. package/esm2020/src/devtools.mjs +0 -108
  37. package/esm2020/src/extension.mjs +0 -163
  38. package/esm2020/src/instrument.mjs +0 -22
  39. package/fesm2015/ngrx-store-devtools.mjs +0 -984
  40. package/fesm2015/ngrx-store-devtools.mjs.map +0 -1
  41. package/fesm2020/ngrx-store-devtools.mjs.map +0 -1
  42. /package/{esm2020 → esm2022}/index.mjs +0 -0
  43. /package/{esm2020 → esm2022}/ngrx-store-devtools.mjs +0 -0
  44. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  45. /package/{esm2020 → esm2022}/src/actions.mjs +0 -0
  46. /package/{esm2020 → esm2022}/src/index.mjs +0 -0
  47. /package/{esm2020 → esm2022}/src/provide-store-devtools.mjs +0 -0
  48. /package/{esm2020 → esm2022}/src/reducer.mjs +0 -0
  49. /package/{esm2020 → esm2022}/src/utils.mjs +0 -0
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- exports.__esModule = true;
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.platformVersion = void 0;
4
- exports.platformVersion = '^15.4.0';
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,SAAS,CAAC","sourcesContent":["export const platformVersion = '^15.4.0';\n"]}
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.__esModule = true;
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["return"])) _a.call(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["return"])) _a.call(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.__esModule = true;
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.addPackageToPackageJson = void 0;
4
4
  /**
5
5
  * Adds a package to the package.json
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- exports.__esModule = true;
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.__esModule = true;
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.isLib = exports.getProjectPath = exports.getProject = void 0;
4
4
  var config_1 = require("./config");
5
5
  function getProject(host, options) {
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- exports.__esModule = true;
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
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- exports.__esModule = true;
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.updatePackage = void 0;
4
4
  var schematics_1 = require("@angular-devkit/schematics");
5
5
  function updatePackage(name) {
@@ -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.__esModule = true;
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["return"])) _a.call(_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["return"])) _e.call(_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["return"])) _f.call(_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 declare type All = PerformAction | Refresh | Reset | Rollback | Commit | Sweep | ToggleAction | SetActionsActive | JumpToState | JumpToAction | ImportState | LockChanges | PauseRecording;
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 declare type ActionSanitizer = (action: Action, id: number) => Action;
4
- export declare type StateSanitizer = (state: any, index: number) => any;
5
- export declare type SerializationOptions = {
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 declare type Predicate = (state: any, action: Action) => boolean;
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 declare type StoreDevtoolsOptions = Partial<StoreDevtoolsConfig> | (() => Partial<StoreDevtoolsConfig>);
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 declare type InitAction = {
5
+ export type InitAction = {
6
6
  readonly type: typeof INIT;
7
7
  };
8
- export declare type UpdateReducerAction = {
8
+ export type UpdateReducerAction = {
9
9
  readonly type: typeof UPDATE;
10
10
  };
11
- export declare type CoreActions = InitAction | UpdateReducerAction;
12
- export declare type Actions = DevtoolsActions.All | CoreActions;
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
  };
@@ -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=
@@ -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"]}