@angular/core 14.0.0-next.3 → 14.0.0-next.6
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 +59 -15
- package/esm2020/src/application_init.mjs +4 -3
- package/esm2020/src/application_module.mjs +5 -95
- package/esm2020/src/application_ref.mjs +4 -3
- package/esm2020/src/application_tokens.mjs +5 -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 +12 -3
- 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/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/renderer_dom.mjs +1 -1
- package/esm2020/src/render3/interfaces/view.mjs +4 -2
- package/esm2020/src/render3/node_manipulation.mjs +12 -3
- package/esm2020/src/render3/util/discovery_utils.mjs +33 -22
- package/esm2020/src/version.mjs +1 -1
- package/esm2020/testing/src/fake_async.mjs +3 -2
- package/esm2020/testing/src/logger.mjs +3 -3
- package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
- package/fesm2015/core.mjs +442 -297
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/testing.mjs +3 -2
- package/fesm2015/testing.mjs.map +1 -1
- package/fesm2020/core.mjs +442 -290
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/testing.mjs +3 -2
- package/fesm2020/testing.mjs.map +1 -1
- package/package.json +2 -2
- package/schematics/migrations/entry-components/util.js +2 -2
- package/schematics/migrations/typed-forms/index.d.ts +1 -5
- package/schematics/migrations/typed-forms/index.js +12 -34
- package/schematics/migrations/typed-forms/util.d.ts +6 -9
- package/schematics/migrations/typed-forms/util.js +63 -40
- package/schematics/utils/import_manager.js +13 -12
- package/schematics/utils/typescript/imports.js +6 -5
- package/schematics/utils/typescript/parse_tsconfig.js +6 -2
- package/schematics/utils/typescript/symbol.js +4 -3
- package/testing/testing.d.ts +3 -2
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.6
|
|
3
3
|
* (c) 2010-2022 Google LLC. https://angular.io/
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -290,12 +290,9 @@ export declare class ApplicationInitStatus {
|
|
|
290
290
|
}
|
|
291
291
|
|
|
292
292
|
/**
|
|
293
|
-
* Configures the root injector for an app with
|
|
294
|
-
* providers of `@angular/core` dependencies that `ApplicationRef` needs
|
|
295
|
-
* to bootstrap components.
|
|
296
|
-
*
|
|
297
293
|
* Re-exported by `BrowserModule`, which is included automatically in the root
|
|
298
|
-
* `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.
|
|
299
296
|
*
|
|
300
297
|
* @publicApi
|
|
301
298
|
*/
|
|
@@ -2435,6 +2432,8 @@ export declare class ElementRef<T = any> {
|
|
|
2435
2432
|
constructor(nativeElement: T);
|
|
2436
2433
|
}
|
|
2437
2434
|
|
|
2435
|
+
declare const EMBEDDED_VIEW_INJECTOR = 21;
|
|
2436
|
+
|
|
2438
2437
|
/**
|
|
2439
2438
|
* Represents an Angular [view](guide/glossary#view) in a view container.
|
|
2440
2439
|
* An [embedded view](guide/glossary#view-tree) can be referenced from a component
|
|
@@ -3343,6 +3342,8 @@ declare const enum IcuType {
|
|
|
3343
3342
|
plural = 1
|
|
3344
3343
|
}
|
|
3345
3344
|
|
|
3345
|
+
declare const ID = 20;
|
|
3346
|
+
|
|
3346
3347
|
/**
|
|
3347
3348
|
* This array contains information about input properties that
|
|
3348
3349
|
* need to be set once from attribute data. It's ordered by
|
|
@@ -4523,6 +4524,13 @@ declare interface LView extends Array<any> {
|
|
|
4523
4524
|
* are not `Dirty`/`CheckAlways`.
|
|
4524
4525
|
*/
|
|
4525
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;
|
|
4526
4534
|
}
|
|
4527
4535
|
|
|
4528
4536
|
/**
|
|
@@ -4703,12 +4711,14 @@ declare const enum LViewFlags {
|
|
|
4703
4711
|
* declaration was dirty.
|
|
4704
4712
|
*/
|
|
4705
4713
|
RefreshTransplantedView = 1024,
|
|
4714
|
+
/** Indicates that the view **or any of its ancestors** have an embedded view injector. */
|
|
4715
|
+
HasEmbeddedViewInjector = 2048,
|
|
4706
4716
|
/**
|
|
4707
4717
|
* Index of the current init phase on last 21 bits
|
|
4708
4718
|
*/
|
|
4709
|
-
IndexWithinInitPhaseIncrementer =
|
|
4710
|
-
IndexWithinInitPhaseShift =
|
|
4711
|
-
IndexWithinInitPhaseReset =
|
|
4719
|
+
IndexWithinInitPhaseIncrementer = 4096,
|
|
4720
|
+
IndexWithinInitPhaseShift = 12,
|
|
4721
|
+
IndexWithinInitPhaseReset = 4095
|
|
4712
4722
|
}
|
|
4713
4723
|
|
|
4714
4724
|
/**
|
|
@@ -6435,6 +6445,7 @@ declare interface RElement extends RNode {
|
|
|
6435
6445
|
style: RCssStyleDeclaration;
|
|
6436
6446
|
classList: RDomTokenList;
|
|
6437
6447
|
className: string;
|
|
6448
|
+
tagName: string;
|
|
6438
6449
|
textContent: string | null;
|
|
6439
6450
|
setAttribute(name: string, value: string | TrustedHTML | TrustedScript | TrustedScriptURL): void;
|
|
6440
6451
|
removeAttribute(name: string): void;
|
|
@@ -7319,9 +7330,10 @@ export declare abstract class TemplateRef<C> {
|
|
|
7319
7330
|
* and attaches it to the view container.
|
|
7320
7331
|
* @param context The data-binding context of the embedded view, as declared
|
|
7321
7332
|
* in the `<ng-template>` usage.
|
|
7333
|
+
* @param injector Injector to be used within the embedded view.
|
|
7322
7334
|
* @returns The new embedded view object.
|
|
7323
7335
|
*/
|
|
7324
|
-
abstract createEmbeddedView(context: C): EmbeddedViewRef<C>;
|
|
7336
|
+
abstract createEmbeddedView(context: C, injector?: Injector): EmbeddedViewRef<C>;
|
|
7325
7337
|
}
|
|
7326
7338
|
|
|
7327
7339
|
/**
|
|
@@ -8999,6 +9011,23 @@ export declare abstract class ViewContainerRef {
|
|
|
8999
9011
|
* @returns The number of views.
|
|
9000
9012
|
*/
|
|
9001
9013
|
abstract get length(): number;
|
|
9014
|
+
/**
|
|
9015
|
+
* Instantiates an embedded view and inserts it
|
|
9016
|
+
* into this container.
|
|
9017
|
+
* @param templateRef The HTML template that defines the view.
|
|
9018
|
+
* @param context The data-binding context of the embedded view, as declared
|
|
9019
|
+
* in the `<ng-template>` usage.
|
|
9020
|
+
* @param options Extra configuration for the created view. Includes:
|
|
9021
|
+
* * index: The 0-based index at which to insert the new view into this container.
|
|
9022
|
+
* If not specified, appends the new view as the last entry.
|
|
9023
|
+
* * injector: Injector to be used within the embedded view.
|
|
9024
|
+
*
|
|
9025
|
+
* @returns The `ViewRef` instance for the newly created view.
|
|
9026
|
+
*/
|
|
9027
|
+
abstract createEmbeddedView<C>(templateRef: TemplateRef<C>, context?: C, options?: {
|
|
9028
|
+
index?: number;
|
|
9029
|
+
injector?: Injector;
|
|
9030
|
+
}): EmbeddedViewRef<C>;
|
|
9002
9031
|
/**
|
|
9003
9032
|
* Instantiates an embedded view and inserts it
|
|
9004
9033
|
* into this container.
|
|
@@ -9948,11 +9977,11 @@ export declare const ɵivyEnabled = true;
|
|
|
9948
9977
|
* function. The component, element and each directive instance will share the same instance
|
|
9949
9978
|
* of the context.
|
|
9950
9979
|
*/
|
|
9951
|
-
export declare
|
|
9980
|
+
export declare class ɵLContext {
|
|
9952
9981
|
/**
|
|
9953
|
-
*
|
|
9982
|
+
* ID of the component's parent view data.
|
|
9954
9983
|
*/
|
|
9955
|
-
|
|
9984
|
+
private lViewId;
|
|
9956
9985
|
/**
|
|
9957
9986
|
* The index instance of the node.
|
|
9958
9987
|
*/
|
|
@@ -9970,12 +9999,27 @@ export declare interface ɵLContext {
|
|
|
9970
9999
|
*/
|
|
9971
10000
|
directives: any[] | null | undefined;
|
|
9972
10001
|
/**
|
|
9973
|
-
* The map of local references (local reference name => element or directive instance) that
|
|
9974
|
-
* on this element.
|
|
10002
|
+
* The map of local references (local reference name => element or directive instance) that
|
|
10003
|
+
* exist on this element.
|
|
9975
10004
|
*/
|
|
9976
10005
|
localRefs: {
|
|
9977
10006
|
[key: string]: any;
|
|
9978
10007
|
} | null | undefined;
|
|
10008
|
+
/** Component's parent view data. */
|
|
10009
|
+
get lView(): LView | null;
|
|
10010
|
+
constructor(
|
|
10011
|
+
/**
|
|
10012
|
+
* ID of the component's parent view data.
|
|
10013
|
+
*/
|
|
10014
|
+
lViewId: number,
|
|
10015
|
+
/**
|
|
10016
|
+
* The index instance of the node.
|
|
10017
|
+
*/
|
|
10018
|
+
nodeIndex: number,
|
|
10019
|
+
/**
|
|
10020
|
+
* The instance of the DOM node that is attached to the lNode.
|
|
10021
|
+
*/
|
|
10022
|
+
native: RNode);
|
|
9979
10023
|
}
|
|
9980
10024
|
|
|
9981
10025
|
/**
|
|
@@ -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,103 +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 { Injector } from './di';
|
|
12
|
-
import { Inject, Optional, SkipSelf } from './di/metadata';
|
|
13
|
-
import { ErrorHandler } from './error_handler';
|
|
14
|
-
import { DEFAULT_LOCALE_ID, USD_CURRENCY_CODE } from './i18n/localization';
|
|
15
|
-
import { DEFAULT_CURRENCY_CODE, LOCALE_ID } from './i18n/tokens';
|
|
16
|
-
import { ComponentFactoryResolver } from './linker';
|
|
17
|
-
import { Compiler } from './linker/compiler';
|
|
18
9
|
import { NgModule } from './metadata';
|
|
19
|
-
import { SCHEDULER } from './render3/component_ref';
|
|
20
|
-
import { NgZone } from './zone';
|
|
21
10
|
import * as i0 from "./r3_symbols";
|
|
22
11
|
import * as i1 from "./application_ref";
|
|
23
|
-
export function _localeFactory(locale) {
|
|
24
|
-
return locale || getGlobalLocale();
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* Work out the locale from the potential global properties.
|
|
28
|
-
*
|
|
29
|
-
* * Closure Compiler: use `goog.getLocale()`.
|
|
30
|
-
* * Ivy enabled: use `$localize.locale`
|
|
31
|
-
*/
|
|
32
|
-
export function getGlobalLocale() {
|
|
33
|
-
if (typeof ngI18nClosureMode !== 'undefined' && ngI18nClosureMode &&
|
|
34
|
-
typeof goog !== 'undefined' && goog.getLocale() !== 'en') {
|
|
35
|
-
// * The default `goog.getLocale()` value is `en`, while Angular used `en-US`.
|
|
36
|
-
// * In order to preserve backwards compatibility, we use Angular default value over
|
|
37
|
-
// Closure Compiler's one.
|
|
38
|
-
return goog.getLocale();
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
// KEEP `typeof $localize !== 'undefined' && $localize.locale` IN SYNC WITH THE LOCALIZE
|
|
42
|
-
// COMPILE-TIME INLINER.
|
|
43
|
-
//
|
|
44
|
-
// * During compile time inlining of translations the expression will be replaced
|
|
45
|
-
// with a string literal that is the current locale. Other forms of this expression are not
|
|
46
|
-
// guaranteed to be replaced.
|
|
47
|
-
//
|
|
48
|
-
// * During runtime translation evaluation, the developer is required to set `$localize.locale`
|
|
49
|
-
// if required, or just to provide their own `LOCALE_ID` provider.
|
|
50
|
-
return (typeof $localize !== 'undefined' && $localize.locale) || DEFAULT_LOCALE_ID;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* A built-in [dependency injection token](guide/glossary#di-token)
|
|
55
|
-
* that is used to configure the root injector for bootstrapping.
|
|
56
|
-
*/
|
|
57
|
-
export const APPLICATION_MODULE_PROVIDERS = [
|
|
58
|
-
{
|
|
59
|
-
provide: ApplicationRef,
|
|
60
|
-
useClass: ApplicationRef,
|
|
61
|
-
deps: [NgZone, Injector, ErrorHandler, ComponentFactoryResolver, ApplicationInitStatus]
|
|
62
|
-
},
|
|
63
|
-
{ provide: SCHEDULER, deps: [NgZone], useFactory: zoneSchedulerFactory },
|
|
64
|
-
{
|
|
65
|
-
provide: ApplicationInitStatus,
|
|
66
|
-
useClass: ApplicationInitStatus,
|
|
67
|
-
deps: [[new Optional(), APP_INITIALIZER]]
|
|
68
|
-
},
|
|
69
|
-
{ provide: Compiler, useClass: Compiler, deps: [] },
|
|
70
|
-
APP_ID_RANDOM_PROVIDER,
|
|
71
|
-
{
|
|
72
|
-
provide: LOCALE_ID,
|
|
73
|
-
useFactory: _localeFactory,
|
|
74
|
-
deps: [[new Inject(LOCALE_ID), new Optional(), new SkipSelf()]]
|
|
75
|
-
},
|
|
76
|
-
{ provide: DEFAULT_CURRENCY_CODE, useValue: USD_CURRENCY_CODE },
|
|
77
|
-
];
|
|
78
12
|
/**
|
|
79
|
-
* Schedule work at next available slot.
|
|
80
|
-
*
|
|
81
|
-
* In Ivy this is just `requestAnimationFrame`. For compatibility reasons when bootstrapped
|
|
82
|
-
* using `platformRef.bootstrap` we need to use `NgZone.onStable` as the scheduling mechanism.
|
|
83
|
-
* This overrides the scheduling mechanism in Ivy to `NgZone.onStable`.
|
|
84
|
-
*
|
|
85
|
-
* @param ngZone NgZone to use for scheduling.
|
|
86
|
-
*/
|
|
87
|
-
export function zoneSchedulerFactory(ngZone) {
|
|
88
|
-
let queue = [];
|
|
89
|
-
ngZone.onStable.subscribe(() => {
|
|
90
|
-
while (queue.length) {
|
|
91
|
-
queue.pop()();
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
return function (fn) {
|
|
95
|
-
queue.push(fn);
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* Configures the root injector for an app with
|
|
100
|
-
* providers of `@angular/core` dependencies that `ApplicationRef` needs
|
|
101
|
-
* to bootstrap components.
|
|
102
|
-
*
|
|
103
13
|
* Re-exported by `BrowserModule`, which is included automatically in the root
|
|
104
|
-
* `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.
|
|
105
16
|
*
|
|
106
17
|
* @publicApi
|
|
107
18
|
*/
|
|
@@ -111,9 +22,8 @@ export class ApplicationModule {
|
|
|
111
22
|
}
|
|
112
23
|
ApplicationModule.ɵfac = function ApplicationModule_Factory(t) { return new (t || ApplicationModule)(i0.ɵɵinject(i1.ApplicationRef)); };
|
|
113
24
|
ApplicationModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: ApplicationModule });
|
|
114
|
-
ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({
|
|
25
|
+
ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
|
|
115
26
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(ApplicationModule, [{
|
|
116
|
-
type: NgModule
|
|
117
|
-
args: [{ providers: APPLICATION_MODULE_PROVIDERS }]
|
|
27
|
+
type: NgModule
|
|
118
28
|
}], function () { return [{ type: i1.ApplicationRef }]; }, null); })();
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb25fbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvYXBwbGljYXRpb25fbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sWUFBWSxDQUFDOzs7QUFFcEM7Ozs7OztHQU1HO0FBRUgsTUFBTSxPQUFPLGlCQUFpQjtJQUM1Qiw0Q0FBNEM7SUFDNUMsWUFBWSxNQUFzQixJQUFHLENBQUM7O2tGQUYzQixpQkFBaUI7bUVBQWpCLGlCQUFpQjs7c0ZBQWpCLGlCQUFpQjtjQUQ3QixRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7QXBwbGljYXRpb25SZWZ9IGZyb20gJy4vYXBwbGljYXRpb25fcmVmJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJy4vbWV0YWRhdGEnO1xuXG4vKipcbiAqIFJlLWV4cG9ydGVkIGJ5IGBCcm93c2VyTW9kdWxlYCwgd2hpY2ggaXMgaW5jbHVkZWQgYXV0b21hdGljYWxseSBpbiB0aGUgcm9vdFxuICogYEFwcE1vZHVsZWAgd2hlbiB5b3UgY3JlYXRlIGEgbmV3IGFwcCB3aXRoIHRoZSBDTEkgYG5ld2AgY29tbWFuZC4gRWFnZXJseSBpbmplY3RzXG4gKiBgQXBwbGljYXRpb25SZWZgIHRvIGluc3RhbnRpYXRlIGl0LlxuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBBcHBsaWNhdGlvbk1vZHVsZSB7XG4gIC8vIEluamVjdCBBcHBsaWNhdGlvblJlZiB0byBtYWtlIGl0IGVhZ2VyLi4uXG4gIGNvbnN0cnVjdG9yKGFwcFJlZjogQXBwbGljYXRpb25SZWYpIHt9XG59XG4iXX0=
|