@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.
Files changed (41) hide show
  1. package/core.d.ts +77 -21
  2. package/esm2020/src/application_init.mjs +4 -3
  3. package/esm2020/src/application_module.mjs +5 -104
  4. package/esm2020/src/application_ref.mjs +4 -3
  5. package/esm2020/src/application_tokens.mjs +14 -2
  6. package/esm2020/src/core.mjs +2 -2
  7. package/esm2020/src/core_render3_private_export.mjs +2 -1
  8. package/esm2020/src/debug/debug_node.mjs +11 -10
  9. package/esm2020/src/i18n/tokens.mjs +39 -3
  10. package/esm2020/src/linker/compiler.mjs +4 -3
  11. package/esm2020/src/linker/template_ref.mjs +3 -3
  12. package/esm2020/src/linker/view_container_ref.mjs +35 -8
  13. package/esm2020/src/render3/component.mjs +3 -3
  14. package/esm2020/src/render3/component_ref.mjs +22 -26
  15. package/esm2020/src/render3/context_discovery.mjs +34 -30
  16. package/esm2020/src/render3/di.mjs +177 -97
  17. package/esm2020/src/render3/hooks.mjs +3 -3
  18. package/esm2020/src/render3/instructions/element.mjs +7 -1
  19. package/esm2020/src/render3/instructions/element_container.mjs +7 -1
  20. package/esm2020/src/render3/instructions/lview_debug.mjs +6 -3
  21. package/esm2020/src/render3/instructions/shared.mjs +16 -7
  22. package/esm2020/src/render3/interfaces/context.mjs +35 -2
  23. package/esm2020/src/render3/interfaces/injector.mjs +1 -1
  24. package/esm2020/src/render3/interfaces/lview_tracking.mjs +33 -0
  25. package/esm2020/src/render3/interfaces/view.mjs +4 -2
  26. package/esm2020/src/render3/node_manipulation.mjs +4 -1
  27. package/esm2020/src/render3/util/discovery_utils.mjs +33 -22
  28. package/esm2020/src/version.mjs +1 -1
  29. package/esm2020/testing/src/logger.mjs +3 -3
  30. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  31. package/fesm2015/core.mjs +478 -308
  32. package/fesm2015/core.mjs.map +1 -1
  33. package/fesm2015/testing.mjs +1 -1
  34. package/fesm2020/core.mjs +478 -301
  35. package/fesm2020/core.mjs.map +1 -1
  36. package/fesm2020/testing.mjs +1 -1
  37. package/package.json +1 -1
  38. package/schematics/migrations/entry-components/util.js +2 -2
  39. package/schematics/utils/import_manager.js +13 -12
  40. package/schematics/utils/typescript/imports.js +6 -5
  41. 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
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 = 2048,
4703
- IndexWithinInitPhaseShift = 11,
4704
- IndexWithinInitPhaseReset = 2047
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 interface ɵLContext {
9979
+ export declare class ɵLContext {
9945
9980
  /**
9946
- * The component's parent view data.
9981
+ * ID of the component's parent view data.
9947
9982
  */
9948
- lView: LView;
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 exist
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): void;
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): void;
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(): void;
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): void;
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(): void;
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): void;
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,{"version":3,"file":"application_init.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_init.ts"],"names":[],"mappings":"AAUA,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAClE,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,aAAa,CAAC;AACpD,OAAO,EAAC,IAAI,EAAC,MAAM,aAAa,CAAC;;AAGjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqEG;AACH,MAAM,CAAC,MAAM,eAAe,GACxB,IAAI,cAAc,CACd,yBAAyB,CAAC,CAAC;AAEnC;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IAOhC,YAAkE,QACc;QADd,aAAQ,GAAR,QAAQ,CACM;QAPxE,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,IAAI,CAAC;QACd,gBAAW,GAAG,KAAK,CAAC;QAEZ,SAAI,GAAG,KAAK,CAAC;QAI3B,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO;SACR;QAED,MAAM,iBAAiB,GAAmB,EAAE,CAAC;QAE7C,MAAM,QAAQ,GAAG,GAAG,EAAE;YACnB,IAAwB,CAAC,IAAI,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtC,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE;oBACzB,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACpC;qBAAM,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE;oBACnC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;wBAChE,UAAU,CAAC,SAAS,CAAC,EAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAC,CAAC,CAAC;oBAC3D,CAAC,CAAC,CAAC;oBACH,iBAAiB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;iBAC7C;aACF;SACF;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;aACzB,IAAI,CAAC,GAAG,EAAE;YACT,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QAEP,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,QAAQ,EAAE,CAAC;SACZ;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;;0FAtDU,qBAAqB,cAOZ,eAAe;2EAPxB,qBAAqB,WAArB,qBAAqB;sFAArB,qBAAqB;cADjC,UAAU;;sBAQI,MAAM;uBAAC,eAAe;;sBAAG,QAAQ","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Observable} from 'rxjs';\n\nimport {Inject, Injectable, InjectionToken, Optional} from './di';\nimport {isObservable, isPromise} from './util/lang';\nimport {noop} from './util/noop';\n\n\n/**\n * A [DI token](guide/glossary#di-token \"DI token definition\") that you can use to provide\n * one or more initialization functions.\n *\n * The provided functions are injected at application startup and executed during\n * app initialization. If any of these functions returns a Promise or an Observable, initialization\n * does not complete until the Promise is resolved or the Observable is completed.\n *\n * You can, for example, create a factory function that loads language data\n * or an external configuration, and provide that function to the `APP_INITIALIZER` token.\n * The function is executed during the application bootstrap process,\n * and the needed data is available on startup.\n *\n * @see `ApplicationInitStatus`\n *\n * @usageNotes\n *\n * The following example illustrates how to configure a multi-provider using `APP_INITIALIZER` token\n * and a function returning a promise.\n *\n * ```\n *  function initializeApp(): Promise<any> {\n *    return new Promise((resolve, reject) => {\n *      // Do some asynchronous stuff\n *      resolve();\n *    });\n *  }\n *\n *  @NgModule({\n *   imports: [BrowserModule],\n *   declarations: [AppComponent],\n *   bootstrap: [AppComponent],\n *   providers: [{\n *     provide: APP_INITIALIZER,\n *     useFactory: () => initializeApp,\n *     multi: true\n *    }]\n *   })\n *  export class AppModule {}\n * ```\n *\n * It's also possible to configure a multi-provider using `APP_INITIALIZER` token and a function\n * returning an observable, see an example below. Note: the `HttpClient` in this example is used for\n * demo purposes to illustrate how the factory function can work with other providers available\n * through DI.\n *\n * ```\n *  function initializeAppFactory(httpClient: HttpClient): () => Observable<any> {\n *   return () => httpClient.get(\"https://someUrl.com/api/user\")\n *     .pipe(\n *        tap(user => { ... })\n *     );\n *  }\n *\n *  @NgModule({\n *    imports: [BrowserModule, HttpClientModule],\n *    declarations: [AppComponent],\n *    bootstrap: [AppComponent],\n *    providers: [{\n *      provide: APP_INITIALIZER,\n *      useFactory: initializeAppFactory,\n *      deps: [HttpClient],\n *      multi: true\n *    }]\n *  })\n *  export class AppModule {}\n * ```\n *\n * @publicApi\n */\nexport const APP_INITIALIZER =\n    new InjectionToken<ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>>(\n        'Application Initializer');\n\n/**\n * A class that reflects the state of running {@link APP_INITIALIZER} functions.\n *\n * @publicApi\n */\n@Injectable()\nexport class ApplicationInitStatus {\n  private resolve = noop;\n  private reject = noop;\n  private initialized = false;\n  public readonly donePromise: Promise<any>;\n  public readonly done = false;\n\n  constructor(@Inject(APP_INITIALIZER) @Optional() private readonly appInits:\n                  ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>) {\n    this.donePromise = new Promise((res, rej) => {\n      this.resolve = res;\n      this.reject = rej;\n    });\n  }\n\n  /** @internal */\n  runInitializers() {\n    if (this.initialized) {\n      return;\n    }\n\n    const asyncInitPromises: Promise<any>[] = [];\n\n    const complete = () => {\n      (this as {done: boolean}).done = true;\n      this.resolve();\n    };\n\n    if (this.appInits) {\n      for (let i = 0; i < this.appInits.length; i++) {\n        const initResult = this.appInits[i]();\n        if (isPromise(initResult)) {\n          asyncInitPromises.push(initResult);\n        } else if (isObservable(initResult)) {\n          const observableAsPromise = new Promise<void>((resolve, reject) => {\n            initResult.subscribe({complete: resolve, error: reject});\n          });\n          asyncInitPromises.push(observableAsPromise);\n        }\n      }\n    }\n\n    Promise.all(asyncInitPromises)\n        .then(() => {\n          complete();\n        })\n        .catch(e => {\n          this.reject(e);\n        });\n\n    if (asyncInitPromises.length === 0) {\n      complete();\n    }\n    this.initialized = true;\n  }\n}\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_init.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_init.ts"],"names":[],"mappings":"AAUA,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAClE,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,aAAa,CAAC;AACpD,OAAO,EAAC,IAAI,EAAC,MAAM,aAAa,CAAC;;AAGjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqEG;AACH,MAAM,CAAC,MAAM,eAAe,GACxB,IAAI,cAAc,CACd,yBAAyB,CAAC,CAAC;AAEnC;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IAOhC,YAAkE,QACc;QADd,aAAQ,GAAR,QAAQ,CACM;QAPxE,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,IAAI,CAAC;QACd,gBAAW,GAAG,KAAK,CAAC;QAEZ,SAAI,GAAG,KAAK,CAAC;QAI3B,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO;SACR;QAED,MAAM,iBAAiB,GAAmB,EAAE,CAAC;QAE7C,MAAM,QAAQ,GAAG,GAAG,EAAE;YACnB,IAAwB,CAAC,IAAI,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtC,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE;oBACzB,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACpC;qBAAM,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE;oBACnC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;wBAChE,UAAU,CAAC,SAAS,CAAC,EAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAC,CAAC,CAAC;oBAC3D,CAAC,CAAC,CAAC;oBACH,iBAAiB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;iBAC7C;aACF;SACF;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;aACzB,IAAI,CAAC,GAAG,EAAE;YACT,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QAEP,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,QAAQ,EAAE,CAAC;SACZ;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;;0FAtDU,qBAAqB,cAOZ,eAAe;2EAPxB,qBAAqB,WAArB,qBAAqB,mBADT,MAAM;sFAClB,qBAAqB;cADjC,UAAU;eAAC,EAAC,UAAU,EAAE,MAAM,EAAC;;sBAQjB,MAAM;uBAAC,eAAe;;sBAAG,QAAQ","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Observable} from 'rxjs';\n\nimport {Inject, Injectable, InjectionToken, Optional} from './di';\nimport {isObservable, isPromise} from './util/lang';\nimport {noop} from './util/noop';\n\n\n/**\n * A [DI token](guide/glossary#di-token \"DI token definition\") that you can use to provide\n * one or more initialization functions.\n *\n * The provided functions are injected at application startup and executed during\n * app initialization. If any of these functions returns a Promise or an Observable, initialization\n * does not complete until the Promise is resolved or the Observable is completed.\n *\n * You can, for example, create a factory function that loads language data\n * or an external configuration, and provide that function to the `APP_INITIALIZER` token.\n * The function is executed during the application bootstrap process,\n * and the needed data is available on startup.\n *\n * @see `ApplicationInitStatus`\n *\n * @usageNotes\n *\n * The following example illustrates how to configure a multi-provider using `APP_INITIALIZER` token\n * and a function returning a promise.\n *\n * ```\n *  function initializeApp(): Promise<any> {\n *    return new Promise((resolve, reject) => {\n *      // Do some asynchronous stuff\n *      resolve();\n *    });\n *  }\n *\n *  @NgModule({\n *   imports: [BrowserModule],\n *   declarations: [AppComponent],\n *   bootstrap: [AppComponent],\n *   providers: [{\n *     provide: APP_INITIALIZER,\n *     useFactory: () => initializeApp,\n *     multi: true\n *    }]\n *   })\n *  export class AppModule {}\n * ```\n *\n * It's also possible to configure a multi-provider using `APP_INITIALIZER` token and a function\n * returning an observable, see an example below. Note: the `HttpClient` in this example is used for\n * demo purposes to illustrate how the factory function can work with other providers available\n * through DI.\n *\n * ```\n *  function initializeAppFactory(httpClient: HttpClient): () => Observable<any> {\n *   return () => httpClient.get(\"https://someUrl.com/api/user\")\n *     .pipe(\n *        tap(user => { ... })\n *     );\n *  }\n *\n *  @NgModule({\n *    imports: [BrowserModule, HttpClientModule],\n *    declarations: [AppComponent],\n *    bootstrap: [AppComponent],\n *    providers: [{\n *      provide: APP_INITIALIZER,\n *      useFactory: initializeAppFactory,\n *      deps: [HttpClient],\n *      multi: true\n *    }]\n *  })\n *  export class AppModule {}\n * ```\n *\n * @publicApi\n */\nexport const APP_INITIALIZER =\n    new InjectionToken<ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>>(\n        'Application Initializer');\n\n/**\n * A class that reflects the state of running {@link APP_INITIALIZER} functions.\n *\n * @publicApi\n */\n@Injectable({providedIn: 'root'})\nexport class ApplicationInitStatus {\n  private resolve = noop;\n  private reject = noop;\n  private initialized = false;\n  public readonly donePromise: Promise<any>;\n  public readonly done = false;\n\n  constructor(@Inject(APP_INITIALIZER) @Optional() private readonly appInits:\n                  ReadonlyArray<() => Observable<unknown>| Promise<unknown>| void>) {\n    this.donePromise = new Promise((res, rej) => {\n      this.resolve = res;\n      this.reject = rej;\n    });\n  }\n\n  /** @internal */\n  runInitializers() {\n    if (this.initialized) {\n      return;\n    }\n\n    const asyncInitPromises: Promise<any>[] = [];\n\n    const complete = () => {\n      (this as {done: boolean}).done = true;\n      this.resolve();\n    };\n\n    if (this.appInits) {\n      for (let i = 0; i < this.appInits.length; i++) {\n        const initResult = this.appInits[i]();\n        if (isPromise(initResult)) {\n          asyncInitPromises.push(initResult);\n        } else if (isObservable(initResult)) {\n          const observableAsPromise = new Promise<void>((resolve, reject) => {\n            initResult.subscribe({complete: resolve, error: reject});\n          });\n          asyncInitPromises.push(observableAsPromise);\n        }\n      }\n    }\n\n    Promise.all(asyncInitPromises)\n        .then(() => {\n          complete();\n        })\n        .catch(e => {\n          this.reject(e);\n        });\n\n    if (asyncInitPromises.length === 0) {\n      complete();\n    }\n    this.initialized = true;\n  }\n}\n"]}
@@ -5,112 +5,14 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- import { APP_INITIALIZER, ApplicationInitStatus } from './application_init';
9
8
  import { ApplicationRef } from './application_ref';
