1 | /**
|
2 | * @license
|
3 | * Copyright Google LLC All Rights Reserved.
|
4 | *
|
5 | * Use of this source code is governed by an MIT-style license that can be
|
6 | * found in the LICENSE file at https://angular.io/license
|
7 | */
|
8 | import './util/ng_jit_mode';
|
9 | import { merge, Observable } from 'rxjs';
|
10 | import { share } from 'rxjs/operators';
|
11 | import { ApplicationInitStatus } from './application_init';
|
12 | import { APP_BOOTSTRAP_LISTENER, PLATFORM_INITIALIZER } from './application_tokens';
|
13 | import { getCompilerFacade } from './compiler/compiler_facade';
|
14 | import { Console } from './console';
|
15 | import { Injectable } from './di/injectable';
|
16 | import { InjectionToken } from './di/injection_token';
|
17 | import { Injector } from './di/injector';
|
18 | import { INJECTOR_SCOPE } from './di/scope';
|
19 | import { ErrorHandler } from './error_handler';
|
20 | import { DEFAULT_LOCALE_ID } from './i18n/localization';
|
21 | import { LOCALE_ID } from './i18n/tokens';
|
22 | import { ivyEnabled } from './ivy_switch';
|
23 | import { COMPILER_OPTIONS, CompilerFactory } from './linker/compiler';
|
24 | import { ComponentFactory } from './linker/component_factory';
|
25 | import { ComponentFactoryBoundToModule, ComponentFactoryResolver } from './linker/component_factory_resolver';
|
26 | import { NgModuleRef } from './linker/ng_module_factory';
|
27 | import { isComponentResourceResolutionQueueEmpty, resolveComponentResources } from './metadata/resource_loading';
|
28 | import { assertNgModuleType } from './render3/assert';
|
29 | import { setLocaleId } from './render3/i18n/i18n_locale_id';
|
30 | import { setJitOptions } from './render3/jit/jit_options';
|
31 | import { NgModuleFactory as R3NgModuleFactory } from './render3/ng_module_ref';
|
32 | import { publishDefaultGlobalUtils as _publishDefaultGlobalUtils } from './render3/util/global_utils';
|
33 | import { Testability, TestabilityRegistry } from './testability/testability';
|
34 | import { isDevMode } from './util/is_dev_mode';
|
35 | import { isPromise } from './util/lang';
|
36 | import { scheduleMicroTask } from './util/microtask';
|
37 | import { stringify } from './util/stringify';
|
38 | import { NgZone, NoopNgZone } from './zone/ng_zone';
|
39 | import * as i0 from "./r3_symbols";
|
40 | import * as i1 from "./di/injector";
|
41 | import * as i2 from "./zone/ng_zone";
|
42 | import * as i3 from "./error_handler";
|
43 | import * as i4 from "./linker/component_factory_resolver";
|
44 | import * as i5 from "./application_init";
|
45 | let _platform;
|
46 | let compileNgModuleFactory = compileNgModuleFactory__POST_R3__;
|
47 | function compileNgModuleFactory__PRE_R3__(injector, options, moduleType) {
|
48 | const compilerFactory = injector.get(CompilerFactory);
|
49 | const compiler = compilerFactory.createCompiler([options]);
|
50 | return compiler.compileModuleAsync(moduleType);
|
51 | }
|
52 | export function compileNgModuleFactory__POST_R3__(injector, options, moduleType) {
|
53 | ngDevMode && assertNgModuleType(moduleType);
|
54 | const moduleFactory = new R3NgModuleFactory(moduleType);
|
55 | // All of the logic below is irrelevant for AOT-compiled code.
|
56 | if (typeof ngJitMode !== 'undefined' && !ngJitMode) {
|
57 | return Promise.resolve(moduleFactory);
|
58 | }
|
59 | const compilerOptions = injector.get(COMPILER_OPTIONS, []).concat(options);
|
60 | // Configure the compiler to use the provided options. This call may fail when multiple modules
|
61 | // are bootstrapped with incompatible options, as a component can only be compiled according to
|
62 | // a single set of options.
|
63 | setJitOptions({
|
64 | defaultEncapsulation: _lastDefined(compilerOptions.map(opts => opts.defaultEncapsulation)),
|
65 | preserveWhitespaces: _lastDefined(compilerOptions.map(opts => opts.preserveWhitespaces)),
|
66 | });
|
67 | if (isComponentResourceResolutionQueueEmpty()) {
|
68 | return Promise.resolve(moduleFactory);
|
69 | }
|
70 | const compilerProviders = _mergeArrays(compilerOptions.map(o => o.providers));
|
71 | // In case there are no compiler providers, we just return the module factory as
|
72 | // there won't be any resource loader. This can happen with Ivy, because AOT compiled
|
73 | // modules can be still passed through "bootstrapModule". In that case we shouldn't
|
74 | // unnecessarily require the JIT compiler.
|
75 | if (compilerProviders.length === 0) {
|
76 | return Promise.resolve(moduleFactory);
|
77 | }
|
78 | const compiler = getCompilerFacade({
|
79 | usage: 0 /* Decorator */,
|
80 | kind: 'NgModule',
|
81 | type: moduleType,
|
82 | });
|
83 | const compilerInjector = Injector.create({ providers: compilerProviders });
|
84 | const resourceLoader = compilerInjector.get(compiler.ResourceLoader);
|
85 | // The resource loader can also return a string while the "resolveComponentResources"
|
86 | // always expects a promise. Therefore we need to wrap the returned value in a promise.
|
87 | return resolveComponentResources(url => Promise.resolve(resourceLoader.get(url)))
|
88 | .then(() => moduleFactory);
|
89 | }
|
90 | // the `window.ng` global utilities are only available in non-VE versions of
|
91 | // Angular. The function switch below will make sure that the code is not
|
92 | // included into Angular when PRE mode is active.
|
93 | export function publishDefaultGlobalUtils__PRE_R3__() { }
|
94 | export function publishDefaultGlobalUtils__POST_R3__() {
|
95 | ngDevMode && _publishDefaultGlobalUtils();
|
96 | }
|
97 | let publishDefaultGlobalUtils = publishDefaultGlobalUtils__POST_R3__;
|
98 | let isBoundToModule = isBoundToModule__POST_R3__;
|
99 | export function isBoundToModule__PRE_R3__(cf) {
|
100 | return cf instanceof ComponentFactoryBoundToModule;
|
101 | }
|
102 | export function isBoundToModule__POST_R3__(cf) {
|
103 | return cf.isBoundToModule;
|
104 | }
|
105 | export const ALLOW_MULTIPLE_PLATFORMS = new InjectionToken('AllowMultipleToken');
|
106 | /**
|
107 | * A token for third-party components that can register themselves with NgProbe.
|
108 | *
|
109 | * @publicApi
|
110 | */
|
111 | export class NgProbeToken {
|
112 | constructor(name, token) {
|
113 | this.name = name;
|
114 | this.token = token;
|
115 | }
|
116 | }
|
117 | /**
|
118 | * Creates a platform.
|
119 | * Platforms must be created on launch using this function.
|
120 | *
|
121 | * @publicApi
|
122 | */
|
123 | export function createPlatform(injector) {
|
124 | if (_platform && !_platform.destroyed &&
|
125 | !_platform.injector.get(ALLOW_MULTIPLE_PLATFORMS, false)) {
|
126 | throw new Error('There can be only one platform. Destroy the previous one to create a new one.');
|
127 | }
|
128 | publishDefaultGlobalUtils();
|
129 | _platform = injector.get(PlatformRef);
|
130 | const inits = injector.get(PLATFORM_INITIALIZER, null);
|
131 | if (inits)
|
132 | inits.forEach((init) => init());
|
133 | return _platform;
|
134 | }
|
135 | /**
|
136 | * Creates a factory for a platform. Can be used to provide or override `Providers` specific to
|
137 | * your application's runtime needs, such as `PLATFORM_INITIALIZER` and `PLATFORM_ID`.
|
138 | * @param parentPlatformFactory Another platform factory to modify. Allows you to compose factories
|
139 | * to build up configurations that might be required by different libraries or parts of the
|
140 | * application.
|
141 | * @param name Identifies the new platform factory.
|
142 | * @param providers A set of dependency providers for platforms created with the new factory.
|
143 | *
|
144 | * @publicApi
|
145 | */
|
146 | export function createPlatformFactory(parentPlatformFactory, name, providers = []) {
|
147 | const desc = `Platform: ${name}`;
|
148 | const marker = new InjectionToken(desc);
|
149 | return (extraProviders = []) => {
|
150 | let platform = getPlatform();
|
151 | if (!platform || platform.injector.get(ALLOW_MULTIPLE_PLATFORMS, false)) {
|
152 | if (parentPlatformFactory) {
|
153 | parentPlatformFactory(providers.concat(extraProviders).concat({ provide: marker, useValue: true }));
|
154 | }
|
155 | else {
|
156 | const injectedProviders = providers.concat(extraProviders).concat({ provide: marker, useValue: true }, {
|
157 | provide: INJECTOR_SCOPE,
|
158 | useValue: 'platform'
|
159 | });
|
160 | createPlatform(Injector.create({ providers: injectedProviders, name: desc }));
|
161 | }
|
162 | }
|
163 | return assertPlatform(marker);
|
164 | };
|
165 | }
|
166 | /**
|
167 | * Checks that there is currently a platform that contains the given token as a provider.
|
168 | *
|
169 | * @publicApi
|
170 | */
|
171 | export function assertPlatform(requiredToken) {
|
172 | const platform = getPlatform();
|
173 | if (!platform) {
|
174 | throw new Error('No platform exists!');
|
175 | }
|
176 | if (!platform.injector.get(requiredToken, null)) {
|
177 | throw new Error('A platform with a different configuration has been created. Please destroy it first.');
|
178 | }
|
179 | return platform;
|
180 | }
|
181 | /**
|
182 | * Destroys the current Angular platform and all Angular applications on the page.
|
183 | * Destroys all modules and listeners registered with the platform.
|
184 | *
|
185 | * @publicApi
|
186 | */
|
187 | export function destroyPlatform() {
|
188 | if (_platform && !_platform.destroyed) {
|
189 | _platform.destroy();
|
190 | }
|
191 | }
|
192 | /**
|
193 | * Returns the current platform.
|
194 | *
|
195 | * @publicApi
|
196 | */
|
197 | export function getPlatform() {
|
198 | return _platform && !_platform.destroyed ? _platform : null;
|
199 | }
|
200 | /**
|
201 | * The Angular platform is the entry point for Angular on a web page.
|
202 | * Each page has exactly one platform. Services (such as reflection) which are common
|
203 | * to every Angular application running on the page are bound in its scope.
|
204 | * A page's platform is initialized implicitly when a platform is created using a platform
|
205 | * factory such as `PlatformBrowser`, or explicitly by calling the `createPlatform()` function.
|
206 | *
|
207 | * @publicApi
|
208 | */
|
209 | export class PlatformRef {
|
210 | /** @internal */
|
211 | constructor(_injector) {
|
212 | this._injector = _injector;
|
213 | this._modules = [];
|
214 | this._destroyListeners = [];
|
215 | this._destroyed = false;
|
216 | }
|
217 | /**
|
218 | * Creates an instance of an `@NgModule` for the given platform for offline compilation.
|
219 | *
|
220 | * @usageNotes
|
221 | *
|
222 | * The following example creates the NgModule for a browser platform.
|
223 | *
|
224 | * ```typescript
|
225 | * my_module.ts:
|
226 | *
|
227 | * @NgModule({
|
228 | * imports: [BrowserModule]
|
229 | * })
|
230 | * class MyModule {}
|
231 | *
|
232 | * main.ts:
|
233 | * import {MyModuleNgFactory} from './my_module.ngfactory';
|
234 | * import {platformBrowser} from '@angular/platform-browser';
|
235 | *
|
236 | * let moduleRef = platformBrowser().bootstrapModuleFactory(MyModuleNgFactory);
|
237 | * ```
|
238 | *
|
239 | * @deprecated Passing NgModule factories as the `PlatformRef.bootstrapModuleFactory` function
|
240 | * argument is deprecated. Use the `PlatformRef.bootstrapModule` API instead.
|
241 | */
|
242 | bootstrapModuleFactory(moduleFactory, options) {
|
243 | // Note: We need to create the NgZone _before_ we instantiate the module,
|
244 | // as instantiating the module creates some providers eagerly.
|
245 | // So we create a mini parent injector that just contains the new NgZone and
|
246 | // pass that as parent to the NgModuleFactory.
|
247 | const ngZoneOption = options ? options.ngZone : undefined;
|
248 | const ngZoneEventCoalescing = (options && options.ngZoneEventCoalescing) || false;
|
249 | const ngZoneRunCoalescing = (options && options.ngZoneRunCoalescing) || false;
|
250 | const ngZone = getNgZone(ngZoneOption, { ngZoneEventCoalescing, ngZoneRunCoalescing });
|
251 | const providers = [{ provide: NgZone, useValue: ngZone }];
|
252 | // Note: Create ngZoneInjector within ngZone.run so that all of the instantiated services are
|
253 | // created within the Angular zone
|
254 | // Do not try to replace ngZone.run with ApplicationRef#run because ApplicationRef would then be
|
255 | // created outside of the Angular zone.
|
256 | return ngZone.run(() => {
|
257 | const ngZoneInjector = Injector.create({ providers: providers, parent: this.injector, name: moduleFactory.moduleType.name });
|
258 | const moduleRef = moduleFactory.create(ngZoneInjector);
|
259 | const exceptionHandler = moduleRef.injector.get(ErrorHandler, null);
|
260 | if (!exceptionHandler) {
|
261 | throw new Error('No ErrorHandler. Is platform module (BrowserModule) included?');
|
262 | }
|
263 | ngZone.runOutsideAngular(() => {
|
264 | const subscription = ngZone.onError.subscribe({
|
265 | next: (error) => {
|
266 | exceptionHandler.handleError(error);
|
267 | }
|
268 | });
|
269 | moduleRef.onDestroy(() => {
|
270 | remove(this._modules, moduleRef);
|
271 | subscription.unsubscribe();
|
272 | });
|
273 | });
|
274 | return _callAndReportToErrorHandler(exceptionHandler, ngZone, () => {
|
275 | const initStatus = moduleRef.injector.get(ApplicationInitStatus);
|
276 | initStatus.runInitializers();
|
277 | return initStatus.donePromise.then(() => {
|
278 | if (ivyEnabled) {
|
279 | // If the `LOCALE_ID` provider is defined at bootstrap then we set the value for ivy
|
280 | const localeId = moduleRef.injector.get(LOCALE_ID, DEFAULT_LOCALE_ID);
|
281 | setLocaleId(localeId || DEFAULT_LOCALE_ID);
|
282 | }
|
283 | this._moduleDoBootstrap(moduleRef);
|
284 | return moduleRef;
|
285 | });
|
286 | });
|
287 | });
|
288 | }
|
289 | /**
|
290 | * Creates an instance of an `@NgModule` for a given platform using the given runtime compiler.
|
291 | *
|
292 | * @usageNotes
|
293 | * ### Simple Example
|
294 | *
|
295 | * ```typescript
|
296 | * @NgModule({
|
297 | * imports: [BrowserModule]
|
298 | * })
|
299 | * class MyModule {}
|
300 | *
|
301 | * let moduleRef = platformBrowser().bootstrapModule(MyModule);
|
302 | * ```
|
303 | *
|
304 | */
|
305 | bootstrapModule(moduleType, compilerOptions = []) {
|
306 | const options = optionsReducer({}, compilerOptions);
|
307 | return compileNgModuleFactory(this.injector, options, moduleType)
|
308 | .then(moduleFactory => this.bootstrapModuleFactory(moduleFactory, options));
|
309 | }
|
310 | _moduleDoBootstrap(moduleRef) {
|
311 | const appRef = moduleRef.injector.get(ApplicationRef);
|
312 | if (moduleRef._bootstrapComponents.length > 0) {
|
313 | moduleRef._bootstrapComponents.forEach(f => appRef.bootstrap(f));
|
314 | }
|
315 | else if (moduleRef.instance.ngDoBootstrap) {
|
316 | moduleRef.instance.ngDoBootstrap(appRef);
|
317 | }
|
318 | else {
|
319 | throw new Error(`The module ${stringify(moduleRef.instance
|
320 | .constructor)} was bootstrapped, but it does not declare "@NgModule.bootstrap" components nor a "ngDoBootstrap" method. ` +
|
321 | `Please define one of these.`);
|
322 | }
|
323 | this._modules.push(moduleRef);
|
324 | }
|
325 | /**
|
326 | * Registers a listener to be called when the platform is destroyed.
|
327 | */
|
328 | onDestroy(callback) {
|
329 | this._destroyListeners.push(callback);
|
330 | }
|
331 | /**
|
332 | * Retrieves the platform {@link Injector}, which is the parent injector for
|
333 | * every Angular application on the page and provides singleton providers.
|
334 | */
|
335 | get injector() {
|
336 | return this._injector;
|
337 | }
|
338 | /**
|
339 | * Destroys the current Angular platform and all Angular applications on the page.
|
340 | * Destroys all modules and listeners registered with the platform.
|
341 | */
|
342 | destroy() {
|
343 | if (this._destroyed) {
|
344 | throw new Error('The platform has already been destroyed!');
|
345 | }
|
346 | this._modules.slice().forEach(module => module.destroy());
|
347 | this._destroyListeners.forEach(listener => listener());
|
348 | this._destroyed = true;
|
349 | }
|
350 | get destroyed() {
|
351 | return this._destroyed;
|
352 | }
|
353 | }
|
354 | PlatformRef.ɵfac = function PlatformRef_Factory(t) { return new (t || PlatformRef)(i0.ɵɵinject(i1.Injector)); };
|
355 | PlatformRef.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: PlatformRef, factory: PlatformRef.ɵfac });
|
356 | (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(PlatformRef, [{
|
357 | type: Injectable
|
358 | }], function () { return [{ type: i1.Injector }]; }, null); })();
|
359 | function getNgZone(ngZoneOption, extra) {
|
360 | let ngZone;
|
361 | if (ngZoneOption === 'noop') {
|
362 | ngZone = new NoopNgZone();
|
363 | }
|
364 | else {
|
365 | ngZone = (ngZoneOption === 'zone.js' ? undefined : ngZoneOption) || new NgZone({
|
366 | enableLongStackTrace: isDevMode(),
|
367 | shouldCoalesceEventChangeDetection: !!extra?.ngZoneEventCoalescing,
|
368 | shouldCoalesceRunChangeDetection: !!extra?.ngZoneRunCoalescing
|
369 | });
|
370 | }
|
371 | return ngZone;
|
372 | }
|
373 | function _callAndReportToErrorHandler(errorHandler, ngZone, callback) {
|
374 | try {
|
375 | const result = callback();
|
376 | if (isPromise(result)) {
|
377 | return result.catch((e) => {
|
378 | ngZone.runOutsideAngular(() => errorHandler.handleError(e));
|
379 | // rethrow as the exception handler might not do it
|
380 | throw e;
|
381 | });
|
382 | }
|
383 | return result;
|
384 | }
|
385 | catch (e) {
|
386 | ngZone.runOutsideAngular(() => errorHandler.handleError(e));
|
387 | // rethrow as the exception handler might not do it
|
388 | throw e;
|
389 | }
|
390 | }
|
391 | function optionsReducer(dst, objs) {
|
392 | if (Array.isArray(objs)) {
|
393 | dst = objs.reduce(optionsReducer, dst);
|
394 | }
|
395 | else {
|
396 | dst = { ...dst, ...objs };
|
397 | }
|
398 | return dst;
|
399 | }
|
400 | /**
|
401 | * A reference to an Angular application running on a page.
|
402 | *
|
403 | * @usageNotes
|
404 | *
|
405 | * {@a is-stable-examples}
|
406 | * ### isStable examples and caveats
|
407 | *
|
408 | * Note two important points about `isStable`, demonstrated in the examples below:
|
409 | * - the application will never be stable if you start any kind
|
410 | * of recurrent asynchronous task when the application starts
|
411 | * (for example for a polling process, started with a `setInterval`, a `setTimeout`
|
412 | * or using RxJS operators like `interval`);
|
413 | * - the `isStable` Observable runs outside of the Angular zone.
|
414 | *
|
415 | * Let's imagine that you start a recurrent task
|
416 | * (here incrementing a counter, using RxJS `interval`),
|
417 | * and at the same time subscribe to `isStable`.
|
418 | *
|
419 | * ```
|
420 | * constructor(appRef: ApplicationRef) {
|
421 | * appRef.isStable.pipe(
|
422 | * filter(stable => stable)
|
423 | * ).subscribe(() => console.log('App is stable now');
|
424 | * interval(1000).subscribe(counter => console.log(counter));
|
425 | * }
|
426 | * ```
|
427 | * In this example, `isStable` will never emit `true`,
|
428 | * and the trace "App is stable now" will never get logged.
|
429 | *
|
430 | * If you want to execute something when the app is stable,
|
431 | * you have to wait for the application to be stable
|
432 | * before starting your polling process.
|
433 | *
|
434 | * ```
|
435 | * constructor(appRef: ApplicationRef) {
|
436 | * appRef.isStable.pipe(
|
437 | * first(stable => stable),
|
438 | * tap(stable => console.log('App is stable now')),
|
439 | * switchMap(() => interval(1000))
|
440 | * ).subscribe(counter => console.log(counter));
|
441 | * }
|
442 | * ```
|
443 | * In this example, the trace "App is stable now" will be logged
|
444 | * and then the counter starts incrementing every second.
|
445 | *
|
446 | * Note also that this Observable runs outside of the Angular zone,
|
447 | * which means that the code in the subscription
|
448 | * to this Observable will not trigger the change detection.
|
449 | *
|
450 | * Let's imagine that instead of logging the counter value,
|
451 | * you update a field of your component
|
452 | * and display it in its template.
|
453 | *
|
454 | * ```
|
455 | * constructor(appRef: ApplicationRef) {
|
456 | * appRef.isStable.pipe(
|
457 | * first(stable => stable),
|
458 | * switchMap(() => interval(1000))
|
459 | * ).subscribe(counter => this.value = counter);
|
460 | * }
|
461 | * ```
|
462 | * As the `isStable` Observable runs outside the zone,
|
463 | * the `value` field will be updated properly,
|
464 | * but the template will not be refreshed!
|
465 | *
|
466 | * You'll have to manually trigger the change detection to update the template.
|
467 | *
|
468 | * ```
|
469 | * constructor(appRef: ApplicationRef, cd: ChangeDetectorRef) {
|
470 | * appRef.isStable.pipe(
|
471 | * first(stable => stable),
|
472 | * switchMap(() => interval(1000))
|
473 | * ).subscribe(counter => {
|
474 | * this.value = counter;
|
475 | * cd.detectChanges();
|
476 | * });
|
477 | * }
|
478 | * ```
|
479 | *
|
480 | * Or make the subscription callback run inside the zone.
|
481 | *
|
482 | * ```
|
483 | * constructor(appRef: ApplicationRef, zone: NgZone) {
|
484 | * appRef.isStable.pipe(
|
485 | * first(stable => stable),
|
486 | * switchMap(() => interval(1000))
|
487 | * ).subscribe(counter => zone.run(() => this.value = counter));
|
488 | * }
|
489 | * ```
|
490 | *
|
491 | * @publicApi
|
492 | */
|
493 | export class ApplicationRef {
|
494 | /** @internal */
|
495 | constructor(_zone, _injector, _exceptionHandler, _componentFactoryResolver, _initStatus) {
|
496 | this._zone = _zone;
|
497 | this._injector = _injector;
|
498 | this._exceptionHandler = _exceptionHandler;
|
499 | this._componentFactoryResolver = _componentFactoryResolver;
|
500 | this._initStatus = _initStatus;
|
501 | /** @internal */
|
502 | this._bootstrapListeners = [];
|
503 | this._views = [];
|
504 | this._runningTick = false;
|
505 | this._stable = true;
|
506 | /**
|
507 | * Get a list of component types registered to this application.
|
508 | * This list is populated even before the component is created.
|
509 | */
|
510 | this.componentTypes = [];
|
511 | /**
|
512 | * Get a list of components registered to this application.
|
513 | */
|
514 | this.components = [];
|
515 | this._onMicrotaskEmptySubscription = this._zone.onMicrotaskEmpty.subscribe({
|
516 | next: () => {
|
517 | this._zone.run(() => {
|
518 | this.tick();
|
519 | });
|
520 | }
|
521 | });
|
522 | const isCurrentlyStable = new Observable((observer) => {
|
523 | this._stable = this._zone.isStable && !this._zone.hasPendingMacrotasks &&
|
524 | !this._zone.hasPendingMicrotasks;
|
525 | this._zone.runOutsideAngular(() => {
|
526 | observer.next(this._stable);
|
527 | observer.complete();
|
528 | });
|
529 | });
|
530 | const isStable = new Observable((observer) => {
|
531 | // Create the subscription to onStable outside the Angular Zone so that
|
532 | // the callback is run outside the Angular Zone.
|
533 | let stableSub;
|
534 | this._zone.runOutsideAngular(() => {
|
535 | stableSub = this._zone.onStable.subscribe(() => {
|
536 | NgZone.assertNotInAngularZone();
|
537 | // Check whether there are no pending macro/micro tasks in the next tick
|
538 | // to allow for NgZone to update the state.
|
539 | scheduleMicroTask(() => {
|
540 | if (!this._stable && !this._zone.hasPendingMacrotasks &&
|
541 | !this._zone.hasPendingMicrotasks) {
|
542 | this._stable = true;
|
543 | observer.next(true);
|
544 | }
|
545 | });
|
546 | });
|
547 | });
|
548 | const unstableSub = this._zone.onUnstable.subscribe(() => {
|
549 | NgZone.assertInAngularZone();
|
550 | if (this._stable) {
|
551 | this._stable = false;
|
552 | this._zone.runOutsideAngular(() => {
|
553 | observer.next(false);
|
554 | });
|
555 | }
|
556 | });
|
557 | return () => {
|
558 | stableSub.unsubscribe();
|
559 | unstableSub.unsubscribe();
|
560 | };
|
561 | });
|
562 | this.isStable =
|
563 | merge(isCurrentlyStable, isStable.pipe(share()));
|
564 | }
|
565 | /**
|
566 | * Bootstrap a component onto the element identified by its selector or, optionally, to a
|
567 | * specified element.
|
568 | *
|
569 | * @usageNotes
|
570 | * ### Bootstrap process
|
571 | *
|
572 | * When bootstrapping a component, Angular mounts it onto a target DOM element
|
573 | * and kicks off automatic change detection. The target DOM element can be
|
574 | * provided using the `rootSelectorOrNode` argument.
|
575 | *
|
576 | * If the target DOM element is not provided, Angular tries to find one on a page
|
577 | * using the `selector` of the component that is being bootstrapped
|
578 | * (first matched element is used).
|
579 | *
|
580 | * ### Example
|
581 | *
|
582 | * Generally, we define the component to bootstrap in the `bootstrap` array of `NgModule`,
|
583 | * but it requires us to know the component while writing the application code.
|
584 | *
|
585 | * Imagine a situation where we have to wait for an API call to decide about the component to
|
586 | * bootstrap. We can use the `ngDoBootstrap` hook of the `NgModule` and call this method to
|
587 | * dynamically bootstrap a component.
|
588 | *
|
589 | * {@example core/ts/platform/platform.ts region='componentSelector'}
|
590 | *
|
591 | * Optionally, a component can be mounted onto a DOM element that does not match the
|
592 | * selector of the bootstrapped component.
|
593 | *
|
594 | * In the following example, we are providing a CSS selector to match the target element.
|
595 | *
|
596 | * {@example core/ts/platform/platform.ts region='cssSelector'}
|
597 | *
|
598 | * While in this example, we are providing reference to a DOM node.
|
599 | *
|
600 | * {@example core/ts/platform/platform.ts region='domNode'}
|
601 | */
|
602 | bootstrap(componentOrFactory, rootSelectorOrNode) {
|
603 | if (!this._initStatus.done) {
|
604 | throw new Error('Cannot bootstrap as there are still asynchronous initializers running. Bootstrap components in the `ngDoBootstrap` method of the root module.');
|
605 | }
|
606 | let componentFactory;
|
607 | if (componentOrFactory instanceof ComponentFactory) {
|
608 | componentFactory = componentOrFactory;
|
609 | }
|
610 | else {
|
611 | componentFactory =
|
612 | this._componentFactoryResolver.resolveComponentFactory(componentOrFactory);
|
613 | }
|
614 | this.componentTypes.push(componentFactory.componentType);
|
615 | // Create a factory associated with the current module if it's not bound to some other
|
616 | const ngModule = isBoundToModule(componentFactory) ? undefined : this._injector.get(NgModuleRef);
|
617 | const selectorOrNode = rootSelectorOrNode || componentFactory.selector;
|
618 | const compRef = componentFactory.create(Injector.NULL, [], selectorOrNode, ngModule);
|
619 | const nativeElement = compRef.location.nativeElement;
|
620 | const testability = compRef.injector.get(Testability, null);
|
621 | const testabilityRegistry = testability && compRef.injector.get(TestabilityRegistry);
|
622 | if (testability && testabilityRegistry) {
|
623 | testabilityRegistry.registerApplication(nativeElement, testability);
|
624 | }
|
625 | compRef.onDestroy(() => {
|
626 | this.detachView(compRef.hostView);
|
627 | remove(this.components, compRef);
|
628 | if (testabilityRegistry) {
|
629 | testabilityRegistry.unregisterApplication(nativeElement);
|
630 | }
|
631 | });
|
632 | this._loadComponent(compRef);
|
633 | // Note that we have still left the `isDevMode()` condition in order to avoid
|
634 | // creating a breaking change for projects that still use the View Engine.
|
635 | if ((typeof ngDevMode === 'undefined' || ngDevMode) && isDevMode()) {
|
636 | const _console = this._injector.get(Console);
|
637 | _console.log(`Angular is running in development mode. Call enableProdMode() to enable production mode.`);
|
638 | }
|
639 | return compRef;
|
640 | }
|
641 | /**
|
642 | * Invoke this method to explicitly process change detection and its side-effects.
|
643 | *
|
644 | * In development mode, `tick()` also performs a second change detection cycle to ensure that no
|
645 | * further changes are detected. If additional changes are picked up during this second cycle,
|
646 | * bindings in the app have side-effects that cannot be resolved in a single change detection
|
647 | * pass.
|
648 | * In this case, Angular throws an error, since an Angular application can only have one change
|
649 | * detection pass during which all change detection must complete.
|
650 | */
|
651 | tick() {
|
652 | if (this._runningTick) {
|
653 | throw new Error('ApplicationRef.tick is called recursively');
|
654 | }
|
655 | try {
|
656 | this._runningTick = true;
|
657 | for (let view of this._views) {
|
658 | view.detectChanges();
|
659 | }
|
660 | // Note that we have still left the `isDevMode()` condition in order to avoid
|
661 | // creating a breaking change for projects that still use the View Engine.
|
662 | if ((typeof ngDevMode === 'undefined' || ngDevMode) && isDevMode()) {
|
663 | for (let view of this._views) {
|
664 | view.checkNoChanges();
|
665 | }
|
666 | }
|
667 | }
|
668 | catch (e) {
|
669 | // Attention: Don't rethrow as it could cancel subscriptions to Observables!
|
670 | this._zone.runOutsideAngular(() => this._exceptionHandler.handleError(e));
|
671 | }
|
672 | finally {
|
673 | this._runningTick = false;
|
674 | }
|
675 | }
|
676 | /**
|
677 | * Attaches a view so that it will be dirty checked.
|
678 | * The view will be automatically detached when it is destroyed.
|
679 | * This will throw if the view is already attached to a ViewContainer.
|
680 | */
|
681 | attachView(viewRef) {
|
682 | const view = viewRef;
|
683 | this._views.push(view);
|
684 | view.attachToAppRef(this);
|
685 | }
|
686 | /**
|
687 | * Detaches a view from dirty checking again.
|
688 | */
|
689 | detachView(viewRef) {
|
690 | const view = viewRef;
|
691 | remove(this._views, view);
|
692 | view.detachFromAppRef();
|
693 | }
|
694 | _loadComponent(componentRef) {
|
695 | this.attachView(componentRef.hostView);
|
696 | this.tick();
|
697 | this.components.push(componentRef);
|
698 | // Get the listeners lazily to prevent DI cycles.
|
699 | const listeners = this._injector.get(APP_BOOTSTRAP_LISTENER, []).concat(this._bootstrapListeners);
|
700 | listeners.forEach((listener) => listener(componentRef));
|
701 | }
|
702 | /** @internal */
|
703 | ngOnDestroy() {
|
704 | this._views.slice().forEach((view) => view.destroy());
|
705 | this._onMicrotaskEmptySubscription.unsubscribe();
|
706 | }
|
707 | /**
|
708 | * Returns the number of attached views.
|
709 | */
|
710 | get viewCount() {
|
711 | return this._views.length;
|
712 | }
|
713 | }
|
714 | ApplicationRef.ɵfac = function ApplicationRef_Factory(t) { return new (t || ApplicationRef)(i0.ɵɵinject(i2.NgZone), i0.ɵɵinject(i1.Injector), i0.ɵɵinject(i3.ErrorHandler), i0.ɵɵinject(i4.ComponentFactoryResolver), i0.ɵɵinject(i5.ApplicationInitStatus)); };
|
715 | ApplicationRef.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ApplicationRef, factory: ApplicationRef.ɵfac });
|
716 | (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(ApplicationRef, [{
|
717 | type: Injectable
|
718 | }], function () { return [{ type: i2.NgZone }, { type: i1.Injector }, { type: i3.ErrorHandler }, { type: i4.ComponentFactoryResolver }, { type: i5.ApplicationInitStatus }]; }, null); })();
|
719 | function remove(list, el) {
|
720 | const index = list.indexOf(el);
|
721 | if (index > -1) {
|
722 | list.splice(index, 1);
|
723 | }
|
724 | }
|
725 | function _lastDefined(args) {
|
726 | for (let i = args.length - 1; i >= 0; i--) {
|
727 | if (args[i] !== undefined) {
|
728 | return args[i];
|
729 | }
|
730 | }
|
731 | return undefined;
|
732 | }
|
733 | function _mergeArrays(parts) {
|
734 | const result = [];
|
735 | parts.forEach((part) => part && result.push(...part));
|
736 | return result;
|
737 | }
|
738 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_ref.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_ref.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 './util/ng_jit_mode';\n\nimport {merge, Observable, Observer, Subscription} from 'rxjs';\nimport {share} from 'rxjs/operators';\n\nimport {ApplicationInitStatus} from './application_init';\nimport {APP_BOOTSTRAP_LISTENER, PLATFORM_INITIALIZER} from './application_tokens';\nimport {getCompilerFacade, JitCompilerUsage} from './compiler/compiler_facade';\nimport {Console} from './console';\nimport {Injectable} from './di/injectable';\nimport {InjectionToken} from './di/injection_token';\nimport {Injector} from './di/injector';\nimport {StaticProvider} from './di/interface/provider';\nimport {INJECTOR_SCOPE} from './di/scope';\nimport {ErrorHandler} from './error_handler';\nimport {DEFAULT_LOCALE_ID} from './i18n/localization';\nimport {LOCALE_ID} from './i18n/tokens';\nimport {Type} from './interface/type';\nimport {ivyEnabled} from './ivy_switch';\nimport {COMPILER_OPTIONS, CompilerFactory, CompilerOptions} from './linker/compiler';\nimport {ComponentFactory, ComponentRef} from './linker/component_factory';\nimport {ComponentFactoryBoundToModule, ComponentFactoryResolver} from './linker/component_factory_resolver';\nimport {InternalNgModuleRef, NgModuleFactory, NgModuleRef} from './linker/ng_module_factory';\nimport {InternalViewRef, ViewRef} from './linker/view_ref';\nimport {isComponentResourceResolutionQueueEmpty, resolveComponentResources} from './metadata/resource_loading';\nimport {assertNgModuleType} from './render3/assert';\nimport {ComponentFactory as R3ComponentFactory} from './render3/component_ref';\nimport {setLocaleId} from './render3/i18n/i18n_locale_id';\nimport {setJitOptions} from './render3/jit/jit_options';\nimport {NgModuleFactory as R3NgModuleFactory} from './render3/ng_module_ref';\nimport {publishDefaultGlobalUtils as _publishDefaultGlobalUtils} from './render3/util/global_utils';\nimport {Testability, TestabilityRegistry} from './testability/testability';\nimport {isDevMode} from './util/is_dev_mode';\nimport {isPromise} from './util/lang';\nimport {scheduleMicroTask} from './util/microtask';\nimport {stringify} from './util/stringify';\nimport {NgZone, NoopNgZone} from './zone/ng_zone';\n\nlet _platform: PlatformRef;\n\nlet compileNgModuleFactory:\n    <M>(injector: Injector, options: CompilerOptions, moduleType: Type<M>) =>\n        Promise<NgModuleFactory<M>> = compileNgModuleFactory__PRE_R3__;\n\nfunction compileNgModuleFactory__PRE_R3__<M>(\n    injector: Injector, options: CompilerOptions,\n    moduleType: Type<M>): Promise<NgModuleFactory<M>> {\n  const compilerFactory: CompilerFactory = injector.get(CompilerFactory);\n  const compiler = compilerFactory.createCompiler([options]);\n  return compiler.compileModuleAsync(moduleType);\n}\n\nexport function compileNgModuleFactory__POST_R3__<M>(\n    injector: Injector, options: CompilerOptions,\n    moduleType: Type<M>): Promise<NgModuleFactory<M>> {\n  ngDevMode && assertNgModuleType(moduleType);\n\n  const moduleFactory = new R3NgModuleFactory(moduleType);\n\n  // All of the logic below is irrelevant for AOT-compiled code.\n  if (typeof ngJitMode !== 'undefined' && !ngJitMode) {\n    return Promise.resolve(moduleFactory);\n  }\n\n  const compilerOptions = injector.get(COMPILER_OPTIONS, []).concat(options);\n\n  // Configure the compiler to use the provided options. This call may fail when multiple modules\n  // are bootstrapped with incompatible options, as a component can only be compiled according to\n  // a single set of options.\n  setJitOptions({\n    defaultEncapsulation: _lastDefined(compilerOptions.map(opts => opts.defaultEncapsulation)),\n    preserveWhitespaces: _lastDefined(compilerOptions.map(opts => opts.preserveWhitespaces)),\n  });\n\n  if (isComponentResourceResolutionQueueEmpty()) {\n    return Promise.resolve(moduleFactory);\n  }\n\n  const compilerProviders = _mergeArrays(compilerOptions.map(o => o.providers!));\n\n  // In case there are no compiler providers, we just return the module factory as\n  // there won't be any resource loader. This can happen with Ivy, because AOT compiled\n  // modules can be still passed through \"bootstrapModule\". In that case we shouldn't\n  // unnecessarily require the JIT compiler.\n  if (compilerProviders.length === 0) {\n    return Promise.resolve(moduleFactory);\n  }\n\n  const compiler = getCompilerFacade({\n    usage: JitCompilerUsage.Decorator,\n    kind: 'NgModule',\n    type: moduleType,\n  });\n  const compilerInjector = Injector.create({providers: compilerProviders});\n  const resourceLoader = compilerInjector.get(compiler.ResourceLoader);\n  // The resource loader can also return a string while the \"resolveComponentResources\"\n  // always expects a promise. Therefore we need to wrap the returned value in a promise.\n  return resolveComponentResources(url => Promise.resolve(resourceLoader.get(url)))\n      .then(() => moduleFactory);\n}\n\n// the `window.ng` global utilities are only available in non-VE versions of\n// Angular. The function switch below will make sure that the code is not\n// included into Angular when PRE mode is active.\nexport function publishDefaultGlobalUtils__PRE_R3__() {}\nexport function publishDefaultGlobalUtils__POST_R3__() {\n  ngDevMode && _publishDefaultGlobalUtils();\n}\n\nlet publishDefaultGlobalUtils: () => any = publishDefaultGlobalUtils__PRE_R3__;\n\nlet isBoundToModule: <C>(cf: ComponentFactory<C>) => boolean = isBoundToModule__PRE_R3__;\n\nexport function isBoundToModule__PRE_R3__<C>(cf: ComponentFactory<C>): boolean {\n  return cf instanceof ComponentFactoryBoundToModule;\n}\n\nexport function isBoundToModule__POST_R3__<C>(cf: ComponentFactory<C>): boolean {\n  return (cf as R3ComponentFactory<C>).isBoundToModule;\n}\n\nexport const ALLOW_MULTIPLE_PLATFORMS = new InjectionToken<boolean>('AllowMultipleToken');\n\n\n\n/**\n * A token for third-party components that can register themselves with NgProbe.\n *\n * @publicApi\n */\nexport class NgProbeToken {\n  constructor(public name: string, public token: any) {}\n}\n\n/**\n * Creates a platform.\n * Platforms must be created on launch using this function.\n *\n * @publicApi\n */\nexport function createPlatform(injector: Injector): PlatformRef {\n  if (_platform && !_platform.destroyed &&\n      !_platform.injector.get(ALLOW_MULTIPLE_PLATFORMS, false)) {\n    throw new Error(\n        'There can be only one platform. Destroy the previous one to create a new one.');\n  }\n  publishDefaultGlobalUtils();\n  _platform = injector.get(PlatformRef);\n  const inits = injector.get(PLATFORM_INITIALIZER, null);\n  if (inits) inits.forEach((init: any) => init());\n  return _platform;\n}\n\n/**\n * Creates a factory for a platform. Can be used to provide or override `Providers` specific to\n * your application's runtime needs, such as `PLATFORM_INITIALIZER` and `PLATFORM_ID`.\n * @param parentPlatformFactory Another platform factory to modify. Allows you to compose factories\n * to build up configurations that might be required by different libraries or parts of the\n * application.\n * @param name Identifies the new platform factory.\n * @param providers A set of dependency providers for platforms created with the new factory.\n *\n * @publicApi\n */\nexport function createPlatformFactory(\n    parentPlatformFactory: ((extraProviders?: StaticProvider[]) => PlatformRef)|null, name: string,\n    providers: StaticProvider[] = []): (extraProviders?: StaticProvider[]) => PlatformRef {\n  const desc = `Platform: ${name}`;\n  const marker = new InjectionToken(desc);\n  return (extraProviders: StaticProvider[] = []) => {\n    let platform = getPlatform();\n    if (!platform || platform.injector.get(ALLOW_MULTIPLE_PLATFORMS, false)) {\n      if (parentPlatformFactory) {\n        parentPlatformFactory(\n            providers.concat(extraProviders).concat({provide: marker, useValue: true}));\n      } else {\n        const injectedProviders: StaticProvider[] =\n            providers.concat(extraProviders).concat({provide: marker, useValue: true}, {\n              provide: INJECTOR_SCOPE,\n              useValue: 'platform'\n            });\n        createPlatform(Injector.create({providers: injectedProviders, name: desc}));\n      }\n    }\n    return assertPlatform(marker);\n  };\n}\n\n/**\n * Checks that there is currently a platform that contains the given token as a provider.\n *\n * @publicApi\n */\nexport function assertPlatform(requiredToken: any): PlatformRef {\n  const platform = getPlatform();\n\n  if (!platform) {\n    throw new Error('No platform exists!');\n  }\n\n  if (!platform.injector.get(requiredToken, null)) {\n    throw new Error(\n        'A platform with a different configuration has been created. Please destroy it first.');\n  }\n\n  return platform;\n}\n\n/**\n * Destroys the current Angular platform and all Angular applications on the page.\n * Destroys all modules and listeners registered with the platform.\n *\n * @publicApi\n */\nexport function destroyPlatform(): void {\n  if (_platform && !_platform.destroyed) {\n    _platform.destroy();\n  }\n}\n\n/**\n * Returns the current platform.\n *\n * @publicApi\n */\nexport function getPlatform(): PlatformRef|null {\n  return _platform && !_platform.destroyed ? _platform : null;\n}\n\n/**\n * Provides additional options to the bootstraping process.\n *\n *\n */\nexport interface BootstrapOptions {\n  /**\n   * Optionally specify which `NgZone` should be used.\n   *\n   * - Provide your own `NgZone` instance.\n   * - `zone.js` - Use default `NgZone` which requires `Zone.js`.\n   * - `noop` - Use `NoopNgZone` which does nothing.\n   */\n  ngZone?: NgZone|'zone.js'|'noop';\n\n  /**\n   * Optionally specify coalescing event change detections or not.\n   * Consider the following case.\n   *\n   * <div (click)=\"doSomething()\">\n   *   <button (click)=\"doSomethingElse()\"></button>\n   * </div>\n   *\n   * When button is clicked, because of the event bubbling, both\n   * event handlers will be called and 2 change detections will be\n   * triggered. We can colesce such kind of events to only trigger\n   * change detection only once.\n   *\n   * By default, this option will be false. So the events will not be\n   * coalesced and the change detection will be triggered multiple times.\n   * And if this option be set to true, the change detection will be\n   * triggered async by scheduling a animation frame. So in the case above,\n   * the change detection will only be triggered once.\n   */\n  ngZoneEventCoalescing?: boolean;\n\n  /**\n   * Optionally specify if `NgZone#run()` method invocations should be coalesced\n   * into a single change detection.\n   *\n   * Consider the following case.\n   *\n   * for (let i = 0; i < 10; i ++) {\n   *   ngZone.run(() => {\n   *     // do something\n   *   });\n   * }\n   *\n   * This case triggers the change detection multiple times.\n   * With ngZoneRunCoalescing options, all change detections in an event loop trigger only once.\n   * In addition, the change detection executes in requestAnimation.\n   *\n   */\n  ngZoneRunCoalescing?: boolean;\n}\n\n/**\n * The Angular platform is the entry point for Angular on a web page.\n * Each page has exactly one platform. Services (such as reflection) which are common\n * to every Angular application running on the page are bound in its scope.\n * A page's platform is initialized implicitly when a platform is created using a platform\n * factory such as `PlatformBrowser`, or explicitly by calling the `createPlatform()` function.\n *\n * @publicApi\n */\n@Injectable()\nexport class PlatformRef {\n  private _modules: NgModuleRef<any>[] = [];\n  private _destroyListeners: Function[] = [];\n  private _destroyed: boolean = false;\n\n  /** @internal */\n  constructor(private _injector: Injector) {}\n\n  /**\n   * Creates an instance of an `@NgModule` for the given platform for offline compilation.\n   *\n   * @usageNotes\n   *\n   * The following example creates the NgModule for a browser platform.\n   *\n   * ```typescript\n   * my_module.ts:\n   *\n   * @NgModule({\n   *   imports: [BrowserModule]\n   * })\n   * class MyModule {}\n   *\n   * main.ts:\n   * import {MyModuleNgFactory} from './my_module.ngfactory';\n   * import {platformBrowser} from '@angular/platform-browser';\n   *\n   * let moduleRef = platformBrowser().bootstrapModuleFactory(MyModuleNgFactory);\n   * ```\n   *\n   * @deprecated Passing NgModule factories as the `PlatformRef.bootstrapModuleFactory` function\n   *     argument is deprecated. Use the `PlatformRef.bootstrapModule` API instead.\n   */\n  bootstrapModuleFactory<M>(moduleFactory: NgModuleFactory<M>, options?: BootstrapOptions):\n      Promise<NgModuleRef<M>> {\n    // Note: We need to create the NgZone _before_ we instantiate the module,\n    // as instantiating the module creates some providers eagerly.\n    // So we create a mini parent injector that just contains the new NgZone and\n    // pass that as parent to the NgModuleFactory.\n    const ngZoneOption = options ? options.ngZone : undefined;\n    const ngZoneEventCoalescing = (options && options.ngZoneEventCoalescing) || false;\n    const ngZoneRunCoalescing = (options && options.ngZoneRunCoalescing) || false;\n    const ngZone = getNgZone(ngZoneOption, {ngZoneEventCoalescing, ngZoneRunCoalescing});\n    const providers: StaticProvider[] = [{provide: NgZone, useValue: ngZone}];\n    // Note: Create ngZoneInjector within ngZone.run so that all of the instantiated services are\n    // created within the Angular zone\n    // Do not try to replace ngZone.run with ApplicationRef#run because ApplicationRef would then be\n    // created outside of the Angular zone.\n    return ngZone.run(() => {\n      const ngZoneInjector = Injector.create(\n          {providers: providers, parent: this.injector, name: moduleFactory.moduleType.name});\n      const moduleRef = <InternalNgModuleRef<M>>moduleFactory.create(ngZoneInjector);\n      const exceptionHandler: ErrorHandler|null = moduleRef.injector.get(ErrorHandler, null);\n      if (!exceptionHandler) {\n        throw new Error('No ErrorHandler. Is platform module (BrowserModule) included?');\n      }\n      ngZone!.runOutsideAngular(() => {\n        const subscription = ngZone!.onError.subscribe({\n          next: (error: any) => {\n            exceptionHandler.handleError(error);\n          }\n        });\n        moduleRef.onDestroy(() => {\n          remove(this._modules, moduleRef);\n          subscription.unsubscribe();\n        });\n      });\n      return _callAndReportToErrorHandler(exceptionHandler, ngZone!, () => {\n        const initStatus: ApplicationInitStatus = moduleRef.injector.get(ApplicationInitStatus);\n        initStatus.runInitializers();\n        return initStatus.donePromise.then(() => {\n          if (ivyEnabled) {\n            // If the `LOCALE_ID` provider is defined at bootstrap then we set the value for ivy\n            const localeId = moduleRef.injector.get(LOCALE_ID, DEFAULT_LOCALE_ID);\n            setLocaleId(localeId || DEFAULT_LOCALE_ID);\n          }\n          this._moduleDoBootstrap(moduleRef);\n          return moduleRef;\n        });\n      });\n    });\n  }\n\n  /**\n   * Creates an instance of an `@NgModule` for a given platform using the given runtime compiler.\n   *\n   * @usageNotes\n   * ### Simple Example\n   *\n   * ```typescript\n   * @NgModule({\n   *   imports: [BrowserModule]\n   * })\n   * class MyModule {}\n   *\n   * let moduleRef = platformBrowser().bootstrapModule(MyModule);\n   * ```\n   *\n   */\n  bootstrapModule<M>(\n      moduleType: Type<M>,\n      compilerOptions: (CompilerOptions&BootstrapOptions)|\n      Array<CompilerOptions&BootstrapOptions> = []): Promise<NgModuleRef<M>> {\n    const options = optionsReducer({}, compilerOptions);\n    return compileNgModuleFactory(this.injector, options, moduleType)\n        .then(moduleFactory => this.bootstrapModuleFactory(moduleFactory, options));\n  }\n\n  private _moduleDoBootstrap(moduleRef: InternalNgModuleRef<any>): void {\n    const appRef = moduleRef.injector.get(ApplicationRef) as ApplicationRef;\n    if (moduleRef._bootstrapComponents.length > 0) {\n      moduleRef._bootstrapComponents.forEach(f => appRef.bootstrap(f));\n    } else if (moduleRef.instance.ngDoBootstrap) {\n      moduleRef.instance.ngDoBootstrap(appRef);\n    } else {\n      throw new Error(\n          `The module ${\n              stringify(\n                  moduleRef.instance\n                      .constructor)} was bootstrapped, but it does not declare \"@NgModule.bootstrap\" components nor a \"ngDoBootstrap\" method. ` +\n          `Please define one of these.`);\n    }\n    this._modules.push(moduleRef);\n  }\n\n  /**\n   * Registers a listener to be called when the platform is destroyed.\n   */\n  onDestroy(callback: () => void): void {\n    this._destroyListeners.push(callback);\n  }\n\n  /**\n   * Retrieves the platform {@link Injector}, which is the parent injector for\n   * every Angular application on the page and provides singleton providers.\n   */\n  get injector(): Injector {\n    return this._injector;\n  }\n\n  /**\n   * Destroys the current Angular platform and all Angular applications on the page.\n   * Destroys all modules and listeners registered with the platform.\n   */\n  destroy() {\n    if (this._destroyed) {\n      throw new Error('The platform has already been destroyed!');\n    }\n    this._modules.slice().forEach(module => module.destroy());\n    this._destroyListeners.forEach(listener => listener());\n    this._destroyed = true;\n  }\n\n  get destroyed() {\n    return this._destroyed;\n  }\n}\n\nfunction getNgZone(\n    ngZoneOption: NgZone|'zone.js'|'noop'|undefined,\n    extra?: {ngZoneEventCoalescing: boolean, ngZoneRunCoalescing: boolean}): NgZone {\n  let ngZone: NgZone;\n\n  if (ngZoneOption === 'noop') {\n    ngZone = new NoopNgZone();\n  } else {\n    ngZone = (ngZoneOption === 'zone.js' ? undefined : ngZoneOption) || new NgZone({\n               enableLongStackTrace: isDevMode(),\n               shouldCoalesceEventChangeDetection: !!extra?.ngZoneEventCoalescing,\n               shouldCoalesceRunChangeDetection: !!extra?.ngZoneRunCoalescing\n             });\n  }\n  return ngZone;\n}\n\nfunction _callAndReportToErrorHandler(\n    errorHandler: ErrorHandler, ngZone: NgZone, callback: () => any): any {\n  try {\n    const result = callback();\n    if (isPromise(result)) {\n      return result.catch((e: any) => {\n        ngZone.runOutsideAngular(() => errorHandler.handleError(e));\n        // rethrow as the exception handler might not do it\n        throw e;\n      });\n    }\n\n    return result;\n  } catch (e) {\n    ngZone.runOutsideAngular(() => errorHandler.handleError(e));\n    // rethrow as the exception handler might not do it\n    throw e;\n  }\n}\n\nfunction optionsReducer<T extends Object>(dst: any, objs: T|T[]): T {\n  if (Array.isArray(objs)) {\n    dst = objs.reduce(optionsReducer, dst);\n  } else {\n    dst = {...dst, ...(objs as any)};\n  }\n  return dst;\n}\n\n/**\n * A reference to an Angular application running on a page.\n *\n * @usageNotes\n *\n * {@a is-stable-examples}\n * ### isStable examples and caveats\n *\n * Note two important points about `isStable`, demonstrated in the examples below:\n * - the application will never be stable if you start any kind\n * of recurrent asynchronous task when the application starts\n * (for example for a polling process, started with a `setInterval`, a `setTimeout`\n * or using RxJS operators like `interval`);\n * - the `isStable` Observable runs outside of the Angular zone.\n *\n * Let's imagine that you start a recurrent task\n * (here incrementing a counter, using RxJS `interval`),\n * and at the same time subscribe to `isStable`.\n *\n * ```\n * constructor(appRef: ApplicationRef) {\n *   appRef.isStable.pipe(\n *      filter(stable => stable)\n *   ).subscribe(() => console.log('App is stable now');\n *   interval(1000).subscribe(counter => console.log(counter));\n * }\n * ```\n * In this example, `isStable` will never emit `true`,\n * and the trace \"App is stable now\" will never get logged.\n *\n * If you want to execute something when the app is stable,\n * you have to wait for the application to be stable\n * before starting your polling process.\n *\n * ```\n * constructor(appRef: ApplicationRef) {\n *   appRef.isStable.pipe(\n *     first(stable => stable),\n *     tap(stable => console.log('App is stable now')),\n *     switchMap(() => interval(1000))\n *   ).subscribe(counter => console.log(counter));\n * }\n * ```\n * In this example, the trace \"App is stable now\" will be logged\n * and then the counter starts incrementing every second.\n *\n * Note also that this Observable runs outside of the Angular zone,\n * which means that the code in the subscription\n * to this Observable will not trigger the change detection.\n *\n * Let's imagine that instead of logging the counter value,\n * you update a field of your component\n * and display it in its template.\n *\n * ```\n * constructor(appRef: ApplicationRef) {\n *   appRef.isStable.pipe(\n *     first(stable => stable),\n *     switchMap(() => interval(1000))\n *   ).subscribe(counter => this.value = counter);\n * }\n * ```\n * As the `isStable` Observable runs outside the zone,\n * the `value` field will be updated properly,\n * but the template will not be refreshed!\n *\n * You'll have to manually trigger the change detection to update the template.\n *\n * ```\n * constructor(appRef: ApplicationRef, cd: ChangeDetectorRef) {\n *   appRef.isStable.pipe(\n *     first(stable => stable),\n *     switchMap(() => interval(1000))\n *   ).subscribe(counter => {\n *     this.value = counter;\n *     cd.detectChanges();\n *   });\n * }\n * ```\n *\n * Or make the subscription callback run inside the zone.\n *\n * ```\n * constructor(appRef: ApplicationRef, zone: NgZone) {\n *   appRef.isStable.pipe(\n *     first(stable => stable),\n *     switchMap(() => interval(1000))\n *   ).subscribe(counter => zone.run(() => this.value = counter));\n * }\n * ```\n *\n * @publicApi\n */\n@Injectable()\nexport class ApplicationRef {\n  /** @internal */\n  private _bootstrapListeners: ((compRef: ComponentRef<any>) => void)[] = [];\n  private _views: InternalViewRef[] = [];\n  private _runningTick: boolean = false;\n  private _stable = true;\n  private _onMicrotaskEmptySubscription: Subscription;\n\n  /**\n   * Get a list of component types registered to this application.\n   * This list is populated even before the component is created.\n   */\n  public readonly componentTypes: Type<any>[] = [];\n\n  /**\n   * Get a list of components registered to this application.\n   */\n  public readonly components: ComponentRef<any>[] = [];\n\n  /**\n   * Returns an Observable that indicates when the application is stable or unstable.\n   *\n   * @see  [Usage notes](#is-stable-examples) for examples and caveats when using this API.\n   */\n  // TODO(issue/24571): remove '!'.\n  public readonly isStable!: Observable<boolean>;\n\n  /** @internal */\n  constructor(\n      private _zone: NgZone, private _injector: Injector, private _exceptionHandler: ErrorHandler,\n      private _componentFactoryResolver: ComponentFactoryResolver,\n      private _initStatus: ApplicationInitStatus) {\n    this._onMicrotaskEmptySubscription = this._zone.onMicrotaskEmpty.subscribe({\n      next: () => {\n        this._zone.run(() => {\n          this.tick();\n        });\n      }\n    });\n\n    const isCurrentlyStable = new Observable<boolean>((observer: Observer<boolean>) => {\n      this._stable = this._zone.isStable && !this._zone.hasPendingMacrotasks &&\n          !this._zone.hasPendingMicrotasks;\n      this._zone.runOutsideAngular(() => {\n        observer.next(this._stable);\n        observer.complete();\n      });\n    });\n\n    const isStable = new Observable<boolean>((observer: Observer<boolean>) => {\n      // Create the subscription to onStable outside the Angular Zone so that\n      // the callback is run outside the Angular Zone.\n      let stableSub: Subscription;\n      this._zone.runOutsideAngular(() => {\n        stableSub = this._zone.onStable.subscribe(() => {\n          NgZone.assertNotInAngularZone();\n\n          // Check whether there are no pending macro/micro tasks in the next tick\n          // to allow for NgZone to update the state.\n          scheduleMicroTask(() => {\n            if (!this._stable && !this._zone.hasPendingMacrotasks &&\n                !this._zone.hasPendingMicrotasks) {\n              this._stable = true;\n              observer.next(true);\n            }\n          });\n        });\n      });\n\n      const unstableSub: Subscription = this._zone.onUnstable.subscribe(() => {\n        NgZone.assertInAngularZone();\n        if (this._stable) {\n          this._stable = false;\n          this._zone.runOutsideAngular(() => {\n            observer.next(false);\n          });\n        }\n      });\n\n      return () => {\n        stableSub.unsubscribe();\n        unstableSub.unsubscribe();\n      };\n    });\n\n    (this as {isStable: Observable<boolean>}).isStable =\n        merge(isCurrentlyStable, isStable.pipe(share()));\n  }\n\n  /**\n   * Bootstrap a component onto the element identified by its selector or, optionally, to a\n   * specified element.\n   *\n   * @usageNotes\n   * ### Bootstrap process\n   *\n   * When bootstrapping a component, Angular mounts it onto a target DOM element\n   * and kicks off automatic change detection. The target DOM element can be\n   * provided using the `rootSelectorOrNode` argument.\n   *\n   * If the target DOM element is not provided, Angular tries to find one on a page\n   * using the `selector` of the component that is being bootstrapped\n   * (first matched element is used).\n   *\n   * ### Example\n   *\n   * Generally, we define the component to bootstrap in the `bootstrap` array of `NgModule`,\n   * but it requires us to know the component while writing the application code.\n   *\n   * Imagine a situation where we have to wait for an API call to decide about the component to\n   * bootstrap. We can use the `ngDoBootstrap` hook of the `NgModule` and call this method to\n   * dynamically bootstrap a component.\n   *\n   * {@example core/ts/platform/platform.ts region='componentSelector'}\n   *\n   * Optionally, a component can be mounted onto a DOM element that does not match the\n   * selector of the bootstrapped component.\n   *\n   * In the following example, we are providing a CSS selector to match the target element.\n   *\n   * {@example core/ts/platform/platform.ts region='cssSelector'}\n   *\n   * While in this example, we are providing reference to a DOM node.\n   *\n   * {@example core/ts/platform/platform.ts region='domNode'}\n   */\n  bootstrap<C>(component: Type<C>, rootSelectorOrNode?: string|any): ComponentRef<C>;\n\n  /**\n   * Bootstrap a component onto the element identified by its selector or, optionally, to a\n   * specified element.\n   *\n   * @usageNotes\n   * ### Bootstrap process\n   *\n   * When bootstrapping a component, Angular mounts it onto a target DOM element\n   * and kicks off automatic change detection. The target DOM element can be\n   * provided using the `rootSelectorOrNode` argument.\n   *\n   * If the target DOM element is not provided, Angular tries to find one on a page\n   * using the `selector` of the component that is being bootstrapped\n   * (first matched element is used).\n   *\n   * ### Example\n   *\n   * Generally, we define the component to bootstrap in the `bootstrap` array of `NgModule`,\n   * but it requires us to know the component while writing the application code.\n   *\n   * Imagine a situation where we have to wait for an API call to decide about the component to\n   * bootstrap. We can use the `ngDoBootstrap` hook of the `NgModule` and call this method to\n   * dynamically bootstrap a component.\n   *\n   * {@example core/ts/platform/platform.ts region='componentSelector'}\n   *\n   * Optionally, a component can be mounted onto a DOM element that does not match the\n   * selector of the bootstrapped component.\n   *\n   * In the following example, we are providing a CSS selector to match the target element.\n   *\n   * {@example core/ts/platform/platform.ts region='cssSelector'}\n   *\n   * While in this example, we are providing reference to a DOM node.\n   *\n   * {@example core/ts/platform/platform.ts region='domNode'}\n   *\n   * @deprecated Passing Component factories as the `Application.bootstrap` function argument is\n   *     deprecated. Pass Component Types instead.\n   */\n  bootstrap<C>(componentFactory: ComponentFactory<C>, rootSelectorOrNode?: string|any):\n      ComponentRef<C>;\n\n  /**\n   * Bootstrap a component onto the element identified by its selector or, optionally, to a\n   * specified element.\n   *\n   * @usageNotes\n   * ### Bootstrap process\n   *\n   * When bootstrapping a component, Angular mounts it onto a target DOM element\n   * and kicks off automatic change detection. The target DOM element can be\n   * provided using the `rootSelectorOrNode` argument.\n   *\n   * If the target DOM element is not provided, Angular tries to find one on a page\n   * using the `selector` of the component that is being bootstrapped\n   * (first matched element is used).\n   *\n   * ### Example\n   *\n   * Generally, we define the component to bootstrap in the `bootstrap` array of `NgModule`,\n   * but it requires us to know the component while writing the application code.\n   *\n   * Imagine a situation where we have to wait for an API call to decide about the component to\n   * bootstrap. We can use the `ngDoBootstrap` hook of the `NgModule` and call this method to\n   * dynamically bootstrap a component.\n   *\n   * {@example core/ts/platform/platform.ts region='componentSelector'}\n   *\n   * Optionally, a component can be mounted onto a DOM element that does not match the\n   * selector of the bootstrapped component.\n   *\n   * In the following example, we are providing a CSS selector to match the target element.\n   *\n   * {@example core/ts/platform/platform.ts region='cssSelector'}\n   *\n   * While in this example, we are providing reference to a DOM node.\n   *\n   * {@example core/ts/platform/platform.ts region='domNode'}\n   */\n  bootstrap<C>(componentOrFactory: ComponentFactory<C>|Type<C>, rootSelectorOrNode?: string|any):\n      ComponentRef<C> {\n    if (!this._initStatus.done) {\n      throw new Error(\n          'Cannot bootstrap as there are still asynchronous initializers running. Bootstrap components in the `ngDoBootstrap` method of the root module.');\n    }\n    let componentFactory: ComponentFactory<C>;\n    if (componentOrFactory instanceof ComponentFactory) {\n      componentFactory = componentOrFactory;\n    } else {\n      componentFactory =\n          this._componentFactoryResolver.resolveComponentFactory(componentOrFactory)!;\n    }\n    this.componentTypes.push(componentFactory.componentType);\n\n    // Create a factory associated with the current module if it's not bound to some other\n    const ngModule =\n        isBoundToModule(componentFactory) ? undefined : this._injector.get(NgModuleRef);\n    const selectorOrNode = rootSelectorOrNode || componentFactory.selector;\n    const compRef = componentFactory.create(Injector.NULL, [], selectorOrNode, ngModule);\n    const nativeElement = compRef.location.nativeElement;\n    const testability = compRef.injector.get(Testability, null);\n    const testabilityRegistry = testability && compRef.injector.get(TestabilityRegistry);\n    if (testability && testabilityRegistry) {\n      testabilityRegistry.registerApplication(nativeElement, testability);\n    }\n\n    compRef.onDestroy(() => {\n      this.detachView(compRef.hostView);\n      remove(this.components, compRef);\n      if (testabilityRegistry) {\n        testabilityRegistry.unregisterApplication(nativeElement);\n      }\n    });\n\n    this._loadComponent(compRef);\n    // Note that we have still left the `isDevMode()` condition in order to avoid\n    // creating a breaking change for projects that still use the View Engine.\n    if ((typeof ngDevMode === 'undefined' || ngDevMode) && isDevMode()) {\n      const _console = this._injector.get(Console);\n      _console.log(\n          `Angular is running in development mode. Call enableProdMode() to enable production mode.`);\n    }\n    return compRef;\n  }\n\n  /**\n   * Invoke this method to explicitly process change detection and its side-effects.\n   *\n   * In development mode, `tick()` also performs a second change detection cycle to ensure that no\n   * further changes are detected. If additional changes are picked up during this second cycle,\n   * bindings in the app have side-effects that cannot be resolved in a single change detection\n   * pass.\n   * In this case, Angular throws an error, since an Angular application can only have one change\n   * detection pass during which all change detection must complete.\n   */\n  tick(): void {\n    if (this._runningTick) {\n      throw new Error('ApplicationRef.tick is called recursively');\n    }\n\n    try {\n      this._runningTick = true;\n      for (let view of this._views) {\n        view.detectChanges();\n      }\n      // Note that we have still left the `isDevMode()` condition in order to avoid\n      // creating a breaking change for projects that still use the View Engine.\n      if ((typeof ngDevMode === 'undefined' || ngDevMode) && isDevMode()) {\n        for (let view of this._views) {\n          view.checkNoChanges();\n        }\n      }\n    } catch (e) {\n      // Attention: Don't rethrow as it could cancel subscriptions to Observables!\n      this._zone.runOutsideAngular(() => this._exceptionHandler.handleError(e));\n    } finally {\n      this._runningTick = false;\n    }\n  }\n\n  /**\n   * Attaches a view so that it will be dirty checked.\n   * The view will be automatically detached when it is destroyed.\n   * This will throw if the view is already attached to a ViewContainer.\n   */\n  attachView(viewRef: ViewRef): void {\n    const view = (viewRef as InternalViewRef);\n    this._views.push(view);\n    view.attachToAppRef(this);\n  }\n\n  /**\n   * Detaches a view from dirty checking again.\n   */\n  detachView(viewRef: ViewRef): void {\n    const view = (viewRef as InternalViewRef);\n    remove(this._views, view);\n    view.detachFromAppRef();\n  }\n\n  private _loadComponent(componentRef: ComponentRef<any>): void {\n    this.attachView(componentRef.hostView);\n    this.tick();\n    this.components.push(componentRef);\n    // Get the listeners lazily to prevent DI cycles.\n    const listeners =\n        this._injector.get(APP_BOOTSTRAP_LISTENER, []).concat(this._bootstrapListeners);\n    listeners.forEach((listener) => listener(componentRef));\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this._views.slice().forEach((view) => view.destroy());\n    this._onMicrotaskEmptySubscription.unsubscribe();\n  }\n\n  /**\n   * Returns the number of attached views.\n   */\n  get viewCount() {\n    return this._views.length;\n  }\n}\n\nfunction remove<T>(list: T[], el: T): void {\n  const index = list.indexOf(el);\n  if (index > -1) {\n    list.splice(index, 1);\n  }\n}\n\nfunction _lastDefined<T>(args: T[]): T|undefined {\n  for (let i = args.length - 1; i >= 0; i--) {\n    if (args[i] !== undefined) {\n      return args[i];\n    }\n  }\n  return undefined;\n}\n\nfunction _mergeArrays(parts: any[][]): any[] {\n  const result: any[] = [];\n  parts.forEach((part) => part && result.push(...part));\n  return result;\n}\n"]} |
\ | No newline at end of file |