@angular/core 13.2.0 → 14.0.0-next.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/core.d.ts +78 -80
  2. package/esm2020/src/application_init.mjs +1 -1
  3. package/esm2020/src/application_ref.mjs +3 -22
  4. package/esm2020/src/change_detection/change_detection.mjs +2 -3
  5. package/esm2020/src/compiler/compiler_facade_interface.mjs +1 -1
  6. package/esm2020/src/core_private_export.mjs +2 -1
  7. package/esm2020/src/debug/debug_node.mjs +128 -45
  8. package/esm2020/src/di/r3_injector.mjs +5 -15
  9. package/esm2020/src/di/reflective_injector.mjs +1 -1
  10. package/esm2020/src/errors.mjs +22 -5
  11. package/esm2020/src/metadata/directives.mjs +14 -5
  12. package/esm2020/src/reflection/reflector.mjs +1 -1
  13. package/esm2020/src/render3/context_discovery.mjs +1 -1
  14. package/esm2020/src/render3/instructions/shared.mjs +2 -2
  15. package/esm2020/src/render3/jit/directive.mjs +5 -2
  16. package/esm2020/src/render3/jit/pipe.mjs +5 -2
  17. package/esm2020/src/util/coercion.mjs +12 -0
  18. package/esm2020/src/version.mjs +1 -1
  19. package/esm2020/testing/src/logger.mjs +3 -3
  20. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  21. package/esm2020/testing/src/r3_test_bed.mjs +6 -1
  22. package/fesm2015/core.mjs +191 -93
  23. package/fesm2015/core.mjs.map +1 -1
  24. package/fesm2015/testing.mjs +6 -1
  25. package/fesm2015/testing.mjs.map +1 -1
  26. package/fesm2020/core.mjs +191 -93
  27. package/fesm2020/core.mjs.map +1 -1
  28. package/fesm2020/testing.mjs +6 -1
  29. package/fesm2020/testing.mjs.map +1 -1
  30. package/package.json +1 -1
  31. package/schematics/migrations/typed-forms/index.js +2 -2
  32. package/schematics/migrations/typed-forms/util.js +3 -8
  33. package/schematics/migrations.json +6 -16
  34. package/testing/testing.d.ts +1 -1
  35. package/schematics/migrations/router-link-empty-expression/analyze_template.d.ts +0 -11
  36. package/schematics/migrations/router-link-empty-expression/analyze_template.js +0 -34
  37. package/schematics/migrations/router-link-empty-expression/angular/html_routerlink_empty_expr_visitor.d.ts +0 -20
  38. package/schematics/migrations/router-link-empty-expression/angular/html_routerlink_empty_expr_visitor.js +0 -47
  39. package/schematics/migrations/router-link-empty-expression/index.d.ts +0 -11
  40. package/schematics/migrations/router-link-empty-expression/index.js +0 -170
  41. package/schematics/migrations/testbed-teardown/index.d.ts +0 -11
  42. package/schematics/migrations/testbed-teardown/index.js +0 -92
  43. package/schematics/migrations/testbed-teardown/util.d.ts +0 -35
  44. package/schematics/migrations/testbed-teardown/util.js +0 -188
package/core.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v13.2.0
2
+ * @license Angular v14.0.0-next.2
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -1702,13 +1702,18 @@ export declare const CUSTOM_ELEMENTS_SCHEMA: SchemaMetadata;
1702
1702
  * @see [Basics of testing components](guide/testing-components-basics)
1703
1703
  * @see [Testing utility APIs](guide/testing-utility-apis)
1704
1704
  */