10
- import { APP_ID_RANDOM_PROVIDER } from './application_tokens';
11
- import { defaultIterableDiffers, defaultKeyValueDiffers, IterableDiffers, KeyValueDiffers } from './change_detection/change_detection';
12
- import { Injector } from './di';
13
- import { Inject, Optional, SkipSelf } from './di/metadata';
14
- import { ErrorHandler } from './error_handler';
15
- import { DEFAULT_LOCALE_ID, USD_CURRENCY_CODE } from './i18n/localization';
16
- import { DEFAULT_CURRENCY_CODE, LOCALE_ID } from './i18n/tokens';
17
- import { ComponentFactoryResolver } from './linker';
18
- import { Compiler } from './linker/compiler';
19
9
  import { NgModule } from './metadata';
20
- import { SCHEDULER } from './render3/component_ref';
21
- import { NgZone } from './zone';
22
10
  import * as i0 from "./r3_symbols";
23
11
  import * as i1 from "./application_ref";
24
- export function _iterableDiffersFactory() {
25
- return defaultIterableDiffers;
26
- }
27
- export function _keyValueDiffersFactory() {
28
- return defaultKeyValueDiffers;
29
- }
30
- export function _localeFactory(locale) {
31
- return locale || getGlobalLocale();
32
- }
33
- /**
34
- * Work out the locale from the potential global properties.
35
- *
36
- * * Closure Compiler: use `goog.getLocale()`.
37
- * * Ivy enabled: use `$localize.locale`
38
- */
39
- export function getGlobalLocale() {
40
- if (typeof ngI18nClosureMode !== 'undefined' && ngI18nClosureMode &&
41
- typeof goog !== 'undefined' && goog.getLocale() !== 'en') {
42
- // * The default `goog.getLocale()` value is `en`, while Angular used `en-US`.
43
- // * In order to preserve backwards compatibility, we use Angular default value over
44
- // Closure Compiler's one.
45
- return goog.getLocale();
46
- }
47
- else {
48
- // KEEP `typeof $localize !== 'undefined' && $localize.locale` IN SYNC WITH THE LOCALIZE
49
- // COMPILE-TIME INLINER.
50
- //
51
- // * During compile time inlining of translations the expression will be replaced
52
- // with a string literal that is the current locale. Other forms of this expression are not
53
- // guaranteed to be replaced.
54
- //
55
- // * During runtime translation evaluation, the developer is required to set `$localize.locale`
56
- // if required, or just to provide their own `LOCALE_ID` provider.
57
- return (typeof $localize !== 'undefined' && $localize.locale) || DEFAULT_LOCALE_ID;
58
- }
59
- }
60
12
  /**
61
- * A built-in [dependency injection token](guide/glossary#di-token)
62
- * that is used to configure the root injector for bootstrapping.
63
- */
64
- export const APPLICATION_MODULE_PROVIDERS = [
65
- {
66
- provide: ApplicationRef,
67
- useClass: ApplicationRef,
68
- deps: [NgZone, Injector, ErrorHandler, ComponentFactoryResolver, ApplicationInitStatus]
69
- },
70
- { provide: SCHEDULER, deps: [NgZone], useFactory: zoneSchedulerFactory },
71
- {
72
- provide: ApplicationInitStatus,
73
- useClass: ApplicationInitStatus,
74
- deps: [[new Optional(), APP_INITIALIZER]]
75
- },
76
- { provide: Compiler, useClass: Compiler, deps: [] },
77
- APP_ID_RANDOM_PROVIDER,
78
- { provide: IterableDiffers, useFactory: _iterableDiffersFactory, deps: [] },
79
- { provide: KeyValueDiffers, useFactory: _keyValueDiffersFactory, deps: [] },
80
- {
81
- provide: LOCALE_ID,
82
- useFactory: _localeFactory,
83
- deps: [[new Inject(LOCALE_ID), new Optional(), new SkipSelf()]]
84
- },
85
- { provide: DEFAULT_CURRENCY_CODE, useValue: USD_CURRENCY_CODE },
86
- ];
87
- /**
88
- * Schedule work at next available slot.
89
- *
90
- * In Ivy this is just `requestAnimationFrame`. For compatibility reasons when bootstrapped
91
- * using `platformRef.bootstrap` we need to use `NgZone.onStable` as the scheduling mechanism.
92
- * This overrides the scheduling mechanism in Ivy to `NgZone.onStable`.
93
- *
94
- * @param ngZone NgZone to use for scheduling.
95
- */
96
- export function zoneSchedulerFactory(ngZone) {
97
- let queue = [];
98
- ngZone.onStable.subscribe(() => {
99
- while (queue.length) {
100
- queue.pop()();
101
- }
102
- });
103
- return function (fn) {
104
- queue.push(fn);
105
- };
106
- }
107
- /**
108
- * Configures the root injector for an app with
109
- * providers of `@angular/core` dependencies that `ApplicationRef` needs
110
- * to bootstrap components.
111
- *
112
13
  * Re-exported by `BrowserModule`, which is included automatically in the root
113
- * `AppModule` when you create a new app with the CLI `new` command.
14
+ * `AppModule` when you create a new app with the CLI `new` command. Eagerly injects
15
+ * `ApplicationRef` to instantiate it.
114
16
  *
115
17
  * @publicApi
116
18
  */
