@ngxs/hmr-plugin 3.7.4 → 3.7.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/README.md +3 -3
  2. package/bundles/ngxs-hmr-plugin.umd.js +665 -665
  3. package/bundles/ngxs-hmr-plugin.umd.js.map +1 -1
  4. package/bundles/ngxs-hmr-plugin.umd.min.js.map +1 -1
  5. package/esm2015/index.js +9 -9
  6. package/esm2015/ngxs-hmr-plugin.js +8 -8
  7. package/esm2015/src/actions/hmr-before-destroy.action.js +24 -24
  8. package/esm2015/src/actions/hmr-init.action.js +24 -24
  9. package/esm2015/src/hmr-bootstrap.js +58 -58
  10. package/esm2015/src/hmr-manager.js +175 -175
  11. package/esm2015/src/internal/hmr-lifecycle.js +160 -160
  12. package/esm2015/src/internal/hmr-options-builder.js +28 -28
  13. package/esm2015/src/internal/hmr-state-context-factory.js +70 -70
  14. package/esm2015/src/internal/hmr-storage.js +35 -35
  15. package/esm2015/src/public_api.js +9 -9
  16. package/esm2015/src/symbols.js +62 -62
  17. package/esm2015/src/utils/externals.js +11 -11
  18. package/esm2015/src/utils/internals.js +22 -22
  19. package/esm5/index.js +9 -9
  20. package/esm5/ngxs-hmr-plugin.js +8 -8
  21. package/esm5/src/actions/hmr-before-destroy.action.js +27 -27
  22. package/esm5/src/actions/hmr-init.action.js +27 -27
  23. package/esm5/src/hmr-bootstrap.js +63 -63
  24. package/esm5/src/hmr-manager.js +222 -222
  25. package/esm5/src/internal/hmr-lifecycle.js +182 -182
  26. package/esm5/src/internal/hmr-options-builder.js +31 -31
  27. package/esm5/src/internal/hmr-state-context-factory.js +86 -86
  28. package/esm5/src/internal/hmr-storage.js +48 -48
  29. package/esm5/src/public_api.js +9 -9
  30. package/esm5/src/symbols.js +62 -62
  31. package/esm5/src/utils/externals.js +11 -11
  32. package/esm5/src/utils/internals.js +22 -22
  33. package/fesm2015/ngxs-hmr-plugin.js +582 -582
  34. package/fesm2015/ngxs-hmr-plugin.js.map +1 -1
  35. package/fesm5/ngxs-hmr-plugin.js +674 -674
  36. package/fesm5/ngxs-hmr-plugin.js.map +1 -1
  37. package/index.d.ts +4 -4
  38. package/ngxs-hmr-plugin.d.ts +4 -4
  39. package/package.json +1 -1
  40. package/src/actions/hmr-before-destroy.action.d.ts +6 -6
  41. package/src/actions/hmr-init.action.d.ts +6 -6
  42. package/src/hmr-bootstrap.d.ts +8 -8
  43. package/src/hmr-manager.d.ts +23 -23
  44. package/src/internal/hmr-lifecycle.d.ts +18 -18
  45. package/src/internal/hmr-options-builder.d.ts +7 -7
  46. package/src/internal/hmr-state-context-factory.d.ts +11 -11
  47. package/src/internal/hmr-storage.d.ts +6 -6
  48. package/src/public_api.d.ts +5 -5
  49. package/src/symbols.d.ts +54 -54
  50. package/src/utils/externals.d.ts +1 -1
  51. package/src/utils/internals.d.ts +2 -2
