@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.
- package/bundles/ngxs-devtools-plugin.umd.js +88 -24
- package/bundles/ngxs-devtools-plugin.umd.js.map +1 -1
- package/bundles/ngxs-devtools-plugin.umd.min.js +2 -2
- package/bundles/ngxs-devtools-plugin.umd.min.js.map +1 -1
- package/esm2015/src/devtools.plugin.js +82 -24
- package/esm2015/src/symbols.js +1 -1
- package/esm5/src/devtools.plugin.js +90 -26
- package/esm5/src/symbols.js +1 -1
- package/fesm2015/ngxs-devtools-plugin.js +81 -23
- package/fesm2015/ngxs-devtools-plugin.js.map +1 -1
- package/fesm5/ngxs-devtools-plugin.js +89 -25
- package/fesm5/ngxs-devtools-plugin.js.map +1 -1
- package/ngxs-devtools-plugin.metadata.json +1 -1
- package/package.json +3 -3
- package/src/devtools.plugin.d.ts +9 -5
- package/src/symbols.d.ts +1 -2
|
@@ -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.
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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
|
-
|
|
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 ===
|
|
99
|
-
if (action.payload.type ===
|
|
100
|
-
action.payload.type ===
|
|
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 ===
|
|
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 ===
|
|
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 ===
|
|
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.
|
|
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"]}
|
package/esm2015/src/symbols.js
CHANGED
|
@@ -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,
|
|
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.
|
|
21
|
-
|
|
22
|
-
|
|
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
|
-
|
|
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 ===
|
|
131
|
-
if (action.payload.type ===
|
|
132
|
-
action.payload.type ===
|
|
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 ===
|
|
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 ===
|
|
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 ===
|
|
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.
|
|
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"]}
|
package/esm5/src/symbols.js
CHANGED
|
@@ -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,
|
|
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.
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
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
|
-
|
|
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 ===
|
|
176
|
-
if (action.payload.type ===
|
|
177
|
-
action.payload.type ===
|
|
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 ===
|
|
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 ===
|
|
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 ===
|
|
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.
|
|
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
|
/**
|