@angular/core 14.0.0-next.2 → 14.0.0-next.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core.d.ts +77 -21
- package/esm2020/src/application_init.mjs +4 -3
- package/esm2020/src/application_module.mjs +5 -104
- package/esm2020/src/application_ref.mjs +4 -3
- package/esm2020/src/application_tokens.mjs +14 -2
- package/esm2020/src/core.mjs +2 -2
- package/esm2020/src/core_render3_private_export.mjs +2 -1
- package/esm2020/src/debug/debug_node.mjs +11 -10
- package/esm2020/src/i18n/tokens.mjs +39 -3
- package/esm2020/src/linker/compiler.mjs +4 -3
- package/esm2020/src/linker/template_ref.mjs +3 -3
- package/esm2020/src/linker/view_container_ref.mjs +35 -8
- package/esm2020/src/render3/component.mjs +3 -3
- package/esm2020/src/render3/component_ref.mjs +22 -26
- package/esm2020/src/render3/context_discovery.mjs +34 -30
- package/esm2020/src/render3/di.mjs +177 -97
- package/esm2020/src/render3/hooks.mjs +3 -3
- package/esm2020/src/render3/instructions/element.mjs +7 -1
- package/esm2020/src/render3/instructions/element_container.mjs +7 -1
- package/esm2020/src/render3/instructions/lview_debug.mjs +6 -3
- package/esm2020/src/render3/instructions/shared.mjs +16 -7
- package/esm2020/src/render3/interfaces/context.mjs +35 -2
- package/esm2020/src/render3/interfaces/injector.mjs +1 -1
- package/esm2020/src/render3/interfaces/lview_tracking.mjs +33 -0
- package/esm2020/src/render3/interfaces/view.mjs +4 -2
- package/esm2020/src/render3/node_manipulation.mjs +4 -1
- package/esm2020/src/render3/util/discovery_utils.mjs +33 -22
- package/esm2020/src/version.mjs +1 -1
- package/esm2020/testing/src/logger.mjs +3 -3
- package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
- package/fesm2015/core.mjs +478 -308
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/testing.mjs +1 -1
- package/fesm2020/core.mjs +478 -301
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/testing.mjs +1 -1
- package/package.json +1 -1
- package/schematics/migrations/entry-components/util.js +2 -2
- package/schematics/utils/import_manager.js +13 -12
- package/schematics/utils/typescript/imports.js +6 -5
- 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.
|
|
2
|
+
* @license Angular v14.0.0-next.5
|
|
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
|
*/
|
|
@@ -2428,6 +2432,8 @@ export declare class ElementRef<T = any> {
|
|
|
2428
2432
|
constructor(nativeElement: T);
|
|
2429
2433
|
}
|
|
2430
2434
|
|
|
2435
|
+
declare const EMBEDDED_VIEW_INJECTOR = 21;
|
|
2436
|
+
|
|
2431
2437
|
/**
|
|
2432
2438
|
* Represents an Angular [view](guide/glossary#view) in a view container.
|
|
2433
2439
|
* An [embedded view](guide/glossary#view-tree) can be referenced from a component
|
|
@@ -3336,6 +3342,8 @@ declare const enum IcuType {
|
|
|
3336
3342
|
plural = 1
|
|
3337
3343
|
}
|
|
3338
3344
|
|
|
3345
|
+
declare const ID = 20;
|
|
3346
|
+
|
|
3339
3347
|
/**
|
|
3340
3348
|
* This array contains information about input properties that
|
|
3341
3349
|
* need to be set once from attribute data. It's ordered by
|
|
@@ -4516,6 +4524,13 @@ declare interface LView extends Array<any> {
|
|
|
4516
4524
|
* are not `Dirty`/`CheckAlways`.
|
|
4517
4525
|
*/
|
|
4518
4526
|
[TRANSPLANTED_VIEWS_TO_REFRESH]: number;
|
|
4527
|
+
/** Unique ID of the view. Used for `__ngContext__` lookups in the `LView` registry. */
|
|
4528
|
+
[ID]: number;
|
|
4529
|
+
/**
|
|
4530
|
+
* Optional injector assigned to embedded views that takes
|
|
4531
|
+
* precedence over the element and module injectors.
|
|
4532
|
+
*/
|
|
4533
|
+
readonly [EMBEDDED_VIEW_INJECTOR]: Injector | null;
|
|
4519
4534
|
}
|
|
4520
4535
|
|
|
4521
4536
|
/**
|
|
@@ -4696,12 +4711,14 @@ declare const enum LViewFlags {
|
|
|
4696
4711
|
* declaration was dirty.
|
|
4697
4712
|
*/
|
|
4698
4713
|
RefreshTransplantedView = 1024,
|
|
4714
|
+
/** Indicates that the view **or any of its ancestors** have an embedded view injector. */
|
|
4715
|
+
HasEmbeddedViewInjector = 2048,
|
|
4699
4716
|
/**
|
|
4700
4717
|
* Index of the current init phase on last 21 bits
|
|
4701
4718
|
*/
|
|
4702
|
-
IndexWithinInitPhaseIncrementer =
|
|
4703
|
-
IndexWithinInitPhaseShift =
|
|
4704
|
-
IndexWithinInitPhaseReset =
|
|
4719
|
+
IndexWithinInitPhaseIncrementer = 4096,
|
|
4720
|
+
IndexWithinInitPhaseShift = 12,
|
|
4721
|
+
IndexWithinInitPhaseReset = 4095
|
|
4705
4722
|
}
|
|
4706
4723
|
|
|
4707
4724
|
/**
|
|
@@ -7312,9 +7329,10 @@ export declare abstract class TemplateRef<C> {
|
|
|
7312
7329
|
* and attaches it to the view container.
|
|
7313
7330
|
* @param context The data-binding context of the embedded view, as declared
|
|
7314
7331
|
* in the `<ng-template>` usage.
|
|
7332
|
+
* @param injector Injector to be used within the embedded view.
|
|
7315
7333
|
* @returns The new embedded view object.
|
|
7316
7334
|
*/
|
|
7317
|
-
abstract createEmbeddedView(context: C): EmbeddedViewRef<C>;
|
|
7335
|
+
abstract createEmbeddedView(context: C, injector?: Injector): EmbeddedViewRef<C>;
|
|
7318
7336
|
}
|
|
7319
7337
|
|
|
7320
7338
|
/**
|
|
@@ -8992,6 +9010,23 @@ export declare abstract class ViewContainerRef {
|
|
|
8992
9010
|
* @returns The number of views.
|
|
8993
9011
|
*/
|
|
8994
9012
|
abstract get length(): number;
|
|
9013
|
+
/**
|
|
9014
|
+
* Instantiates an embedded view and inserts it
|
|
9015
|
+
* into this container.
|
|
9016
|
+
* @param templateRef The HTML template that defines the view.
|
|
9017
|
+
* @param context The data-binding context of the embedded view, as declared
|
|
9018
|
+
* in the `<ng-template>` usage.
|
|
9019
|
+
* @param options Extra configuration for the created view. Includes:
|
|
9020
|
+
* * index: The 0-based index at which to insert the new view into this container.
|
|
9021
|
+
* If not specified, appends the new view as the last entry.
|
|
9022
|
+
* * injector: Injector to be used within the embedded view.
|
|
9023
|
+
*
|
|
9024
|
+
* @returns The `ViewRef` instance for the newly created view.
|
|
9025
|
+
*/
|
|
9026
|
+
abstract createEmbeddedView<C>(templateRef: TemplateRef<C>, context?: C, options?: {
|
|
9027
|
+
index?: number;
|
|
9028
|
+
injector?: Injector;
|
|
9029
|
+
}): EmbeddedViewRef<C>;
|
|
8995
9030
|
/**
|
|
8996
9031
|
* Instantiates an embedded view and inserts it
|
|
8997
9032
|
* into this container.
|
|
@@ -9941,11 +9976,11 @@ export declare const ɵivyEnabled = true;
|
|
|
9941
9976
|
* function. The component, element and each directive instance will share the same instance
|
|
9942
9977
|
* of the context.
|
|
9943
9978
|
*/
|
|
9944
|
-
export declare
|
|
9979
|
+
export declare class ɵLContext {
|
|
9945
9980
|
/**
|
|
9946
|
-
*
|
|
9981
|
+
* ID of the component's parent view data.
|
|
9947
9982
|
*/
|
|
9948
|
-
|
|
9983
|
+
private lViewId;
|
|
9949
9984
|
/**
|
|
9950
9985
|
* The index instance of the node.
|
|
9951
9986
|
*/
|
|
@@ -9963,12 +9998,27 @@ export declare interface ɵLContext {
|
|
|
9963
9998
|
*/
|
|
9964
9999
|
directives: any[] | null | undefined;
|
|
9965
10000
|
/**
|
|
9966
|
-
* The map of local references (local reference name => element or directive instance) that
|
|
9967
|
-
* on this element.
|
|
10001
|
+
* The map of local references (local reference name => element or directive instance) that
|
|
10002
|
+
* exist on this element.
|
|
9968
10003
|
*/
|
|
9969
10004
|
localRefs: {
|
|
9970
10005
|
[key: string]: any;
|
|
9971
10006
|
} | null | undefined;
|
|
10007
|
+
/** Component's parent view data. */
|
|
10008
|
+
get lView(): LView | null;
|
|
10009
|
+
constructor(
|
|
10010
|
+
/**
|
|
10011
|
+
* ID of the component's parent view data.
|
|
10012
|
+
*/
|
|
10013
|
+
lViewId: number,
|
|
10014
|
+
/**
|
|
10015
|
+
* The index instance of the node.
|
|
10016
|
+
*/
|
|
10017
|
+
nodeIndex: number,
|
|
10018
|
+
/**
|
|
10019
|
+
* The instance of the DOM node that is attached to the lNode.
|
|
10020
|
+
*/
|
|
10021
|
+
native: RNode);
|
|
9972
10022
|
}
|
|
9973
10023
|
|
|
9974
10024
|
/**
|
|
@@ -12107,10 +12157,11 @@ export declare function ɵɵdisableBindings(): void;
|
|
|
12107
12157
|
* @param name Name of the DOM Node
|
|
12108
12158
|
* @param attrsIndex Index of the element's attributes in the `consts` array.
|
|
12109
12159
|
* @param localRefsIndex Index of the element's local references in the `consts` array.
|
|
12160
|
+
* @returns This function returns itself so that it may be chained.
|
|
12110
12161
|
*
|
|
12111
12162
|
* @codeGenApi
|
|
12112
12163
|
*/
|
|
12113
|
-
export declare function ɵɵelement(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number):
|
|
12164
|
+
export declare function ɵɵelement(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelement;
|
|
12114
12165
|
|
|
12115
12166
|
/**
|
|
12116
12167
|
* Creates an empty logical container using {@link elementContainerStart}
|
|
@@ -12119,17 +12170,19 @@ export declare function ɵɵelement(index: number, name: string, attrsIndex?: nu
|
|
|
12119
12170
|
* @param index Index of the element in the LView array
|
|
12120
12171
|
* @param attrsIndex Index of the container attributes in the `consts` array.
|
|
12121
12172
|
* @param localRefsIndex Index of the container's local references in the `consts` array.
|
|
12173
|
+
* @returns This function returns itself so that it may be chained.
|
|
12122
12174
|
*
|
|
12123
12175
|
* @codeGenApi
|
|
12124
12176
|
*/
|
|
12125
|
-
export declare function ɵɵelementContainer(index: number, attrsIndex?: number | null, localRefsIndex?: number):
|
|
12177
|
+
export declare function ɵɵelementContainer(index: number, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementContainer;
|
|
12126
12178
|
|
|
12127
12179
|
/**
|
|
12128
12180
|
* Mark the end of the <ng-container>.
|
|
12181
|
+
* @returns This function returns itself so that it may be chained.
|
|
12129
12182
|
*
|
|
12130
12183
|
* @codeGenApi
|
|
12131
12184
|
*/
|
|
12132
|
-
export declare function ɵɵelementContainerEnd():
|
|
12185
|
+
export declare function ɵɵelementContainerEnd(): typeof ɵɵelementContainerEnd;
|
|
12133
12186
|
|
|
12134
12187
|
/**
|
|
12135
12188
|
* Creates a logical container for other nodes (<ng-container>) backed by a comment node in the DOM.
|
|
@@ -12138,6 +12191,7 @@ export declare function ɵɵelementContainerEnd(): void;
|
|
|
12138
12191
|
* @param index Index of the element in the LView array
|
|
12139
12192
|
* @param attrsIndex Index of the container attributes in the `consts` array.
|
|
12140
12193
|
* @param localRefsIndex Index of the container's local references in the `consts` array.
|
|
12194
|
+
* @returns This function returns itself so that it may be chained.
|
|
12141
12195
|
*
|
|
12142
12196
|
* Even if this instruction accepts a set of attributes no actual attribute values are propagated to
|
|
12143
12197
|
* the DOM (as a comment node can't have attributes). Attributes are here only for directive
|
|
@@ -12145,14 +12199,15 @@ export declare function ɵɵelementContainerEnd(): void;
|
|
|
12145
12199
|
*
|
|
12146
12200
|
* @codeGenApi
|
|
12147
12201
|
*/
|
|
12148
|
-
export declare function ɵɵelementContainerStart(index: number, attrsIndex?: number | null, localRefsIndex?: number):
|
|
12202
|
+
export declare function ɵɵelementContainerStart(index: number, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementContainerStart;
|
|
12149
12203
|
|
|
12150
12204
|
/**
|
|
12151
12205
|
* Mark the end of the element.
|
|
12206
|
+
* @returns This function returns itself so that it may be chained.
|
|
12152
12207
|
*
|
|
12153
12208
|
* @codeGenApi
|
|
12154
12209
|
*/
|
|
12155
|
-
export declare function ɵɵelementEnd():
|
|
12210
|
+
export declare function ɵɵelementEnd(): typeof ɵɵelementEnd;
|
|
12156
12211
|
|
|
12157
12212
|
|
|
12158
12213
|
/**
|
|
@@ -12162,6 +12217,7 @@ export declare function ɵɵelementEnd(): void;
|
|
|
12162
12217
|
* @param name Name of the DOM Node
|
|
12163
12218
|
* @param attrsIndex Index of the element's attributes in the `consts` array.
|
|
12164
12219
|
* @param localRefsIndex Index of the element's local references in the `consts` array.
|
|
12220
|
+
* @returns This function returns itself so that it may be chained.
|
|
12165
12221
|
*
|
|
12166
12222
|
* Attributes and localRefs are passed as an array of strings where elements with an even index
|
|
12167
12223
|
* hold an attribute name and elements with an odd index hold an attribute value, ex.:
|
|
@@ -12169,7 +12225,7 @@ export declare function ɵɵelementEnd(): void;
|
|
|
12169
12225
|
*
|
|
12170
12226
|
* @codeGenApi
|
|
12171
12227
|
*/
|
|
12172
|
-
export declare function ɵɵelementStart(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number):
|
|
12228
|
+
export declare function ɵɵelementStart(index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): typeof ɵɵelementStart;
|
|
12173
12229
|
|
|
12174
12230
|
/**
|
|
12175
12231
|
* 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,
|
|
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({
|
|
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=
|