@@ -120,9 +22,8 @@ export class ApplicationModule {
120
22
  }
121
23
  ApplicationModule.ɵfac = function ApplicationModule_Factory(t) { return new (t || ApplicationModule)(i0.ɵɵinject(i1.ApplicationRef)); };
122
24
  ApplicationModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: ApplicationModule });
123
- ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ providers: APPLICATION_MODULE_PROVIDERS });
25
+ ApplicationModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({});
124
26
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.setClassMetadata(ApplicationModule, [{
125
- type: NgModule,
126
- args: [{ providers: APPLICATION_MODULE_PROVIDERS }]
27
+ type: NgModule
127
28
  }], function () { return [{ type: i1.ApplicationRef }]; }, null); })();
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application_module.js","sourceRoot":"","sources":["../../../../../../packages/core/src/application_module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {APP_INITIALIZER, ApplicationInitStatus} from './application_init';\nimport {ApplicationRef} from './application_ref';\nimport {APP_ID_RANDOM_PROVIDER} from './application_tokens';\nimport {defaultIterableDiffers, defaultKeyValueDiffers, IterableDiffers, KeyValueDiffers} from './change_detection/change_detection';\nimport {Injector, StaticProvider} from './di';\nimport {Inject, Optional, SkipSelf} from './di/metadata';\nimport {ErrorHandler} from './error_handler';\nimport {DEFAULT_LOCALE_ID, USD_CURRENCY_CODE} from './i18n/localization';\nimport {DEFAULT_CURRENCY_CODE, LOCALE_ID} from './i18n/tokens';\nimport {ComponentFactoryResolver} from './linker';\nimport {Compiler} from './linker/compiler';\nimport {NgModule} from './metadata';\nimport {SCHEDULER} from './render3/component_ref';\nimport {NgZone} from './zone';\n\ndeclare const $localize: {locale?: string};\n\nexport function _iterableDiffersFactory() {\n  return defaultIterableDiffers;\n}\n\nexport function _keyValueDiffersFactory() {\n  return defaultKeyValueDiffers;\n}\n\nexport function _localeFactory(locale?: string): string {\n  return locale || getGlobalLocale();\n}\n/**\n * Work out the locale from the potential global properties.\n *\n * * Closure Compiler: use `goog.getLocale()`.\n * * Ivy enabled: use `$localize.locale`\n */\nexport function getGlobalLocale(): string {\n  if (typeof ngI18nClosureMode !== 'undefined' && ngI18nClosureMode &&\n      typeof goog !== 'undefined' && goog.getLocale() !== 'en') {\n    // * The default `goog.getLocale()` value is `en`, while Angular used `en-US`.\n    // * In order to preserve backwards compatibility, we use Angular default value over\n    //   Closure Compiler's one.\n    return goog.getLocale();\n  } else {\n    // KEEP `typeof $localize !== 'undefined' && $localize.locale` IN SYNC WITH THE LOCALIZE\n    // COMPILE-TIME INLINER.\n    //\n    // * During compile time inlining of translations the expression will be replaced\n    //   with a string literal that is the current locale. Other forms of this expression are not\n    //   guaranteed to be replaced.\n    //\n    // * During runtime translation evaluation, the developer is required to set `$localize.locale`\n    //   if required, or just to provide their own `LOCALE_ID` provider.\n    return (typeof $localize !== 'undefined' && $localize.locale) || DEFAULT_LOCALE_ID;\n  }\n}\n\n/**\n * A built-in [dependency injection token](guide/glossary#di-token)\n * that is used to configure the root injector for bootstrapping.\n */\nexport const APPLICATION_MODULE_PROVIDERS: StaticProvider[] = [\n  {\n    provide: ApplicationRef,\n    useClass: ApplicationRef,\n    deps: [NgZone, Injector, ErrorHandler, ComponentFactoryResolver, ApplicationInitStatus]\n  },\n  {provide: SCHEDULER, deps: [NgZone], useFactory: zoneSchedulerFactory},\n  {\n    provide: ApplicationInitStatus,\n    useClass: ApplicationInitStatus,\n    deps: [[new Optional(), APP_INITIALIZER]]\n  },\n  {provide: Compiler, useClass: Compiler, deps: []},\n  APP_ID_RANDOM_PROVIDER,\n  {provide: IterableDiffers, useFactory: _iterableDiffersFactory, deps: []},\n  {provide: KeyValueDiffers, useFactory: _keyValueDiffersFactory, deps: []},\n  {\n    provide: LOCALE_ID,\n    useFactory: _localeFactory,\n    deps: [[new Inject(LOCALE_ID), new Optional(), new SkipSelf()]]\n  },\n  {provide: DEFAULT_CURRENCY_CODE, useValue: USD_CURRENCY_CODE},\n];\n\n/**\n * Schedule work at next available slot.\n *\n * In Ivy this is just `requestAnimationFrame`. For compatibility reasons when bootstrapped\n * using `platformRef.bootstrap` we need to use `NgZone.onStable` as the scheduling mechanism.\n * This overrides the scheduling mechanism in Ivy to `NgZone.onStable`.\n *\n * @param ngZone NgZone to use for scheduling.\n */\nexport function zoneSchedulerFactory(ngZone: NgZone): (fn: () => void) => void {\n  let queue: (() => void)[] = [];\n  ngZone.onStable.subscribe(() => {\n    while (queue.length) {\n      queue.pop()!();\n    }\n  });\n  return function(fn: () => void) {\n    queue.push(fn);\n  };\n}\n\n/**\n * Configures the root injector for an app with\n * providers of `@angular/core` dependencies that `ApplicationRef` needs\n * to bootstrap components.\n *\n * Re-exported by `BrowserModule`, which is included automatically in the root\n * `AppModule` when you create a new app with the CLI `new` command.\n *\n * @publicApi\n */\n@NgModule({providers: APPLICATION_MODULE_PROVIDERS})\nexport class ApplicationModule {\n  // Inject ApplicationRef to make it eager...\n  constructor(appRef: ApplicationRef) {}\n}\n"]}
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb25fbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvYXBwbGljYXRpb25fbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sWUFBWSxDQUFDOzs7QUFFcEM7Ozs7OztHQU1HO0FBRUgsTUFBTSxPQUFPLGlCQUFpQjtJQUM1Qiw0Q0FBNEM7SUFDNUMsWUFBWSxNQUFzQixJQUFHLENBQUM7O2tGQUYzQixpQkFBaUI7bUVBQWpCLGlCQUFpQjs7c0ZBQWpCLGlCQUFpQjtjQUQ3QixRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7QXBwbGljYXRpb25SZWZ9IGZyb20gJy4vYXBwbGljYXRpb25fcmVmJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJy4vbWV0YWRhdGEnO1xuXG4vKipcbiAqIFJlLWV4cG9ydGVkIGJ5IGBCcm93c2VyTW9kdWxlYCwgd2hpY2ggaXMgaW5jbHVkZWQgYXV0b21hdGljYWxseSBpbiB0aGUgcm9vdFxuICogYEFwcE1vZHVsZWAgd2hlbiB5b3UgY3JlYXRlIGEgbmV3IGFwcCB3aXRoIHRoZSBDTEkgYG5ld2AgY29tbWFuZC4gRWFnZXJseSBpbmplY3RzXG4gKiBgQXBwbGljYXRpb25SZWZgIHRvIGluc3RhbnRpYXRlIGl0LlxuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBBcHBsaWNhdGlvbk1vZHVsZSB7XG4gIC8vIEluamVjdCBBcHBsaWNhdGlvblJlZiB0byBtYWtlIGl0IGVhZ2VyLi4uXG4gIGNvbnN0cnVjdG9yKGFwcFJlZjogQXBwbGljYXRpb25SZWYpIHt9XG59XG4iXX0=