@angular/core 13.0.0-rc.1 → 13.1.0-next.0

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 (174) hide show
  1. package/core.d.ts +224 -221
  2. package/esm2020/index.mjs +6 -5
  3. package/esm2020/src/application_module.mjs +2 -7
  4. package/esm2020/src/core_render3_private_export.mjs +2 -1
  5. package/esm2020/src/linker/component_factory_resolver.mjs +5 -5
  6. package/esm2020/src/linker/ng_module_factory.mjs +1 -1
  7. package/esm2020/src/render3/definition.mjs +2 -5
  8. package/esm2020/src/render3/di.mjs +3 -3
  9. package/esm2020/src/render3/error_code.mjs +2 -5
  10. package/esm2020/src/render3/error_details_base_url.mjs +16 -0
  11. package/esm2020/src/render3/fields.mjs +1 -2
  12. package/esm2020/src/render3/ng_module_ref.mjs +2 -5
  13. package/esm2020/src/version.mjs +1 -1
  14. package/esm2020/testing/src/logger.mjs +3 -3
  15. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  16. package/esm2020/testing/src/test_compiler.mjs +3 -3
  17. package/fesm2015/core.mjs +25 -23
  18. package/fesm2015/core.mjs.map +1 -1
  19. package/fesm2015/testing.mjs +4 -4
  20. package/fesm2020/core.mjs +25 -23
  21. package/fesm2020/core.mjs.map +1 -1
  22. package/fesm2020/testing.mjs +4 -4
  23. package/package.json +1 -1
  24. package/schematics/migrations/router-link-empty-expression/index.js +2 -2
  25. package/schematics/migrations.json +0 -100
  26. package/schematics/utils/ng_component_template.d.ts +4 -1
  27. package/schematics/utils/ng_component_template.js +28 -14
  28. package/testing/testing.d.ts +1 -1
  29. package/schematics/migrations/abstract-control-parent/index.d.ts +0 -11
  30. package/schematics/migrations/abstract-control-parent/index.js +0 -69
  31. package/schematics/migrations/abstract-control-parent/util.d.ts +0 -14
  32. package/schematics/migrations/abstract-control-parent/util.js +0 -67
  33. package/schematics/migrations/activated-route-snapshot-fragment/index.d.ts +0 -13
  34. package/schematics/migrations/activated-route-snapshot-fragment/index.js +0 -73
  35. package/schematics/migrations/activated-route-snapshot-fragment/util.d.ts +0 -16
  36. package/schematics/migrations/activated-route-snapshot-fragment/util.js +0 -51
  37. package/schematics/migrations/can-activate-with-redirect-to/index.d.ts +0 -11
  38. package/schematics/migrations/can-activate-with-redirect-to/index.js +0 -69
  39. package/schematics/migrations/can-activate-with-redirect-to/util.d.ts +0 -11
  40. package/schematics/migrations/can-activate-with-redirect-to/util.js +0 -73
  41. package/schematics/migrations/deep-shadow-piercing-selector/index.d.ts +0 -10
  42. package/schematics/migrations/deep-shadow-piercing-selector/index.js +0 -49
  43. package/schematics/migrations/dynamic-queries/index.d.ts +0 -13
  44. package/schematics/migrations/dynamic-queries/index.js +0 -76
  45. package/schematics/migrations/dynamic-queries/util.d.ts +0 -25
  46. package/schematics/migrations/dynamic-queries/util.js +0 -84
  47. package/schematics/migrations/initial-navigation/collector.d.ts +0 -22
  48. package/schematics/migrations/initial-navigation/collector.js +0 -122
  49. package/schematics/migrations/initial-navigation/index.d.ts +0 -11
  50. package/schematics/migrations/initial-navigation/index.js +0 -83
  51. package/schematics/migrations/initial-navigation/transform.d.ts +0 -20
  52. package/schematics/migrations/initial-navigation/transform.js +0 -71
  53. package/schematics/migrations/initial-navigation/update_recorder.d.ts +0 -18
  54. package/schematics/migrations/initial-navigation/update_recorder.js +0 -20
  55. package/schematics/migrations/initial-navigation/util.d.ts +0 -12
  56. package/schematics/migrations/initial-navigation/util.js +0 -46
  57. package/schematics/migrations/missing-injectable/definition_collector.d.ts +0 -37
  58. package/schematics/migrations/missing-injectable/definition_collector.js +0 -92
  59. package/schematics/migrations/missing-injectable/index.d.ts +0 -11
  60. package/schematics/migrations/missing-injectable/index.js +0 -136
  61. package/schematics/migrations/missing-injectable/providers_evaluator.d.ts +0 -26
  62. package/schematics/migrations/missing-injectable/providers_evaluator.js +0 -71
  63. package/schematics/migrations/missing-injectable/transform.d.ts +0 -70
  64. package/schematics/migrations/missing-injectable/transform.js +0 -203
  65. package/schematics/migrations/missing-injectable/update_recorder.d.ts +0 -21
  66. package/schematics/migrations/missing-injectable/update_recorder.js +0 -20
  67. package/schematics/migrations/module-with-providers/collector.d.ts +0 -34
  68. package/schematics/migrations/module-with-providers/collector.js +0 -76
  69. package/schematics/migrations/module-with-providers/index.d.ts +0 -13
  70. package/schematics/migrations/module-with-providers/index.js +0 -107
  71. package/schematics/migrations/module-with-providers/transform.d.ts +0 -50
  72. package/schematics/migrations/module-with-providers/transform.js +0 -149
  73. package/schematics/migrations/module-with-providers/util.d.ts +0 -13
  74. package/schematics/migrations/module-with-providers/util.js +0 -43
  75. package/schematics/migrations/move-document/document_import_visitor.d.ts +0 -27
  76. package/schematics/migrations/move-document/document_import_visitor.js +0 -77
  77. package/schematics/migrations/move-document/index.d.ts +0 -11
  78. package/schematics/migrations/move-document/index.js +0 -93
  79. package/schematics/migrations/move-document/move-import.d.ts +0 -12
  80. package/schematics/migrations/move-document/move-import.js +0 -64
  81. package/schematics/migrations/native-view-encapsulation/index.d.ts +0 -11
  82. package/schematics/migrations/native-view-encapsulation/index.js +0 -63
  83. package/schematics/migrations/native-view-encapsulation/util.d.ts +0 -11
  84. package/schematics/migrations/native-view-encapsulation/util.js +0 -51
  85. package/schematics/migrations/navigation-extras-omissions/index.d.ts +0 -11
  86. package/schematics/migrations/navigation-extras-omissions/index.js +0 -72
  87. package/schematics/migrations/navigation-extras-omissions/util.d.ts +0 -11
  88. package/schematics/migrations/navigation-extras-omissions/util.js +0 -129
  89. package/schematics/migrations/relative-link-resolution/collector.d.ts +0 -22
  90. package/schematics/migrations/relative-link-resolution/collector.js +0 -98
  91. package/schematics/migrations/relative-link-resolution/index.d.ts +0 -11
  92. package/schematics/migrations/relative-link-resolution/index.js +0 -84
  93. package/schematics/migrations/relative-link-resolution/transform.d.ts +0 -22
  94. package/schematics/migrations/relative-link-resolution/transform.js +0 -68
  95. package/schematics/migrations/relative-link-resolution/update_recorder.d.ts +0 -18
  96. package/schematics/migrations/relative-link-resolution/update_recorder.js +0 -20
  97. package/schematics/migrations/relative-link-resolution/util.d.ts +0 -12
  98. package/schematics/migrations/relative-link-resolution/util.js +0 -46
  99. package/schematics/migrations/renderer-to-renderer2/helpers.d.ts +0 -25
  100. package/schematics/migrations/renderer-to-renderer2/helpers.js +0 -241
  101. package/schematics/migrations/renderer-to-renderer2/index.d.ts +0 -14
  102. package/schematics/migrations/renderer-to-renderer2/index.js +0 -138
  103. package/schematics/migrations/renderer-to-renderer2/migration.d.ts +0 -18
  104. package/schematics/migrations/renderer-to-renderer2/migration.js +0 -228
  105. package/schematics/migrations/renderer-to-renderer2/util.d.ts +0 -18
  106. package/schematics/migrations/renderer-to-renderer2/util.js +0 -86
  107. package/schematics/migrations/router-preserve-query-params/index.d.ts +0 -14
  108. package/schematics/migrations/router-preserve-query-params/index.js +0 -75
  109. package/schematics/migrations/router-preserve-query-params/util.d.ts +0 -11
  110. package/schematics/migrations/router-preserve-query-params/util.js +0 -106
  111. package/schematics/migrations/static-queries/angular/directive_inputs.d.ts +0 -11
  112. package/schematics/migrations/static-queries/angular/directive_inputs.js +0 -87
  113. package/schematics/migrations/static-queries/angular/ng_query_visitor.d.ts +0 -45
  114. package/schematics/migrations/static-queries/angular/ng_query_visitor.js +0 -130
  115. package/schematics/migrations/static-queries/angular/query-definition.d.ts +0 -37
  116. package/schematics/migrations/static-queries/angular/query-definition.js +0 -33
  117. package/schematics/migrations/static-queries/angular/super_class.d.ts +0 -15
  118. package/schematics/migrations/static-queries/angular/super_class.js +0 -35
  119. package/schematics/migrations/static-queries/index.d.ts +0 -11
  120. package/schematics/migrations/static-queries/index.js +0 -244
  121. package/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.d.ts +0 -41
  122. package/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.js +0 -210
  123. package/schematics/migrations/static-queries/strategies/test_strategy/test_strategy.d.ts +0 -24
  124. package/schematics/migrations/static-queries/strategies/test_strategy/test_strategy.js +0 -38
  125. package/schematics/migrations/static-queries/strategies/timing-strategy.d.ts +0 -19
  126. package/schematics/migrations/static-queries/strategies/timing-strategy.js +0 -20
  127. package/schematics/migrations/static-queries/strategies/usage_strategy/declaration_usage_visitor.d.ts +0 -82
  128. package/schematics/migrations/static-queries/strategies/usage_strategy/declaration_usage_visitor.js +0 -372
  129. package/schematics/migrations/static-queries/strategies/usage_strategy/super_class_context.d.ts +0 -18
  130. package/schematics/migrations/static-queries/strategies/usage_strategy/super_class_context.js +0 -55
  131. package/schematics/migrations/static-queries/strategies/usage_strategy/template_usage_visitor.d.ts +0 -27
  132. package/schematics/migrations/static-queries/strategies/usage_strategy/template_usage_visitor.js +0 -93
  133. package/schematics/migrations/static-queries/strategies/usage_strategy/usage_strategy.d.ts +0 -34
  134. package/schematics/migrations/static-queries/strategies/usage_strategy/usage_strategy.js +0 -172
  135. package/schematics/migrations/static-queries/transform.d.ts +0 -21
  136. package/schematics/migrations/static-queries/transform.js +0 -105
  137. package/schematics/migrations/template-var-assignment/analyze_template.d.ts +0 -20
  138. package/schematics/migrations/template-var-assignment/analyze_template.js +0 -38
  139. package/schematics/migrations/template-var-assignment/angular/html_variable_assignment_visitor.d.ts +0 -28
  140. package/schematics/migrations/template-var-assignment/angular/html_variable_assignment_visitor.js +0 -80
  141. package/schematics/migrations/template-var-assignment/index.d.ts +0 -11
  142. package/schematics/migrations/template-var-assignment/index.js +0 -101
  143. package/schematics/migrations/undecorated-classes-with-decorated-fields/index.d.ts +0 -14
  144. package/schematics/migrations/undecorated-classes-with-decorated-fields/index.js +0 -128
  145. package/schematics/migrations/undecorated-classes-with-decorated-fields/transform.d.ts +0 -64
  146. package/schematics/migrations/undecorated-classes-with-decorated-fields/transform.js +0 -302
  147. package/schematics/migrations/undecorated-classes-with-decorated-fields/update_recorder.d.ts +0 -19
  148. package/schematics/migrations/undecorated-classes-with-decorated-fields/update_recorder.js +0 -20
  149. package/schematics/migrations/undecorated-classes-with-di/create_ngc_program.d.ts +0 -18
  150. package/schematics/migrations/undecorated-classes-with-di/create_ngc_program.js +0 -56
  151. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/convert_directive_metadata.d.ts +0 -18
  152. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/convert_directive_metadata.js +0 -99
  153. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/decorator_rewriter.d.ts +0 -37
  154. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/decorator_rewriter.js +0 -118
  155. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/import_rewrite_visitor.d.ts +0 -37
  156. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/import_rewrite_visitor.js +0 -129
  157. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/path_format.d.ts +0 -10
  158. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/path_format.js +0 -31
  159. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/source_file_exports.d.ts +0 -16
  160. package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/source_file_exports.js +0 -68
  161. package/schematics/migrations/undecorated-classes-with-di/index.d.ts +0 -11
  162. package/schematics/migrations/undecorated-classes-with-di/index.js +0 -226
  163. package/schematics/migrations/undecorated-classes-with-di/ng_declaration_collector.d.ts +0 -38
  164. package/schematics/migrations/undecorated-classes-with-di/ng_declaration_collector.js +0 -135
  165. package/schematics/migrations/undecorated-classes-with-di/transform.d.ts +0 -97
  166. package/schematics/migrations/undecorated-classes-with-di/transform.js +0 -373
  167. package/schematics/migrations/undecorated-classes-with-di/update_recorder.d.ts +0 -20
  168. package/schematics/migrations/undecorated-classes-with-di/update_recorder.js +0 -20
  169. package/schematics/migrations/wait-for-async/index.d.ts +0 -11
  170. package/schematics/migrations/wait-for-async/index.js +0 -101
  171. package/schematics/migrations/wait-for-async/util.d.ts +0 -11
  172. package/schematics/migrations/wait-for-async/util.js +0 -40
  173. package/schematics/migrations/xhr-factory/index.d.ts +0 -10
  174. package/schematics/migrations/xhr-factory/index.js +0 -107