@@ -1,222 +1,222 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import * as tslib_1 from "tslib";
6
- import { ApplicationRef } from '@angular/core';
7
- import { InitialState, NgxsBootstrapper } from '@ngxs/store/internals';
8
- import { HmrStateContextFactory } from './internal/hmr-state-context-factory';
9
- import { HmrOptionBuilder } from './internal/hmr-options-builder';
10
- import { HmrInitAction } from './actions/hmr-init.action';
11
- import { HmrLifecycle } from './internal/hmr-lifecycle';
12
- /**
13
- * @template T, S
14
- */
15
- var /**
16
- * @template T, S
17
- */
18
- HmrManager = /** @class */ (function () {
19
- function HmrManager(options, storage) {
20
- this.storage = storage;
21
- this.optionsBuilder = new HmrOptionBuilder(options);
22
- }
23
- Object.defineProperty(HmrManager.prototype, "applicationRef", {
24
- get: /**
25
- * @private
26
- * @return {?}
27
- */
28
- function () {
29
- return this.ngModule.injector.get(ApplicationRef);
30
- },
31
- enumerable: true,
32
- configurable: true
33
- });
34
- Object.defineProperty(HmrManager.prototype, "bootstrap", {
35
- get: /**
36
- * @private
37
- * @return {?}
38
- */
39
- function () {
40
- return this.ngModule.injector.get(NgxsBootstrapper);
41
- },
42
- enumerable: true,
43
- configurable: true
44
- });
45
- /**
46
- * @param {?} bootstrapFn
47
- * @param {?} tick
48
- * @return {?}
49
- */
50
- HmrManager.prototype.hmrModule = /**
51
- * @param {?} bootstrapFn
52
- * @param {?} tick
53
- * @return {?}
54
- */
55
- function (bootstrapFn, tick) {
56
- return tslib_1.__awaiter(this, void 0, void 0, function () {
57
- var _a;
58
- return tslib_1.__generator(this, function (_b) {
59
- switch (_b.label) {
60
- case 0:
61
- InitialState.set(this.storage.snapshot);
62
- _a = this;
63
- return [4 /*yield*/, bootstrapFn()];
64
- case 1:
65
- _a.ngModule = _b.sent();
66
- this.context = new HmrStateContextFactory(this.ngModule);
67
- this.lifecycle = this.createLifecycle();
68
- tick();
69
- InitialState.pop();
70
- return [2 /*return*/, this.ngModule];
71
- }
72
- });
73
- });
74
- };
75
- /**
76
- * @return {?}
77
- */
78
- HmrManager.prototype.beforeModuleBootstrap = /**
79
- * @return {?}
80
- */
81
- function () {
82
- this.lifecycle.hmrNgxsStoreOnInit((/**
83
- * @param {?} ctx
84
- * @param {?} state
85
- * @return {?}
86
- */
87
- function (ctx, state) {
88
- ctx.dispatch(new HmrInitAction(state));
89
- }));
90
- };
91
- /**
92
- * @return {?}
93
- */
94
- HmrManager.prototype.beforeModuleOnDestroy = /**
95
- * @return {?}
96
- */
97
- function () {
98
- this.optionsBuilder.clearLogs();
99
- return this.lifecycle.hmrNgxsStoreBeforeOnDestroy();
100
- };
101
- /**
102
- * @return {?}
103
- */
104
- HmrManager.prototype.createNewModule = /**
105
- * @return {?}
106
- */
107
- function () {
108
- /** @type {?} */
109
- var removeOldHosts = this.cloneHostsBeforeDestroy();
110
- this.removeNgStyles();
111
- this.ngModule.destroy();
112
- removeOldHosts();
113
- };
114
- /**
115
- * @private
116
- * @return {?}
117
- */
118
- HmrManager.prototype.createLifecycle = /**
119
- * @private
120
- * @return {?}
121
- */
122
- function () {
123
- return new HmrLifecycle(this.ngModule.instance, this.bootstrap, this.storage, this.context, this.optionsBuilder);
124
- };
125
- /**
126
- * @private
127
- * @return {?}
128
- */
129
- HmrManager.prototype.cloneHostsBeforeDestroy = /**
130
- * @private
131
- * @return {?}
132
- */
133
- function () {
134
- /** @type {?} */
135
- var elements = this.applicationRef.components.map((/**
136
- * @param {?} component
137
- * @return {?}
138
- */
139
- function (component) { return component.location.nativeElement; }));
140
- /** @type {?} */
141
- var removableList = elements.map((/**
142
- * @param {?} componentNode
143
- * @return {?}
144
- */
145
- function (componentNode) {
146
- /** @type {?} */
147
- var newNode = document.createElement(componentNode.tagName);
148
- /** @type {?} */
149
- var parentNode = (/** @type {?} */ (componentNode.parentNode));
150
- /** @type {?} */
151
- var currentDisplay = newNode.style.display;
152
- newNode.style.display = 'none';
153
- parentNode.insertBefore(newNode, componentNode);
154
- return (/**
155
- * @return {?}
156
- */
157
- function () {
158
- newNode.style.display = currentDisplay;
159
- try {
160
- parentNode.removeChild(componentNode);
161
- }
162
- catch (_a) { }
163
- });
164
- }));
165
- return (/**
166
- * @return {?}
167
- */
168
- function removeOldHosts() {
169
- removableList.forEach((/**
170
- * @param {?} removeOldHost
171
- * @return {?}
172
- */
173
- function (removeOldHost) { return removeOldHost(); }));
174
- });
175
- };
176
- /**
177
- * @private
178
- * @return {?}
179
- */
180
- HmrManager.prototype.removeNgStyles = /**
181
- * @private
182
- * @return {?}
183
- */
184
- function () {
185
- /** @type {?} */
186
- var head = (/** @type {?} */ (document.head));
187
- /** @type {?} */
188
- var styles = Array.from((/** @type {?} */ (head)).querySelectorAll('style'));
189
- styles
190
- .filter((/**
191
- * @param {?} style
192
- * @return {?}
193
- */
194
- function (style) { return style.innerText.includes('_ng'); }))
195
- .map((/**
196
- * @param {?} style
197
- * @return {?}
198
- */
199
- function (style) { return (/** @type {?} */ (head)).removeChild(style); }));
200
- };
201
- return HmrManager;
202
- }());
203
- /**
204
- * @template T, S
205
- */
206
- export { HmrManager };
207
- if (false) {
208
- /** @type {?} */
209
- HmrManager.prototype.storage;
210
- /** @type {?} */
211
- HmrManager.prototype.context;
212
- /** @type {?} */
213
- HmrManager.prototype.lifecycle;
214
- /** @type {?} */
215
- HmrManager.prototype.optionsBuilder;
216
- /**
217
- * @type {?}
218
- * @private
219
- */
220
- HmrManager.prototype.ngModule;
221
- }
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hmr-manager.js","sourceRoot":"ng://@ngxs/hmr-plugin/","sources":["src/hmr-manager.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,cAAc,EAA6B,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AASvE,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;;;;AAIxD;;;;IAOE,oBAAY,OAAuB,EAAE,OAAsB;QACzD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,IAAI,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,sBAAY,sCAAc;;;;;QAA1B;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACpD,CAAC;;;OAAA;IAED,sBAAY,iCAAS;;;;;QAArB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QACtD,CAAC;;;OAAA;;;;;;IAEY,8BAAS;;;;;IAAtB,UACE,WAAiC,EACjC,IAAgB;;;;;;wBAEhB,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;wBACxC,KAAA,IAAI,CAAA;wBAAY,qBAAM,WAAW,EAAE,EAAA;;wBAAnC,GAAK,QAAQ,GAAG,SAAmB,CAAC;wBACpC,IAAI,CAAC,OAAO,GAAG,IAAI,sBAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBACzD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;wBAExC,IAAI,EAAE,CAAC;wBAEP,YAAY,CAAC,GAAG,EAAE,CAAC;wBACnB,sBAAO,IAAI,CAAC,QAAQ,EAAC;;;;KACtB;;;;IAEM,0CAAqB;;;IAA5B;QACE,IAAI,CAAC,SAAS,CAAC,kBAAkB;;;;;QAAC,UAAC,GAAG,EAAE,KAAK;YAC3C,GAAG,CAAC,QAAQ,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;QACzC,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,0CAAqB;;;IAA5B;QACE,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,SAAS,CAAC,2BAA2B,EAAE,CAAC;IACtD,CAAC;;;;IAEM,oCAAe;;;IAAtB;;YACQ,cAAc,GAAe,IAAI,CAAC,uBAAuB,EAAE;QACjE,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QACxB,cAAc,EAAE,CAAC;IACnB,CAAC;;;;;IAEO,oCAAe;;;;IAAvB;QACE,OAAO,IAAI,YAAY,CACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EACtB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;;;;;IAEO,4CAAuB;;;;IAA/B;;YACQ,QAAQ,GAAc,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG;;;;QAC5D,UAAC,SAAgC,IAAK,OAAA,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAhC,CAAgC,EACvE;;YAEK,aAAa,GAAuB,QAAQ,CAAC,GAAG;;;;QAAC,UAAC,aAAsB;;gBACtE,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC;;gBACvD,UAAU,GAAS,mBAAA,aAAa,CAAC,UAAU,EAAQ;;gBACnD,cAAc,GAAkB,OAAO,CAAC,KAAK,CAAC,OAAO;YAE3D,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;YAC/B,UAAU,CAAC,YAAY,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;YAEhD;;;YAAO;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,cAAc,CAAC;gBACvC,IAAI;oBACF,UAAU,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;iBACvC;gBAAC,WAAM,GAAE;YACZ,CAAC,EAAC;QACJ,CAAC,EAAC;QAEF;;;QAAO,SAAS,cAAc;YAC5B,aAAa,CAAC,OAAO;;;;YAAC,UAAC,aAA+B,IAAK,OAAA,aAAa,EAAE,EAAf,CAAe,EAAC,CAAC;QAC9E,CAAC,EAAC;IACJ,CAAC;;;;;IAEO,mCAAc;;;;IAAtB;;YACQ,IAAI,GAAoB,mBAAA,QAAQ,CAAC,IAAI,EAAC;;YACtC,MAAM,GAAuB,KAAK,CAAC,IAAI,CAAC,mBAAA,IAAI,EAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAE9E,MAAM;aACH,MAAM;;;;QAAC,UAAC,KAAuB,IAAK,OAAA,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,EAA/B,CAA+B,EAAC;aACpE,GAAG;;;;QAAC,UAAC,KAAuB,IAAK,OAAA,mBAAA,IAAI,EAAC,CAAC,WAAW,CAAC,KAAK,CAAC,EAAxB,CAAwB,EAAC,CAAC;IAChE,CAAC;IACH,iBAAC;AAAD,CAAC,AAjGD,IAiGC;;;;;;;IAhGC,6BAA8B;;IAC9B,6BAA6C;;IAC7C,+BAAqC;;IACrC,oCAAwC;;;;;IACxC,8BAAiC","sourcesContent":["import { ApplicationRef, ComponentRef, NgModuleRef } from '@angular/core';\r\nimport { InitialState, NgxsBootstrapper } from '@ngxs/store/internals';\r\n\r\nimport { HmrStorage } from './internal/hmr-storage';\r\nimport {\r\n  BootstrapModuleFn,\r\n  NgxsHmrLifeCycle,\r\n  NgxsHmrOptions,\r\n  NgxsHmrSnapshot\r\n} from './symbols';\r\nimport { HmrStateContextFactory } from './internal/hmr-state-context-factory';\r\nimport { HmrOptionBuilder } from './internal/hmr-options-builder';\r\nimport { HmrInitAction } from './actions/hmr-init.action';\r\nimport { HmrLifecycle } from './internal/hmr-lifecycle';\r\n\r\ntype OldHostRemoverFn = () => void;\r\n\r\nexport class HmrManager<T extends Partial<NgxsHmrLifeCycle<S>>, S = NgxsHmrSnapshot> {\r\n  public storage: HmrStorage<S>;\r\n  public context: HmrStateContextFactory<T, S>;\r\n  public lifecycle: HmrLifecycle<T, S>;\r\n  public optionsBuilder: HmrOptionBuilder;\r\n  private ngModule: NgModuleRef<T>;\r\n\r\n  constructor(options: NgxsHmrOptions, storage: HmrStorage<S>) {\r\n    this.storage = storage;\r\n    this.optionsBuilder = new HmrOptionBuilder(options);\r\n  }\r\n\r\n  private get applicationRef(): ApplicationRef {\r\n    return this.ngModule.injector.get(ApplicationRef);\r\n  }\r\n\r\n  private get bootstrap(): NgxsBootstrapper {\r\n    return this.ngModule.injector.get(NgxsBootstrapper);\r\n  }\r\n\r\n  public async hmrModule(\r\n    bootstrapFn: BootstrapModuleFn<T>,\r\n    tick: () => void\r\n  ): Promise<NgModuleRef<T>> {\r\n    InitialState.set(this.storage.snapshot);\r\n    this.ngModule = await bootstrapFn();\r\n    this.context = new HmrStateContextFactory(this.ngModule);\r\n    this.lifecycle = this.createLifecycle();\r\n\r\n    tick();\r\n\r\n    InitialState.pop();\r\n    return this.ngModule;\r\n  }\r\n\r\n  public beforeModuleBootstrap(): void {\r\n    this.lifecycle.hmrNgxsStoreOnInit((ctx, state) => {\r\n      ctx.dispatch(new HmrInitAction(state));\r\n    });\r\n  }\r\n\r\n  public beforeModuleOnDestroy(): Partial<S> {\r\n    this.optionsBuilder.clearLogs();\r\n    return this.lifecycle.hmrNgxsStoreBeforeOnDestroy();\r\n  }\r\n\r\n  public createNewModule(): void {\r\n    const removeOldHosts: () => void = this.cloneHostsBeforeDestroy();\r\n    this.removeNgStyles();\r\n    this.ngModule.destroy();\r\n    removeOldHosts();\r\n  }\r\n\r\n  private createLifecycle(): HmrLifecycle<T, S> {\r\n    return new HmrLifecycle(\r\n      this.ngModule.instance,\r\n      this.bootstrap,\r\n      this.storage,\r\n      this.context,\r\n      this.optionsBuilder\r\n    );\r\n  }\r\n\r\n  private cloneHostsBeforeDestroy(): () => void {\r\n    const elements: Element[] = this.applicationRef.components.map(\r\n      (component: ComponentRef<Element>) => component.location.nativeElement\r\n    );\r\n\r\n    const removableList: OldHostRemoverFn[] = elements.map((componentNode: Element) => {\r\n      const newNode = document.createElement(componentNode.tagName);\r\n      const parentNode: Node = componentNode.parentNode as Node;\r\n      const currentDisplay: string | null = newNode.style.display;\r\n\r\n      newNode.style.display = 'none';\r\n      parentNode.insertBefore(newNode, componentNode);\r\n\r\n      return (): void => {\r\n        newNode.style.display = currentDisplay;\r\n        try {\r\n          parentNode.removeChild(componentNode);\r\n        } catch {}\r\n      };\r\n    });\r\n\r\n    return function removeOldHosts(): void {\r\n      removableList.forEach((removeOldHost: OldHostRemoverFn) => removeOldHost());\r\n    };\r\n  }\r\n\r\n  private removeNgStyles(): void {\r\n    const head: HTMLHeadElement = document.head!;\r\n    const styles: HTMLStyleElement[] = Array.from(head!.querySelectorAll('style'));\r\n\r\n    styles\r\n      .filter((style: HTMLStyleElement) => style.innerText.includes('_ng'))\r\n      .map((style: HTMLStyleElement) => head!.removeChild(style));\r\n  }\r\n}\r\n"]}
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import * as tslib_1 from "tslib";
6
+ import { ApplicationRef } from '@angular/core';
7
+ import { InitialState, NgxsBootstrapper } from '@ngxs/store/internals';
8
+ import { HmrStateContextFactory } from './internal/hmr-state-context-factory';
9
+ import { HmrOptionBuilder } from './internal/hmr-options-builder';
10
+ import { HmrInitAction } from './actions/hmr-init.action';
11
+ import { HmrLifecycle } from './internal/hmr-lifecycle';
12
+ /**
13
+ * @template T, S
14
+ */
15
+ var /**
16
+ * @template T, S
17
+ */
18
+ HmrManager = /** @class */ (function () {
19
+ function HmrManager(options, storage) {
20
+ this.storage = storage;
21
+ this.optionsBuilder = new HmrOptionBuilder(options);
22
+ }
23
+ Object.defineProperty(HmrManager.prototype, "applicationRef", {
24
+ get: /**
25
+ * @private
26
+ * @return {?}
27
+ */
28
+ function () {
29
+ return this.ngModule.injector.get(ApplicationRef);
30
+ },
31
+ enumerable: true,
32
+ configurable: true
33
+ });
34
+ Object.defineProperty(HmrManager.prototype, "bootstrap", {
35
+ get: /**
36
+ * @private
37
+ * @return {?}
38
+ */
39
+ function () {
40
+ return this.ngModule.injector.get(NgxsBootstrapper);
41
+ },
42
+ enumerable: true,
43
+ configurable: true
44
+ });
45
+ /**
46
+ * @param {?} bootstrapFn
47
+ * @param {?} tick
48
+ * @return {?}
49
+ */
50
+ HmrManager.prototype.hmrModule = /**
51
+ * @param {?} bootstrapFn
52
+ * @param {?} tick
53
+ * @return {?}
54
+ */
55
+ function (bootstrapFn, tick) {
56
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
57
+ var _a;
58
+ return tslib_1.__generator(this, function (_b) {
59
+ switch (_b.label) {
60
+ case 0:
61
+ InitialState.set(this.storage.snapshot);
62
+ _a = this;
63
+ return [4 /*yield*/, bootstrapFn()];
64
+ case 1:
65
+ _a.ngModule = _b.sent();
66
+ this.context = new HmrStateContextFactory(this.ngModule);
67
+ this.lifecycle = this.createLifecycle();
68
+ tick();
69
+ InitialState.pop();
70
+ return [2 /*return*/, this.ngModule];
71
+ }
72
+ });
73
+ });
74
+ };
75
+ /**
76
+ * @return {?}
77
+ */
78
+ HmrManager.prototype.beforeModuleBootstrap = /**
79
+ * @return {?}
80
+ */
81
+ function () {
82
+ this.lifecycle.hmrNgxsStoreOnInit((/**
83
+ * @param {?} ctx
84
+ * @param {?} state
85
+ * @return {?}
86
+ */
87
+ function (ctx, state) {
88
+ ctx.dispatch(new HmrInitAction(state));
89
+ }));
90
+ };
91
+ /**
92
+ * @return {?}
93
+ */
94
+ HmrManager.prototype.beforeModuleOnDestroy = /**
95
+ * @return {?}
96
+ */
97
+ function () {
98
+ this.optionsBuilder.clearLogs();
99
+ return this.lifecycle.hmrNgxsStoreBeforeOnDestroy();
100
+ };
101
+ /**
102
+ * @return {?}
103
+ */
104
+ HmrManager.prototype.createNewModule = /**
105
+ * @return {?}
106
+ */
107
+ function () {
108
+ /** @type {?} */
109
+ var removeOldHosts = this.cloneHostsBeforeDestroy();
110
+ this.removeNgStyles();
111
+ this.ngModule.destroy();
112
+ removeOldHosts();
113
+ };
114
+ /**
115
+ * @private
116
+ * @return {?}
117
+ */
118
+ HmrManager.prototype.createLifecycle = /**
119
+ * @private
120
+ * @return {?}
121
+ */
122
+ function () {
123
+ return new HmrLifecycle(this.ngModule.instance, this.bootstrap, this.storage, this.context, this.optionsBuilder);
124
+ };
125
+ /**
126
+ * @private
127
+ * @return {?}
128
+ */
129
+ HmrManager.prototype.cloneHostsBeforeDestroy = /**
130
+ * @private
131
+ * @return {?}
132
+ */
133
+ function () {
134
+ /** @type {?} */
135
+ var elements = this.applicationRef.components.map((/**
136
+ * @param {?} component
137
+ * @return {?}
138
+ */
139
+ function (component) { return component.location.nativeElement; }));
140
+ /** @type {?} */
141
+ var removableList = elements.map((/**
142
+ * @param {?} componentNode
143
+ * @return {?}
144
+ */
145
+ function (componentNode) {
146
+ /** @type {?} */
147
+ var newNode = document.createElement(componentNode.tagName);
148
+ /** @type {?} */
149
+ var parentNode = (/** @type {?} */ (componentNode.parentNode));
150
+ /** @type {?} */
151
+ var currentDisplay = newNode.style.display;
152
+ newNode.style.display = 'none';
153
+ parentNode.insertBefore(newNode, componentNode);
154
+ return (/**
155
+ * @return {?}
156
+ */
157
+ function () {
158
+ newNode.style.display = currentDisplay;
159
+ try {
160
+ parentNode.removeChild(componentNode);
161
+ }
162
+ catch (_a) { }
163
+ });
164
+ }));
165
+ return (/**
166
+ * @return {?}
167
+ */
168
+ function removeOldHosts() {
169
+ removableList.forEach((/**
170
+ * @param {?} removeOldHost
171
+ * @return {?}
172
+ */
173
+ function (removeOldHost) { return removeOldHost(); }));
174
+ });
175
+ };
176
+ /**
177
+ * @private
178
+ * @return {?}
179
+ */
180
+ HmrManager.prototype.removeNgStyles = /**
181
+ * @private
182
+ * @return {?}
183
+ */
184
+ function () {
185
+ /** @type {?} */
186
+ var head = (/** @type {?} */ (document.head));
187
+ /** @type {?} */
188
+ var styles = Array.from((/** @type {?} */ (head)).querySelectorAll('style'));
189
+ styles
190
+ .filter((/**
191
+ * @param {?} style
192
+ * @return {?}
193
+ */
194
+ function (style) { return style.innerText.includes('_ng'); }))
195
+ .map((/**
196
+ * @param {?} style
197
+ * @return {?}
198
+ */
199
+ function (style) { return (/** @type {?} */ (head)).removeChild(style); }));
200
+ };
201
+ return HmrManager;
202
+ }());
203
+ /**
204
+ * @template T, S
205
+ */
206
+ export { HmrManager };
207
+ if (false) {
208
+ /** @type {?} */
209
+ HmrManager.prototype.storage;
210
+ /** @type {?} */
211
+ HmrManager.prototype.context;
212
+ /** @type {?} */
213
+ HmrManager.prototype.lifecycle;
214
+ /** @type {?} */
215
+ HmrManager.prototype.optionsBuilder;
216
+ /**
217
+ * @type {?}
218
+ * @private
219
+ */
220
+ HmrManager.prototype.ngModule;
221
+ }
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hmr-manager.js","sourceRoot":"ng://@ngxs/hmr-plugin/","sources":["src/hmr-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, ComponentRef, NgModuleRef } from '@angular/core';\nimport { InitialState, NgxsBootstrapper } from '@ngxs/store/internals';\n\nimport { HmrStorage } from './internal/hmr-storage';\nimport {\n  BootstrapModuleFn,\n  NgxsHmrLifeCycle,\n  NgxsHmrOptions,\n  NgxsHmrSnapshot\n} from './symbols';\nimport { HmrStateContextFactory } from './internal/hmr-state-context-factory';\nimport { HmrOptionBuilder } from './internal/hmr-options-builder';\nimport { HmrInitAction } from './actions/hmr-init.action';\nimport { HmrLifecycle } from './internal/hmr-lifecycle';\n\ntype OldHostRemoverFn = () => void;\n\nexport class HmrManager<T extends Partial<NgxsHmrLifeCycle<S>>, S = NgxsHmrSnapshot> {\n  public storage: HmrStorage<S>;\n  public context: HmrStateContextFactory<T, S>;\n  public lifecycle: HmrLifecycle<T, S>;\n  public optionsBuilder: HmrOptionBuilder;\n  private ngModule: NgModuleRef<T>;\n\n  constructor(options: NgxsHmrOptions, storage: HmrStorage<S>) {\n    this.storage = storage;\n    this.optionsBuilder = new HmrOptionBuilder(options);\n  }\n\n  private get applicationRef(): ApplicationRef {\n    return this.ngModule.injector.get(ApplicationRef);\n  }\n\n  private get bootstrap(): NgxsBootstrapper {\n    return this.ngModule.injector.get(NgxsBootstrapper);\n  }\n\n  public async hmrModule(\n    bootstrapFn: BootstrapModuleFn<T>,\n    tick: () => void\n  ): Promise<NgModuleRef<T>> {\n    InitialState.set(this.storage.snapshot);\n    this.ngModule = await bootstrapFn();\n    this.context = new HmrStateContextFactory(this.ngModule);\n    this.lifecycle = this.createLifecycle();\n\n    tick();\n\n    InitialState.pop();\n    return this.ngModule;\n  }\n\n  public beforeModuleBootstrap(): void {\n    this.lifecycle.hmrNgxsStoreOnInit((ctx, state) => {\n      ctx.dispatch(new HmrInitAction(state));\n    });\n  }\n\n  public beforeModuleOnDestroy(): Partial<S> {\n    this.optionsBuilder.clearLogs();\n    return this.lifecycle.hmrNgxsStoreBeforeOnDestroy();\n  }\n\n  public createNewModule(): void {\n    const removeOldHosts: () => void = this.cloneHostsBeforeDestroy();\n    this.removeNgStyles();\n    this.ngModule.destroy();\n    removeOldHosts();\n  }\n\n  private createLifecycle(): HmrLifecycle<T, S> {\n    return new HmrLifecycle(\n      this.ngModule.instance,\n      this.bootstrap,\n      this.storage,\n      this.context,\n      this.optionsBuilder\n    );\n  }\n\n  private cloneHostsBeforeDestroy(): () => void {\n    const elements: Element[] = this.applicationRef.components.map(\n      (component: ComponentRef<Element>) => component.location.nativeElement\n    );\n\n    const removableList: OldHostRemoverFn[] = elements.map((componentNode: Element) => {\n      const newNode = document.createElement(componentNode.tagName);\n      const parentNode: Node = componentNode.parentNode as Node;\n      const currentDisplay: string | null = newNode.style.display;\n\n      newNode.style.display = 'none';\n      parentNode.insertBefore(newNode, componentNode);\n\n      return (): void => {\n        newNode.style.display = currentDisplay;\n        try {\n          parentNode.removeChild(componentNode);\n        } catch {}\n      };\n    });\n\n    return function removeOldHosts(): void {\n      removableList.forEach((removeOldHost: OldHostRemoverFn) => removeOldHost());\n    };\n  }\n\n  private removeNgStyles(): void {\n    const head: HTMLHeadElement = document.head!;\n    const styles: HTMLStyleElement[] = Array.from(head!.querySelectorAll('style'));\n\n    styles\n      .filter((style: HTMLStyleElement) => style.innerText.includes('_ng'))\n      .map((style: HTMLStyleElement) => head!.removeChild(style));\n  }\n}\n"]}