1705
- export declare interface DebugElement extends DebugNode {
1705
+ export declare class DebugElement extends DebugNode {
1706
+ constructor(nativeNode: Element);
1707
+ /**
1708
+ * The underlying DOM element at the root of the component.
1709
+ */
1710
+ get nativeElement(): any;
1706
1711
  /**
1707
1712
  * The element tag name, if it is an element.
1708
1713
  */
1709
- readonly name: string;
1714
+ get name(): string;
1710
1715
  /**
1711
- * A map of property names to property values for an element.
1716
+ * Gets a map of property names to property values for an element.
1712
1717
  *
1713
1718
  * This map includes:
1714
1719
  * - Regular property bindings (e.g. `[id]="id"`)
@@ -1719,13 +1724,23 @@ export declare interface DebugElement extends DebugNode {
1719
1724
  * - input property bindings (e.g. `[myCustomInput]="value"`)
1720
1725
  * - attribute bindings (e.g. `[attr.role]="menu"`)
1721
1726
  */
1722
- readonly properties: {
1727
+ get properties(): {
1723
1728
  [key: string]: any;
1724
1729
  };
1725
1730
  /**
1726
1731
  * A map of attribute names to attribute values for an element.
1727
1732
  */
1728
- readonly attributes: {
1733
+ get attributes(): {
1734
+ [key: string]: string | null;
1735
+ };
1736
+ /**
1737
+ * The inline styles of the DOM element.
1738
+ *
1739
+ * Will be `null` if there is no `style` property on the underlying DOM element.
1740
+ *
1741
+ * @see [ElementCSSInlineStyle](https://developer.mozilla.org/en-US/docs/Web/API/ElementCSSInlineStyle/style)
1742
+ */
1743
+ get styles(): {
1729
1744
  [key: string]: string | null;
1730
1745
  };
1731
1746
  /**
@@ -1738,33 +1753,19 @@ export declare interface DebugElement extends DebugNode {
1738
1753
  *
1739
1754
  * @see [Element.className](https://developer.mozilla.org/en-US/docs/Web/API/Element/className)
1740
1755
  */
1741
- readonly classes: {
1756
+ get classes(): {
1742
1757
  [key: string]: boolean;
1743
1758
  };
1744
- /**
1745
- * The inline styles of the DOM element.
1746
- *
1747
- * Will be `null` if there is no `style` property on the underlying DOM element.
1748
- *
1749
- * @see [ElementCSSInlineStyle](https://developer.mozilla.org/en-US/docs/Web/API/ElementCSSInlineStyle/style)
1750
- */
1751
- readonly styles: {
1752
- [key: string]: string | null;
1753
- };
1754
1759
  /**
1755
1760
  * The `childNodes` of the DOM element as a `DebugNode` array.
1756
1761
  *
1757
1762
  * @see [Node.childNodes](https://developer.mozilla.org/en-US/docs/Web/API/Node/childNodes)
1758
1763
  */
1759
- readonly childNodes: DebugNode[];
1760
- /**
1761
- * The underlying DOM element at the root of the component.
1762
- */
1763
- readonly nativeElement: any;
1764
+ get childNodes(): DebugNode[];
1764
1765
  /**
1765
1766
  * The immediate `DebugElement` children. Walk the tree by descending through `children`.
1766
1767
  */
1767
- readonly children: DebugElement[];
1768
+ get children(): DebugElement[];
1768
1769
  /**
1769
1770
  * @returns the first `DebugElement` that matches the predicate at any depth in the subtree.
1770
1771
  */
@@ -1792,13 +1793,6 @@ export declare interface DebugElement extends DebugNode {
1792
1793
  triggerEventHandler(eventName: string, eventObj: any): void;
1793
1794
  }
1794
1795
 
1795
- /**
1796
- * @publicApi
1797
- */
1798
- export declare const DebugElement: {
1799
- new (...args: any[]): DebugElement;
1800
- };
1801
-
1802
1796
  /**
1803
1797
  * @publicApi
1804
1798
  */
@@ -1811,28 +1805,24 @@ export declare class DebugEventListener {
1811
1805
  /**
1812
1806
  * @publicApi
1813
1807
  */
1814
- export declare interface DebugNode {
1808
+ export declare class DebugNode {
1815
1809
  /**
1816
- * The callbacks attached to the component's @Output properties and/or the element's event
1817
- * properties.
1810
+ * The underlying DOM node.
1818
1811
  */
1819
- readonly listeners: DebugEventListener[];
1812
+ readonly nativeNode: any;
1813
+ constructor(nativeNode: Node);
1820
1814
  /**
1821
1815
  * The `DebugElement` parent. Will be `null` if this is the root element.
1822
1816
  */
1823
- readonly parent: DebugElement | null;
1824
- /**
1825
- * The underlying DOM node.
1826
- */
1827
- readonly nativeNode: any;
1817
+ get parent(): DebugElement | null;
1828
1818
  /**
1829
1819
  * The host dependency injector. For example, the root element's component instance injector.
1830
1820
  */
1831
- readonly injector: Injector;
1821
+ get injector(): Injector;
1832
1822
  /**
1833
1823
  * The element's own component instance, if it has one.
1834
1824
  */
1835
- readonly componentInstance: any;
1825
+ get componentInstance(): any;
1836
1826
  /**
1837
1827
  * An object that provides parent context for this element. Often an ancestor component instance
1838
1828
  * that governs this element.
@@ -1841,28 +1831,26 @@ export declare interface DebugNode {
1841
1831
  * property is the value of the row instance value. For example, the `hero` in `*ngFor="let hero
1842
1832
  * of heroes"`.
1843
1833
  */
1844
- readonly context: any;
1834
+ get context(): any;
1835
+ /**
1836
+ * The callbacks attached to the component's @Output properties and/or the element's event
1837
+ * properties.
1838
+ */
1839
+ get listeners(): DebugEventListener[];
1845
1840
  /**
1846
1841
  * Dictionary of objects associated with template local variables (e.g. #foo), keyed by the local
1847
1842
  * variable name.
1848
1843
  */
1849
- readonly references: {
1844
+ get references(): {
1850
1845
  [key: string]: any;
1851
1846
  };
1852
1847
  /**
1853
1848
  * This component's injector lookup tokens. Includes the component itself plus the tokens that the
1854
1849
  * component lists in its providers metadata.
1855
1850
  */
1856
- readonly providerTokens: any[];
1851
+ get providerTokens(): any[];
1857
1852
  }
1858
1853
 
1859
- /**
1860
- * @publicApi
1861
- */
1862
- export declare const DebugNode: {
1863
- new (...args: any[]): DebugNode;
1864
- };
1865
-
1866
1854
  /**
1867
1855
  * A logical node which comprise into `LView`s.
1868
1856
  *
@@ -2779,7 +2767,7 @@ export declare interface ForwardRefFn {
2779
2767
  /**
2780
2768
  * @publicApi
2781
2769
  */
2782
- declare const getDebugNode: (nativeNode: any) => DebugNode | null;
2770
+ declare function getDebugNode(nativeNode: any): DebugNode | null;
2783
2771
  export { getDebugNode }
2784
2772
  export { getDebugNode as ɵgetDebugNode }
2785
2773
 
@@ -3072,19 +3060,20 @@ export declare interface HostListener {
3072
3060
  *
3073
3061
  * ```
3074
3062
  *
3075
- * The following example registers another DOM event handler that listens for key-press events.
3063
+ * The following example registers another DOM event handler that listens for `Enter` key-press
3064
+ * events on the global `window`.
3076
3065
  * ``` ts
3077
3066
  * import { HostListener, Component } from "@angular/core";
3078
3067
  *
3079
3068
  * @Component({
3080
3069
  * selector: 'app',
3081
- * template: `<h1>Hello, you have pressed keys {{counter}} number of times!</h1> Press any key to
3082
- * increment the counter.
3070
+ * template: `<h1>Hello, you have pressed enter {{counter}} number of times!</h1> Press enter key
3071
+ * to increment the counter.
3083
3072
  * <button (click)="resetCounter()">Reset Counter</button>`
3084
3073
  * })
3085
3074
  * class AppComponent {
3086
3075
  * counter = 0;
3087
- * @HostListener('window:keydown', ['$event'])
3076
+ * @HostListener('window:keydown.enter', ['$event'])
3088
3077
  * handleKeyDown(event: KeyboardEvent) {
3089
3078
  * this.counter++;
3090
3079
  * }
@@ -3093,6 +3082,14 @@ export declare interface HostListener {
3093
3082
  * }
3094
3083
  * }
3095
3084
  * ```
3085
+ * The list of valid key names for `keydown` and `keyup` events
3086
+ * can be found here:
3087
+ * https://www.w3.org/TR/DOM-Level-3-Events-key/#named-key-attribute-values
3088
+ *
3089
+ * Note that keys can also be combined, e.g. `@HostListener('keydown.shift.a')`.
3090
+ *
3091
+ * The global target names that can be used to prefix an event name are
3092
+ * `document:`, `window:` and `body:`.
3096
3093
  *
3097
3094
  * @Annotation
3098
3095
  * @publicApi
@@ -5583,33 +5580,14 @@ export declare class PlatformRef {
5583
5580
  private _destroyListeners;
5584
5581
  private _destroyed;
5585
5582
  /**
5586
- * Creates an instance of an `@NgModule` for the given platform for offline compilation.
5587
- *
5588
- * @usageNotes
5589
- *
5590
- * The following example creates the NgModule for a browser platform.
5591
- *
5592
- * ```typescript
5593
- * my_module.ts:
5594
- *
5595
- * @NgModule({
5596
- * imports: [BrowserModule]
5597
- * })
5598
- * class MyModule {}
5599
- *
5600
- * main.ts:
5601
- * import {MyModuleNgFactory} from './my_module.ngfactory';
5602
- * import {platformBrowser} from '@angular/platform-browser';
5603
- *
5604
- * let moduleRef = platformBrowser().bootstrapModuleFactory(MyModuleNgFactory);
5605
- * ```
5583
+ * Creates an instance of an `@NgModule` for the given platform.
5606
5584
  *
5607
5585
  * @deprecated Passing NgModule factories as the `PlatformRef.bootstrapModuleFactory` function
5608
5586
  * argument is deprecated. Use the `PlatformRef.bootstrapModule` API instead.
5609
5587
  */
5610
5588
  bootstrapModuleFactory<M>(moduleFactory: NgModuleFactory<M>, options?: BootstrapOptions): Promise<NgModuleRef<M>>;
5611
5589
  /**
5612
- * Creates an instance of an `@NgModule` for a given platform using the given runtime compiler.
5590
+ * Creates an instance of an `@NgModule` for a given platform.
5613
5591
  *
5614
5592
  * @usageNotes
5615
5593
  * ### Simple Example
@@ -6028,6 +6006,7 @@ declare interface R3DeclareDirectiveFacade {
6028
6006
  exportAs?: string[];
6029
6007
  usesInheritance?: boolean;
6030
6008
  usesOnChanges?: boolean;
6009
+ isStandalone?: boolean;
6031
6010
  }
6032
6011
 
6033
6012
  declare interface R3DeclareFactoryFacade {
@@ -9455,6 +9434,10 @@ export declare enum ɵChangeDetectorStatus {
9455
9434
 
9456
9435
  export declare function ɵclearResolutionOfComponentResourcesQueue(): Map<Type<any>, Component>;
9457
9436
 
9437
+
9438
+ /** Coerces a value (typically a string) to a boolean. */
9439
+ export declare function ɵcoerceToBoolean(value: unknown): boolean;
9440
+
9458
9441
  /**
9459
9442
  * Compile an Angular component according to its decorator metadata, and patch the resulting
9460
9443
  * component def (ɵcmp) onto the component type.
@@ -9802,7 +9785,7 @@ export declare function ɵfindLocaleData(locale: string): any;
9802
9785
  */
9803
9786
  export declare function ɵflushModuleScopingQueueAsMuchAsPossible(): void;
9804
9787
 
9805
- export declare const ɵgetDebugNodeR2: (nativeNode: any) => DebugNode | null;
9788
+ export declare function ɵgetDebugNodeR2(_nativeNode: any): DebugNode | null;
9806
9789
 
9807
9790
  /**
9808
9791
  * Retrieves directive instances associated with a given DOM node. Does not include
@@ -10525,9 +10508,24 @@ export declare function ɵresolveComponentResources(resourceResolver: (url: stri
10525
10508
  text(): Promise<string>;
10526
10509
  }>)): Promise<void>;
10527
10510
 
10528
- export declare class ɵRuntimeError<T = RuntimeErrorCode> extends Error {
10511
+ /**
10512
+ * Class that represents a runtime error.
10513
+ * Formats and outputs the error message in a consistent way.
10514
+ *
10515
+ * Example:
10516
+ * ```
10517
+ * throw new RuntimeError(
10518
+ * RuntimeErrorCode.INJECTOR_ALREADY_DESTROYED,
10519
+ * ngDevMode && 'Injector has already been destroyed.');
10520
+ * ```
10521
+ *
10522
+ * Note: the `message` argument contains a descriptive error message as a string in development
10523
+ * mode (when the `ngDevMode` is defined). In production mode (after tree-shaking pass), the
10524
+ * `message` argument becomes `false`, thus we account for it in the typings and the runtime logic.
10525
+ */
10526
+ export declare class ɵRuntimeError<T extends number = RuntimeErrorCode> extends Error {
10529
10527
  code: T;
10530
- constructor(code: T, message: string);
10528
+ constructor(code: T, message: null | false | string);
10531
10529
  }
10532
10530
 
10533
10531
  /**
@@ -137,4 +137,4 @@ ApplicationInitStatus.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: Ap
137
137
  }, {
138
138
  type: Optional
139
139
  }] }]; }, null); })();
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_init.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_init.ts"],"names":[],"mappings":"AASA,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAClE,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,aAAa,CAAC;AACpD,OAAO,EAAC,IAAI,EAAC,MAAM,aAAa,CAAC;;AAGjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqEG;AACH,MAAM,CAAC,MAAM,eAAe,GACxB,IAAI,cAAc,CACd,yBAAyB,CAAC,CAAC;AAEnC;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IAOhC,YAAkE,QACc;QADd,aAAQ,GAAR,QAAQ,CACM;QAPxE,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,IAAI,CAAC;QACd,gBAAW,GAAG,KAAK,CAAC;QAEZ,SAAI,GAAG,KAAK,CAAC;QAI3B,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO;SACR;QAED,MAAM,iBAAiB,GAAmB,EAAE,CAAC;QAE7C,MAAM,QAAQ,GAAG,GAAG,EAAE;YACnB,IAAwB,CAAC,IAAI,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtC,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE;oBACzB,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACpC;qBAAM,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE;oBACnC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;wBAChE,UAAU,CAAC,SAAS,CAAC,EAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAC,CAAC,CAAC;oBAC3D,CAAC,CAAC,CAAC;oBACH,iBAAiB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;iBAC7C;aACF;SACF;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;aACzB,IAAI,CAAC,GAAG,EAAE;YACT,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QAEP,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,QAAQ,EAAE,CAAC;SACZ;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;;0FAtDU,qBAAqB,cAOZ,eAAe;2EAPxB,qBAAqB,WAArB,qBAAqB;sFAArB,qBAAqB;cADjC,UAAU;;sBAQI,MAAM;uBAAC,eAAe;;sBAAG,QAAQ","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 {Observable} from 'rxjs';\nimport {Inject, Injectable, InjectionToken, Optional} from './di';\nimport {isObservable, isPromise} from './util/lang';\nimport {noop} from './util/noop';\n\n\n/**\n * A [DI token](guide/glossary#di-token \"DI token definition\") that you can use to provide\n * one or more initialization functions.\n *\n * The provided functions are injected at application startup and executed during\n * app initialization. If any of these functions returns a Promise or an Observable, initialization\n * does not complete until the Promise is resolved or the Observable is completed.\n *\n * You can, for example, create a factory function that loads language data\n * or an external configuration, and provide that function to the `APP_INITIALIZER` token.\n * The function is executed during the application bootstrap process,\n * and the needed data is available on startup.\n *\n * @see `ApplicationInitStatus`\n *\n * @usageNotes\n *\n * The following example illustrates how to configure a multi-provider using `APP_INITIALIZER` token\n * and a function returning a promise.\n *\n * ```\n *  function initializeApp(): Promise<any> {\n *    return new Promise((resolve, reject) => {\n *      // Do some asynchronous stuff\n *      resolve();\n *    });\n *  }\n *\n *  @NgModule({\n *   imports: [BrowserModule],\n *   declarations: [AppComponent],\n *   bootstrap: [AppComponent],\n *   providers: [{\n *     provide: APP_INITIALIZER,\n *     useFactory: () => initializeApp,\n *     multi: true\n *    }]\n *   })\n *  export class AppModule {}\n * ```\n *\n * It's also possible to configure a multi-provider using `APP_INITIALIZER` token and a function\n * returning an observable, see an example below. Note: the `HttpClient` in this example is used for\n * demo purposes to illustrate how the factory function can work with other providers available\n * through DI.\n *\n * ```\n *  function initializeAppFactory(httpClient: HttpClient): () => Observable<any> {\n *   return () => httpClient.get(\"https://someUrl.com/api/user\")\n *     .pipe(\n *        tap(user => { ... })\n *     );\n *  }\n *\n *  @NgModule({\n *    imports: [BrowserModule, HttpClientModule],\n *    declarations: [AppComponent],\n *    bootstrap: [AppComponent],\n *    providers: [{\n *      provide: APP_INITIALIZER,\n *      useFactory: initializeAppFactory,\n *      deps: [HttpClient],\n *      multi: true\n *    }]\n *  })\n *  export class AppModule {}\n * ```\n *\n * @publicApi\n */\nexport const APP_INITIALIZER =\n    new InjectionToken<ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>>(\n        'Application Initializer');\n\n/**\n * A class that reflects the state of running {@link APP_INITIALIZER} functions.\n *\n * @publicApi\n */\n@Injectable()\nexport class ApplicationInitStatus {\n  private resolve = noop;\n  private reject = noop;\n  private initialized = false;\n  public readonly donePromise: Promise<any>;\n  public readonly done = false;\n\n  constructor(@Inject(APP_INITIALIZER) @Optional() private readonly appInits:\n                  ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>) {\n    this.donePromise = new Promise((res, rej) => {\n      this.resolve = res;\n      this.reject = rej;\n    });\n  }\n\n  /** @internal */\n  runInitializers() {\n    if (this.initialized) {\n      return;\n    }\n\n    const asyncInitPromises: Promise<any>[] = [];\n\n    const complete = () => {\n      (this as {done: boolean}).done = true;\n      this.resolve();\n    };\n\n    if (this.appInits) {\n      for (let i = 0; i < this.appInits.length; i++) {\n        const initResult = this.appInits[i]();\n        if (isPromise(initResult)) {\n          asyncInitPromises.push(initResult);\n        } else if (isObservable(initResult)) {\n          const observableAsPromise = new Promise<void>((resolve, reject) => {\n            initResult.subscribe({complete: resolve, error: reject});\n          });\n          asyncInitPromises.push(observableAsPromise);\n        }\n      }\n    }\n\n    Promise.all(asyncInitPromises)\n        .then(() => {\n          complete();\n        })\n        .catch(e => {\n          this.reject(e);\n        });\n\n    if (asyncInitPromises.length === 0) {\n      complete();\n    }\n    this.initialized = true;\n  }\n}\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_init.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_init.ts"],"names":[],"mappings":"AAUA,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAClE,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,aAAa,CAAC;AACpD,OAAO,EAAC,IAAI,EAAC,MAAM,aAAa,CAAC;;AAGjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqEG;AACH,MAAM,CAAC,MAAM,eAAe,GACxB,IAAI,cAAc,CACd,yBAAyB,CAAC,CAAC;AAEnC;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IAOhC,YAAkE,QACc;QADd,aAAQ,GAAR,QAAQ,CACM;QAPxE,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,IAAI,CAAC;QACd,gBAAW,GAAG,KAAK,CAAC;QAEZ,SAAI,GAAG,KAAK,CAAC;QAI3B,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO;SACR;QAED,MAAM,iBAAiB,GAAmB,EAAE,CAAC;QAE7C,MAAM,QAAQ,GAAG,GAAG,EAAE;YACnB,IAAwB,CAAC,IAAI,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtC,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE;oBACzB,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACpC;qBAAM,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE;oBACnC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;wBAChE,UAAU,CAAC,SAAS,CAAC,EAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAC,CAAC,CAAC;oBAC3D,CAAC,CAAC,CAAC;oBACH,iBAAiB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;iBAC7C;aACF;SACF;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;aACzB,IAAI,CAAC,GAAG,EAAE;YACT,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QAEP,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,QAAQ,EAAE,CAAC;SACZ;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;;0FAtDU,qBAAqB,cAOZ,eAAe;2EAPxB,qBAAqB,WAArB,qBAAqB;sFAArB,qBAAqB;cADjC,UAAU;;sBAQI,MAAM;uBAAC,eAAe;;sBAAG,QAAQ","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 {Observable} from 'rxjs';\n\nimport {Inject, Injectable, InjectionToken, Optional} from './di';\nimport {isObservable, isPromise} from './util/lang';\nimport {noop} from './util/noop';\n\n\n/**\n * A [DI token](guide/glossary#di-token \"DI token definition\") that you can use to provide\n * one or more initialization functions.\n *\n * The provided functions are injected at application startup and executed during\n * app initialization. If any of these functions returns a Promise or an Observable, initialization\n * does not complete until the Promise is resolved or the Observable is completed.\n *\n * You can, for example, create a factory function that loads language data\n * or an external configuration, and provide that function to the `APP_INITIALIZER` token.\n * The function is executed during the application bootstrap process,\n * and the needed data is available on startup.\n *\n * @see `ApplicationInitStatus`\n *\n * @usageNotes\n *\n * The following example illustrates how to configure a multi-provider using `APP_INITIALIZER` token\n * and a function returning a promise.\n *\n * ```\n *  function initializeApp(): Promise<any> {\n *    return new Promise((resolve, reject) => {\n *      // Do some asynchronous stuff\n *      resolve();\n *    });\n *  }\n *\n *  @NgModule({\n *   imports: [BrowserModule],\n *   declarations: [AppComponent],\n *   bootstrap: [AppComponent],\n *   providers: [{\n *     provide: APP_INITIALIZER,\n *     useFactory: () => initializeApp,\n *     multi: true\n *    }]\n *   })\n *  export class AppModule {}\n * ```\n *\n * It's also possible to configure a multi-provider using `APP_INITIALIZER` token and a function\n * returning an observable, see an example below. Note: the `HttpClient` in this example is used for\n * demo purposes to illustrate how the factory function can work with other providers available\n * through DI.\n *\n * ```\n *  function initializeAppFactory(httpClient: HttpClient): () => Observable<any> {\n *   return () => httpClient.get(\"https://someUrl.com/api/user\")\n *     .pipe(\n *        tap(user => { ... })\n *     );\n *  }\n *\n *  @NgModule({\n *    imports: [BrowserModule, HttpClientModule],\n *    declarations: [AppComponent],\n *    bootstrap: [AppComponent],\n *    providers: [{\n *      provide: APP_INITIALIZER,\n *      useFactory: initializeAppFactory,\n *      deps: [HttpClient],\n *      multi: true\n *    }]\n *  })\n *  export class AppModule {}\n * ```\n *\n * @publicApi\n */\nexport const APP_INITIALIZER =\n    new InjectionToken<ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>>(\n        'Application Initializer');\n\n/**\n * A class that reflects the state of running {@link APP_INITIALIZER} functions.\n *\n * @publicApi\n */\n@Injectable()\nexport class ApplicationInitStatus {\n  private resolve = noop;\n  private reject = noop;\n  private initialized = false;\n  public readonly donePromise: Promise<any>;\n  public readonly done = false;\n\n  constructor(@Inject(APP_INITIALIZER) @Optional() private readonly appInits:\n                  ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>) {\n    this.donePromise = new Promise((res, rej) => {\n      this.resolve = res;\n      this.reject = rej;\n    });\n  }\n\n  /** @internal */\n  runInitializers() {\n    if (this.initialized) {\n      return;\n    }\n\n    const asyncInitPromises: Promise<any>[] = [];\n\n    const complete = () => {\n      (this as {done: boolean}).done = true;\n      this.resolve();\n    };\n\n    if (this.appInits) {\n      for (let i = 0; i < this.appInits.length; i++) {\n        const initResult = this.appInits[i]();\n        if (isPromise(initResult)) {\n          asyncInitPromises.push(initResult);\n        } else if (isObservable(initResult)) {\n          const observableAsPromise = new Promise<void>((resolve, reject) => {\n            initResult.subscribe({complete: resolve, error: reject});\n          });\n          asyncInitPromises.push(observableAsPromise);\n        }\n      }\n    }\n\n    Promise.all(asyncInitPromises)\n        .then(() => {\n          complete();\n        })\n        .catch(e => {\n          this.reject(e);\n        });\n\n    if (asyncInitPromises.length === 0) {\n      complete();\n    }\n    this.initialized = true;\n  }\n}\n"]}