@ngxs/devtools-plugin 3.7.3 → 3.7.4

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.
@@ -2,10 +2,22 @@
2
2
  * @fileoverview added by tsickle
3
3
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
- import { Inject, Injectable, Injector } from '@angular/core';
5
+ import { Inject, Injectable, Injector, NgZone, ɵglobal } from '@angular/core';
6
6
  import { getActionTypeFromInstance, Store } from '@ngxs/store';
7
7
  import { tap, catchError } from 'rxjs/operators';
8
8
  import { NGXS_DEVTOOLS_OPTIONS } from './symbols';
9
+ /** @enum {string} */
10
+ const ReduxDevtoolsActionType = {
11
+ Dispatch: 'DISPATCH',
12
+ Action: 'ACTION',
13
+ };
14
+ /** @enum {string} */
15
+ const ReduxDevtoolsPayloadType = {
16
+ JumpToAction: 'JUMP_TO_ACTION',
17
+ JumpToState: 'JUMP_TO_STATE',
18
+ ToggleAction: 'TOGGLE_ACTION',
19
+ ImportState: 'IMPORT_STATE',
20
+ };
9
21
  /**
10
22
  * Adds support for the Redux Devtools extension:
11
23
  * http://extension.remotedev.io/
@@ -14,21 +26,26 @@ export class NgxsReduxDevtoolsPlugin {
14
26
  /**
15
27
  * @param {?} _options
16
28
  * @param {?} _injector
29
+ * @param {?} _ngZone
17
30
  */
