@angular/core 14.0.0-next.1 → 14.0.0-next.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/core.d.ts +93 -90
  2. package/esm2020/src/application_init.mjs +4 -3
  3. package/esm2020/src/application_module.mjs +5 -104
  4. package/esm2020/src/application_ref.mjs +6 -24
  5. package/esm2020/src/application_tokens.mjs +14 -2
  6. package/esm2020/src/change_detection/change_detection.mjs +2 -3
  7. package/esm2020/src/compiler/compiler_facade_interface.mjs +1 -1
  8. package/esm2020/src/core.mjs +2 -2
  9. package/esm2020/src/core_private_export.mjs +2 -1
  10. package/esm2020/src/core_render3_private_export.mjs +2 -1
  11. package/esm2020/src/debug/debug_node.mjs +137 -53
  12. package/esm2020/src/i18n/tokens.mjs +39 -3
  13. package/esm2020/src/linker/compiler.mjs +4 -3
  14. package/esm2020/src/linker/view_container_ref.mjs +24 -6
  15. package/esm2020/src/reflection/reflector.mjs +1 -1
  16. package/esm2020/src/render3/component_ref.mjs +1 -11
  17. package/esm2020/src/render3/context_discovery.mjs +28 -30
  18. package/esm2020/src/render3/instructions/element.mjs +7 -1
  19. package/esm2020/src/render3/instructions/element_container.mjs +7 -1
  20. package/esm2020/src/render3/instructions/lview_debug.mjs +5 -2
  21. package/esm2020/src/render3/instructions/shared.mjs +9 -4
  22. package/esm2020/src/render3/interfaces/context.mjs +35 -2
  23. package/esm2020/src/render3/interfaces/lview_tracking.mjs +30 -0
  24. package/esm2020/src/render3/interfaces/view.mjs +3 -2
  25. package/esm2020/src/render3/jit/directive.mjs +5 -2
  26. package/esm2020/src/render3/jit/pipe.mjs +5 -2
  27. package/esm2020/src/render3/node_manipulation.mjs +4 -1
  28. package/esm2020/src/render3/util/discovery_utils.mjs +33 -22
  29. package/esm2020/src/util/coercion.mjs +12 -0
  30. package/esm2020/src/version.mjs +1 -1
  31. package/esm2020/testing/src/logger.mjs +3 -3
  32. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  33. package/fesm2015/core.mjs +392 -249
  34. package/fesm2015/core.mjs.map +1 -1
  35. package/fesm2015/testing.mjs +1 -1
  36. package/fesm2020/core.mjs +392 -242
  37. package/fesm2020/core.mjs.map +1 -1
  38. package/fesm2020/testing.mjs +1 -1
  39. package/package.json +1 -1
  40. package/schematics/migrations/entry-components/util.js +2 -2
  41. package/schematics/utils/import_manager.js +13 -12
  42. package/schematics/utils/typescript/imports.js +6 -5
  43. package/testing/testing.d.ts +1 -1
