@angular/core 16.2.4 → 16.2.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.
- package/esm2022/src/render3/after_render_hooks.mjs +83 -49
- package/esm2022/src/version.mjs +1 -1
- package/esm2022/testing/src/logger.mjs +3 -3
- package/fesm2022/core.mjs +142 -110
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/rxjs-interop.mjs +1 -1
- package/fesm2022/testing.mjs +142 -110
- package/fesm2022/testing.mjs.map +1 -1
- package/index.d.ts +6 -20
- package/package.json +1 -1
- package/rxjs-interop/index.d.ts +1 -1
- package/schematics/ng-generate/standalone-migration/bundle.js +9 -9
- package/schematics/ng-generate/standalone-migration/bundle.js.map +1 -1
- package/testing/index.d.ts +1 -1
|
@@ -7,8 +7,10 @@
|
|
|
7
7
|
*/
|
|
8
8
|
import { assertInInjectionContext, Injector, ɵɵdefineInjectable } from '../di';
|
|
9
9
|
import { inject } from '../di/injector_compatibility';
|
|
10
|
+
import { ErrorHandler } from '../error_handler';
|
|
10
11
|
import { RuntimeError } from '../errors';
|
|
11
12
|
import { DestroyRef } from '../linker/destroy_ref';
|
|
13
|
+
import { assertGreaterThan } from '../util/assert';
|
|
12
14
|
import { NgZone } from '../zone';
|
|
13
15
|
import { isPlatformBrowser } from './util/misc_utils';
|
|
14
16
|
/**
|
|
@@ -60,14 +62,18 @@ export function afterRender(callback, options) {
|
|
|
60
62
|
}
|
|
61
63
|
let destroy;
|
|
62
64
|
const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());
|
|
63
|
-
const
|
|
65
|
+
const afterRenderEventManager = injector.get(AfterRenderEventManager);
|
|
66
|
+
// Lazily initialize the handler implementation, if necessary. This is so that it can be
|
|
67
|
+
// tree-shaken if `afterRender` and `afterNextRender` aren't used.
|
|
68
|
+
const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();
|
|
64
69
|
const ngZone = injector.get(NgZone);
|
|
65
|
-
const
|
|
70
|
+
const errorHandler = injector.get(ErrorHandler, null, { optional: true });
|
|
71
|
+
const instance = new AfterRenderCallback(ngZone, errorHandler, callback);
|
|
66
72
|
destroy = () => {
|
|
67
|
-
|
|
73
|
+
callbackHandler.unregister(instance);
|
|
68
74
|
unregisterFn();
|
|
69
75
|
};
|
|
70
|
-
|
|
76
|
+
callbackHandler.register(instance);
|
|
71
77
|
return { destroy };
|
|
72
78
|
}
|
|
73
79
|
/**
|
|
@@ -120,89 +126,117 @@ export function afterNextRender(callback, options) {
|
|
|
120
126
|
}
|
|
121
127
|
let destroy;
|
|
122
128
|
const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());
|
|
123
|
-
const
|
|
129
|
+
const afterRenderEventManager = injector.get(AfterRenderEventManager);
|
|
130
|
+
// Lazily initialize the handler implementation, if necessary. This is so that it can be
|
|
131
|
+
// tree-shaken if `afterRender` and `afterNextRender` aren't used.
|
|
132
|
+
const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();
|
|
124
133
|
const ngZone = injector.get(NgZone);
|
|
125
|
-
const
|
|
134
|
+
const errorHandler = injector.get(ErrorHandler, null, { optional: true });
|
|
135
|
+
const instance = new AfterRenderCallback(ngZone, errorHandler, () => {
|
|
126
136
|
destroy?.();
|
|
127
|
-
|
|
137
|
+
callback();
|
|
128
138
|
});
|
|
129
139
|
destroy = () => {
|
|
130
|
-
|
|
140
|
+
callbackHandler.unregister(instance);
|
|
131
141
|
unregisterFn();
|
|
132
142
|
};
|
|
133
|
-
|
|
143
|
+
callbackHandler.register(instance);
|
|
134
144
|
return { destroy };
|
|
135
145
|
}
|
|
136
146
|
/**
|
|
137
147
|
* A wrapper around a function to be used as an after render callback.
|
|
138
|
-
* @private
|
|
139
148
|
*/
|
|
140
149
|
class AfterRenderCallback {
|
|
141
|
-
constructor(
|
|
142
|
-
this.
|
|
150
|
+
constructor(zone, errorHandler, callbackFn) {
|
|
151
|
+
this.zone = zone;
|
|
152
|
+
this.errorHandler = errorHandler;
|
|
153
|
+
this.callbackFn = callbackFn;
|
|
143
154
|
}
|
|
144
155
|
invoke() {
|
|
145
|
-
|
|
156
|
+
try {
|
|
157
|
+
this.zone.runOutsideAngular(this.callbackFn);
|
|
158
|
+
}
|
|
159
|
+
catch (err) {
|
|
160
|
+
this.errorHandler?.handleError(err);
|
|
161
|
+
}
|
|
146
162
|
}
|
|
147
163
|
}
|
|
148
164
|
/**
|
|
149
|
-
*
|
|
165
|
+
* Core functionality for `afterRender` and `afterNextRender`. Kept separate from
|
|
166
|
+
* `AfterRenderEventManager` for tree-shaking.
|
|
150
167
|
*/
|
|
151
|
-
|
|
168
|
+
class AfterRenderCallbackHandlerImpl {
|
|
152
169
|
constructor() {
|
|
170
|
+
this.executingCallbacks = false;
|
|
153
171
|
this.callbacks = new Set();
|
|
154
172
|
this.deferredCallbacks = new Set();
|
|
155
|
-
this.renderDepth = 0;
|
|
156
|
-
this.runningCallbacks = false;
|
|
157
173
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
* Throws if called from an `afterRender` callback.
|
|
161
|
-
*/
|
|
162
|
-
begin() {
|
|
163
|
-
if (this.runningCallbacks) {
|
|
174
|
+
validateBegin() {
|
|
175
|
+
if (this.executingCallbacks) {
|
|
164
176
|
throw new RuntimeError(102 /* RuntimeErrorCode.RECURSIVE_APPLICATION_RENDER */, ngDevMode &&
|
|
165
177
|
'A new render operation began before the previous operation ended. ' +
|
|
166
178
|
'Did you trigger change detection from afterRender or afterNextRender?');
|
|
167
179
|
}
|
|
168
|
-
this.renderDepth++;
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* Mark the end of a render operation. Registered callbacks
|
|
172
|
-
* are invoked if there are no more pending operations.
|
|
173
|
-
*/
|
|
174
|
-
end() {
|
|
175
|
-
this.renderDepth--;
|
|
176
|
-
if (this.renderDepth === 0) {
|
|
177
|
-
try {
|
|
178
|
-
this.runningCallbacks = true;
|
|
179
|
-
for (const callback of this.callbacks) {
|
|
180
|
-
callback.invoke();
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
finally {
|
|
184
|
-
this.runningCallbacks = false;
|
|
185
|
-
for (const callback of this.deferredCallbacks) {
|
|
186
|
-
this.callbacks.add(callback);
|
|
187
|
-
}
|
|
188
|
-
this.deferredCallbacks.clear();
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
180
|
}
|
|
192
181
|
register(callback) {
|
|
193
182
|
// If we're currently running callbacks, new callbacks should be deferred
|
|
194
183
|
// until the next render operation.
|
|
195
|
-
const target = this.
|
|
184
|
+
const target = this.executingCallbacks ? this.deferredCallbacks : this.callbacks;
|
|
196
185
|
target.add(callback);
|
|
197
186
|
}
|
|
198
187
|
unregister(callback) {
|
|
199
188
|
this.callbacks.delete(callback);
|
|
200
189
|
this.deferredCallbacks.delete(callback);
|
|
201
190
|
}
|
|
202
|
-
|
|
191
|
+
execute() {
|
|
192
|
+
this.executingCallbacks = true;
|
|
193
|
+
for (const callback of this.callbacks) {
|
|
194
|
+
callback.invoke();
|
|
195
|
+
}
|
|
196
|
+
this.executingCallbacks = false;
|
|
197
|
+
for (const callback of this.deferredCallbacks) {
|
|
198
|
+
this.callbacks.add(callback);
|
|
199
|
+
}
|
|
200
|
+
this.deferredCallbacks.clear();
|
|
201
|
+
}
|
|
202
|
+
destroy() {
|
|
203
203
|
this.callbacks.clear();
|
|
204
204
|
this.deferredCallbacks.clear();
|
|
205
205
|
}
|
|
206
|
+
}
|
|
207
|
+
/**
|
|
208
|
+
* Implements core timing for `afterRender` and `afterNextRender` events.
|
|
209
|
+
* Delegates to an optional `AfterRenderCallbackHandler` for implementation.
|
|
210
|
+
*/
|
|
211
|
+
export class AfterRenderEventManager {
|
|
212
|
+
constructor() {
|
|
213
|
+
this.renderDepth = 0;
|
|
214
|
+
/* @internal */
|
|
215
|
+
this.handler = null;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Mark the beginning of a render operation (i.e. CD cycle).
|
|
219
|
+
* Throws if called while executing callbacks.
|
|
220
|
+
*/
|
|
221
|
+
begin() {
|
|
222
|
+
this.handler?.validateBegin();
|
|
223
|
+
this.renderDepth++;
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Mark the end of a render operation. Callbacks will be
|
|
227
|
+
* executed if there are no more pending operations.
|
|
228
|
+
*/
|
|
229
|
+
end() {
|
|
230
|
+
ngDevMode && assertGreaterThan(this.renderDepth, 0, 'renderDepth must be greater than 0');
|
|
231
|
+
this.renderDepth--;
|
|
232
|
+
if (this.renderDepth === 0) {
|
|
233
|
+
this.handler?.execute();
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
ngOnDestroy() {
|
|
237
|
+
this.handler?.destroy();
|
|
238
|
+
this.handler = null;
|
|
239
|
+
}
|
|
206
240
|
/** @nocollapse */
|
|
207
241
|
static { this.ɵprov = ɵɵdefineInjectable({
|
|
208
242
|
token: AfterRenderEventManager,
|
|
@@ -210,4 +244,4 @@ export class AfterRenderEventManager {
|
|
|
210
244
|
factory: () => new AfterRenderEventManager(),
|
|
211
245
|
}); }
|
|
212
246
|
}
|
|
213
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"after_render_hooks.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/after_render_hooks.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {assertInInjectionContext, Injector, ɵɵdefineInjectable} from '../di';\nimport {inject} from '../di/injector_compatibility';\nimport {RuntimeError, RuntimeErrorCode} from '../errors';\nimport {DestroyRef} from '../linker/destroy_ref';\nimport {NgZone} from '../zone';\n\nimport {isPlatformBrowser} from './util/misc_utils';\n\n/**\n * Options passed to `afterRender` and `afterNextRender`.\n *\n * @developerPreview\n */\nexport interface AfterRenderOptions {\n  /**\n   * The `Injector` to use during creation.\n   *\n   * If this is not provided, the current injection context will be used instead (via `inject`).\n   */\n  injector?: Injector;\n}\n\n/**\n * A callback that runs after render.\n *\n * @developerPreview\n */\nexport interface AfterRenderRef {\n  /**\n   * Shut down the callback, preventing it from being called again.\n   */\n  destroy(): void;\n}\n\n/**\n * Register a callback to be invoked each time the application\n * finishes rendering.\n *\n * Note that the callback will run\n * - in the order it was registered\n * - once per render\n * - on browser platforms only\n *\n * <div class=\"alert is-important\">\n *\n * Components are not guaranteed to be [hydrated](guide/hydration) before the callback runs.\n * You must use caution when directly reading or writing the DOM and layout.\n *\n * </div>\n *\n * @param callback A callback function to register\n *\n * @usageNotes\n *\n * Use `afterRender` to read or write the DOM after each render.\n *\n * ### Example\n * ```ts\n * @Component({\n *   selector: 'my-cmp',\n *   template: `<span #content>{{ ... }}</span>`,\n * })\n * export class MyComponent {\n *   @ViewChild('content') contentRef: ElementRef;\n *\n *   constructor() {\n *     afterRender(() => {\n *       console.log('content height: ' + this.contentRef.nativeElement.scrollHeight);\n *     });\n *   }\n * }\n * ```\n *\n * @developerPreview\n */\nexport function afterRender(callback: VoidFunction, options?: AfterRenderOptions): AfterRenderRef {\n  !options && assertInInjectionContext(afterRender);\n  const injector = options?.injector ?? inject(Injector);\n\n  if (!isPlatformBrowser(injector)) {\n    return {destroy() {}};\n  }\n\n  let destroy: VoidFunction|undefined;\n  const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());\n  const manager = injector.get(AfterRenderEventManager);\n  const ngZone = injector.get(NgZone);\n  const instance = new AfterRenderCallback(() => ngZone.runOutsideAngular(callback));\n\n  destroy = () => {\n    manager.unregister(instance);\n    unregisterFn();\n  };\n  manager.register(instance);\n  return {destroy};\n}\n\n/**\n * Register a callback to be invoked the next time the application\n * finishes rendering.\n *\n * Note that the callback will run\n * - in the order it was registered\n * - on browser platforms only\n *\n * <div class=\"alert is-important\">\n *\n * Components are not guaranteed to be [hydrated](guide/hydration) before the callback runs.\n * You must use caution when directly reading or writing the DOM and layout.\n *\n * </div>\n *\n * @param callback A callback function to register\n *\n * @usageNotes\n *\n * Use `afterNextRender` to read or write the DOM once,\n * for example to initialize a non-Angular library.\n *\n * ### Example\n * ```ts\n * @Component({\n *   selector: 'my-chart-cmp',\n *   template: `<div #chart>{{ ... }}</div>`,\n * })\n * export class MyChartCmp {\n *   @ViewChild('chart') chartRef: ElementRef;\n *   chart: MyChart|null;\n *\n *   constructor() {\n *     afterNextRender(() => {\n *       this.chart = new MyChart(this.chartRef.nativeElement);\n *     });\n *   }\n * }\n * ```\n *\n * @developerPreview\n */\nexport function afterNextRender(\n    callback: VoidFunction, options?: AfterRenderOptions): AfterRenderRef {\n  !options && assertInInjectionContext(afterNextRender);\n  const injector = options?.injector ?? inject(Injector);\n\n  if (!isPlatformBrowser(injector)) {\n    return {destroy() {}};\n  }\n\n  let destroy: VoidFunction|undefined;\n  const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());\n  const manager = injector.get(AfterRenderEventManager);\n  const ngZone = injector.get(NgZone);\n  const instance = new AfterRenderCallback(() => {\n    destroy?.();\n    ngZone.runOutsideAngular(callback);\n  });\n\n  destroy = () => {\n    manager.unregister(instance);\n    unregisterFn();\n  };\n  manager.register(instance);\n  return {destroy};\n}\n\n/**\n * A wrapper around a function to be used as an after render callback.\n * @private\n */\nclass AfterRenderCallback {\n  private callback: VoidFunction;\n\n  constructor(callback: VoidFunction) {\n    this.callback = callback;\n  }\n\n  invoke() {\n    this.callback();\n  }\n}\n\n/**\n * Implements `afterRender` and `afterNextRender` callback manager logic.\n */\nexport class AfterRenderEventManager {\n  private callbacks = new Set<AfterRenderCallback>();\n  private deferredCallbacks = new Set<AfterRenderCallback>();\n  private renderDepth = 0;\n  private runningCallbacks = false;\n\n  /**\n   * Mark the beginning of a render operation (i.e. CD cycle).\n   * Throws if called from an `afterRender` callback.\n   */\n  begin() {\n    if (this.runningCallbacks) {\n      throw new RuntimeError(\n          RuntimeErrorCode.RECURSIVE_APPLICATION_RENDER,\n          ngDevMode &&\n              'A new render operation began before the previous operation ended. ' +\n                  'Did you trigger change detection from afterRender or afterNextRender?');\n    }\n\n    this.renderDepth++;\n  }\n\n  /**\n   * Mark the end of a render operation. Registered callbacks\n   * are invoked if there are no more pending operations.\n   */\n  end() {\n    this.renderDepth--;\n\n    if (this.renderDepth === 0) {\n      try {\n        this.runningCallbacks = true;\n        for (const callback of this.callbacks) {\n          callback.invoke();\n        }\n      } finally {\n        this.runningCallbacks = false;\n        for (const callback of this.deferredCallbacks) {\n          this.callbacks.add(callback);\n        }\n        this.deferredCallbacks.clear();\n      }\n    }\n  }\n\n  register(callback: AfterRenderCallback) {\n    // If we're currently running callbacks, new callbacks should be deferred\n    // until the next render operation.\n    const target = this.runningCallbacks ? this.deferredCallbacks : this.callbacks;\n    target.add(callback);\n  }\n\n  unregister(callback: AfterRenderCallback) {\n    this.callbacks.delete(callback);\n    this.deferredCallbacks.delete(callback);\n  }\n\n  ngOnDestroy() {\n    this.callbacks.clear();\n    this.deferredCallbacks.clear();\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: AfterRenderEventManager,\n    providedIn: 'root',\n    factory: () => new AfterRenderEventManager(),\n  });\n}\n"]}
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"after_render_hooks.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/after_render_hooks.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {assertInInjectionContext, Injector, ɵɵdefineInjectable} from '../di';\nimport {inject} from '../di/injector_compatibility';\nimport {ErrorHandler} from '../error_handler';\nimport {RuntimeError, RuntimeErrorCode} from '../errors';\nimport {DestroyRef} from '../linker/destroy_ref';\nimport {assertGreaterThan} from '../util/assert';\nimport {NgZone} from '../zone';\n\nimport {isPlatformBrowser} from './util/misc_utils';\n\n/**\n * Options passed to `afterRender` and `afterNextRender`.\n *\n * @developerPreview\n */\nexport interface AfterRenderOptions {\n  /**\n   * The `Injector` to use during creation.\n   *\n   * If this is not provided, the current injection context will be used instead (via `inject`).\n   */\n  injector?: Injector;\n}\n\n/**\n * A callback that runs after render.\n *\n * @developerPreview\n */\nexport interface AfterRenderRef {\n  /**\n   * Shut down the callback, preventing it from being called again.\n   */\n  destroy(): void;\n}\n\n/**\n * Register a callback to be invoked each time the application\n * finishes rendering.\n *\n * Note that the callback will run\n * - in the order it was registered\n * - once per render\n * - on browser platforms only\n *\n * <div class=\"alert is-important\">\n *\n * Components are not guaranteed to be [hydrated](guide/hydration) before the callback runs.\n * You must use caution when directly reading or writing the DOM and layout.\n *\n * </div>\n *\n * @param callback A callback function to register\n *\n * @usageNotes\n *\n * Use `afterRender` to read or write the DOM after each render.\n *\n * ### Example\n * ```ts\n * @Component({\n *   selector: 'my-cmp',\n *   template: `<span #content>{{ ... }}</span>`,\n * })\n * export class MyComponent {\n *   @ViewChild('content') contentRef: ElementRef;\n *\n *   constructor() {\n *     afterRender(() => {\n *       console.log('content height: ' + this.contentRef.nativeElement.scrollHeight);\n *     });\n *   }\n * }\n * ```\n *\n * @developerPreview\n */\nexport function afterRender(callback: VoidFunction, options?: AfterRenderOptions): AfterRenderRef {\n  !options && assertInInjectionContext(afterRender);\n  const injector = options?.injector ?? inject(Injector);\n\n  if (!isPlatformBrowser(injector)) {\n    return {destroy() {}};\n  }\n\n  let destroy: VoidFunction|undefined;\n  const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());\n  const afterRenderEventManager = injector.get(AfterRenderEventManager);\n  // Lazily initialize the handler implementation, if necessary. This is so that it can be\n  // tree-shaken if `afterRender` and `afterNextRender` aren't used.\n  const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();\n  const ngZone = injector.get(NgZone);\n  const errorHandler = injector.get(ErrorHandler, null, {optional: true});\n  const instance = new AfterRenderCallback(ngZone, errorHandler, callback);\n\n  destroy = () => {\n    callbackHandler.unregister(instance);\n    unregisterFn();\n  };\n  callbackHandler.register(instance);\n  return {destroy};\n}\n\n/**\n * Register a callback to be invoked the next time the application\n * finishes rendering.\n *\n * Note that the callback will run\n * - in the order it was registered\n * - on browser platforms only\n *\n * <div class=\"alert is-important\">\n *\n * Components are not guaranteed to be [hydrated](guide/hydration) before the callback runs.\n * You must use caution when directly reading or writing the DOM and layout.\n *\n * </div>\n *\n * @param callback A callback function to register\n *\n * @usageNotes\n *\n * Use `afterNextRender` to read or write the DOM once,\n * for example to initialize a non-Angular library.\n *\n * ### Example\n * ```ts\n * @Component({\n *   selector: 'my-chart-cmp',\n *   template: `<div #chart>{{ ... }}</div>`,\n * })\n * export class MyChartCmp {\n *   @ViewChild('chart') chartRef: ElementRef;\n *   chart: MyChart|null;\n *\n *   constructor() {\n *     afterNextRender(() => {\n *       this.chart = new MyChart(this.chartRef.nativeElement);\n *     });\n *   }\n * }\n * ```\n *\n * @developerPreview\n */\nexport function afterNextRender(\n    callback: VoidFunction, options?: AfterRenderOptions): AfterRenderRef {\n  !options && assertInInjectionContext(afterNextRender);\n  const injector = options?.injector ?? inject(Injector);\n\n  if (!isPlatformBrowser(injector)) {\n    return {destroy() {}};\n  }\n\n  let destroy: VoidFunction|undefined;\n  const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());\n  const afterRenderEventManager = injector.get(AfterRenderEventManager);\n  // Lazily initialize the handler implementation, if necessary. This is so that it can be\n  // tree-shaken if `afterRender` and `afterNextRender` aren't used.\n  const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();\n  const ngZone = injector.get(NgZone);\n  const errorHandler = injector.get(ErrorHandler, null, {optional: true});\n  const instance = new AfterRenderCallback(ngZone, errorHandler, () => {\n    destroy?.();\n    callback();\n  });\n\n  destroy = () => {\n    callbackHandler.unregister(instance);\n    unregisterFn();\n  };\n  callbackHandler.register(instance);\n  return {destroy};\n}\n\n/**\n * A wrapper around a function to be used as an after render callback.\n */\nclass AfterRenderCallback {\n  constructor(\n      private zone: NgZone, private errorHandler: ErrorHandler|null,\n      private callbackFn: VoidFunction) {}\n\n  invoke() {\n    try {\n      this.zone.runOutsideAngular(this.callbackFn);\n    } catch (err) {\n      this.errorHandler?.handleError(err);\n    }\n  }\n}\n\n/**\n * Implements `afterRender` and `afterNextRender` callback handler logic.\n */\ninterface AfterRenderCallbackHandler {\n  /**\n   * Validate that it's safe for a render operation to begin,\n   * throwing if not. Not guaranteed to be called if a render\n   * operation is started before handler was registered.\n   */\n  validateBegin(): void;\n\n  /**\n   * Register a new callback.\n   */\n  register(callback: AfterRenderCallback): void;\n\n  /**\n   * Unregister an existing callback.\n   */\n  unregister(callback: AfterRenderCallback): void;\n\n  /**\n   * Execute callbacks.\n   */\n  execute(): void;\n\n  /**\n   * Perform any necessary cleanup.\n   */\n  destroy(): void;\n}\n\n/**\n * Core functionality for `afterRender` and `afterNextRender`. Kept separate from\n * `AfterRenderEventManager` for tree-shaking.\n */\nclass AfterRenderCallbackHandlerImpl implements AfterRenderCallbackHandler {\n  private executingCallbacks = false;\n  private callbacks = new Set<AfterRenderCallback>();\n  private deferredCallbacks = new Set<AfterRenderCallback>();\n\n  validateBegin(): void {\n    if (this.executingCallbacks) {\n      throw new RuntimeError(\n          RuntimeErrorCode.RECURSIVE_APPLICATION_RENDER,\n          ngDevMode &&\n              'A new render operation began before the previous operation ended. ' +\n                  'Did you trigger change detection from afterRender or afterNextRender?');\n    }\n  }\n\n  register(callback: AfterRenderCallback): void {\n    // If we're currently running callbacks, new callbacks should be deferred\n    // until the next render operation.\n    const target = this.executingCallbacks ? this.deferredCallbacks : this.callbacks;\n    target.add(callback);\n  }\n\n  unregister(callback: AfterRenderCallback): void {\n    this.callbacks.delete(callback);\n    this.deferredCallbacks.delete(callback);\n  }\n\n  execute(): void {\n    this.executingCallbacks = true;\n    for (const callback of this.callbacks) {\n      callback.invoke();\n    }\n    this.executingCallbacks = false;\n\n    for (const callback of this.deferredCallbacks) {\n      this.callbacks.add(callback);\n    }\n    this.deferredCallbacks.clear();\n  }\n\n  destroy(): void {\n    this.callbacks.clear();\n    this.deferredCallbacks.clear();\n  }\n}\n\n/**\n * Implements core timing for `afterRender` and `afterNextRender` events.\n * Delegates to an optional `AfterRenderCallbackHandler` for implementation.\n */\nexport class AfterRenderEventManager {\n  private renderDepth = 0;\n\n  /* @internal */\n  handler: AfterRenderCallbackHandler|null = null;\n\n  /**\n   * Mark the beginning of a render operation (i.e. CD cycle).\n   * Throws if called while executing callbacks.\n   */\n  begin() {\n    this.handler?.validateBegin();\n    this.renderDepth++;\n  }\n\n  /**\n   * Mark the end of a render operation. Callbacks will be\n   * executed if there are no more pending operations.\n   */\n  end() {\n    ngDevMode && assertGreaterThan(this.renderDepth, 0, 'renderDepth must be greater than 0');\n    this.renderDepth--;\n\n    if (this.renderDepth === 0) {\n      this.handler?.execute();\n    }\n  }\n\n  ngOnDestroy() {\n    this.handler?.destroy();\n    this.handler = null;\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: AfterRenderEventManager,\n    providedIn: 'root',\n    factory: () => new AfterRenderEventManager(),\n  });\n}\n"]}
|
package/esm2022/src/version.mjs
CHANGED
|
@@ -21,5 +21,5 @@ export class Version {
|
|
|
21
21
|
/**
|
|
22
22
|
* @publicApi
|
|
23
23
|
*/
|
|
24
|
-
export const VERSION = new Version('16.2.
|
|
24
|
+
export const VERSION = new Version('16.2.5');
|
|
25
25
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUg7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBS2xCLFlBQW1CLElBQVk7UUFBWixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQzdCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbEQsQ0FBQztDQUNGO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBSZXByZXNlbnRzIHRoZSB2ZXJzaW9uIG9mIEFuZ3VsYXJcbiAqXG4gKiBAcHVibGljQXBpXG4gKi9cbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIHJlYWRvbmx5IG1ham9yOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBtaW5vcjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgcGF0Y2g6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgZnVsbDogc3RyaW5nKSB7XG4gICAgdGhpcy5tYWpvciA9IGZ1bGwuc3BsaXQoJy4nKVswXTtcbiAgICB0aGlzLm1pbm9yID0gZnVsbC5zcGxpdCgnLicpWzFdO1xuICAgIHRoaXMucGF0Y2ggPSBmdWxsLnNwbGl0KCcuJykuc2xpY2UoMikuam9pbignLicpO1xuICB9XG59XG5cbi8qKlxuICogQHB1YmxpY0FwaVxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcwLjAuMC1QTEFDRUhPTERFUicpO1xuIl19
|
|
@@ -25,10 +25,10 @@ export class Log {
|
|
|
25
25
|
result() {
|
|
26
26
|
return this.logItems.join('; ');
|
|
27
27
|
}
|
|
28
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.
|
|
29
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: Log, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
29
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: Log }); }
|
|
30
30
|
}
|
|
31
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: Log, decorators: [{
|
|
32
32
|
type: Injectable
|
|
33
33
|
}], ctorParameters: function () { return []; } });
|
|
34
34
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS90ZXN0aW5nL3NyYy9sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFHekMsTUFBTSxPQUFPLEdBQUc7SUFHZDtRQUNFLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxHQUFHLENBQUMsS0FBUTtRQUNWLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxFQUFFLENBQUMsS0FBUTtRQUNULE9BQU8sR0FBRyxFQUFFO1lBQ1YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsTUFBTTtRQUNKLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzt5SEF2QlUsR0FBRzs2SEFBSCxHQUFHOztzR0FBSCxHQUFHO2tCQURmLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIExvZzxUID0gc3RyaW5nPiB7XG4gIGxvZ0l0ZW1zOiBUW107XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5sb2dJdGVtcyA9IFtdO1xuICB9XG5cbiAgYWRkKHZhbHVlOiBUKTogdm9pZCB7XG4gICAgdGhpcy5sb2dJdGVtcy5wdXNoKHZhbHVlKTtcbiAgfVxuXG4gIGZuKHZhbHVlOiBUKSB7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHRoaXMubG9nSXRlbXMucHVzaCh2YWx1ZSk7XG4gICAgfTtcbiAgfVxuXG4gIGNsZWFyKCk6IHZvaWQge1xuICAgIHRoaXMubG9nSXRlbXMgPSBbXTtcbiAgfVxuXG4gIHJlc3VsdCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmxvZ0l0ZW1zLmpvaW4oJzsgJyk7XG4gIH1cbn1cbiJdfQ==
|
package/fesm2022/core.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v16.2.
|
|
2
|
+
* @license Angular v16.2.5
|
|
3
3
|
* (c) 2010-2022 Google LLC. https://angular.io/
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -10256,7 +10256,7 @@ class Version {
|
|
|
10256
10256
|
/**
|
|
10257
10257
|
* @publicApi
|
|
10258
10258
|
*/
|
|
10259
|
-
const VERSION = new Version('16.2.
|
|
10259
|
+
const VERSION = new Version('16.2.5');
|
|
10260
10260
|
|
|
10261
10261
|
// This default value is when checking the hierarchy for a token.
|
|
10262
10262
|
//
|
|
@@ -10524,6 +10524,66 @@ class Injector {
|
|
|
10524
10524
|
* safe to delete this file.
|
|
10525
10525
|
*/
|
|
10526
10526
|
|
|
10527
|
+
const ERROR_ORIGINAL_ERROR = 'ngOriginalError';
|
|
10528
|
+
function wrappedError(message, originalError) {
|
|
10529
|
+
const msg = `${message} caused by: ${originalError instanceof Error ? originalError.message : originalError}`;
|
|
10530
|
+
const error = Error(msg);
|
|
10531
|
+
error[ERROR_ORIGINAL_ERROR] = originalError;
|
|
10532
|
+
return error;
|
|
10533
|
+
}
|
|
10534
|
+
function getOriginalError(error) {
|
|
10535
|
+
return error[ERROR_ORIGINAL_ERROR];
|
|
10536
|
+
}
|
|
10537
|
+
|
|
10538
|
+
/**
|
|
10539
|
+
* Provides a hook for centralized exception handling.
|
|
10540
|
+
*
|
|
10541
|
+
* The default implementation of `ErrorHandler` prints error messages to the `console`. To
|
|
10542
|
+
* intercept error handling, write a custom exception handler that replaces this default as
|
|
10543
|
+
* appropriate for your app.
|
|
10544
|
+
*
|
|
10545
|
+
* @usageNotes
|
|
10546
|
+
* ### Example
|
|
10547
|
+
*
|
|
10548
|
+
* ```
|
|
10549
|
+
* class MyErrorHandler implements ErrorHandler {
|
|
10550
|
+
* handleError(error) {
|
|
10551
|
+
* // do something with the exception
|
|
10552
|
+
* }
|
|
10553
|
+
* }
|
|
10554
|
+
*
|
|
10555
|
+
* @NgModule({
|
|
10556
|
+
* providers: [{provide: ErrorHandler, useClass: MyErrorHandler}]
|
|
10557
|
+
* })
|
|
10558
|
+
* class MyModule {}
|
|
10559
|
+
* ```
|
|
10560
|
+
*
|
|
10561
|
+
* @publicApi
|
|
10562
|
+
*/
|
|
10563
|
+
class ErrorHandler {
|
|
10564
|
+
constructor() {
|
|
10565
|
+
/**
|
|
10566
|
+
* @internal
|
|
10567
|
+
*/
|
|
10568
|
+
this._console = console;
|
|
10569
|
+
}
|
|
10570
|
+
handleError(error) {
|
|
10571
|
+
const originalError = this._findOriginalError(error);
|
|
10572
|
+
this._console.error('ERROR', error);
|
|
10573
|
+
if (originalError) {
|
|
10574
|
+
this._console.error('ORIGINAL ERROR', originalError);
|
|
10575
|
+
}
|
|
10576
|
+
}
|
|
10577
|
+
/** @internal */
|
|
10578
|
+
_findOriginalError(error) {
|
|
10579
|
+
let e = error && getOriginalError(error);
|
|
10580
|
+
while (e && getOriginalError(e)) {
|
|
10581
|
+
e = getOriginalError(e);
|
|
10582
|
+
}
|
|
10583
|
+
return e || null;
|
|
10584
|
+
}
|
|
10585
|
+
}
|
|
10586
|
+
|
|
10527
10587
|
/**
|
|
10528
10588
|
* `DestroyRef` lets you set callbacks to run for any cleanup or destruction behavior.
|
|
10529
10589
|
* The scope of this destruction depends on where `DestroyRef` is injected. If `DestroyRef`
|
|
@@ -11234,14 +11294,18 @@ function afterRender(callback, options) {
|
|
|
11234
11294
|
}
|
|
11235
11295
|
let destroy;
|
|
11236
11296
|
const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());
|
|
11237
|
-
const
|
|
11297
|
+
const afterRenderEventManager = injector.get(AfterRenderEventManager);
|
|
11298
|
+
// Lazily initialize the handler implementation, if necessary. This is so that it can be
|
|
11299
|
+
// tree-shaken if `afterRender` and `afterNextRender` aren't used.
|
|
11300
|
+
const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();
|
|
11238
11301
|
const ngZone = injector.get(NgZone);
|
|
11239
|
-
const
|
|
11302
|
+
const errorHandler = injector.get(ErrorHandler, null, { optional: true });
|
|
11303
|
+
const instance = new AfterRenderCallback(ngZone, errorHandler, callback);
|
|
11240
11304
|
destroy = () => {
|
|
11241
|
-
|
|
11305
|
+
callbackHandler.unregister(instance);
|
|
11242
11306
|
unregisterFn();
|
|
11243
11307
|
};
|
|
11244
|
-
|
|
11308
|
+
callbackHandler.register(instance);
|
|
11245
11309
|
return { destroy };
|
|
11246
11310
|
}
|
|
11247
11311
|
/**
|
|
@@ -11294,89 +11358,117 @@ function afterNextRender(callback, options) {
|
|
|
11294
11358
|
}
|
|
11295
11359
|
let destroy;
|
|
11296
11360
|
const unregisterFn = injector.get(DestroyRef).onDestroy(() => destroy?.());
|
|
11297
|
-
const
|
|
11361
|
+
const afterRenderEventManager = injector.get(AfterRenderEventManager);
|
|
11362
|
+
// Lazily initialize the handler implementation, if necessary. This is so that it can be
|
|
11363
|
+
// tree-shaken if `afterRender` and `afterNextRender` aren't used.
|
|
11364
|
+
const callbackHandler = afterRenderEventManager.handler ??= new AfterRenderCallbackHandlerImpl();
|
|
11298
11365
|
const ngZone = injector.get(NgZone);
|
|
11299
|
-
const
|
|
11366
|
+
const errorHandler = injector.get(ErrorHandler, null, { optional: true });
|
|
11367
|
+
const instance = new AfterRenderCallback(ngZone, errorHandler, () => {
|
|
11300
11368
|
destroy?.();
|
|
11301
|
-
|
|
11369
|
+
callback();
|
|
11302
11370
|
});
|
|
11303
11371
|
destroy = () => {
|
|
11304
|
-
|
|
11372
|
+
callbackHandler.unregister(instance);
|
|
11305
11373
|
unregisterFn();
|
|
11306
11374
|
};
|
|
11307
|
-
|
|
11375
|
+
callbackHandler.register(instance);
|
|
11308
11376
|
return { destroy };
|
|
11309
11377
|
}
|
|
11310
11378
|
/**
|
|
11311
11379
|
* A wrapper around a function to be used as an after render callback.
|
|
11312
|
-
* @private
|
|
11313
11380
|
*/
|
|
11314
11381
|
class AfterRenderCallback {
|
|
11315
|
-
constructor(
|
|
11316
|
-
this.
|
|
11382
|
+
constructor(zone, errorHandler, callbackFn) {
|
|
11383
|
+
this.zone = zone;
|
|
11384
|
+
this.errorHandler = errorHandler;
|
|
11385
|
+
this.callbackFn = callbackFn;
|
|
11317
11386
|
}
|
|
11318
11387
|
invoke() {
|
|
11319
|
-
|
|
11388
|
+
try {
|
|
11389
|
+
this.zone.runOutsideAngular(this.callbackFn);
|
|
11390
|
+
}
|
|
11391
|
+
catch (err) {
|
|
11392
|
+
this.errorHandler?.handleError(err);
|
|
11393
|
+
}
|
|
11320
11394
|
}
|
|
11321
11395
|
}
|
|
11322
11396
|
/**
|
|
11323
|
-
*
|
|
11397
|
+
* Core functionality for `afterRender` and `afterNextRender`. Kept separate from
|
|
11398
|
+
* `AfterRenderEventManager` for tree-shaking.
|
|
11324
11399
|
*/
|
|
11325
|
-
class
|
|
11400
|
+
class AfterRenderCallbackHandlerImpl {
|
|
11326
11401
|
constructor() {
|
|
11402
|
+
this.executingCallbacks = false;
|
|
11327
11403
|
this.callbacks = new Set();
|
|
11328
11404
|
this.deferredCallbacks = new Set();
|
|
11329
|
-
this.renderDepth = 0;
|
|
11330
|
-
this.runningCallbacks = false;
|
|
11331
11405
|
}
|
|
11332
|
-
|
|
11333
|
-
|
|
11334
|
-
* Throws if called from an `afterRender` callback.
|
|
11335
|
-
*/
|
|
11336
|
-
begin() {
|
|
11337
|
-
if (this.runningCallbacks) {
|
|
11406
|
+
validateBegin() {
|
|
11407
|
+
if (this.executingCallbacks) {
|
|
11338
11408
|
throw new RuntimeError(102 /* RuntimeErrorCode.RECURSIVE_APPLICATION_RENDER */, ngDevMode &&
|
|
11339
11409
|
'A new render operation began before the previous operation ended. ' +
|
|
11340
11410
|
'Did you trigger change detection from afterRender or afterNextRender?');
|
|
11341
11411
|
}
|
|
11342
|
-
this.renderDepth++;
|
|
11343
|
-
}
|
|
11344
|
-
/**
|
|
11345
|
-
* Mark the end of a render operation. Registered callbacks
|
|
11346
|
-
* are invoked if there are no more pending operations.
|
|
11347
|
-
*/
|
|
11348
|
-
end() {
|
|
11349
|
-
this.renderDepth--;
|
|
11350
|
-
if (this.renderDepth === 0) {
|
|
11351
|
-
try {
|
|
11352
|
-
this.runningCallbacks = true;
|
|
11353
|
-
for (const callback of this.callbacks) {
|
|
11354
|
-
callback.invoke();
|
|
11355
|
-
}
|
|
11356
|
-
}
|
|
11357
|
-
finally {
|
|
11358
|
-
this.runningCallbacks = false;
|
|
11359
|
-
for (const callback of this.deferredCallbacks) {
|
|
11360
|
-
this.callbacks.add(callback);
|
|
11361
|
-
}
|
|
11362
|
-
this.deferredCallbacks.clear();
|
|
11363
|
-
}
|
|
11364
|
-
}
|
|
11365
11412
|
}
|
|
11366
11413
|
register(callback) {
|
|
11367
11414
|
// If we're currently running callbacks, new callbacks should be deferred
|
|
11368
11415
|
// until the next render operation.
|
|
11369
|
-
const target = this.
|
|
11416
|
+
const target = this.executingCallbacks ? this.deferredCallbacks : this.callbacks;
|
|
11370
11417
|
target.add(callback);
|
|
11371
11418
|
}
|
|
11372
11419
|
unregister(callback) {
|
|
11373
11420
|
this.callbacks.delete(callback);
|
|
11374
11421
|
this.deferredCallbacks.delete(callback);
|
|
11375
11422
|
}
|
|
11376
|
-
|
|
11423
|
+
execute() {
|
|
11424
|
+
this.executingCallbacks = true;
|
|
11425
|
+
for (const callback of this.callbacks) {
|
|
11426
|
+
callback.invoke();
|
|
11427
|
+
}
|
|
11428
|
+
this.executingCallbacks = false;
|
|
11429
|
+
for (const callback of this.deferredCallbacks) {
|
|
11430
|
+
this.callbacks.add(callback);
|
|
11431
|
+
}
|
|
11432
|
+
this.deferredCallbacks.clear();
|
|
11433
|
+
}
|
|
11434
|
+
destroy() {
|
|
11377
11435
|
this.callbacks.clear();
|
|
11378
11436
|
this.deferredCallbacks.clear();
|
|
11379
11437
|
}
|
|
11438
|
+
}
|
|
11439
|
+
/**
|
|
11440
|
+
* Implements core timing for `afterRender` and `afterNextRender` events.
|
|
11441
|
+
* Delegates to an optional `AfterRenderCallbackHandler` for implementation.
|
|
11442
|
+
*/
|
|
11443
|
+
class AfterRenderEventManager {
|
|
11444
|
+
constructor() {
|
|
11445
|
+
this.renderDepth = 0;
|
|
11446
|
+
/* @internal */
|
|
11447
|
+
this.handler = null;
|
|
11448
|
+
}
|
|
11449
|
+
/**
|
|
11450
|
+
* Mark the beginning of a render operation (i.e. CD cycle).
|
|
11451
|
+
* Throws if called while executing callbacks.
|
|
11452
|
+
*/
|
|
11453
|
+
begin() {
|
|
11454
|
+
this.handler?.validateBegin();
|
|
11455
|
+
this.renderDepth++;
|
|
11456
|
+
}
|
|
11457
|
+
/**
|
|
11458
|
+
* Mark the end of a render operation. Callbacks will be
|
|
11459
|
+
* executed if there are no more pending operations.
|
|
11460
|
+
*/
|
|
11461
|
+
end() {
|
|
11462
|
+
ngDevMode && assertGreaterThan(this.renderDepth, 0, 'renderDepth must be greater than 0');
|
|
11463
|
+
this.renderDepth--;
|
|
11464
|
+
if (this.renderDepth === 0) {
|
|
11465
|
+
this.handler?.execute();
|
|
11466
|
+
}
|
|
11467
|
+
}
|
|
11468
|
+
ngOnDestroy() {
|
|
11469
|
+
this.handler?.destroy();
|
|
11470
|
+
this.handler = null;
|
|
11471
|
+
}
|
|
11380
11472
|
/** @nocollapse */
|
|
11381
11473
|
static { this.ɵprov = ɵɵdefineInjectable({
|
|
11382
11474
|
token: AfterRenderEventManager,
|
|
@@ -11410,66 +11502,6 @@ function markViewDirty(lView) {
|
|
|
11410
11502
|
return null;
|
|
11411
11503
|
}
|
|
11412
11504
|
|
|
11413
|
-
const ERROR_ORIGINAL_ERROR = 'ngOriginalError';
|
|
11414
|
-
function wrappedError(message, originalError) {
|
|
11415
|
-
const msg = `${message} caused by: ${originalError instanceof Error ? originalError.message : originalError}`;
|
|
11416
|
-
const error = Error(msg);
|
|
11417
|
-
error[ERROR_ORIGINAL_ERROR] = originalError;
|
|
11418
|
-
return error;
|
|
11419
|
-
}
|
|
11420
|
-
function getOriginalError(error) {
|
|
11421
|
-
return error[ERROR_ORIGINAL_ERROR];
|
|
11422
|
-
}
|
|
11423
|
-
|
|
11424
|
-
/**
|
|
11425
|
-
* Provides a hook for centralized exception handling.
|
|
11426
|
-
*
|
|
11427
|
-
* The default implementation of `ErrorHandler` prints error messages to the `console`. To
|
|
11428
|
-
* intercept error handling, write a custom exception handler that replaces this default as
|
|
11429
|
-
* appropriate for your app.
|
|
11430
|
-
*
|
|
11431
|
-
* @usageNotes
|
|
11432
|
-
* ### Example
|
|
11433
|
-
*
|
|
11434
|
-
* ```
|
|
11435
|
-
* class MyErrorHandler implements ErrorHandler {
|
|
11436
|
-
* handleError(error) {
|
|
11437
|
-
* // do something with the exception
|
|
11438
|
-
* }
|
|
11439
|
-
* }
|
|
11440
|
-
*
|
|
11441
|
-
* @NgModule({
|
|
11442
|
-
* providers: [{provide: ErrorHandler, useClass: MyErrorHandler}]
|
|
11443
|
-
* })
|
|
11444
|
-
* class MyModule {}
|
|
11445
|
-
* ```
|
|
11446
|
-
*
|
|
11447
|
-
* @publicApi
|
|
11448
|
-
*/
|
|
11449
|
-
class ErrorHandler {
|
|
11450
|
-
constructor() {
|
|
11451
|
-
/**
|
|
11452
|
-
* @internal
|
|
11453
|
-
*/
|
|
11454
|
-
this._console = console;
|
|
11455
|
-
}
|
|
11456
|
-
handleError(error) {
|
|
11457
|
-
const originalError = this._findOriginalError(error);
|
|
11458
|
-
this._console.error('ERROR', error);
|
|
11459
|
-
if (originalError) {
|
|
11460
|
-
this._console.error('ORIGINAL ERROR', originalError);
|
|
11461
|
-
}
|
|
11462
|
-
}
|
|
11463
|
-
/** @internal */
|
|
11464
|
-
_findOriginalError(error) {
|
|
11465
|
-
let e = error && getOriginalError(error);
|
|
11466
|
-
while (e && getOriginalError(e)) {
|
|
11467
|
-
e = getOriginalError(e);
|
|
11468
|
-
}
|
|
11469
|
-
return e || null;
|
|
11470
|
-
}
|
|
11471
|
-
}
|
|
11472
|
-
|
|
11473
11505
|
/**
|
|
11474
11506
|
* Internal token that specifies whether DOM reuse logic
|
|
11475
11507
|
* during hydration is enabled.
|