18
- constructor(_options, _injector) {
31
+ constructor(_options, _injector, _ngZone) {
19
32
  this._options = _options;
20
33
  this._injector = _injector;
34
+ this._ngZone = _ngZone;
21
35
  this.devtoolsExtension = null;
22
- this.windowObj = typeof window !== 'undefined' ? window : {};
23
- /** @type {?} */
24
- const globalDevtools = this.windowObj['__REDUX_DEVTOOLS_EXTENSION__'] || this.windowObj['devToolsExtension'];
25
- if (globalDevtools) {
26
- this.devtoolsExtension = (/** @type {?} */ (globalDevtools.connect(_options)));
27
- this.devtoolsExtension.subscribe((/**
28
- * @param {?} a
29
- * @return {?}
30
- */
31
- a => this.dispatched(a)));
36
+ this.globalDevtools = ɵglobal['__REDUX_DEVTOOLS_EXTENSION__'] || ɵglobal['devToolsExtension'];
37
+ this.unsubscribe = null;
38
+ this.connect();
39
+ }
40
+ /**
41
+ * @return {?}
42
+ */
43
+ ngOnDestroy() {
44
+ if (this.unsubscribe !== null) {
45
+ this.unsubscribe();
46
+ }
47
+ if (this.globalDevtools) {
48
+ this.globalDevtools.disconnect();
32
49
  }
33
50
  }
34
51
  /**
@@ -47,9 +64,7 @@ export class NgxsReduxDevtoolsPlugin {
47
64
  * @return {?}
48
65
  */
49
66
  handle(state, action, next) {
50
- /** @type {?} */
51
- const isDisabled = this._options && this._options.disabled;
52
- if (!this.devtoolsExtension || isDisabled) {
67
+ if (!this.devtoolsExtension || this._options.disabled) {
53
68
  return next(state, action);
54
69
  }
55
70
  return next(state, action).pipe(catchError((/**
@@ -95,17 +110,17 @@ export class NgxsReduxDevtoolsPlugin {
95
110
  * @return {?}
96
111
  */
97
112
  dispatched(action) {
98
- if (action.type === 'DISPATCH') {
99
- if (action.payload.type === 'JUMP_TO_ACTION' ||
100
- action.payload.type === 'JUMP_TO_STATE') {
113
+ if (action.type === "DISPATCH" /* Dispatch */) {
114
+ if (action.payload.type === "JUMP_TO_ACTION" /* JumpToAction */ ||
115
+ action.payload.type === "JUMP_TO_STATE" /* JumpToState */) {
101
116
  /** @type {?} */
102
117
  const prevState = JSON.parse(action.state);
103
118
  this.store.reset(prevState);
104
119
  }
105
- else if (action.payload.type === 'TOGGLE_ACTION') {
120
+ else if (action.payload.type === "TOGGLE_ACTION" /* ToggleAction */) {
106
121
  console.warn('Skip is not supported at this time.');
107
122
  }
108
- else if (action.payload.type === 'IMPORT_STATE') {
123
+ else if (action.payload.type === "IMPORT_STATE" /* ImportState */) {
109
124
  const { actionsById, computedStates, currentStateIndex } = action.payload.nextLiftedState;
110
125
  (/** @type {?} */ (this.devtoolsExtension)).init(computedStates[0].state);
111
126
  Object.keys(actionsById)
@@ -122,12 +137,44 @@ export class NgxsReduxDevtoolsPlugin {
122
137
  this.store.reset(computedStates[currentStateIndex].state);
123
138
  }
124
139
  }
125
- else if (action.type === 'ACTION') {
140
+ else if (action.type === "ACTION" /* Action */) {
126
141
  /** @type {?} */
127
142
  const actionPayload = JSON.parse(action.payload);
128
143
  this.store.dispatch(actionPayload);
129
144
  }
130
145
  }
146
+ /**
147
+ * @private
148
+ * @return {?}
149
+ */
150
+ connect() {
151
+ if (!this.globalDevtools || this._options.disabled) {
152
+ return;
153
+ }
154
+ // The `connect` method adds `message` event listener since it communicates
155
+ // with an extension through `window.postMessage` and message events.
156
+ // We handle only 2 events; thus, we don't want to run many change detections
157
+ // because the extension sends events that we don't have to handle.
158
+ this.devtoolsExtension = this._ngZone.runOutsideAngular((/**
159
+ * @return {?}
160
+ */
161
+ () => (/** @type {?} */ (this.globalDevtools.connect(this._options)))));
162
+ this.unsubscribe = this.devtoolsExtension.subscribe((/**
163
+ * @param {?} action
164
+ * @return {?}
165
+ */
166
+ action => {
167
+ if (action.type === "DISPATCH" /* Dispatch */ ||
168
+ action.type === "ACTION" /* Action */) {
169
+ this._ngZone.run((/**
170
+ * @return {?}
171
+ */
172
+ () => {
173
+ this.dispatched(action);
174
+ }));
175
+ }
176
+ }));
177
+ }
131
178
  }
132
179
  NgxsReduxDevtoolsPlugin.decorators = [
133
180
  { type: Injectable }
@@ -135,7 +182,8 @@ NgxsReduxDevtoolsPlugin.decorators = [
135
182
  /** @nocollapse */
136
183
  NgxsReduxDevtoolsPlugin.ctorParameters = () => [
137
184
  { type: undefined, decorators: [{ type: Inject, args: [NGXS_DEVTOOLS_OPTIONS,] }] },
138
- { type: Injector }
185
+ { type: Injector },
186
+ { type: NgZone }
139
187
  ];
140
188
  if (false) {
141
189
  /**
@@ -147,7 +195,12 @@ if (false) {
147
195
  * @type {?}
148
196
  * @private
149
197
  */
150
- NgxsReduxDevtoolsPlugin.prototype.windowObj;
198
+ NgxsReduxDevtoolsPlugin.prototype.globalDevtools;
199
+ /**
200
+ * @type {?}
201
+ * @private
202
+ */
203
+ NgxsReduxDevtoolsPlugin.prototype.unsubscribe;
151
204
  /**
152
205
  * @type {?}
153
206
  * @private
@@ -158,5 +211,10 @@ if (false) {
158
211
  * @private
159
212
  */
160
213
  NgxsReduxDevtoolsPlugin.prototype._injector;
214
+ /**
215
+ * @type {?}
216
+ * @private
217
+ */
218
+ NgxsReduxDevtoolsPlugin.prototype._ngZone;
161
219
  }
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devtools.plugin.js","sourceRoot":"ng://@ngxs/devtools-plugin/","sources":["src/devtools.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Injector } from '@angular/core';\r\nimport { getActionTypeFromInstance, NgxsNextPluginFn, NgxsPlugin, Store } from '@ngxs/store';\r\nimport { tap, catchError } from 'rxjs/operators';\r\n\r\nimport {\r\n  NGXS_DEVTOOLS_OPTIONS,\r\n  NgxsDevtoolsAction,\r\n  NgxsDevtoolsExtension,\r\n  NgxsDevtoolsOptions\r\n} from './symbols';\r\n\r\n/**\r\n * Adds support for the Redux Devtools extension:\r\n * http://extension.remotedev.io/\r\n */\r\n@Injectable()\r\nexport class NgxsReduxDevtoolsPlugin implements NgxsPlugin {\r\n  private readonly devtoolsExtension: NgxsDevtoolsExtension | null = null;\r\n  private readonly windowObj: any = typeof window !== 'undefined' ? window : {};\r\n\r\n  constructor(\r\n    @Inject(NGXS_DEVTOOLS_OPTIONS) private _options: NgxsDevtoolsOptions,\r\n    private _injector: Injector\r\n  ) {\r\n    const globalDevtools =\r\n      this.windowObj['__REDUX_DEVTOOLS_EXTENSION__'] || this.windowObj['devToolsExtension'];\r\n    if (globalDevtools) {\r\n      this.devtoolsExtension = globalDevtools.connect(_options) as NgxsDevtoolsExtension;\r\n      this.devtoolsExtension.subscribe(a => this.dispatched(a));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Lazy get the store for circular dependency issues\r\n   */\r\n  private get store(): Store {\r\n    return this._injector.get<Store>(Store);\r\n  }\r\n\r\n  /**\r\n   * Middleware handle function\r\n   */\r\n  handle(state: any, action: any, next: NgxsNextPluginFn) {\r\n    const isDisabled = this._options && this._options.disabled;\r\n    if (!this.devtoolsExtension || isDisabled) {\r\n      return next(state, action);\r\n    }\r\n\r\n    return next(state, action).pipe(\r\n      catchError(error => {\r\n        const newState = this.store.snapshot();\r\n        this.sendToDevTools(state, action, newState);\r\n        throw error;\r\n      }),\r\n      tap(newState => {\r\n        this.sendToDevTools(state, action, newState);\r\n      })\r\n    );\r\n  }\r\n\r\n  private sendToDevTools(state: any, action: any, newState: any) {\r\n    const type = getActionTypeFromInstance(action);\r\n    // if init action, send initial state to dev tools\r\n    const isInitAction = type === '@@INIT';\r\n    if (isInitAction) {\r\n      this.devtoolsExtension!.init(state);\r\n    } else {\r\n      this.devtoolsExtension!.send({ ...action, action: null, type }, newState);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle the action from the dev tools subscription\r\n   */\r\n  dispatched(action: NgxsDevtoolsAction) {\r\n    if (action.type === 'DISPATCH') {\r\n      if (\r\n        action.payload.type === 'JUMP_TO_ACTION' ||\r\n        action.payload.type === 'JUMP_TO_STATE'\r\n      ) {\r\n        const prevState = JSON.parse(action.state);\r\n        this.store.reset(prevState);\r\n      } else if (action.payload.type === 'TOGGLE_ACTION') {\r\n        console.warn('Skip is not supported at this time.');\r\n      } else if (action.payload.type === 'IMPORT_STATE') {\r\n        const {\r\n          actionsById,\r\n          computedStates,\r\n          currentStateIndex\r\n        } = action.payload.nextLiftedState;\r\n        this.devtoolsExtension!.init(computedStates[0].state);\r\n        Object.keys(actionsById)\r\n          .filter(actionId => actionId !== '0')\r\n          .forEach(actionId =>\r\n            this.devtoolsExtension!.send(actionsById[actionId], computedStates[actionId].state)\r\n          );\r\n        this.store.reset(computedStates[currentStateIndex].state);\r\n      }\r\n    } else if (action.type === 'ACTION') {\r\n      const actionPayload = JSON.parse(action.payload);\r\n      this.store.dispatch(actionPayload);\r\n    }\r\n  }\r\n}\r\n"]}
220
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devtools.plugin.js","sourceRoot":"ng://@ngxs/devtools-plugin/","sources":["src/devtools.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Injector, NgZone, OnDestroy, ɵglobal } from '@angular/core';\r\nimport { getActionTypeFromInstance, NgxsNextPluginFn, NgxsPlugin, Store } from '@ngxs/store';\r\nimport { tap, catchError } from 'rxjs/operators';\r\n\r\nimport {\r\n  NGXS_DEVTOOLS_OPTIONS,\r\n  NgxsDevtoolsAction,\r\n  NgxsDevtoolsExtension,\r\n  NgxsDevtoolsOptions\r\n} from './symbols';\r\n\r\nconst enum ReduxDevtoolsActionType {\r\n  Dispatch = 'DISPATCH',\r\n  Action = 'ACTION'\r\n}\r\n\r\nconst enum ReduxDevtoolsPayloadType {\r\n  JumpToAction = 'JUMP_TO_ACTION',\r\n  JumpToState = 'JUMP_TO_STATE',\r\n  ToggleAction = 'TOGGLE_ACTION',\r\n  ImportState = 'IMPORT_STATE'\r\n}\r\n\r\n/**\r\n * Adds support for the Redux Devtools extension:\r\n * http://extension.remotedev.io/\r\n */\r\n@Injectable()\r\nexport class NgxsReduxDevtoolsPlugin implements OnDestroy, NgxsPlugin {\r\n  private devtoolsExtension: NgxsDevtoolsExtension | null = null;\r\n  private readonly globalDevtools =\r\n    ɵglobal['__REDUX_DEVTOOLS_EXTENSION__'] || ɵglobal['devToolsExtension'];\r\n\r\n  private unsubscribe: VoidFunction | null = null;\r\n\r\n  constructor(\r\n    @Inject(NGXS_DEVTOOLS_OPTIONS) private _options: NgxsDevtoolsOptions,\r\n    private _injector: Injector,\r\n    private _ngZone: NgZone\r\n  ) {\r\n    this.connect();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.unsubscribe !== null) {\r\n      this.unsubscribe();\r\n    }\r\n    if (this.globalDevtools) {\r\n      this.globalDevtools.disconnect();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Lazy get the store for circular dependency issues\r\n   */\r\n  private get store(): Store {\r\n    return this._injector.get<Store>(Store);\r\n  }\r\n\r\n  /**\r\n   * Middleware handle function\r\n   */\r\n  handle(state: any, action: any, next: NgxsNextPluginFn) {\r\n    if (!this.devtoolsExtension || this._options.disabled) {\r\n      return next(state, action);\r\n    }\r\n\r\n    return next(state, action).pipe(\r\n      catchError(error => {\r\n        const newState = this.store.snapshot();\r\n        this.sendToDevTools(state, action, newState);\r\n        throw error;\r\n      }),\r\n      tap(newState => {\r\n        this.sendToDevTools(state, action, newState);\r\n      })\r\n    );\r\n  }\r\n\r\n  private sendToDevTools(state: any, action: any, newState: any) {\r\n    const type = getActionTypeFromInstance(action);\r\n    // if init action, send initial state to dev tools\r\n    const isInitAction = type === '@@INIT';\r\n    if (isInitAction) {\r\n      this.devtoolsExtension!.init(state);\r\n    } else {\r\n      this.devtoolsExtension!.send({ ...action, action: null, type }, newState);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle the action from the dev tools subscription\r\n   */\r\n  dispatched(action: NgxsDevtoolsAction) {\r\n    if (action.type === ReduxDevtoolsActionType.Dispatch) {\r\n      if (\r\n        action.payload.type === ReduxDevtoolsPayloadType.JumpToAction ||\r\n        action.payload.type === ReduxDevtoolsPayloadType.JumpToState\r\n      ) {\r\n        const prevState = JSON.parse(action.state);\r\n        this.store.reset(prevState);\r\n      } else if (action.payload.type === ReduxDevtoolsPayloadType.ToggleAction) {\r\n        console.warn('Skip is not supported at this time.');\r\n      } else if (action.payload.type === ReduxDevtoolsPayloadType.ImportState) {\r\n        const {\r\n          actionsById,\r\n          computedStates,\r\n          currentStateIndex\r\n        } = action.payload.nextLiftedState;\r\n        this.devtoolsExtension!.init(computedStates[0].state);\r\n        Object.keys(actionsById)\r\n          .filter(actionId => actionId !== '0')\r\n          .forEach(actionId =>\r\n            this.devtoolsExtension!.send(actionsById[actionId], computedStates[actionId].state)\r\n          );\r\n        this.store.reset(computedStates[currentStateIndex].state);\r\n      }\r\n    } else if (action.type === ReduxDevtoolsActionType.Action) {\r\n      const actionPayload = JSON.parse(action.payload);\r\n      this.store.dispatch(actionPayload);\r\n    }\r\n  }\r\n\r\n  private connect(): void {\r\n    if (!this.globalDevtools || this._options.disabled) {\r\n      return;\r\n    }\r\n\r\n    // The `connect` method adds `message` event listener since it communicates\r\n    // with an extension through `window.postMessage` and message events.\r\n    // We handle only 2 events; thus, we don't want to run many change detections\r\n    // because the extension sends events that we don't have to handle.\r\n    this.devtoolsExtension = this._ngZone.runOutsideAngular(\r\n      () => <NgxsDevtoolsExtension>this.globalDevtools.connect(this._options)\r\n    );\r\n\r\n    this.unsubscribe = this.devtoolsExtension.subscribe(action => {\r\n      if (\r\n        action.type === ReduxDevtoolsActionType.Dispatch ||\r\n        action.type === ReduxDevtoolsActionType.Action\r\n      ) {\r\n        this._ngZone.run(() => {\r\n          this.dispatched(action);\r\n        });\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
@@ -75,4 +75,4 @@ if (false) {
75
75
  }
76
76
  /** @type {?} */
77
77
  export const NGXS_DEVTOOLS_OPTIONS = new InjectionToken('NGXS_DEVTOOLS_OPTIONS');
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL2RldnRvb2xzLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zeW1ib2xzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQU0vQywyQ0FJQzs7Ozs7O0lBSEMsNERBQXVCOzs7Ozs7SUFDdkIsb0VBQXFDOzs7OztJQUNyQyw4REFBbUU7Ozs7O0FBR3JFLHdDQU1DOzs7SUFMQyxrQ0FBYTs7SUFDYixxQ0FBYTs7SUFDYixtQ0FBVzs7SUFDWCxnQ0FBVzs7SUFDWCxvQ0FBZTs7Ozs7QUFHakIseUNBeUJDOzs7Ozs7SUFyQkMsbUNBQWM7Ozs7O0lBS2QsdUNBQW1COzs7OztJQUtuQixxQ0FBZ0I7Ozs7O0lBS2hCLDhDQUF3Qzs7Ozs7SUFLeEMsNkNBQXNDOzs7QUFHeEMsTUFBTSxPQUFPLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFDLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcblxyXG4vKipcclxuICogSW50ZXJmYWNlIGZvciB0aGUgcmVkdXgtZGV2dG9vbHMtZXh0ZW5zaW9uIEFQSS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgTmd4c0RldnRvb2xzRXh0ZW5zaW9uIHtcclxuICBpbml0KHN0YXRlOiBhbnkpOiB2b2lkO1xyXG4gIHNlbmQoYWN0aW9uOiBhbnksIHN0YXRlPzogYW55KTogdm9pZDtcclxuICBzdWJzY3JpYmUoZm46IChtZXNzYWdlOiBOZ3hzRGV2dG9vbHNBY3Rpb24pID0+IHZvaWQpOiBTdWJzY3JpcHRpb247XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTmd4c0RldnRvb2xzQWN0aW9uIHtcclxuICB0eXBlOiBzdHJpbmc7XHJcbiAgcGF5bG9hZDogYW55O1xyXG4gIHN0YXRlOiBhbnk7XHJcbiAgaWQ6IG51bWJlcjtcclxuICBzb3VyY2U6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNPcHRpb25zIHtcclxuICAvKipcclxuICAgKiBUaGUgbmFtZSBvZiB0aGUgZXh0ZW5zaW9uXHJcbiAgICovXHJcbiAgbmFtZT86IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogV2hldGhlciB0aGUgZGV2IHRvb2xzIGlzIGVuYWJsZWQgb3Igbm90ZS4gVXNlZnVsIGZvciBzZXR0aW5nIGR1cmluZyBwcm9kdWN0aW9uLlxyXG4gICAqL1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqXHJcbiAgICogTWF4IG51bWJlciBvZiBlbnRpcmllcyB0byBrZWVwLlxyXG4gICAqL1xyXG4gIG1heEFnZT86IG51bWJlcjtcclxuXHJcbiAgLyoqXHJcbiAgICogUmVmb3JtYXQgYWN0aW9ucyBiZWZvcmUgc2VuZGluZyB0byBkZXYgdG9vbHNcclxuICAgKi9cclxuICBhY3Rpb25TYW5pdGl6ZXI/OiAoYWN0aW9uOiBhbnkpID0+IHZvaWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIFJlZm9ybWF0IHN0YXRlIGJlZm9yZSBzZW5kaW5nIHRvIGRldnRvb2xzXHJcbiAgICovXHJcbiAgc3RhdGVTYW5pdGl6ZXI/OiAoc3RhdGU6IGFueSkgPT4gdm9pZDtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IE5HWFNfREVWVE9PTFNfT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbignTkdYU19ERVZUT09MU19PUFRJT05TJyk7XHJcbiJdfQ==
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL2RldnRvb2xzLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zeW1ib2xzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQUsvQywyQ0FJQzs7Ozs7O0lBSEMsNERBQXVCOzs7Ozs7SUFDdkIsb0VBQXFDOzs7OztJQUNyQyw4REFBbUU7Ozs7O0FBR3JFLHdDQU1DOzs7SUFMQyxrQ0FBYTs7SUFDYixxQ0FBYTs7SUFDYixtQ0FBVzs7SUFDWCxnQ0FBVzs7SUFDWCxvQ0FBZTs7Ozs7QUFHakIseUNBeUJDOzs7Ozs7SUFyQkMsbUNBQWM7Ozs7O0lBS2QsdUNBQW1COzs7OztJQUtuQixxQ0FBZ0I7Ozs7O0lBS2hCLDhDQUF3Qzs7Ozs7SUFLeEMsNkNBQXNDOzs7QUFHeEMsTUFBTSxPQUFPLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFDLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBJbnRlcmZhY2UgZm9yIHRoZSByZWR1eC1kZXZ0b29scy1leHRlbnNpb24gQVBJLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNFeHRlbnNpb24ge1xyXG4gIGluaXQoc3RhdGU6IGFueSk6IHZvaWQ7XHJcbiAgc2VuZChhY3Rpb246IGFueSwgc3RhdGU/OiBhbnkpOiB2b2lkO1xyXG4gIHN1YnNjcmliZShmbjogKG1lc3NhZ2U6IE5neHNEZXZ0b29sc0FjdGlvbikgPT4gdm9pZCk6IFZvaWRGdW5jdGlvbjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNBY3Rpb24ge1xyXG4gIHR5cGU6IHN0cmluZztcclxuICBwYXlsb2FkOiBhbnk7XHJcbiAgc3RhdGU6IGFueTtcclxuICBpZDogbnVtYmVyO1xyXG4gIHNvdXJjZTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE5neHNEZXZ0b29sc09wdGlvbnMge1xyXG4gIC8qKlxyXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBleHRlbnNpb25cclxuICAgKi9cclxuICBuYW1lPzogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBXaGV0aGVyIHRoZSBkZXYgdG9vbHMgaXMgZW5hYmxlZCBvciBub3RlLiBVc2VmdWwgZm9yIHNldHRpbmcgZHVyaW5nIHByb2R1Y3Rpb24uXHJcbiAgICovXHJcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBNYXggbnVtYmVyIG9mIGVudGlyaWVzIHRvIGtlZXAuXHJcbiAgICovXHJcbiAgbWF4QWdlPzogbnVtYmVyO1xyXG5cclxuICAvKipcclxuICAgKiBSZWZvcm1hdCBhY3Rpb25zIGJlZm9yZSBzZW5kaW5nIHRvIGRldiB0b29sc1xyXG4gICAqL1xyXG4gIGFjdGlvblNhbml0aXplcj86IChhY3Rpb246IGFueSkgPT4gdm9pZDtcclxuXHJcbiAgLyoqXHJcbiAgICogUmVmb3JtYXQgc3RhdGUgYmVmb3JlIHNlbmRpbmcgdG8gZGV2dG9vbHNcclxuICAgKi9cclxuICBzdGF0ZVNhbml0aXplcj86IChzdGF0ZTogYW55KSA9PiB2b2lkO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgTkdYU19ERVZUT09MU19PUFRJT05TID0gbmV3IEluamVjdGlvblRva2VuKCdOR1hTX0RFVlRPT0xTX09QVElPTlMnKTtcclxuIl19
@@ -3,32 +3,50 @@
3
3
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
4
  */
5
5
  import * as tslib_1 from "tslib";
6
- import { Inject, Injectable, Injector } from '@angular/core';
6
+ import { Inject, Injectable, Injector, NgZone, ɵglobal } from '@angular/core';
7
7
  import { getActionTypeFromInstance, Store } from '@ngxs/store';
8
8
  import { tap, catchError } from 'rxjs/operators';
9
9
  import { NGXS_DEVTOOLS_OPTIONS } from './symbols';
10
+ /** @enum {string} */
11
+ var ReduxDevtoolsActionType = {
12
+ Dispatch: 'DISPATCH',
13
+ Action: 'ACTION',
14
+ };
15
+ /** @enum {string} */
16
+ var ReduxDevtoolsPayloadType = {
17
+ JumpToAction: 'JUMP_TO_ACTION',
18
+ JumpToState: 'JUMP_TO_STATE',
19
+ ToggleAction: 'TOGGLE_ACTION',
20
+ ImportState: 'IMPORT_STATE',
21
+ };
10
22
  /**
11
23
  * Adds support for the Redux Devtools extension:
12
24
  * http://extension.remotedev.io/
13
25
  */
14
26
  var NgxsReduxDevtoolsPlugin = /** @class */ (function () {
15
- function NgxsReduxDevtoolsPlugin(_options, _injector) {
16
- var _this = this;
27
+ function NgxsReduxDevtoolsPlugin(_options, _injector, _ngZone) {
17
28
  this._options = _options;
18
29
  this._injector = _injector;
30
+ this._ngZone = _ngZone;
19
31
  this.devtoolsExtension = null;
20
- this.windowObj = typeof window !== 'undefined' ? window : {};
21
- /** @type {?} */
22
- var globalDevtools = this.windowObj['__REDUX_DEVTOOLS_EXTENSION__'] || this.windowObj['devToolsExtension'];
23
- if (globalDevtools) {
24
- this.devtoolsExtension = (/** @type {?} */ (globalDevtools.connect(_options)));
25
- this.devtoolsExtension.subscribe((/**
26
- * @param {?} a
27
- * @return {?}
28
- */
29
- function (a) { return _this.dispatched(a); }));
30
- }
32
+ this.globalDevtools = ɵglobal['__REDUX_DEVTOOLS_EXTENSION__'] || ɵglobal['devToolsExtension'];
33
+ this.unsubscribe = null;
34
+ this.connect();
31
35
  }
36
+ /**
37
+ * @return {?}
38
+ */
39
+ NgxsReduxDevtoolsPlugin.prototype.ngOnDestroy = /**
40
+ * @return {?}
41
+ */
42
+ function () {
43
+ if (this.unsubscribe !== null) {
44
+ this.unsubscribe();
45
+ }
46
+ if (this.globalDevtools) {
47
+ this.globalDevtools.disconnect();
48
+ }
49
+ };
32
50
  Object.defineProperty(NgxsReduxDevtoolsPlugin.prototype, "store", {
33
51
  /**
34
52
  * Lazy get the store for circular dependency issues
@@ -63,9 +81,7 @@ var NgxsReduxDevtoolsPlugin = /** @class */ (function () {
63
81
  */
64
82
  function (state, action, next) {
65
83
  var _this = this;
66
- /** @type {?} */
67
- var isDisabled = this._options && this._options.disabled;
68
- if (!this.devtoolsExtension || isDisabled) {
84
+ if (!this.devtoolsExtension || this._options.disabled) {
69
85
  return next(state, action);
70
86
  }
71
87
  return next(state, action).pipe(catchError((/**
@@ -127,17 +143,17 @@ var NgxsReduxDevtoolsPlugin = /** @class */ (function () {
127
143
  */
128
144
  function (action) {
129
145
  var _this = this;
130
- if (action.type === 'DISPATCH') {
131
- if (action.payload.type === 'JUMP_TO_ACTION' ||
132
- action.payload.type === 'JUMP_TO_STATE') {
146
+ if (action.type === "DISPATCH" /* Dispatch */) {
147
+ if (action.payload.type === "JUMP_TO_ACTION" /* JumpToAction */ ||
148
+ action.payload.type === "JUMP_TO_STATE" /* JumpToState */) {
133
149
  /** @type {?} */
134
150
  var prevState = JSON.parse(action.state);
135
151
  this.store.reset(prevState);
136
152
  }
137
- else if (action.payload.type === 'TOGGLE_ACTION') {
153
+ else if (action.payload.type === "TOGGLE_ACTION" /* ToggleAction */) {
138
154
  console.warn('Skip is not supported at this time.');
139
155
  }
140
- else if (action.payload.type === 'IMPORT_STATE') {
156
+ else if (action.payload.type === "IMPORT_STATE" /* ImportState */) {
141
157
  var _a = action.payload.nextLiftedState, actionsById_1 = _a.actionsById, computedStates_1 = _a.computedStates, currentStateIndex = _a.currentStateIndex;
142
158
  (/** @type {?} */ (this.devtoolsExtension)).init(computedStates_1[0].state);
143
159
  Object.keys(actionsById_1)
@@ -156,19 +172,57 @@ var NgxsReduxDevtoolsPlugin = /** @class */ (function () {
156
172
  this.store.reset(computedStates_1[currentStateIndex].state);
157
173
  }
158
174
  }
159
- else if (action.type === 'ACTION') {
175
+ else if (action.type === "ACTION" /* Action */) {
160
176
  /** @type {?} */
161
177
  var actionPayload = JSON.parse(action.payload);
162
178
  this.store.dispatch(actionPayload);
163
179
  }
164
180
  };
181
+ /**
182
+ * @private
183
+ * @return {?}
184
+ */
185
+ NgxsReduxDevtoolsPlugin.prototype.connect = /**
186
+ * @private
187
+ * @return {?}
188
+ */
189
+ function () {
190
+ var _this = this;
191
+ if (!this.globalDevtools || this._options.disabled) {
192
+ return;
193
+ }
194
+ // The `connect` method adds `message` event listener since it communicates
195
+ // with an extension through `window.postMessage` and message events.
196
+ // We handle only 2 events; thus, we don't want to run many change detections
197
+ // because the extension sends events that we don't have to handle.
198
+ this.devtoolsExtension = this._ngZone.runOutsideAngular((/**
199
+ * @return {?}
200
+ */
201
+ function () { return (/** @type {?} */ (_this.globalDevtools.connect(_this._options))); }));
202
+ this.unsubscribe = this.devtoolsExtension.subscribe((/**
203
+ * @param {?} action
204
+ * @return {?}
205
+ */
206
+ function (action) {
207
+ if (action.type === "DISPATCH" /* Dispatch */ ||
208
+ action.type === "ACTION" /* Action */) {
209
+ _this._ngZone.run((/**
210
+ * @return {?}
211
+ */
212
+ function () {
213
+ _this.dispatched(action);
214
+ }));
215
+ }
216
+ }));
217
+ };
165
218
  NgxsReduxDevtoolsPlugin.decorators = [
166
219
  { type: Injectable }
167
220
  ];
168
221
  /** @nocollapse */
169
222
  NgxsReduxDevtoolsPlugin.ctorParameters = function () { return [
170
223
  { type: undefined, decorators: [{ type: Inject, args: [NGXS_DEVTOOLS_OPTIONS,] }] },
171
- { type: Injector }
224
+ { type: Injector },
225
+ { type: NgZone }
172
226
  ]; };
173
227
  return NgxsReduxDevtoolsPlugin;
174
228
  }());
@@ -183,7 +237,12 @@ if (false) {
183
237
  * @type {?}
184
238
  * @private
185
239
  */
186
- NgxsReduxDevtoolsPlugin.prototype.windowObj;
240
+ NgxsReduxDevtoolsPlugin.prototype.globalDevtools;
241
+ /**
242
+ * @type {?}
243
+ * @private
244
+ */
245
+ NgxsReduxDevtoolsPlugin.prototype.unsubscribe;
187
246
  /**
188
247
  * @type {?}
189
248
  * @private
@@ -194,5 +253,10 @@ if (false) {
194
253
  * @private
195
254
  */
196
255
  NgxsReduxDevtoolsPlugin.prototype._injector;
256
+ /**
257
+ * @type {?}
258
+ * @private
259
+ */
260
+ NgxsReduxDevtoolsPlugin.prototype._ngZone;
197
261
  }
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devtools.plugin.js","sourceRoot":"ng://@ngxs/devtools-plugin/","sources":["src/devtools.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Injector } from '@angular/core';\r\nimport { getActionTypeFromInstance, NgxsNextPluginFn, NgxsPlugin, Store } from '@ngxs/store';\r\nimport { tap, catchError } from 'rxjs/operators';\r\n\r\nimport {\r\n  NGXS_DEVTOOLS_OPTIONS,\r\n  NgxsDevtoolsAction,\r\n  NgxsDevtoolsExtension,\r\n  NgxsDevtoolsOptions\r\n} from './symbols';\r\n\r\n/**\r\n * Adds support for the Redux Devtools extension:\r\n * http://extension.remotedev.io/\r\n */\r\n@Injectable()\r\nexport class NgxsReduxDevtoolsPlugin implements NgxsPlugin {\r\n  private readonly devtoolsExtension: NgxsDevtoolsExtension | null = null;\r\n  private readonly windowObj: any = typeof window !== 'undefined' ? window : {};\r\n\r\n  constructor(\r\n    @Inject(NGXS_DEVTOOLS_OPTIONS) private _options: NgxsDevtoolsOptions,\r\n    private _injector: Injector\r\n  ) {\r\n    const globalDevtools =\r\n      this.windowObj['__REDUX_DEVTOOLS_EXTENSION__'] || this.windowObj['devToolsExtension'];\r\n    if (globalDevtools) {\r\n      this.devtoolsExtension = globalDevtools.connect(_options) as NgxsDevtoolsExtension;\r\n      this.devtoolsExtension.subscribe(a => this.dispatched(a));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Lazy get the store for circular dependency issues\r\n   */\r\n  private get store(): Store {\r\n    return this._injector.get<Store>(Store);\r\n  }\r\n\r\n  /**\r\n   * Middleware handle function\r\n   */\r\n  handle(state: any, action: any, next: NgxsNextPluginFn) {\r\n    const isDisabled = this._options && this._options.disabled;\r\n    if (!this.devtoolsExtension || isDisabled) {\r\n      return next(state, action);\r\n    }\r\n\r\n    return next(state, action).pipe(\r\n      catchError(error => {\r\n        const newState = this.store.snapshot();\r\n        this.sendToDevTools(state, action, newState);\r\n        throw error;\r\n      }),\r\n      tap(newState => {\r\n        this.sendToDevTools(state, action, newState);\r\n      })\r\n    );\r\n  }\r\n\r\n  private sendToDevTools(state: any, action: any, newState: any) {\r\n    const type = getActionTypeFromInstance(action);\r\n    // if init action, send initial state to dev tools\r\n    const isInitAction = type === '@@INIT';\r\n    if (isInitAction) {\r\n      this.devtoolsExtension!.init(state);\r\n    } else {\r\n      this.devtoolsExtension!.send({ ...action, action: null, type }, newState);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle the action from the dev tools subscription\r\n   */\r\n  dispatched(action: NgxsDevtoolsAction) {\r\n    if (action.type === 'DISPATCH') {\r\n      if (\r\n        action.payload.type === 'JUMP_TO_ACTION' ||\r\n        action.payload.type === 'JUMP_TO_STATE'\r\n      ) {\r\n        const prevState = JSON.parse(action.state);\r\n        this.store.reset(prevState);\r\n      } else if (action.payload.type === 'TOGGLE_ACTION') {\r\n        console.warn('Skip is not supported at this time.');\r\n      } else if (action.payload.type === 'IMPORT_STATE') {\r\n        const {\r\n          actionsById,\r\n          computedStates,\r\n          currentStateIndex\r\n        } = action.payload.nextLiftedState;\r\n        this.devtoolsExtension!.init(computedStates[0].state);\r\n        Object.keys(actionsById)\r\n          .filter(actionId => actionId !== '0')\r\n          .forEach(actionId =>\r\n            this.devtoolsExtension!.send(actionsById[actionId], computedStates[actionId].state)\r\n          );\r\n        this.store.reset(computedStates[currentStateIndex].state);\r\n      }\r\n    } else if (action.type === 'ACTION') {\r\n      const actionPayload = JSON.parse(action.payload);\r\n      this.store.dispatch(actionPayload);\r\n    }\r\n  }\r\n}\r\n"]}
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devtools.plugin.js","sourceRoot":"ng://@ngxs/devtools-plugin/","sources":["src/devtools.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Injector, NgZone, OnDestroy, ɵglobal } from '@angular/core';\r\nimport { getActionTypeFromInstance, NgxsNextPluginFn, NgxsPlugin, Store } from '@ngxs/store';\r\nimport { tap, catchError } from 'rxjs/operators';\r\n\r\nimport {\r\n  NGXS_DEVTOOLS_OPTIONS,\r\n  NgxsDevtoolsAction,\r\n  NgxsDevtoolsExtension,\r\n  NgxsDevtoolsOptions\r\n} from './symbols';\r\n\r\nconst enum ReduxDevtoolsActionType {\r\n  Dispatch = 'DISPATCH',\r\n  Action = 'ACTION'\r\n}\r\n\r\nconst enum ReduxDevtoolsPayloadType {\r\n  JumpToAction = 'JUMP_TO_ACTION',\r\n  JumpToState = 'JUMP_TO_STATE',\r\n  ToggleAction = 'TOGGLE_ACTION',\r\n  ImportState = 'IMPORT_STATE'\r\n}\r\n\r\n/**\r\n * Adds support for the Redux Devtools extension:\r\n * http://extension.remotedev.io/\r\n */\r\n@Injectable()\r\nexport class NgxsReduxDevtoolsPlugin implements OnDestroy, NgxsPlugin {\r\n  private devtoolsExtension: NgxsDevtoolsExtension | null = null;\r\n  private readonly globalDevtools =\r\n    ɵglobal['__REDUX_DEVTOOLS_EXTENSION__'] || ɵglobal['devToolsExtension'];\r\n\r\n  private unsubscribe: VoidFunction | null = null;\r\n\r\n  constructor(\r\n    @Inject(NGXS_DEVTOOLS_OPTIONS) private _options: NgxsDevtoolsOptions,\r\n    private _injector: Injector,\r\n    private _ngZone: NgZone\r\n  ) {\r\n    this.connect();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.unsubscribe !== null) {\r\n      this.unsubscribe();\r\n    }\r\n    if (this.globalDevtools) {\r\n      this.globalDevtools.disconnect();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Lazy get the store for circular dependency issues\r\n   */\r\n  private get store(): Store {\r\n    return this._injector.get<Store>(Store);\r\n  }\r\n\r\n  /**\r\n   * Middleware handle function\r\n   */\r\n  handle(state: any, action: any, next: NgxsNextPluginFn) {\r\n    if (!this.devtoolsExtension || this._options.disabled) {\r\n      return next(state, action);\r\n    }\r\n\r\n    return next(state, action).pipe(\r\n      catchError(error => {\r\n        const newState = this.store.snapshot();\r\n        this.sendToDevTools(state, action, newState);\r\n        throw error;\r\n      }),\r\n      tap(newState => {\r\n        this.sendToDevTools(state, action, newState);\r\n      })\r\n    );\r\n  }\r\n\r\n  private sendToDevTools(state: any, action: any, newState: any) {\r\n    const type = getActionTypeFromInstance(action);\r\n    // if init action, send initial state to dev tools\r\n    const isInitAction = type === '@@INIT';\r\n    if (isInitAction) {\r\n      this.devtoolsExtension!.init(state);\r\n    } else {\r\n      this.devtoolsExtension!.send({ ...action, action: null, type }, newState);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle the action from the dev tools subscription\r\n   */\r\n  dispatched(action: NgxsDevtoolsAction) {\r\n    if (action.type === ReduxDevtoolsActionType.Dispatch) {\r\n      if (\r\n        action.payload.type === ReduxDevtoolsPayloadType.JumpToAction ||\r\n        action.payload.type === ReduxDevtoolsPayloadType.JumpToState\r\n      ) {\r\n        const prevState = JSON.parse(action.state);\r\n        this.store.reset(prevState);\r\n      } else if (action.payload.type === ReduxDevtoolsPayloadType.ToggleAction) {\r\n        console.warn('Skip is not supported at this time.');\r\n      } else if (action.payload.type === ReduxDevtoolsPayloadType.ImportState) {\r\n        const {\r\n          actionsById,\r\n          computedStates,\r\n          currentStateIndex\r\n        } = action.payload.nextLiftedState;\r\n        this.devtoolsExtension!.init(computedStates[0].state);\r\n        Object.keys(actionsById)\r\n          .filter(actionId => actionId !== '0')\r\n          .forEach(actionId =>\r\n            this.devtoolsExtension!.send(actionsById[actionId], computedStates[actionId].state)\r\n          );\r\n        this.store.reset(computedStates[currentStateIndex].state);\r\n      }\r\n    } else if (action.type === ReduxDevtoolsActionType.Action) {\r\n      const actionPayload = JSON.parse(action.payload);\r\n      this.store.dispatch(actionPayload);\r\n    }\r\n  }\r\n\r\n  private connect(): void {\r\n    if (!this.globalDevtools || this._options.disabled) {\r\n      return;\r\n    }\r\n\r\n    // The `connect` method adds `message` event listener since it communicates\r\n    // with an extension through `window.postMessage` and message events.\r\n    // We handle only 2 events; thus, we don't want to run many change detections\r\n    // because the extension sends events that we don't have to handle.\r\n    this.devtoolsExtension = this._ngZone.runOutsideAngular(\r\n      () => <NgxsDevtoolsExtension>this.globalDevtools.connect(this._options)\r\n    );\r\n\r\n    this.unsubscribe = this.devtoolsExtension.subscribe(action => {\r\n      if (\r\n        action.type === ReduxDevtoolsActionType.Dispatch ||\r\n        action.type === ReduxDevtoolsActionType.Action\r\n      ) {\r\n        this._ngZone.run(() => {\r\n          this.dispatched(action);\r\n        });\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
@@ -75,4 +75,4 @@ if (false) {
75
75
  }
76
76
  /** @type {?} */
77
77
  export var NGXS_DEVTOOLS_OPTIONS = new InjectionToken('NGXS_DEVTOOLS_OPTIONS');
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL2RldnRvb2xzLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zeW1ib2xzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQU0vQywyQ0FJQzs7Ozs7O0lBSEMsNERBQXVCOzs7Ozs7SUFDdkIsb0VBQXFDOzs7OztJQUNyQyw4REFBbUU7Ozs7O0FBR3JFLHdDQU1DOzs7SUFMQyxrQ0FBYTs7SUFDYixxQ0FBYTs7SUFDYixtQ0FBVzs7SUFDWCxnQ0FBVzs7SUFDWCxvQ0FBZTs7Ozs7QUFHakIseUNBeUJDOzs7Ozs7SUFyQkMsbUNBQWM7Ozs7O0lBS2QsdUNBQW1COzs7OztJQUtuQixxQ0FBZ0I7Ozs7O0lBS2hCLDhDQUF3Qzs7Ozs7SUFLeEMsNkNBQXNDOzs7QUFHeEMsTUFBTSxLQUFPLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFDLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcblxyXG4vKipcclxuICogSW50ZXJmYWNlIGZvciB0aGUgcmVkdXgtZGV2dG9vbHMtZXh0ZW5zaW9uIEFQSS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgTmd4c0RldnRvb2xzRXh0ZW5zaW9uIHtcclxuICBpbml0KHN0YXRlOiBhbnkpOiB2b2lkO1xyXG4gIHNlbmQoYWN0aW9uOiBhbnksIHN0YXRlPzogYW55KTogdm9pZDtcclxuICBzdWJzY3JpYmUoZm46IChtZXNzYWdlOiBOZ3hzRGV2dG9vbHNBY3Rpb24pID0+IHZvaWQpOiBTdWJzY3JpcHRpb247XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTmd4c0RldnRvb2xzQWN0aW9uIHtcclxuICB0eXBlOiBzdHJpbmc7XHJcbiAgcGF5bG9hZDogYW55O1xyXG4gIHN0YXRlOiBhbnk7XHJcbiAgaWQ6IG51bWJlcjtcclxuICBzb3VyY2U6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNPcHRpb25zIHtcclxuICAvKipcclxuICAgKiBUaGUgbmFtZSBvZiB0aGUgZXh0ZW5zaW9uXHJcbiAgICovXHJcbiAgbmFtZT86IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogV2hldGhlciB0aGUgZGV2IHRvb2xzIGlzIGVuYWJsZWQgb3Igbm90ZS4gVXNlZnVsIGZvciBzZXR0aW5nIGR1cmluZyBwcm9kdWN0aW9uLlxyXG4gICAqL1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqXHJcbiAgICogTWF4IG51bWJlciBvZiBlbnRpcmllcyB0byBrZWVwLlxyXG4gICAqL1xyXG4gIG1heEFnZT86IG51bWJlcjtcclxuXHJcbiAgLyoqXHJcbiAgICogUmVmb3JtYXQgYWN0aW9ucyBiZWZvcmUgc2VuZGluZyB0byBkZXYgdG9vbHNcclxuICAgKi9cclxuICBhY3Rpb25TYW5pdGl6ZXI/OiAoYWN0aW9uOiBhbnkpID0+IHZvaWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIFJlZm9ybWF0IHN0YXRlIGJlZm9yZSBzZW5kaW5nIHRvIGRldnRvb2xzXHJcbiAgICovXHJcbiAgc3RhdGVTYW5pdGl6ZXI/OiAoc3RhdGU6IGFueSkgPT4gdm9pZDtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IE5HWFNfREVWVE9PTFNfT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbignTkdYU19ERVZUT09MU19PUFRJT05TJyk7XHJcbiJdfQ==
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL2RldnRvb2xzLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zeW1ib2xzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQUsvQywyQ0FJQzs7Ozs7O0lBSEMsNERBQXVCOzs7Ozs7SUFDdkIsb0VBQXFDOzs7OztJQUNyQyw4REFBbUU7Ozs7O0FBR3JFLHdDQU1DOzs7SUFMQyxrQ0FBYTs7SUFDYixxQ0FBYTs7SUFDYixtQ0FBVzs7SUFDWCxnQ0FBVzs7SUFDWCxvQ0FBZTs7Ozs7QUFHakIseUNBeUJDOzs7Ozs7SUFyQkMsbUNBQWM7Ozs7O0lBS2QsdUNBQW1COzs7OztJQUtuQixxQ0FBZ0I7Ozs7O0lBS2hCLDhDQUF3Qzs7Ozs7SUFLeEMsNkNBQXNDOzs7QUFHeEMsTUFBTSxLQUFPLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFDLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBJbnRlcmZhY2UgZm9yIHRoZSByZWR1eC1kZXZ0b29scy1leHRlbnNpb24gQVBJLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNFeHRlbnNpb24ge1xyXG4gIGluaXQoc3RhdGU6IGFueSk6IHZvaWQ7XHJcbiAgc2VuZChhY3Rpb246IGFueSwgc3RhdGU/OiBhbnkpOiB2b2lkO1xyXG4gIHN1YnNjcmliZShmbjogKG1lc3NhZ2U6IE5neHNEZXZ0b29sc0FjdGlvbikgPT4gdm9pZCk6IFZvaWRGdW5jdGlvbjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBOZ3hzRGV2dG9vbHNBY3Rpb24ge1xyXG4gIHR5cGU6IHN0cmluZztcclxuICBwYXlsb2FkOiBhbnk7XHJcbiAgc3RhdGU6IGFueTtcclxuICBpZDogbnVtYmVyO1xyXG4gIHNvdXJjZTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE5neHNEZXZ0b29sc09wdGlvbnMge1xyXG4gIC8qKlxyXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBleHRlbnNpb25cclxuICAgKi9cclxuICBuYW1lPzogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBXaGV0aGVyIHRoZSBkZXYgdG9vbHMgaXMgZW5hYmxlZCBvciBub3RlLiBVc2VmdWwgZm9yIHNldHRpbmcgZHVyaW5nIHByb2R1Y3Rpb24uXHJcbiAgICovXHJcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBNYXggbnVtYmVyIG9mIGVudGlyaWVzIHRvIGtlZXAuXHJcbiAgICovXHJcbiAgbWF4QWdlPzogbnVtYmVyO1xyXG5cclxuICAvKipcclxuICAgKiBSZWZvcm1hdCBhY3Rpb25zIGJlZm9yZSBzZW5kaW5nIHRvIGRldiB0b29sc1xyXG4gICAqL1xyXG4gIGFjdGlvblNhbml0aXplcj86IChhY3Rpb246IGFueSkgPT4gdm9pZDtcclxuXHJcbiAgLyoqXHJcbiAgICogUmVmb3JtYXQgc3RhdGUgYmVmb3JlIHNlbmRpbmcgdG8gZGV2dG9vbHNcclxuICAgKi9cclxuICBzdGF0ZVNhbml0aXplcj86IChzdGF0ZTogYW55KSA9PiB2b2lkO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgTkdYU19ERVZUT09MU19PUFRJT05TID0gbmV3IEluamVjdGlvblRva2VuKCdOR1hTX0RFVlRPT0xTX09QVElPTlMnKTtcclxuIl19
@@ -1,4 +1,4 @@
1
- import { InjectionToken, Injectable, Inject, Injector, NgModule } from '@angular/core';
1
+ import { InjectionToken, ɵglobal, Injectable, Inject, Injector, NgZone, NgModule } from '@angular/core';
2
2
  import { Store, getActionTypeFromInstance, NGXS_PLUGINS } from '@ngxs/store';
3
3
  import { catchError, tap } from 'rxjs/operators';
4
4
 
@@ -83,6 +83,18 @@ const NGXS_DEVTOOLS_OPTIONS = new InjectionToken('NGXS_DEVTOOLS_OPTIONS');
83
83
  * @fileoverview added by tsickle
84
84
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
85
85
  */
86
+ /** @enum {string} */
87
+ const ReduxDevtoolsActionType = {
88
+ Dispatch: 'DISPATCH',
89
+ Action: 'ACTION',
90
+ };
91
+ /** @enum {string} */
92
+ const ReduxDevtoolsPayloadType = {
93
+ JumpToAction: 'JUMP_TO_ACTION',
94
+ JumpToState: 'JUMP_TO_STATE',
95
+ ToggleAction: 'TOGGLE_ACTION',
96
+ ImportState: 'IMPORT_STATE',
97
+ };
86
98
  /**
87
99
  * Adds support for the Redux Devtools extension:
88
100
  * http://extension.remotedev.io/
@@ -91,21 +103,26 @@ class NgxsReduxDevtoolsPlugin {
91
103
  /**
92
104
  * @param {?} _options
93
105
  * @param {?} _injector
106
+ * @param {?} _ngZone
94
107
  */
95
- constructor(_options, _injector) {
108
+ constructor(_options, _injector, _ngZone) {
96
109
  this._options = _options;
97
110
  this._injector = _injector;
111
+ this._ngZone = _ngZone;
98
112
  this.devtoolsExtension = null;
99
- this.windowObj = typeof window !== 'undefined' ? window : {};
100
- /** @type {?} */
101
- const globalDevtools = this.windowObj['__REDUX_DEVTOOLS_EXTENSION__'] || this.windowObj['devToolsExtension'];
102
- if (globalDevtools) {
103
- this.devtoolsExtension = (/** @type {?} */ (globalDevtools.connect(_options)));
104
- this.devtoolsExtension.subscribe((/**
105
- * @param {?} a
106
- * @return {?}
107
- */
108
- a => this.dispatched(a)));
113
+ this.globalDevtools = ɵglobal['__REDUX_DEVTOOLS_EXTENSION__'] || ɵglobal['devToolsExtension'];
114
+ this.unsubscribe = null;
115
+ this.connect();
116
+ }
117
+ /**
118
+ * @return {?}
119
+ */
120
+ ngOnDestroy() {
121
+ if (this.unsubscribe !== null) {
122
+ this.unsubscribe();
123
+ }
124
+ if (this.globalDevtools) {
125
+ this.globalDevtools.disconnect();
109
126
  }
110
127
  }
111
128
  /**
@@ -124,9 +141,7 @@ class NgxsReduxDevtoolsPlugin {
124
141
  * @return {?}
125
142
  */
126
143
  handle(state, action, next) {
127
- /** @type {?} */
128
- const isDisabled = this._options && this._options.disabled;
129
- if (!this.devtoolsExtension || isDisabled) {
144
+ if (!this.devtoolsExtension || this._options.disabled) {
130
145
  return next(state, action);
131
146
  }
132
147
  return next(state, action).pipe(catchError((/**
@@ -172,17 +187,17 @@ class NgxsReduxDevtoolsPlugin {
172
187
  * @return {?}
173
188
  */
174
189
  dispatched(action) {
175
- if (action.type === 'DISPATCH') {
176
- if (action.payload.type === 'JUMP_TO_ACTION' ||
177
- action.payload.type === 'JUMP_TO_STATE') {
190
+ if (action.type === "DISPATCH" /* Dispatch */) {
191
+ if (action.payload.type === "JUMP_TO_ACTION" /* JumpToAction */ ||
192
+ action.payload.type === "JUMP_TO_STATE" /* JumpToState */) {
178
193
  /** @type {?} */
179
194
  const prevState = JSON.parse(action.state);
180
195
  this.store.reset(prevState);
181
196
  }
182
- else if (action.payload.type === 'TOGGLE_ACTION') {
197
+ else if (action.payload.type === "TOGGLE_ACTION" /* ToggleAction */) {
183
198
  console.warn('Skip is not supported at this time.');
184
199
  }
185
- else if (action.payload.type === 'IMPORT_STATE') {
200
+ else if (action.payload.type === "IMPORT_STATE" /* ImportState */) {
186
201
  const { actionsById, computedStates, currentStateIndex } = action.payload.nextLiftedState;
187
202
  (/** @type {?} */ (this.devtoolsExtension)).init(computedStates[0].state);
188
203
  Object.keys(actionsById)
@@ -199,12 +214,44 @@ class NgxsReduxDevtoolsPlugin {
199
214
  this.store.reset(computedStates[currentStateIndex].state);
200
215
  }
201
216
  }
202
- else if (action.type === 'ACTION') {
217
+ else if (action.type === "ACTION" /* Action */) {
203
218
  /** @type {?} */
204
219
  const actionPayload = JSON.parse(action.payload);
205
220
  this.store.dispatch(actionPayload);
206
221
  }
207
222
  }
223
+ /**
224
+ * @private
225
+ * @return {?}
226
+ */
227
+ connect() {
228
+ if (!this.globalDevtools || this._options.disabled) {
229
+ return;
230
+ }
231
+ // The `connect` method adds `message` event listener since it communicates
232
+ // with an extension through `window.postMessage` and message events.
233
+ // We handle only 2 events; thus, we don't want to run many change detections
234
+ // because the extension sends events that we don't have to handle.
235
+ this.devtoolsExtension = this._ngZone.runOutsideAngular((/**
236
+ * @return {?}
237
+ */
238
+ () => (/** @type {?} */ (this.globalDevtools.connect(this._options)))));
239
+ this.unsubscribe = this.devtoolsExtension.subscribe((/**
240
+ * @param {?} action
241
+ * @return {?}
242
+ */
243
+ action => {
244
+ if (action.type === "DISPATCH" /* Dispatch */ ||
245
+ action.type === "ACTION" /* Action */) {
246
+ this._ngZone.run((/**
247
+ * @return {?}
248
+ */
249
+ () => {
250
+ this.dispatched(action);
251
+ }));
252
+ }
253
+ }));
254
+ }
208
255
  }
209
256
  NgxsReduxDevtoolsPlugin.decorators = [
210
257
  { type: Injectable }
@@ -212,7 +259,8 @@ NgxsReduxDevtoolsPlugin.decorators = [
212
259
  /** @nocollapse */
213
260
  NgxsReduxDevtoolsPlugin.ctorParameters = () => [
214
261
  { type: undefined, decorators: [{ type: Inject, args: [NGXS_DEVTOOLS_OPTIONS,] }] },
215
- { type: Injector }
262
+ { type: Injector },
263
+ { type: NgZone }
216
264
  ];
217
265
  if (false) {
218
266
  /**
@@ -224,7 +272,12 @@ if (false) {
224
272
  * @type {?}
225
273
  * @private
226
274
  */
227
- NgxsReduxDevtoolsPlugin.prototype.windowObj;
275
+ NgxsReduxDevtoolsPlugin.prototype.globalDevtools;
276
+ /**
277
+ * @type {?}
278
+ * @private
279
+ */
280
+ NgxsReduxDevtoolsPlugin.prototype.unsubscribe;
228
281
  /**
229
282
  * @type {?}
230
283
  * @private
@@ -235,6 +288,11 @@ if (false) {
235
288
  * @private
236
289
  */
237
290
  NgxsReduxDevtoolsPlugin.prototype._injector;
291
+ /**
292
+ * @type {?}
293
+ * @private
294
+ */
295
+ NgxsReduxDevtoolsPlugin.prototype._ngZone;
238
296
  }
239
297
 
240
298
  /**