package/core.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v14.0.0-next.1
2
+ * @license Angular v14.0.0-next.4
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -166,6 +166,13 @@ export declare interface AfterViewInit {
166
166
  */
167
167
  export declare const ANALYZE_FOR_ENTRY_COMPONENTS: InjectionToken<any>;
168
168
 
169
+ /**
170
+ * A [DI token](guide/glossary#di-token "DI token definition") that indicates which animations
171
+ * module has been loaded.
172
+ * @publicApi
173
+ */
174
+ export declare const ANIMATION_MODULE_TYPE: InjectionToken<"NoopAnimations" | "BrowserAnimations">;
175
+
169
176
  /**
170
177
  * A [DI token](guide/glossary#di-token "DI token definition") that provides a set of callbacks to
171
178
  * be called for every component that is bootstrapped.
@@ -283,12 +290,9 @@ export declare class ApplicationInitStatus {
283
290
  }
284
291
 
285
292
  /**
286
- * Configures the root injector for an app with
287
- * providers of `@angular/core` dependencies that `ApplicationRef` needs
288
- * to bootstrap components.
289
- *
290
293
  * Re-exported by `BrowserModule`, which is included automatically in the root
291
- * `AppModule` when you create a new app with the CLI `new` command.
294
+ * `AppModule` when you create a new app with the CLI `new` command. Eagerly injects
295
+ * `ApplicationRef` to instantiate it.
292
296
  *
293
297
  * @publicApi
294
298
  */
@@ -1702,13 +1706,18 @@ export declare const CUSTOM_ELEMENTS_SCHEMA: SchemaMetadata;
1702
1706
  * @see [Basics of testing components](guide/testing-components-basics)
1703
1707
  * @see [Testing utility APIs](guide/testing-utility-apis)
1704
1708
  */
1705
- export declare interface DebugElement extends DebugNode {
1709
+ export declare class DebugElement extends DebugNode {
1710
+ constructor(nativeNode: Element);
1711
+ /**
1712
+ * The underlying DOM element at the root of the component.
1713
+ */
1714
+ get nativeElement(): any;
1706
1715
  /**
1707
1716
  * The element tag name, if it is an element.
1708
1717
  */
1709
- readonly name: string;
1718
+ get name(): string;
1710
1719
  /**
1711
- * A map of property names to property values for an element.
1720
+ * Gets a map of property names to property values for an element.
1712
1721
  *
1713
1722
  * This map includes:
1714
1723
  * - Regular property bindings (e.g. `[id]="id"`)
@@ -1719,13 +1728,23 @@ export declare interface DebugElement extends DebugNode {
1719
1728
  * - input property bindings (e.g. `[myCustomInput]="value"`)
1720
1729
  * - attribute bindings (e.g. `[attr.role]="menu"`)
1721
1730
  */
1722
- readonly properties: {
1731
+ get properties(): {
1723
1732
  [key: string]: any;
1724
1733
  };
1725
1734
  /**
1726
1735
  * A map of attribute names to attribute values for an element.
1727
1736
  */
1728
- readonly attributes: {
1737
+ get attributes(): {
1738
+ [key: string]: string | null;
1739
+ };
1740
+ /**
1741
+ * The inline styles of the DOM element.
1742
+ *
1743
+ * Will be `null` if there is no `style` property on the underlying DOM element.
1744
+ *
1745
+ * @see [ElementCSSInlineStyle](https://developer.mozilla.org/en-US/docs/Web/API/ElementCSSInlineStyle/style)
1746
+ */
1747
+ get styles(): {
1729
1748
  [key: string]: string | null;
1730
1749
  };
1731
1750
  /**
@@ -1738,33 +1757,19 @@ export declare interface DebugElement extends DebugNode {
1738
1757
  *
1739
1758
  * @see [Element.className](https://developer.mozilla.org/en-US/docs/Web/API/Element/className)
1740
1759
  */
1741
- readonly classes: {
1760
+ get classes(): {
1742
1761
  [key: string]: boolean;
1743
1762
  };
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
1763
  /**
1755
1764
  * The `childNodes` of the DOM element as a `DebugNode` array.
1756
1765
  *
1757
1766
  * @see [Node.childNodes](https://developer.mozilla.org/en-US/docs/Web/API/Node/childNodes)
1758
1767
  */
1759
- readonly childNodes: DebugNode[];
1760
- /**
1761
- * The underlying DOM element at the root of the component.
1762
- */
1763
- readonly nativeElement: any;
1768
+ get childNodes(): DebugNode[];
1764
1769
  /**
1765
1770
  * The immediate `DebugElement` children. Walk the tree by descending through `children`.
1766
1771
  */
1767
- readonly children: DebugElement[];
1772
+ get children(): DebugElement[];
1768
1773
  /**
1769
1774
  * @returns the first `DebugElement` that matches the predicate at any depth in the subtree.
1770
1775
  */
@@ -1792,13 +1797,6 @@ export declare interface DebugElement extends DebugNode {
1792
1797
  triggerEventHandler(eventName: string, eventObj: any): void;
1793
1798
  }
1794
1799
 
1795
- /**
1796
- * @publicApi
1797
- */
1798
- export declare const DebugElement: {
1799
- new (...args: any[]): DebugElement;
1800
- };
1801
-
1802
1800
  /**
1803
1801
  * @publicApi
1804
1802
  */
@@ -1811,28 +1809,24 @@ export declare class DebugEventListener {
1811
1809
  /**
1812
1810
  * @publicApi
1813
1811
  */
1814
- export declare interface DebugNode {
1812
+ export declare class DebugNode {
1815
1813
  /**
1816
- * The callbacks attached to the component's @Output properties and/or the element's event
1817
- * properties.
1814
+ * The underlying DOM node.
1818
1815
  */
1819
- readonly listeners: DebugEventListener[];
1816
+ readonly nativeNode: any;
1817
+ constructor(nativeNode: Node);
1820
1818
  /**
1821
1819
  * The `DebugElement` parent. Will be `null` if this is the root element.
1822
1820
  */
1823
- readonly parent: DebugElement | null;
1824
- /**
1825
- * The underlying DOM node.
1826
- */
1827
- readonly nativeNode: any;
1821
+ get parent(): DebugElement | null;
1828
1822
  /**
1829
1823
  * The host dependency injector. For example, the root element's component instance injector.
1830
1824
  */
1831
- readonly injector: Injector;
1825
+ get injector(): Injector;
1832
1826
  /**
1833
1827
  * The element's own component instance, if it has one.
1834
1828
  */
1835
- readonly componentInstance: any;
1829
+ get componentInstance(): any;
1836
1830
  /**
1837
1831
  * An object that provides parent context for this element. Often an ancestor component instance
1838
1832
  * that governs this element.
@@ -1841,28 +1835,26 @@ export declare interface DebugNode {
1841
1835
  * property is the value of the row instance value. For example, the `hero` in `*ngFor="let hero
1842
1836
  * of heroes"`.
1843
1837
  */
1844
- readonly context: any;
1838
+ get context(): any;
1839
+ /**
1840
+ * The callbacks attached to the component's @Output properties and/or the element's event
1841
+ * properties.
1842
+ */
1843
+ get listeners(): DebugEventListener[];
1845
1844
  /**
1846
1845
  * Dictionary of objects associated with template local variables (e.g. #foo), keyed by the local
1847
1846
  * variable name.
1848
1847
  */
1849
- readonly references: {
1848
+ get references(): {
1850
1849
  [key: string]: any;
1851
1850
  };
1852
1851
  /**
1853
1852
  * This component's injector lookup tokens. Includes the component itself plus the tokens that the
1854
1853
  * component lists in its providers metadata.
1855
1854
  */
1856
- readonly providerTokens: any[];
1855
+ get providerTokens(): any[];
1857
1856
  }
1858
1857
 
1859
- /**
1860
- * @publicApi
1861
- */
1862
- export declare const DebugNode: {
1863
- new (...args: any[]): DebugNode;
1864
- };
1865
-
1866
1858
  /**
1867
1859
  * A logical node which comprise into `LView`s.
1868
1860
  *
@@ -2779,7 +2771,7 @@ export declare interface ForwardRefFn {
2779
2771
  /**
2780
2772
  * @publicApi
2781
2773
  */
2782
- declare const getDebugNode: (nativeNode: any) => DebugNode | null;
2774
+ declare function getDebugNode(nativeNode: any): DebugNode | null;
2783
2775
  export { getDebugNode }
2784
2776
  export { getDebugNode as ɵgetDebugNode }
2785
2777
 
@@ -3348,6 +3340,8 @@ declare const enum IcuType {
3348
3340
  plural = 1
3349
3341
  }
3350
3342
 
3343
+ declare const ID = 20;
3344
+
3351
3345
  /**
3352
3346
  * This array contains information about input properties that
3353
3347
  * need to be set once from attribute data. It's ordered by
@@ -4528,6 +4522,8 @@ declare interface LView extends Array<any> {
4528
4522
  * are not `Dirty`/`CheckAlways`.
4529
4523
  */
4530
4524
  [TRANSPLANTED_VIEWS_TO_REFRESH]: number;
4525
+ /** Unique ID of the view. Used for `__ngContext__` lookups in the `LView` registry. */
4526
+ [ID]: number;
4531
4527
  }
4532
4528
 
4533
4529
  /**
@@ -5592,33 +5588,14 @@ export declare class PlatformRef {
5592
5588
  private _destroyListeners;
5593
5589
  private _destroyed;
5594
5590
  /**
5595
- * Creates an instance of an `@NgModule` for the given platform for offline compilation.
5596
- *
5597
- * @usageNotes
5598
- *
5599
- * The following example creates the NgModule for a browser platform.
5600
- *
5601
- * ```typescript
5602
- * my_module.ts:
5603
- *
5604
- * @NgModule({
5605
- * imports: [BrowserModule]
5606
- * })
5607
- * class MyModule {}
5608
- *
5609
- * main.ts:
5610
- * import {MyModuleNgFactory} from './my_module.ngfactory';
5611
- * import {platformBrowser} from '@angular/platform-browser';
5612
- *
5613
- * let moduleRef = platformBrowser().bootstrapModuleFactory(MyModuleNgFactory);
5614
- * ```
5591
+ * Creates an instance of an `@NgModule` for the given platform.
5615
5592
  *
5616
5593
  * @deprecated Passing NgModule factories as the `PlatformRef.bootstrapModuleFactory` function
5617
5594
  * argument is deprecated. Use the `PlatformRef.bootstrapModule` API instead.
5618
5595
  */
5619
5596
  bootstrapModuleFactory<M>(moduleFactory: NgModuleFactory<M>, options?: BootstrapOptions): Promise<NgModuleRef<M>>;
5620
5597
  /**
5621
- * Creates an instance of an `@NgModule` for a given platform using the given runtime compiler.
5598
+ * Creates an instance of an `@NgModule` for a given platform.
5622
5599
  *
5623
5600
  * @usageNotes
5624
5601
  * ### Simple Example
@@ -6037,6 +6014,7 @@ declare interface R3DeclareDirectiveFacade {
6037
6014
  exportAs?: string[];
6038
6015
  usesInheritance?: boolean;
6039
6016
  usesOnChanges?: boolean;
6017
+ isStandalone?: boolean;
6040
6018
  }
6041
6019
 
6042
6020
  declare interface R3DeclareFactoryFacade {
@@ -9464,6 +9442,10 @@ export declare enum ɵChangeDetectorStatus {
9464
9442
 
9465
9443
  export declare function ɵclearResolutionOfComponentResourcesQueue(): Map<Type<any>, Component>;
9466
9444
 
9445
+
9446
+ /** Coerces a value (typically a string) to a boolean. */
9447
+ export declare function ɵcoerceToBoolean(value: unknown): boolean;
9448
+
9467
9449
  /**
9468
9450
  * Compile an Angular component according to its decorator metadata, and patch the resulting
9469
9451
  * component def (ɵcmp) onto the component type.
@@ -9811,7 +9793,7 @@ export declare function ɵfindLocaleData(locale: string): any;
9811
9793
  */
9812
9794
  export declare function ɵflushModuleScopingQueueAsMuchAsPossible(): void;
9813
9795
 
9814
- export declare const ɵgetDebugNodeR2: (nativeNode: any) => DebugNode | null;
9796
+ export declare function ɵgetDebugNodeR2(_nativeNode: any): DebugNode | null;
9815
9797
 
9816
9798
  /**
9817
9799
  * Retrieves directive instances associated with a given DOM node. Does not include
@@ -9967,11 +9949,11 @@ export declare const ɵivyEnabled = true;
9967
9949
  * function. The component, element and each directive instance will share the same instance
9968
9950
  * of the context.
9969
9951
  */
9970
- export declare interface ɵLContext {
9952
+ export declare class ɵLContext {
9971
9953
  /**
9972
- * The component's parent view data.
9954
+ * ID of the component's parent view data.
9973
9955
  */
9974
- lView: LView;
9956
+ private lViewId;
9975
9957
  /**
9976
9958
  * The index instance of the node.
9977
9959
  */
@@ -9989,12 +9971,27 @@ export declare interface ɵLContext {
9989
9971
  */
9990
9972
  directives: any[] | null | undefined;
9991
9973
  /**
9992
- * The map of local references (local reference name => element or directive instance) that exist
9993
- * on this element.
9974
+ * The map of local references (local reference name => element or directive instance) that
9975
+ * exist on this element.
9994
9976
  */
9995
9977
  localRefs: {
9996
9978
  [key: string]: any;
9997
9979
  } | null | undefined;
9980
+ /** Component's parent view data. */
9981
+ get lView(): LView | null;
9982
+ constructor(
9983
+ /**
9984
+ * ID of the component's parent view data.
9985
+ */
9986
+ lViewId: number,
9987
+ /**
9988
+ * The index instance of the node.
9989
+ */
9990
+ nodeIndex: number,
9991
+ /**
9992
+ * The instance of the DOM node that is attached to the lNode.
9993
+ */
9994
+ native: RNode);
9998
9995
  }
9999
9996
 
10000
9997
  /**
@@ -12133,10 +12130,11 @@ export declare function ɵɵdisableBindings(): void;
12133
12130
  * @param name Name of the DOM Node
12134
12131
  * @param attrsIndex Index of the element's attributes in the `consts` array.
12135
12132
  * @param localRefsIndex Index of the element's local references in the `consts` array.
12133
+ * @returns This function returns itself so that it may be chained.
12136
12134
  *
12137
12135
  * @codeGenApi
12138
12136
  */
12139
- export declare function ɵɵelement(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void;
12137
+ export declare function ɵɵelement(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelement;
12140
12138
 
12141
12139
  /**
12142
12140
  * Creates an empty logical container using {@link elementContainerStart}
@@ -12145,17 +12143,19 @@ export declare function ɵɵelement(index: number, name: string, attrsIndex?: nu
12145
12143
  * @param index Index of the element in the LView array
12146
12144
  * @param attrsIndex Index of the container attributes in the `consts` array.
12147
12145
  * @param localRefsIndex Index of the container's local references in the `consts` array.
12146
+ * @returns This function returns itself so that it may be chained.
12148
12147
  *
12149
12148
  * @codeGenApi
12150
12149
  */
12151
- export declare function ɵɵelementContainer(index: number, attrsIndex?: number | null, localRefsIndex?: number): void;
12150
+ export declare function ɵɵelementContainer(index: number, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementContainer;
12152
12151
 
12153
12152
  /**
12154
12153
  * Mark the end of the <ng-container>.
12154
+ * @returns This function returns itself so that it may be chained.
12155
12155
  *
12156
12156
  * @codeGenApi
12157
12157
  */
12158
- export declare function ɵɵelementContainerEnd(): void;
12158
+ export declare function ɵɵelementContainerEnd(): typeof ɵɵelementContainerEnd;
12159
12159
 
12160
12160
  /**
12161
12161
  * Creates a logical container for other nodes (<ng-container>) backed by a comment node in the DOM.
@@ -12164,6 +12164,7 @@ export declare function ɵɵelementContainerEnd(): void;
12164
12164
  * @param index Index of the element in the LView array
12165
12165
  * @param attrsIndex Index of the container attributes in the `consts` array.
12166
12166
  * @param localRefsIndex Index of the container's local references in the `consts` array.
12167
+ * @returns This function returns itself so that it may be chained.
12167
12168
  *
12168
12169
  * Even if this instruction accepts a set of attributes no actual attribute values are propagated to
12169
12170
  * the DOM (as a comment node can't have attributes). Attributes are here only for directive
@@ -12171,14 +12172,15 @@ export declare function ɵɵelementContainerEnd(): void;
12171
12172
  *
12172
12173
  * @codeGenApi
12173
12174
  */
12174
- export declare function ɵɵelementContainerStart(index: number, attrsIndex?: number | null, localRefsIndex?: number): void;
12175
+ export declare function ɵɵelementContainerStart(index: number, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementContainerStart;
12175
12176
 
12176
12177
  /**
12177
12178
  * Mark the end of the element.
12179
+ * @returns This function returns itself so that it may be chained.
12178
12180
  *
12179
12181
  * @codeGenApi
12180
12182
  */
12181
- export declare function ɵɵelementEnd(): void;
12183
+ export declare function ɵɵelementEnd(): typeof ɵɵelementEnd;
12182
12184
 
12183
12185
 
12184
12186
  /**
@@ -12188,6 +12190,7 @@ export declare function ɵɵelementEnd(): void;
12188
12190
  * @param name Name of the DOM Node
12189
12191
  * @param attrsIndex Index of the element's attributes in the `consts` array.
12190
12192
  * @param localRefsIndex Index of the element's local references in the `consts` array.
12193
+ * @returns This function returns itself so that it may be chained.
12191
12194
  *
12192
12195
  * Attributes and localRefs are passed as an array of strings where elements with an even index
12193
12196
  * hold an attribute name and elements with an odd index hold an attribute value, ex.:
@@ -12195,7 +12198,7 @@ export declare function ɵɵelementEnd(): void;
12195
12198
  *
12196
12199
  * @codeGenApi
12197
12200
  */
12198
- export declare function ɵɵelementStart(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void;
12201
+ export declare function ɵɵelementStart(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementStart;
12199
12202
 
12200
12203
  /**
12201
12204
  * Enables directive matching on elements.
@@ -128,13 +128,14 @@ export class ApplicationInitStatus {
128
128
  }
129
129
  }
130
130
  ApplicationInitStatus.ɵfac = function ApplicationInitStatus_Factory(t) { return new (t || ApplicationInitStatus)(i0.ɵɵinject(APP_INITIALIZER, 8)); };
131
- ApplicationInitStatus.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ApplicationInitStatus, factory: ApplicationInitStatus.ɵfac });
131
+ ApplicationInitStatus.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ApplicationInitStatus, factory: ApplicationInitStatus.ɵfac, providedIn: 'root' });
132
132
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(ApplicationInitStatus, [{
133
- type: Injectable
133
+ type: Injectable,
134
+ args: [{ providedIn: 'root' }]
134
135
  }], function () { return [{ type: undefined, decorators: [{
135
136
  type: Inject,
136
137
  args: [APP_INITIALIZER]
137
138
  }, {
138
139
  type: Optional
139
140
  }] }]; }, 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"]}
141
+ //# 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,mBADT,MAAM;sFAClB,qBAAqB;cADjC,UAAU;eAAC,EAAC,UAAU,EAAE,MAAM,EAAC;;sBAQjB,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({providedIn: 'root'})\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"]}
@@ -5,112 +5,14 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- import { APP_INITIALIZER, ApplicationInitStatus } from './application_init';
9
8
  import { ApplicationRef } from './application_ref';
10
- import { APP_ID_RANDOM_PROVIDER } from './application_tokens';
11
- import { defaultIterableDiffers, defaultKeyValueDiffers, IterableDiffers, KeyValueDiffers } from './change_detection/change_detection';
12
- import { Injector } from './di';
13
- import { Inject, Optional, SkipSelf } from './di/metadata';
14
- import { ErrorHandler } from './error_handler';
15
- import { DEFAULT_LOCALE_ID, USD_CURRENCY_CODE } from './i18n/localization';
16
- import { DEFAULT_CURRENCY_CODE, LOCALE_ID } from './i18n/tokens';
17
- import { ComponentFactoryResolver } from './linker';
18
- import { Compiler } from './linker/compiler';
19
9
  import { NgModule } from './metadata';
20
- import { SCHEDULER } from './render3/component_ref';
21
- import { NgZone } from './zone';
22
10
  import * as i0 from "./r3_symbols";
23
11
  import * as i1 from "./application_ref";
24
- export function _iterableDiffersFactory() {
25
- return defaultIterableDiffers;
26
- }
27
- export function _keyValueDiffersFactory() {
28
- return defaultKeyValueDiffers;
29
- }
30
- export function _localeFactory(locale) {
31
- return locale || getGlobalLocale();
32
- }
33
- /**
34
- * Work out the locale from the potential global properties.
35
- *
36
- * * Closure Compiler: use `goog.getLocale()`.
37
- * * Ivy enabled: use `$localize.locale`
38
- */
39
- export function getGlobalLocale() {
40
- if (typeof ngI18nClosureMode !== 'undefined' && ngI18nClosureMode &&
41
- typeof goog !== 'undefined' && goog.getLocale() !== 'en') {
42
- // * The default `goog.getLocale()` value is `en`, while Angular used `en-US`.
43
- // * In order to preserve backwards compatibility, we use Angular default value over
44
- // Closure Compiler's one.
45
- return goog.getLocale();
46
- }
47
- else {
48
- // KEEP `typeof $localize !== 'undefined' && $localize.locale` IN SYNC WITH THE LOCALIZE
49
- // COMPILE-TIME INLINER.
50
- //
51
- // * During compile time inlining of translations the expression will be replaced
52
- // with a string literal that is the current locale. Other forms of this expression are not
53
- // guaranteed to be replaced.
54
- //
55
- // * During runtime translation evaluation, the developer is required to set `$localize.locale`
56
- // if required, or just to provide their own `LOCALE_ID` provider.
57
- return (typeof $localize !== 'undefined' && $localize.locale) || DEFAULT_LOCALE_ID;
58
- }
59
- }
60
12
  /**
61
- * A built-in [dependency injection token](guide/glossary#di-token)
62
- * that is used to configure the root injector for bootstrapping.
63
- */
64
- export const APPLICATION_MODULE_PROVIDERS = [
65
- {
66
- provide: ApplicationRef,
67
- useClass: ApplicationRef,
68
- deps: [NgZone, Injector, ErrorHandler, ComponentFactoryResolver, ApplicationInitStatus]
69
- },
70
- { provide: SCHEDULER, deps: [NgZone], useFactory: zoneSchedulerFactory },
71
- {
72
- provide: ApplicationInitStatus,
73
- useClass: ApplicationInitStatus,
74
- deps: [[new Optional(), APP_INITIALIZER]]
75
- },
76
- { provide: Compiler, useClass: Compiler, deps: [] },
77
- APP_ID_RANDOM_PROVIDER,
78
- { provide: IterableDiffers, useFactory: _iterableDiffersFactory, deps: [] },
79
- { provide: KeyValueDiffers, useFactory: _keyValueDiffersFactory, deps: [] },
80
- {
81
- provide: LOCALE_ID,
82
- useFactory: _localeFactory,
83
- deps: [[new Inject(LOCALE_ID), new Optional(), new SkipSelf()]]
84
- },
85
- { provide: DEFAULT_CURRENCY_CODE, useValue: USD_CURRENCY_CODE },
86
- ];
87
- /**
88
- * Schedule work at next available slot.
89
- *
90
- * In Ivy this is just `requestAnimationFrame`. For compatibility reasons when bootstrapped
91
- * using `platformRef.bootstrap` we need to use `NgZone.onStable` as the scheduling mechanism.
92
- * This overrides the scheduling mechanism in Ivy to `NgZone.onStable`.
93
- *
94
- * @param ngZone NgZone to use for scheduling.
95
- */
96
- export function zoneSchedulerFactory(ngZone) {
97
- let queue = [];
98
- ngZone.onStable.subscribe(() => {
99
- while (queue.length) {
100
- queue.pop()();
101
- }
102
- });
103
- return function (fn) {
104
- queue.push(fn);
105
- };
106
- }
107
- /**
108
- * Configures the root injector for an app with
109
- * providers of `@angular/core` dependencies that `ApplicationRef` needs
110
- * to bootstrap components.
111
- *
112
13
  * Re-exported by `BrowserModule`, which is included automatically in the root
113
- * `AppModule` when you create a new app with the CLI `new` command.
14
+ * `AppModule` when you create a new app with the CLI `new` command. Eagerly injects
15
+ * `ApplicationRef` to instantiate it.
114
16
  *
115
17
  * @publicApi
116
18
  */
@@ -120,9 +22,8 @@ export class ApplicationModule {
120
22
  }
121
23
  ApplicationModule.ɵfac = function ApplicationModule_Factory(t) { return new (t || ApplicationModule)(i0.ɵɵinject(i1.ApplicationRef)); };
122
24
  ApplicationModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: ApplicationModule });
123
- ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ providers: APPLICATION_MODULE_PROVIDERS });
25
+ ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
124
26
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(ApplicationModule, [{
125
- type: NgModule,
126
- args: [{ providers: APPLICATION_MODULE_PROVIDERS }]
27
+ type: NgModule
127
28
  }], function () { return [{ type: i1.ApplicationRef }]; }, null); })();
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_module.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_module.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 {APP_INITIALIZER, ApplicationInitStatus} from './application_init';\nimport {ApplicationRef} from './application_ref';\nimport {APP_ID_RANDOM_PROVIDER} from './application_tokens';\nimport {defaultIterableDiffers, defaultKeyValueDiffers, IterableDiffers, KeyValueDiffers} from './change_detection/change_detection';\nimport {Injector, StaticProvider} from './di';\nimport {Inject, Optional, SkipSelf} from './di/metadata';\nimport {ErrorHandler} from './error_handler';\nimport {DEFAULT_LOCALE_ID, USD_CURRENCY_CODE} from './i18n/localization';\nimport {DEFAULT_CURRENCY_CODE, LOCALE_ID} from './i18n/tokens';\nimport {ComponentFactoryResolver} from './linker';\nimport {Compiler} from './linker/compiler';\nimport {NgModule} from './metadata';\nimport {SCHEDULER} from './render3/component_ref';\nimport {NgZone} from './zone';\n\ndeclare const $localize: {locale?: string};\n\nexport function _iterableDiffersFactory() {\n  return defaultIterableDiffers;\n}\n\nexport function _keyValueDiffersFactory() {\n  return defaultKeyValueDiffers;\n}\n\nexport function _localeFactory(locale?: string): string {\n  return locale || getGlobalLocale();\n}\n/**\n * Work out the locale from the potential global properties.\n *\n * * Closure Compiler: use `goog.getLocale()`.\n * * Ivy enabled: use `$localize.locale`\n */\nexport function getGlobalLocale(): string {\n  if (typeof ngI18nClosureMode !== 'undefined' && ngI18nClosureMode &&\n      typeof goog !== 'undefined' && goog.getLocale() !== 'en') {\n    // * The default `goog.getLocale()` value is `en`, while Angular used `en-US`.\n    // * In order to preserve backwards compatibility, we use Angular default value over\n    //   Closure Compiler's one.\n    return goog.getLocale();\n  } else {\n    // KEEP `typeof $localize !== 'undefined' && $localize.locale` IN SYNC WITH THE LOCALIZE\n    // COMPILE-TIME INLINER.\n    //\n    // * During compile time inlining of translations the expression will be replaced\n    //   with a string literal that is the current locale. Other forms of this expression are not\n    //   guaranteed to be replaced.\n    //\n    // * During runtime translation evaluation, the developer is required to set `$localize.locale`\n    //   if required, or just to provide their own `LOCALE_ID` provider.\n    return (typeof $localize !== 'undefined' && $localize.locale) || DEFAULT_LOCALE_ID;\n  }\n}\n\n/**\n * A built-in [dependency injection token](guide/glossary#di-token)\n * that is used to configure the root injector for bootstrapping.\n */\nexport const APPLICATION_MODULE_PROVIDERS: StaticProvider[] = [\n  {\n    provide: ApplicationRef,\n    useClass: ApplicationRef,\n    deps: [NgZone, Injector, ErrorHandler, ComponentFactoryResolver, ApplicationInitStatus]\n  },\n  {provide: SCHEDULER, deps: [NgZone], useFactory: zoneSchedulerFactory},\n  {\n    provide: ApplicationInitStatus,\n    useClass: ApplicationInitStatus,\n    deps: [[new Optional(), APP_INITIALIZER]]\n  },\n  {provide: Compiler, useClass: Compiler, deps: []},\n  APP_ID_RANDOM_PROVIDER,\n  {provide: IterableDiffers, useFactory: _iterableDiffersFactory, deps: []},\n  {provide: KeyValueDiffers, useFactory: _keyValueDiffersFactory, deps: []},\n  {\n    provide: LOCALE_ID,\n    useFactory: _localeFactory,\n    deps: [[new Inject(LOCALE_ID), new Optional(), new SkipSelf()]]\n  },\n  {provide: DEFAULT_CURRENCY_CODE, useValue: USD_CURRENCY_CODE},\n];\n\n/**\n * Schedule work at next available slot.\n *\n * In Ivy this is just `requestAnimationFrame`. For compatibility reasons when bootstrapped\n * using `platformRef.bootstrap` we need to use `NgZone.onStable` as the scheduling mechanism.\n * This overrides the scheduling mechanism in Ivy to `NgZone.onStable`.\n *\n * @param ngZone NgZone to use for scheduling.\n */\nexport function zoneSchedulerFactory(ngZone: NgZone): (fn: () => void) => void {\n  let queue: (() => void)[] = [];\n  ngZone.onStable.subscribe(() => {\n    while (queue.length) {\n      queue.pop()!();\n    }\n  });\n  return function(fn: () => void) {\n    queue.push(fn);\n  };\n}\n\n/**\n * Configures the root injector for an app with\n * providers of `@angular/core` dependencies that `ApplicationRef` needs\n * to bootstrap components.\n *\n * Re-exported by `BrowserModule`, which is included automatically in the root\n * `AppModule` when you create a new app with the CLI `new` command.\n *\n * @publicApi\n */\n@NgModule({providers: APPLICATION_MODULE_PROVIDERS})\nexport class ApplicationModule {\n  // Inject ApplicationRef to make it eager...\n  constructor(appRef: ApplicationRef) {}\n}\n"]}
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb25fbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvYXBwbGljYXRpb25fbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sWUFBWSxDQUFDOzs7QUFFcEM7Ozs7OztHQU1HO0FBRUgsTUFBTSxPQUFPLGlCQUFpQjtJQUM1Qiw0Q0FBNEM7SUFDNUMsWUFBWSxNQUFzQixJQUFHLENBQUM7O2tGQUYzQixpQkFBaUI7bUVBQWpCLGlCQUFpQjs7c0ZBQWpCLGlCQUFpQjtjQUQ3QixRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7QXBwbGljYXRpb25SZWZ9IGZyb20gJy4vYXBwbGljYXRpb25fcmVmJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJy4vbWV0YWRhdGEnO1xuXG4vKipcbiAqIFJlLWV4cG9ydGVkIGJ5IGBCcm93c2VyTW9kdWxlYCwgd2hpY2ggaXMgaW5jbHVkZWQgYXV0b21hdGljYWxseSBpbiB0aGUgcm9vdFxuICogYEFwcE1vZHVsZWAgd2hlbiB5b3UgY3JlYXRlIGEgbmV3IGFwcCB3aXRoIHRoZSBDTEkgYG5ld2AgY29tbWFuZC4gRWFnZXJseSBpbmplY3RzXG4gKiBgQXBwbGljYXRpb25SZWZgIHRvIGluc3RhbnRpYXRlIGl0LlxuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBBcHBsaWNhdGlvbk1vZHVsZSB7XG4gIC8vIEluamVjdCBBcHBsaWNhdGlvblJlZiB0byBtYWtlIGl0IGVhZ2VyLi4uXG4gIGNvbnN0cnVjdG9yKGFwcFJlZjogQXBwbGljYXRpb25SZWYpIHt9XG59XG4iXX0=