package/core.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v13.0.0-rc.1
2
+ * @license Angular v13.1.0-next.0
3
3
  * (c) 2010-2021 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -1235,10 +1235,10 @@ export { ComponentFactory as ɵComponentFactory }
1235
1235
  * Use to obtain the factory for a given component type,
1236
1236
  * then use the factory's `create()` method to create a component of that type.
1237
1237
  *
1238
- * @see [Dynamic Components](guide/dynamic-component-loader)
1239
- * @see [Usage Example](guide/dynamic-component-loader#resolving-components)
1240
- * @see <live-example name="dynamic-component-loader" noDownload></live-example>
1241
- of the code in this cookbook
1238
+ * Note: since v13, dynamic component creation via
1239
+ * [`ViewContainerRef.createComponent`](api/core/ViewContainerRef#createComponent)
1240
+ * does **not** require resolving component factory: component class can be used directly.
1241
+ *
1242
1242
  * @publicApi
1243
1243
  */
1244
1244
  export declare abstract class ComponentFactoryResolver {
@@ -5174,8 +5174,11 @@ export declare abstract class NgModuleRef<T> {
5174
5174
  */
5175
5175
  abstract get injector(): Injector;
5176
5176
  /**
5177
- * The resolver that can retrieve the component factories
5178
- * declared in the `entryComponents` property of the module.
5177
+ * The resolver that can retrieve component factories in a context of this module.
5178
+ *
5179
+ * Note: since v13, dynamic component creation via
5180
+ * [`ViewContainerRef.createComponent`](api/core/ViewContainerRef#createComponent)
5181
+ * does **not** require resolving component factory: component class can be used directly.
5179
5182
  */
5180
5183
  abstract get componentFactoryResolver(): ComponentFactoryResolver;
5181
5184
  /**
@@ -9452,219 +9455,6 @@ export declare abstract class ViewRef extends ChangeDetectorRef {
9452
9455
  abstract onDestroy(callback: Function): any /** TODO #9100 */;
9453
9456
  }
9454
9457
 
9455
- declare class ViewRef_2<T> implements EmbeddedViewRef<T>, InternalViewRef, viewEngine_ChangeDetectorRef_interface {
9456
- /**
9457
- * This represents the `LView` associated with the point where `ChangeDetectorRef` was
9458
- * requested.
9459
- *
9460
- * This may be different from `_lView` if the `_cdRefInjectingView` is an embedded view.
9461
- */
9462
- private _cdRefInjectingView?;
9463
- private _appRef;
9464
- private _attachedToViewContainer;
9465
- get rootNodes(): any[];
9466
- constructor(
9467
- /**
9468
- * This represents `LView` associated with the component when ViewRef is a ChangeDetectorRef.
9469
- *
9470
- * When ViewRef is created for a dynamic component, this also represents the `LView` for the
9471
- * component.
9472
- *
9473
- * For a "regular" ViewRef created for an embedded view, this is the `LView` for the embedded
9474
- * view.
9475
- *
9476
- * @internal
9477
- */
9478
- _lView: LView,
9479
- /**
9480
- * This represents the `LView` associated with the point where `ChangeDetectorRef` was
9481
- * requested.
9482
- *
9483
- * This may be different from `_lView` if the `_cdRefInjectingView` is an embedded view.
9484
- */
9485
- _cdRefInjectingView?: LView | undefined);
9486
- get context(): T;
9487
- set context(value: T);
9488
- get destroyed(): boolean;
9489
- destroy(): void;
9490
- onDestroy(callback: Function): void;
9491
- /**
9492
- * Marks a view and all of its ancestors dirty.
9493
- *
9494
- * This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is
9495
- * checked when it needs to be re-rendered but the two normal triggers haven't marked it
9496
- * dirty (i.e. inputs haven't changed and events haven't fired in the view).
9497
- *
9498
- * <!-- TODO: Add a link to a chapter on OnPush components -->
9499
- *
9500
- * @usageNotes
9501
- * ### Example
9502
- *
9503
- * ```typescript
9504
- * @Component({
9505
- * selector: 'app-root',
9506
- * template: `Number of ticks: {{numberOfTicks}}`
9507
- * changeDetection: ChangeDetectionStrategy.OnPush,
9508
- * })
9509
- * class AppComponent {
9510
- * numberOfTicks = 0;
9511
- *
9512
- * constructor(private ref: ChangeDetectorRef) {
9513
- * setInterval(() => {
9514
- * this.numberOfTicks++;
9515
- * // the following is required, otherwise the view will not be updated
9516
- * this.ref.markForCheck();
9517
- * }, 1000);
9518
- * }
9519
- * }
9520
- * ```
9521
- */
9522
- markForCheck(): void;
9523
- /**
9524
- * Detaches the view from the change detection tree.
9525
- *
9526
- * Detached views will not be checked during change detection runs until they are
9527
- * re-attached, even if they are dirty. `detach` can be used in combination with
9528
- * {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change
9529
- * detection checks.
9530
- *
9531
- * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
9532
- * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
9533
- *
9534
- * @usageNotes
9535
- * ### Example
9536
- *
9537
- * The following example defines a component with a large list of readonly data.
9538
- * Imagine the data changes constantly, many times per second. For performance reasons,
9539
- * we want to check and update the list every five seconds. We can do that by detaching
9540
- * the component's change detector and doing a local check every five seconds.
9541
- *
9542
- * ```typescript
9543
- * class DataProvider {
9544
- * // in a real application the returned data will be different every time
9545
- * get data() {
9546
- * return [1,2,3,4,5];
9547
- * }
9548
- * }
9549
- *
9550
- * @Component({
9551
- * selector: 'giant-list',
9552
- * template: `
9553
- * <li *ngFor="let d of dataProvider.data">Data {{d}}</li>
9554
- * `,
9555
- * })
9556
- * class GiantList {
9557
- * constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {
9558
- * ref.detach();
9559
- * setInterval(() => {
9560
- * this.ref.detectChanges();
9561
- * }, 5000);
9562
- * }
9563
- * }
9564
- *
9565
- * @Component({
9566
- * selector: 'app',
9567
- * providers: [DataProvider],
9568
- * template: `
9569
- * <giant-list><giant-list>
9570
- * `,
9571
- * })
9572
- * class App {
9573
- * }
9574
- * ```
9575
- */
9576
- detach(): void;
9577
- /**
9578
- * Re-attaches a view to the change detection tree.
9579
- *
9580
- * This can be used to re-attach views that were previously detached from the tree
9581
- * using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.
9582
- *
9583
- * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
9584
- *
9585
- * @usageNotes
9586
- * ### Example
9587
- *
9588
- * The following example creates a component displaying `live` data. The component will detach
9589
- * its change detector from the main change detector tree when the component's live property
9590
- * is set to false.
9591
- *
9592
- * ```typescript
9593
- * class DataProvider {
9594
- * data = 1;
9595
- *
9596
- * constructor() {
9597
- * setInterval(() => {
9598
- * this.data = this.data * 2;
9599
- * }, 500);
9600
- * }
9601
- * }
9602
- *
9603
- * @Component({
9604
- * selector: 'live-data',
9605
- * inputs: ['live'],
9606
- * template: 'Data: {{dataProvider.data}}'
9607
- * })
9608
- * class LiveData {
9609
- * constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}
9610
- *
9611
- * set live(value) {
9612
- * if (value) {
9613
- * this.ref.reattach();
9614
- * } else {
9615
- * this.ref.detach();
9616
- * }
9617
- * }
9618
- * }
9619
- *
9620
- * @Component({
9621
- * selector: 'app-root',
9622
- * providers: [DataProvider],
9623
- * template: `
9624
- * Live Update: <input type="checkbox" [(ngModel)]="live">
9625
- * <live-data [live]="live"><live-data>
9626
- * `,
9627
- * })
9628
- * class AppComponent {
9629
- * live = true;
9630
- * }
9631
- * ```
9632
- */
9633
- reattach(): void;
9634
- /**
9635
- * Checks the view and its children.
9636
- *
9637
- * This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement
9638
- * local change detection checks.
9639
- *
9640
- * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
9641
- * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
9642
- *
9643
- * @usageNotes
9644
- * ### Example
9645
- *
9646
- * The following example defines a component with a large list of readonly data.
9647
- * Imagine, the data changes constantly, many times per second. For performance reasons,
9648
- * we want to check and update the list every five seconds.
9649
- *
9650
- * We can do that by detaching the component's change detector and doing a local change detection
9651
- * check every five seconds.
9652
- *
9653
- * See {@link ChangeDetectorRef#detach detach} for more information.
9654
- */
9655
- detectChanges(): void;
9656
- /**
9657
- * Checks the change detector and its children, and throws if any changes are detected.
9658
- *
9659
- * This is used in development mode to verify that running change detection doesn't
9660
- * introduce other changes.
9661
- */
9662
- checkNoChanges(): void;
9663
- attachToViewContainerRef(): void;
9664
- detachFromAppRef(): void;
9665
- attachToAppRef(appRef: ViewRefTracker): void;
9666
- }
9667
-
9668
9458
  /**
9669
9459
  * Interface for tracking root `ViewRef`s in `ApplicationRef`.
9670
9460
  *
@@ -11137,7 +10927,7 @@ export declare class ɵRender3ComponentRef<T> extends ComponentRef<T> {
11137
10927
  private _rootLView;
11138
10928
  private _tNode;
11139
10929
  instance: T;
11140
- hostView: ViewRef_2<T>;
10930
+ hostView: ɵViewRef<T>;
11141
10931
  changeDetectorRef: ChangeDetectorRef;
11142
10932
  componentType: Type<T>;
11143
10933
  constructor(componentType: Type<T>, instance: T, location: ElementRef, _rootLView: LView, _tNode: TElementNode | TContainerNode | TElementContainerNode);
@@ -11417,6 +11207,219 @@ export declare const enum ɵViewFlags {
11417
11207
  OnPush = 2
11418
11208
  }
11419
11209
 
11210
+ export declare class ɵViewRef<T> implements EmbeddedViewRef<T>, InternalViewRef, viewEngine_ChangeDetectorRef_interface {
11211
+ /**
11212
+ * This represents the `LView` associated with the point where `ChangeDetectorRef` was
11213
+ * requested.
11214
+ *
11215
+ * This may be different from `_lView` if the `_cdRefInjectingView` is an embedded view.
11216
+ */
11217
+ private _cdRefInjectingView?;
11218
+ private _appRef;
11219
+ private _attachedToViewContainer;
11220
+ get rootNodes(): any[];
11221
+ constructor(
11222
+ /**
11223
+ * This represents `LView` associated with the component when ViewRef is a ChangeDetectorRef.
11224
+ *
11225
+ * When ViewRef is created for a dynamic component, this also represents the `LView` for the
11226
+ * component.
11227
+ *
11228
+ * For a "regular" ViewRef created for an embedded view, this is the `LView` for the embedded
11229
+ * view.
11230
+ *
11231
+ * @internal
11232
+ */
11233
+ _lView: LView,
11234
+ /**
11235
+ * This represents the `LView` associated with the point where `ChangeDetectorRef` was
11236
+ * requested.
11237
+ *
11238
+ * This may be different from `_lView` if the `_cdRefInjectingView` is an embedded view.
11239
+ */
11240
+ _cdRefInjectingView?: LView | undefined);
11241
+ get context(): T;
11242
+ set context(value: T);
11243
+ get destroyed(): boolean;
11244
+ destroy(): void;
11245
+ onDestroy(callback: Function): void;
11246
+ /**
11247
+ * Marks a view and all of its ancestors dirty.
11248
+ *
11249
+ * This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is
11250
+ * checked when it needs to be re-rendered but the two normal triggers haven't marked it
11251
+ * dirty (i.e. inputs haven't changed and events haven't fired in the view).
11252
+ *
11253
+ * <!-- TODO: Add a link to a chapter on OnPush components -->
11254
+ *
11255
+ * @usageNotes
11256
+ * ### Example
11257
+ *
11258
+ * ```typescript
11259
+ * @Component({
11260
+ * selector: 'app-root',
11261
+ * template: `Number of ticks: {{numberOfTicks}}`
11262
+ * changeDetection: ChangeDetectionStrategy.OnPush,
11263
+ * })
11264
+ * class AppComponent {
11265
+ * numberOfTicks = 0;
11266
+ *
11267
+ * constructor(private ref: ChangeDetectorRef) {
11268
+ * setInterval(() => {
11269
+ * this.numberOfTicks++;
11270
+ * // the following is required, otherwise the view will not be updated
11271
+ * this.ref.markForCheck();
11272
+ * }, 1000);
11273
+ * }
11274
+ * }
11275
+ * ```
11276
+ */
11277
+ markForCheck(): void;
11278
+ /**
11279
+ * Detaches the view from the change detection tree.
11280
+ *
11281
+ * Detached views will not be checked during change detection runs until they are
11282
+ * re-attached, even if they are dirty. `detach` can be used in combination with
11283
+ * {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change
11284
+ * detection checks.
11285
+ *
11286
+ * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
11287
+ * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
11288
+ *
11289
+ * @usageNotes
11290
+ * ### Example
11291
+ *
11292
+ * The following example defines a component with a large list of readonly data.
11293
+ * Imagine the data changes constantly, many times per second. For performance reasons,
11294
+ * we want to check and update the list every five seconds. We can do that by detaching
11295
+ * the component's change detector and doing a local check every five seconds.
11296
+ *
11297
+ * ```typescript
11298
+ * class DataProvider {
11299
+ * // in a real application the returned data will be different every time
11300
+ * get data() {
11301
+ * return [1,2,3,4,5];
11302
+ * }
11303
+ * }
11304
+ *
11305
+ * @Component({
11306
+ * selector: 'giant-list',
11307
+ * template: `
11308
+ * <li *ngFor="let d of dataProvider.data">Data {{d}}</li>
11309
+ * `,
11310
+ * })
11311
+ * class GiantList {
11312
+ * constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {
11313
+ * ref.detach();
11314
+ * setInterval(() => {
11315
+ * this.ref.detectChanges();
11316
+ * }, 5000);
11317
+ * }
11318
+ * }
11319
+ *
11320
+ * @Component({
11321
+ * selector: 'app',
11322
+ * providers: [DataProvider],
11323
+ * template: `
11324
+ * <giant-list><giant-list>
11325
+ * `,
11326
+ * })
11327
+ * class App {
11328
+ * }
11329
+ * ```
11330
+ */
11331
+ detach(): void;
11332
+ /**
11333
+ * Re-attaches a view to the change detection tree.
11334
+ *
11335
+ * This can be used to re-attach views that were previously detached from the tree
11336
+ * using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.
11337
+ *
11338
+ * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
11339
+ *
11340
+ * @usageNotes
11341
+ * ### Example
11342
+ *
11343
+ * The following example creates a component displaying `live` data. The component will detach
11344
+ * its change detector from the main change detector tree when the component's live property
11345
+ * is set to false.
11346
+ *
11347
+ * ```typescript
11348
+ * class DataProvider {
11349
+ * data = 1;
11350
+ *
11351
+ * constructor() {
11352
+ * setInterval(() => {
11353
+ * this.data = this.data * 2;
11354
+ * }, 500);
11355
+ * }
11356
+ * }
11357
+ *
11358
+ * @Component({
11359
+ * selector: 'live-data',
11360
+ * inputs: ['live'],
11361
+ * template: 'Data: {{dataProvider.data}}'
11362
+ * })
11363
+ * class LiveData {
11364
+ * constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}
11365
+ *
11366
+ * set live(value) {
11367
+ * if (value) {
11368
+ * this.ref.reattach();
11369
+ * } else {
11370
+ * this.ref.detach();
11371
+ * }
11372
+ * }
11373
+ * }
11374
+ *
11375
+ * @Component({
11376
+ * selector: 'app-root',
11377
+ * providers: [DataProvider],
11378
+ * template: `
11379
+ * Live Update: <input type="checkbox" [(ngModel)]="live">
11380
+ * <live-data [live]="live"><live-data>
11381
+ * `,
11382
+ * })
11383
+ * class AppComponent {
11384
+ * live = true;
11385
+ * }
11386
+ * ```
11387
+ */
11388
+ reattach(): void;
11389
+ /**
11390
+ * Checks the view and its children.
11391
+ *
11392
+ * This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement
11393
+ * local change detection checks.
11394
+ *
11395
+ * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
11396
+ * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
11397
+ *
11398
+ * @usageNotes
11399
+ * ### Example
11400
+ *
11401
+ * The following example defines a component with a large list of readonly data.
11402
+ * Imagine, the data changes constantly, many times per second. For performance reasons,
11403
+ * we want to check and update the list every five seconds.
11404
+ *
11405
+ * We can do that by detaching the component's change detector and doing a local change detection
11406
+ * check every five seconds.
11407
+ *
11408
+ * See {@link ChangeDetectorRef#detach detach} for more information.
11409
+ */
11410
+ detectChanges(): void;
11411
+ /**
11412
+ * Checks the change detector and its children, and throws if any changes are detected.
11413
+ *
11414
+ * This is used in development mode to verify that running change detection doesn't
11415
+ * introduce other changes.
11416
+ */
11417
+ checkNoChanges(): void;
11418
+ attachToViewContainerRef(): void;
11419
+ detachFromAppRef(): void;
11420
+ attachToAppRef(appRef: ViewRefTracker): void;
11421
+ }
11422
+
11420
11423
  /**
11421
11424
  * Wait on component until it is rendered.
11422
11425
  *
package/esm2020/index.mjs CHANGED
@@ -5,9 +5,10 @@
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
- // This file is not used to build this module. It is only used during editing
9
- // by the TypeScript language service and during build for verification. `ngc`
10
- // replaces this file with production index.ts when it rewrites private symbol
11
- // names.
8
+ /* This file is not used to build this module. It is only used during editing
9
+ * by the TypeScript language service and during build for verification. `ngc`
10
+ * replaces this file with production index.ts when it rewrites private symbol
11
+ * names.
12
+ */
12
13
  export * from './public_api';
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILDZFQUE2RTtBQUM3RSw4RUFBOEU7QUFDOUUsOEVBQThFO0FBQzlFLFNBQVM7QUFFVCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vLyBUaGlzIGZpbGUgaXMgbm90IHVzZWQgdG8gYnVpbGQgdGhpcyBtb2R1bGUuIEl0IGlzIG9ubHkgdXNlZCBkdXJpbmcgZWRpdGluZ1xuLy8gYnkgdGhlIFR5cGVTY3JpcHQgbGFuZ3VhZ2Ugc2VydmljZSBhbmQgZHVyaW5nIGJ1aWxkIGZvciB2ZXJpZmljYXRpb24uIGBuZ2NgXG4vLyByZXBsYWNlcyB0aGlzIGZpbGUgd2l0aCBwcm9kdWN0aW9uIGluZGV4LnRzIHdoZW4gaXQgcmV3cml0ZXMgcHJpdmF0ZSBzeW1ib2xcbi8vIG5hbWVzLlxuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVIOzs7O0dBSUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vKiBUaGlzIGZpbGUgaXMgbm90IHVzZWQgdG8gYnVpbGQgdGhpcyBtb2R1bGUuIEl0IGlzIG9ubHkgdXNlZCBkdXJpbmcgZWRpdGluZ1xuICogYnkgdGhlIFR5cGVTY3JpcHQgbGFuZ3VhZ2Ugc2VydmljZSBhbmQgZHVyaW5nIGJ1aWxkIGZvciB2ZXJpZmljYXRpb24uIGBuZ2NgXG4gKiByZXBsYWNlcyB0aGlzIGZpbGUgd2l0aCBwcm9kdWN0aW9uIGluZGV4LnRzIHdoZW4gaXQgcmV3cml0ZXMgcHJpdmF0ZSBzeW1ib2xcbiAqIG5hbWVzLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0=
@@ -19,7 +19,6 @@ import { ComponentFactoryResolver } from './linker';
19
19
  import { Compiler } from './linker/compiler';
20
20
  import { NgModule } from './metadata';
21
21
  import { SCHEDULER } from './render3/component_ref';
22
- import { setLocaleId } from './render3/i18n/i18n_locale_id';
23
22
  import { NgZone } from './zone';
24
23
  import * as i0 from "./r3_symbols";
25
24
  import * as i1 from "./application_ref";
@@ -30,11 +29,7 @@ export function _keyValueDiffersFactory() {
30
29
  return defaultKeyValueDiffers;
31
30
  }
32
31
  export function _localeFactory(locale) {
33
- locale = locale || getGlobalLocale();
34
- if (ivyEnabled) {
35
- setLocaleId(locale);
36
- }
37
- return locale;
32
+ return locale || getGlobalLocale();
38
33
  }
39
34
  /**
40
35
  * Work out the locale from the potential global properties.
@@ -132,4 +127,4 @@ ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ providers: APPLI
132
127
  type: NgModule,
133
128
  args: [{ providers: APPLICATION_MODULE_PROVIDERS }]
134
129
  }], function () { return [{ type: i1.ApplicationRef }]; }, null); })();
135
- //# 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 {ivyEnabled} from './ivy_switch';\nimport {ComponentFactoryResolver} from './linker';\nimport {Compiler} from './linker/compiler';\nimport {NgModule} from './metadata';\nimport {SCHEDULER} from './render3/component_ref';\nimport {setLocaleId} from './render3/i18n/i18n_locale_id';\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  locale = locale || getGlobalLocale();\n  if (ivyEnabled) {\n    setLocaleId(locale);\n  }\n  return locale;\n}\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 (ivyEnabled && typeof $localize !== 'undefined' && $localize.locale) ||\n        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"]}
130
+ //# 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 {ivyEnabled} from './ivy_switch';\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 (ivyEnabled && typeof $localize !== 'undefined' && $localize.locale) ||\n        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"]}