@angular/platform-server 16.0.0-next.3 → 16.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 (49) hide show
  1. package/esm2022/src/http.mjs +26 -0
  2. package/{esm2020 → esm2022}/src/location.mjs +4 -4
  3. package/{esm2020 → esm2022}/src/platform_state.mjs +4 -4
  4. package/esm2022/src/server.mjs +104 -0
  5. package/{esm2020 → esm2022}/src/server_events.mjs +4 -4
  6. package/{esm2020 → esm2022}/src/server_renderer.mjs +4 -4
  7. package/{esm2020 → esm2022}/src/tokens.mjs +1 -1
  8. package/esm2022/src/transfer_state.mjs +59 -0
  9. package/esm2022/src/utils.mjs +146 -0
  10. package/{esm2020 → esm2022}/src/version.mjs +1 -1
  11. package/{esm2020 → esm2022}/testing/src/server.mjs +5 -5
  12. package/{fesm2015 → fesm2022}/init.mjs +1 -1
  13. package/{fesm2020 → fesm2022}/platform-server.mjs +69 -194
  14. package/{fesm2020 → fesm2022}/platform-server.mjs.map +1 -1
  15. package/{fesm2020 → fesm2022}/testing.mjs +5 -5
  16. package/{fesm2015 → fesm2022}/testing.mjs.map +1 -1
  17. package/index.d.ts +9 -42
  18. package/init/index.d.ts +1 -1
  19. package/package.json +19 -30
  20. package/testing/index.d.ts +1 -1
  21. package/esm2020/src/http.mjs +0 -125
  22. package/esm2020/src/server.mjs +0 -107
  23. package/esm2020/src/styles_host.mjs +0 -48
  24. package/esm2020/src/transfer_state.mjs +0 -60
  25. package/esm2020/src/utils.mjs +0 -138
  26. package/fesm2015/platform-server.mjs +0 -21176
  27. package/fesm2015/platform-server.mjs.map +0 -1
  28. package/fesm2015/testing.mjs +0 -58
  29. package/fesm2020/init.mjs +0 -35
  30. package/fesm2020/init.mjs.map +0 -1
  31. package/fesm2020/testing.mjs.map +0 -1
  32. /package/{esm2020 → esm2022}/index.mjs +0 -0
  33. /package/{esm2020 → esm2022}/init/index.mjs +0 -0
  34. /package/{esm2020 → esm2022}/init/init.mjs +0 -0
  35. /package/{esm2020 → esm2022}/init/public_api.mjs +0 -0
  36. /package/{esm2020 → esm2022}/init/src/init.mjs +0 -0
  37. /package/{esm2020 → esm2022}/init/src/shims.mjs +0 -0
  38. /package/{esm2020 → esm2022}/platform-server.mjs +0 -0
  39. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  40. /package/{esm2020 → esm2022}/src/bundled-domino.mjs +0 -0
  41. /package/{esm2020 → esm2022}/src/domino_adapter.mjs +0 -0
  42. /package/{esm2020 → esm2022}/src/platform-server.mjs +0 -0
  43. /package/{esm2020 → esm2022}/src/private_export.mjs +0 -0
  44. /package/{esm2020 → esm2022}/src/provide_server.mjs +0 -0
  45. /package/{esm2020 → esm2022}/testing/index.mjs +0 -0
  46. /package/{esm2020 → esm2022}/testing/public_api.mjs +0 -0
  47. /package/{esm2020 → esm2022}/testing/src/testing.mjs +0 -0
  48. /package/{esm2020 → esm2022}/testing/testing.mjs +0 -0
  49. /package/{fesm2015 → fesm2022}/init.mjs.map +0 -0
@@ -0,0 +1,146 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { ApplicationRef, InjectionToken, Renderer2, ɵannotateForHydration as annotateForHydration, ɵInitialRenderPendingTasks as InitialRenderPendingTasks, ɵIS_HYDRATION_FEATURE_ENABLED as IS_HYDRATION_FEATURE_ENABLED, ɵisPromise } from '@angular/core';
9
+ import { first } from 'rxjs/operators';
10
+ import { PlatformState } from './platform_state';
11
+ import { platformDynamicServer } from './server';
12
+ import { BEFORE_APP_SERIALIZED, INITIAL_CONFIG } from './tokens';
13
+ function _getPlatform(platformFactory, options) {
14
+ const extraProviders = options.platformProviders ?? [];
15
+ return platformFactory([
16
+ { provide: INITIAL_CONFIG, useValue: { document: options.document, url: options.url } },
17
+ extraProviders
18
+ ]);
19
+ }
20
+ /**
21
+ * Adds the `ng-server-context` attribute to host elements of all bootstrapped components
22
+ * within a given application.
23
+ */
24
+ function appendServerContextInfo(serverContext, applicationRef) {
25
+ applicationRef.components.forEach(componentRef => {
26
+ const renderer = componentRef.injector.get(Renderer2);
27
+ const element = componentRef.location.nativeElement;
28
+ if (element) {
29
+ renderer.setAttribute(element, 'ng-server-context', serverContext);
30
+ }
31
+ });
32
+ }
33
+ function _render(platform, bootstrapPromise) {
34
+ return bootstrapPromise.then((moduleOrApplicationRef) => {
35
+ const environmentInjector = moduleOrApplicationRef.injector;
36
+ const applicationRef = moduleOrApplicationRef instanceof ApplicationRef ?
37
+ moduleOrApplicationRef :
38
+ environmentInjector.get(ApplicationRef);
39
+ const serverContext = sanitizeServerContext(environmentInjector.get(SERVER_CONTEXT, DEFAULT_SERVER_CONTEXT));
40
+ const isStablePromise = applicationRef.isStable.pipe((first((isStable) => isStable))).toPromise();
41
+ const pendingTasks = environmentInjector.get(InitialRenderPendingTasks);
42
+ const pendingTasksPromise = pendingTasks.whenAllTasksComplete;
43
+ return Promise.allSettled([isStablePromise, pendingTasksPromise]).then(() => {
44
+ appendServerContextInfo(serverContext, applicationRef);
45
+ const platformState = platform.injector.get(PlatformState);
46
+ const asyncPromises = [];
47
+ if (applicationRef.injector.get(IS_HYDRATION_FEATURE_ENABLED, false)) {
48
+ annotateForHydration(applicationRef, platformState.getDocument());
49
+ }
50
+ // Run any BEFORE_APP_SERIALIZED callbacks just before rendering to string.
51
+ const callbacks = environmentInjector.get(BEFORE_APP_SERIALIZED, null);
52
+ if (callbacks) {
53
+ for (const callback of callbacks) {
54
+ try {
55
+ const callbackResult = callback();
56
+ if (ɵisPromise(callbackResult)) {
57
+ // TODO: in TS3.7, callbackResult is void.
58
+ asyncPromises.push(callbackResult);
59
+ }
60
+ }
61
+ catch (e) {
62
+ // Ignore exceptions.
63
+ console.warn('Ignoring BEFORE_APP_SERIALIZED Exception: ', e);
64
+ }
65
+ }
66
+ }
67
+ const complete = () => {
68
+ const output = platformState.renderToString();
69
+ platform.destroy();
70
+ return output;
71
+ };
72
+ if (asyncPromises.length === 0) {
73
+ return complete();
74
+ }
75
+ return Promise
76
+ .all(asyncPromises.map(asyncPromise => {
77
+ return asyncPromise.catch(e => {
78
+ console.warn('Ignoring BEFORE_APP_SERIALIZED Exception: ', e);
79
+ });
80
+ }))
81
+ .then(complete);
82
+ });
83
+ });
84
+ }
85
+ /**
86
+ * Specifies the value that should be used if no server context value has been provided.
87
+ */
88
+ const DEFAULT_SERVER_CONTEXT = 'other';
89
+ /**
90
+ * An internal token that allows providing extra information about the server context
91
+ * (e.g. whether SSR or SSG was used). The value is a string and characters other
92
+ * than [a-zA-Z0-9\-] are removed. See the default value in `DEFAULT_SERVER_CONTEXT` const.
93
+ */
94
+ export const SERVER_CONTEXT = new InjectionToken('SERVER_CONTEXT');
95
+ /**
96
+ * Sanitizes provided server context:
97
+ * - removes all characters other than a-z, A-Z, 0-9 and `-`
98
+ * - returns `other` if nothing is provided or the string is empty after sanitization
99
+ */
100
+ function sanitizeServerContext(serverContext) {
101
+ const context = serverContext.replace(/[^a-zA-Z0-9\-]/g, '');
102
+ return context.length > 0 ? context : DEFAULT_SERVER_CONTEXT;
103
+ }
104
+ /**
105
+ * Bootstraps an application using provided NgModule and serializes the page content to string.
106
+ *
107
+ * @param moduleType A reference to an NgModule that should be used for bootstrap.
108
+ * @param options Additional configuration for the render operation:
109
+ * - `document` - the document of the page to render, either as an HTML string or
110
+ * as a reference to the `document` instance.
111
+ * - `url` - the URL for the current render request.
112
+ * - `extraProviders` - set of platform level providers for the current render request.
113
+ *
114
+ * @publicApi
115
+ */
116
+ export function renderModule(moduleType, options) {
117
+ const { document, url, extraProviders: platformProviders } = options;
118
+ const platform = _getPlatform(platformDynamicServer, { document, url, platformProviders });
119
+ return _render(platform, platform.bootstrapModule(moduleType));
120
+ }
121
+ /**
122
+ * Bootstraps an instance of an Angular application and renders it to a string.
123
+
124
+ * ```typescript
125
+ * const bootstrap = () => bootstrapApplication(RootComponent, appConfig);
126
+ * const output: string = await renderApplication(bootstrap);
127
+ * ```
128
+ *
129
+ * @param bootstrap A method that when invoked returns a promise that returns an `ApplicationRef`
130
+ * instance once resolved.
131
+ * @param options Additional configuration for the render operation:
132
+ * - `document` - the document of the page to render, either as an HTML string or
133
+ * as a reference to the `document` instance.
134
+ * - `url` - the URL for the current render request.
135
+ * - `platformProviders` - the platform level providers for the current render request.
136
+ *
137
+ * @returns A Promise, that returns serialized (to a string) rendered page, once resolved.
138
+ *
139
+ * @publicApi
140
+ * @developerPreview
141
+ */
142
+ export function renderApplication(bootstrap, options) {
143
+ const platform = _getPlatform(platformDynamicServer, options);
144
+ return _render(platform, bootstrap());
145
+ }
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../packages/platform-server/src/utils.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 {ApplicationRef, InjectionToken, NgModuleRef, PlatformRef, Provider, Renderer2, StaticProvider, Type, ɵannotateForHydration as annotateForHydration, ɵInitialRenderPendingTasks as InitialRenderPendingTasks, ɵIS_HYDRATION_FEATURE_ENABLED as IS_HYDRATION_FEATURE_ENABLED, ɵisPromise} from '@angular/core';\nimport {first} from 'rxjs/operators';\n\nimport {PlatformState} from './platform_state';\nimport {platformDynamicServer} from './server';\nimport {BEFORE_APP_SERIALIZED, INITIAL_CONFIG} from './tokens';\n\ninterface PlatformOptions {\n  document?: string|Document;\n  url?: string;\n  platformProviders?: Provider[];\n}\n\nfunction _getPlatform(\n    platformFactory: (extraProviders: StaticProvider[]) => PlatformRef,\n    options: PlatformOptions): PlatformRef {\n  const extraProviders = options.platformProviders ?? [];\n  return platformFactory([\n    {provide: INITIAL_CONFIG, useValue: {document: options.document, url: options.url}},\n    extraProviders\n  ]);\n}\n\n/**\n * Adds the `ng-server-context` attribute to host elements of all bootstrapped components\n * within a given application.\n */\nfunction appendServerContextInfo(serverContext: string, applicationRef: ApplicationRef) {\n  applicationRef.components.forEach(componentRef => {\n    const renderer = componentRef.injector.get(Renderer2);\n    const element = componentRef.location.nativeElement;\n    if (element) {\n      renderer.setAttribute(element, 'ng-server-context', serverContext);\n    }\n  });\n}\n\nfunction _render<T>(\n    platform: PlatformRef,\n    bootstrapPromise: Promise<NgModuleRef<T>|ApplicationRef>): Promise<string> {\n  return bootstrapPromise.then((moduleOrApplicationRef) => {\n    const environmentInjector = moduleOrApplicationRef.injector;\n    const applicationRef: ApplicationRef = moduleOrApplicationRef instanceof ApplicationRef ?\n        moduleOrApplicationRef :\n        environmentInjector.get(ApplicationRef);\n    const serverContext =\n        sanitizeServerContext(environmentInjector.get(SERVER_CONTEXT, DEFAULT_SERVER_CONTEXT));\n    const isStablePromise =\n        applicationRef.isStable.pipe((first((isStable: boolean) => isStable))).toPromise();\n    const pendingTasks = environmentInjector.get(InitialRenderPendingTasks);\n    const pendingTasksPromise = pendingTasks.whenAllTasksComplete;\n    return Promise.allSettled([isStablePromise, pendingTasksPromise]).then(() => {\n      appendServerContextInfo(serverContext, applicationRef);\n\n      const platformState = platform.injector.get(PlatformState);\n\n      const asyncPromises: Promise<any>[] = [];\n\n      if (applicationRef.injector.get(IS_HYDRATION_FEATURE_ENABLED, false)) {\n        annotateForHydration(applicationRef, platformState.getDocument());\n      }\n\n      // Run any BEFORE_APP_SERIALIZED callbacks just before rendering to string.\n      const callbacks = environmentInjector.get(BEFORE_APP_SERIALIZED, null);\n\n      if (callbacks) {\n        for (const callback of callbacks) {\n          try {\n            const callbackResult = callback();\n            if (ɵisPromise(callbackResult)) {\n              // TODO: in TS3.7, callbackResult is void.\n              asyncPromises.push(callbackResult as any);\n            }\n\n          } catch (e) {\n            // Ignore exceptions.\n            console.warn('Ignoring BEFORE_APP_SERIALIZED Exception: ', e);\n          }\n        }\n      }\n\n      const complete = () => {\n        const output = platformState.renderToString();\n        platform.destroy();\n        return output;\n      };\n\n      if (asyncPromises.length === 0) {\n        return complete();\n      }\n\n      return Promise\n          .all(asyncPromises.map(asyncPromise => {\n            return asyncPromise.catch(e => {\n              console.warn('Ignoring BEFORE_APP_SERIALIZED Exception: ', e);\n            });\n          }))\n          .then(complete);\n    });\n  });\n}\n\n/**\n * Specifies the value that should be used if no server context value has been provided.\n */\nconst DEFAULT_SERVER_CONTEXT = 'other';\n\n/**\n * An internal token that allows providing extra information about the server context\n * (e.g. whether SSR or SSG was used). The value is a string and characters other\n * than [a-zA-Z0-9\\-] are removed. See the default value in `DEFAULT_SERVER_CONTEXT` const.\n */\nexport const SERVER_CONTEXT = new InjectionToken<string>('SERVER_CONTEXT');\n\n/**\n * Sanitizes provided server context:\n * - removes all characters other than a-z, A-Z, 0-9 and `-`\n * - returns `other` if nothing is provided or the string is empty after sanitization\n */\nfunction sanitizeServerContext(serverContext: string): string {\n  const context = serverContext.replace(/[^a-zA-Z0-9\\-]/g, '');\n  return context.length > 0 ? context : DEFAULT_SERVER_CONTEXT;\n}\n\n/**\n * Bootstraps an application using provided NgModule and serializes the page content to string.\n *\n * @param moduleType A reference to an NgModule that should be used for bootstrap.\n * @param options Additional configuration for the render operation:\n *  - `document` - the document of the page to render, either as an HTML string or\n *                 as a reference to the `document` instance.\n *  - `url` - the URL for the current render request.\n *  - `extraProviders` - set of platform level providers for the current render request.\n *\n * @publicApi\n */\nexport function renderModule<T>(moduleType: Type<T>, options: {\n  document?: string|Document,\n  url?: string,\n  extraProviders?: StaticProvider[],\n}): Promise<string> {\n  const {document, url, extraProviders: platformProviders} = options;\n  const platform = _getPlatform(platformDynamicServer, {document, url, platformProviders});\n  return _render(platform, platform.bootstrapModule(moduleType));\n}\n\n/**\n * Bootstraps an instance of an Angular application and renders it to a string.\n\n * ```typescript\n * const bootstrap = () => bootstrapApplication(RootComponent, appConfig);\n * const output: string = await renderApplication(bootstrap);\n * ```\n *\n * @param bootstrap A method that when invoked returns a promise that returns an `ApplicationRef`\n *     instance once resolved.\n * @param options Additional configuration for the render operation:\n *  - `document` - the document of the page to render, either as an HTML string or\n *                 as a reference to the `document` instance.\n *  - `url` - the URL for the current render request.\n *  - `platformProviders` - the platform level providers for the current render request.\n *\n * @returns A Promise, that returns serialized (to a string) rendered page, once resolved.\n *\n * @publicApi\n * @developerPreview\n */\nexport function renderApplication<T>(bootstrap: () => Promise<ApplicationRef>, options: {\n  document?: string|Document,\n  url?: string,\n  platformProviders?: Provider[],\n}): Promise<string> {\n  const platform = _getPlatform(platformDynamicServer, options);\n\n  return _render(platform, bootstrap());\n}\n"]}
@@ -14,5 +14,5 @@ import { Version } from '@angular/core';
14
14
  /**
15
15
  * @publicApi
16
16
  */
17
- export const VERSION = new Version('16.0.0-next.3');
17
+ export const VERSION = new Version('16.0.0-next.5');
18
18
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYXRmb3JtLXNlcnZlci9zcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSDs7OztHQUlHO0FBRUgsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV0Qzs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBwbGF0Zm9ybS1zZXJ2ZXIgcGFja2FnZS5cbiAqL1xuXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
@@ -22,12 +22,12 @@ export const platformServerTesting = createPlatformFactory(platformCoreDynamicTe
22
22
  * @publicApi
23
23
  */
24
24
  class ServerTestingModule {
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTestingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTestingModule, imports: [NoopAnimationsModule], exports: [BrowserDynamicTestingModule] }); }
27
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTestingModule, providers: SERVER_RENDER_PROVIDERS, imports: [NoopAnimationsModule, BrowserDynamicTestingModule] }); }
25
28
  }
26
- ServerTestingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTestingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
27
- ServerTestingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTestingModule, imports: [NoopAnimationsModule], exports: [BrowserDynamicTestingModule] });
28
- ServerTestingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTestingModule, providers: SERVER_RENDER_PROVIDERS, imports: [NoopAnimationsModule, BrowserDynamicTestingModule] });
29
29
  export { ServerTestingModule };
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTestingModule, decorators: [{
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTestingModule, decorators: [{
31
31
  type: NgModule,
32
32
  args: [{
33
33
  exports: [BrowserDynamicTestingModule],
@@ -35,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3",
35
35
  providers: SERVER_RENDER_PROVIDERS
36
36
  }]
37
37
  }] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhdGZvcm0tc2VydmVyL3Rlc3Rpbmcvc3JjL3NlcnZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMscUJBQXFCLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBQywyQkFBMkIsRUFBRSwyQkFBMkIsSUFBSSwwQkFBMEIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ2pKLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxtQ0FBbUMsSUFBSSxrQ0FBa0MsRUFBRSx3QkFBd0IsSUFBSSx1QkFBdUIsRUFBQyxNQUFNLDBCQUEwQixDQUFDOztBQUd4Szs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcscUJBQXFCLENBQ3RELDBCQUEwQixFQUFFLGVBQWUsRUFBRSxrQ0FBa0MsQ0FBQyxDQUFDO0FBRXJGOzs7O0dBSUc7QUFDSCxNQUthLG1CQUFtQjs7MkhBQW5CLG1CQUFtQjs0SEFBbkIsbUJBQW1CLFlBSHBCLG9CQUFvQixhQURwQiwyQkFBMkI7NEhBSTFCLG1CQUFtQixhQUZuQix1QkFBdUIsWUFEeEIsb0JBQW9CLEVBRHBCLDJCQUEyQjtTQUkxQixtQkFBbUI7c0dBQW5CLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQy9CLFNBQVMsRUFBRSx1QkFBdUI7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7Y3JlYXRlUGxhdGZvcm1GYWN0b3J5LCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Jyb3dzZXJEeW5hbWljVGVzdGluZ01vZHVsZSwgybVwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZyBhcyBwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZ30gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci1keW5hbWljL3Rlc3RpbmcnO1xuaW1wb3J0IHtOb29wQW5pbWF0aW9uc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcbmltcG9ydCB7ybVJTlRFUk5BTF9TRVJWRVJfUExBVEZPUk1fUFJPVklERVJTIGFzIElOVEVSTkFMX1NFUlZFUl9QTEFURk9STV9QUk9WSURFUlMsIMm1U0VSVkVSX1JFTkRFUl9QUk9WSURFUlMgYXMgU0VSVkVSX1JFTkRFUl9QUk9WSURFUlN9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLXNlcnZlcic7XG5cblxuLyoqXG4gKiBQbGF0Zm9ybSBmb3IgdGVzdGluZ1xuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGNvbnN0IHBsYXRmb3JtU2VydmVyVGVzdGluZyA9IGNyZWF0ZVBsYXRmb3JtRmFjdG9yeShcbiAgICBwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZywgJ3NlcnZlclRlc3RpbmcnLCBJTlRFUk5BTF9TRVJWRVJfUExBVEZPUk1fUFJPVklERVJTKTtcblxuLyoqXG4gKiBOZ01vZHVsZSBmb3IgdGVzdGluZy5cbiAqXG4gKiBAcHVibGljQXBpXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtCcm93c2VyRHluYW1pY1Rlc3RpbmdNb2R1bGVdLFxuICBpbXBvcnRzOiBbTm9vcEFuaW1hdGlvbnNNb2R1bGVdLFxuICBwcm92aWRlcnM6IFNFUlZFUl9SRU5ERVJfUFJPVklERVJTXG59KVxuZXhwb3J0IGNsYXNzIFNlcnZlclRlc3RpbmdNb2R1bGUge1xufVxuIl19
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhdGZvcm0tc2VydmVyL3Rlc3Rpbmcvc3JjL3NlcnZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMscUJBQXFCLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBQywyQkFBMkIsRUFBRSwyQkFBMkIsSUFBSSwwQkFBMEIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ2pKLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxtQ0FBbUMsSUFBSSxrQ0FBa0MsRUFBRSx3QkFBd0IsSUFBSSx1QkFBdUIsRUFBQyxNQUFNLDBCQUEwQixDQUFDOztBQUd4Szs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcscUJBQXFCLENBQ3RELDBCQUEwQixFQUFFLGVBQWUsRUFBRSxrQ0FBa0MsQ0FBQyxDQUFDO0FBRXJGOzs7O0dBSUc7QUFDSCxNQUthLG1CQUFtQjt5SEFBbkIsbUJBQW1COzBIQUFuQixtQkFBbUIsWUFIcEIsb0JBQW9CLGFBRHBCLDJCQUEyQjswSEFJMUIsbUJBQW1CLGFBRm5CLHVCQUF1QixZQUR4QixvQkFBb0IsRUFEcEIsMkJBQTJCOztTQUkxQixtQkFBbUI7c0dBQW5CLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQy9CLFNBQVMsRUFBRSx1QkFBdUI7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7Y3JlYXRlUGxhdGZvcm1GYWN0b3J5LCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Jyb3dzZXJEeW5hbWljVGVzdGluZ01vZHVsZSwgybVwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZyBhcyBwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZ30gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci1keW5hbWljL3Rlc3RpbmcnO1xuaW1wb3J0IHtOb29wQW5pbWF0aW9uc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcbmltcG9ydCB7ybVJTlRFUk5BTF9TRVJWRVJfUExBVEZPUk1fUFJPVklERVJTIGFzIElOVEVSTkFMX1NFUlZFUl9QTEFURk9STV9QUk9WSURFUlMsIMm1U0VSVkVSX1JFTkRFUl9QUk9WSURFUlMgYXMgU0VSVkVSX1JFTkRFUl9QUk9WSURFUlN9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLXNlcnZlcic7XG5cblxuLyoqXG4gKiBQbGF0Zm9ybSBmb3IgdGVzdGluZ1xuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGNvbnN0IHBsYXRmb3JtU2VydmVyVGVzdGluZyA9IGNyZWF0ZVBsYXRmb3JtRmFjdG9yeShcbiAgICBwbGF0Zm9ybUNvcmVEeW5hbWljVGVzdGluZywgJ3NlcnZlclRlc3RpbmcnLCBJTlRFUk5BTF9TRVJWRVJfUExBVEZPUk1fUFJPVklERVJTKTtcblxuLyoqXG4gKiBOZ01vZHVsZSBmb3IgdGVzdGluZy5cbiAqXG4gKiBAcHVibGljQXBpXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtCcm93c2VyRHluYW1pY1Rlc3RpbmdNb2R1bGVdLFxuICBpbXBvcnRzOiBbTm9vcEFuaW1hdGlvbnNNb2R1bGVdLFxuICBwcm92aWRlcnM6IFNFUlZFUl9SRU5ERVJfUFJPVklERVJTXG59KVxuZXhwb3J0IGNsYXNzIFNlcnZlclRlc3RpbmdNb2R1bGUge1xufVxuIl19
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v16.0.0-next.3
2
+ * @license Angular v16.0.0-next.5
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -1,20 +1,20 @@
1
1
  /**
2
- * @license Angular v16.0.0-next.3
2
+ * @license Angular v16.0.0-next.5
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
6
6
 
7
- import { ɵsetRootDomAdapter, DOCUMENT, XhrFactory, PlatformLocation, ɵgetDOM, ɵPLATFORM_SERVER_ID, ViewportScroller, ɵNullViewportScroller } from '@angular/common';
7
+ import { ɵsetRootDomAdapter, DOCUMENT, XhrFactory, ɵgetDOM, ɵPLATFORM_SERVER_ID, PlatformLocation, ViewportScroller, ɵNullViewportScroller } from '@angular/common';
8
8
  import * as i0 from '@angular/core';
9
- import { Injectable, Inject, InjectionToken, inject, EnvironmentInjector, Optional, ViewEncapsulation, APP_ID, RendererStyleFlags2, ɵescapeTransferStateContent, NgModule, Injector, PLATFORM_ID, PLATFORM_INITIALIZER, ɵALLOW_MULTIPLE_PLATFORMS, RendererFactory2, NgZone, Testability, ɵTESTABILITY, ɵsetDocument, createPlatformFactory, platformCore, makeEnvironmentProviders, Renderer2, ApplicationRef, ɵIS_HYDRATION_FEATURE_ENABLED, ɵannotateForHydration, ɵisPromise, importProvidersFrom, ɵinternalCreateApplication, ɵgetComponentDef, Version } from '@angular/core';
9
+ import { Injectable, Inject, InjectionToken, Optional, ViewEncapsulation, APP_ID, RendererStyleFlags2, TransferState, ɵescapeTransferStateContent, NgModule, Injector, PLATFORM_ID, PLATFORM_INITIALIZER, ɵALLOW_MULTIPLE_PLATFORMS, RendererFactory2, NgZone, Testability, ɵTESTABILITY, ɵsetDocument, createPlatformFactory, platformCore, makeEnvironmentProviders, Renderer2, ApplicationRef, ɵInitialRenderPendingTasks, ɵIS_HYDRATION_FEATURE_ENABLED, ɵannotateForHydration, ɵisPromise, Version } from '@angular/core';
10
10
  import * as i1 from '@angular/platform-browser';
11
- import { ɵBrowserDomAdapter, ɵshimStyles, ɵNAMESPACE_URIS, ɵshimContentAttribute, ɵshimHostAttribute, ɵSharedStylesHost, TransferState, EVENT_MANAGER_PLUGINS, BrowserModule } from '@angular/platform-browser';
12
- import { ɵHttpInterceptorHandler, HttpBackend, HttpHandler, HttpClientModule, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
11
+ import { ɵBrowserDomAdapter, ɵshimStyles, ɵNAMESPACE_URIS, ɵshimContentAttribute, ɵshimHostAttribute, EVENT_MANAGER_PLUGINS, BrowserModule } from '@angular/platform-browser';
12
+ import { HttpClientModule, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
13
13
  import { ɵAnimationRendererFactory, NoopAnimationsModule, provideNoopAnimations } from '@angular/platform-browser/animations';
14
14
  import { ɵAnimationEngine } from '@angular/animations/browser';
15
15
  import { ɵplatformCoreDynamic } from '@angular/platform-browser-dynamic';
16
- import { Observable, Subject } from 'rxjs';
17
16
  import * as xhr2 from 'xhr2';
17
+ import { Subject } from 'rxjs';
18
18
  import * as url from 'url';
19
19
  import { DomElementSchemaRegistry } from '@angular/compiler';
20
20
  import { first } from 'rxjs/operators';
@@ -20084,16 +20084,30 @@ class PlatformState {
20084
20084
  getDocument() {
20085
20085
  return this._doc;
20086
20086
  }
20087
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: PlatformState, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
20088
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: PlatformState }); }
20087
20089
  }
20088
- PlatformState.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: PlatformState, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
20089
- PlatformState.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: PlatformState });
20090
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: PlatformState, decorators: [{
20090
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: PlatformState, decorators: [{
20091
20091
  type: Injectable
20092
20092
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
20093
20093
  type: Inject,
20094
20094
  args: [DOCUMENT]
20095
20095
  }] }]; } });
20096
20096
 
20097
+ class ServerXhr {
20098
+ build() {
20099
+ return new xhr2.XMLHttpRequest();
20100
+ }
20101
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerXhr, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
20102
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerXhr }); }
20103
+ }
20104
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerXhr, decorators: [{
20105
+ type: Injectable
20106
+ }] });
20107
+ const SERVER_HTTP_PROVIDERS = [
20108
+ { provide: XhrFactory, useClass: ServerXhr },
20109
+ ];
20110
+
20097
20111
  /**
20098
20112
  * The DI token for setting the initial config for the platform.
20099
20113
  *
@@ -20108,116 +20122,6 @@ const INITIAL_CONFIG = new InjectionToken('Server.INITIAL_CONFIG');
20108
20122
  */
20109
20123
  const BEFORE_APP_SERIALIZED = new InjectionToken('Server.RENDER_MODULE_HOOK');
20110
20124
 
20111
- // @see https://www.w3.org/Protocols/HTTP/1.1/draft-ietf-http-v11-spec-01#URI-syntax
20112
- const isAbsoluteUrl = /^[a-zA-Z\-\+.]+:\/\//;
20113
- class ServerXhr {
20114
- build() {
20115
- return new xhr2.XMLHttpRequest();
20116
- }
20117
- }
20118
- ServerXhr.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerXhr, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
20119
- ServerXhr.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerXhr });
20120
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerXhr, decorators: [{
20121
- type: Injectable
20122
- }] });
20123
- class ZoneMacroTaskWrapper {
20124
- wrap(request) {
20125
- return new Observable((observer) => {
20126
- let task = null;
20127
- let scheduled = false;
20128
- let sub = null;
20129
- let savedResult = null;
20130
- let savedError = null;
20131
- const scheduleTask = (_task) => {
20132
- task = _task;
20133
- scheduled = true;
20134
- const delegate = this.delegate(request);
20135
- sub = delegate.subscribe(res => savedResult = res, err => {
20136
- if (!scheduled) {
20137
- throw new Error('An http observable was completed twice. This shouldn\'t happen, please file a bug.');
20138
- }
20139
- savedError = err;
20140
- scheduled = false;
20141
- task.invoke();
20142
- }, () => {
20143
- if (!scheduled) {
20144
- throw new Error('An http observable was completed twice. This shouldn\'t happen, please file a bug.');
20145
- }
20146
- scheduled = false;
20147
- task.invoke();
20148
- });
20149
- };
20150
- const cancelTask = (_task) => {
20151
- if (!scheduled) {
20152
- return;
20153
- }
20154
- scheduled = false;
20155
- if (sub) {
20156
- sub.unsubscribe();
20157
- sub = null;
20158
- }
20159
- };
20160
- const onComplete = () => {
20161
- if (savedError !== null) {
20162
- observer.error(savedError);
20163
- }
20164
- else {
20165
- observer.next(savedResult);
20166
- observer.complete();
20167
- }
20168
- };
20169
- // MockBackend for Http is synchronous, which means that if scheduleTask is by
20170
- // scheduleMacroTask, the request will hit MockBackend and the response will be
20171
- // sent, causing task.invoke() to be called.
20172
- const _task = Zone.current.scheduleMacroTask('ZoneMacroTaskWrapper.subscribe', onComplete, {}, () => null, cancelTask);
20173
- scheduleTask(_task);
20174
- return () => {
20175
- if (scheduled && task) {
20176
- task.zone.cancelTask(task);
20177
- scheduled = false;
20178
- }
20179
- if (sub) {
20180
- sub.unsubscribe();
20181
- sub = null;
20182
- }
20183
- };
20184
- });
20185
- }
20186
- }
20187
- class ZoneClientBackend extends ZoneMacroTaskWrapper {
20188
- constructor(backend, platformLocation, config) {
20189
- super();
20190
- this.backend = backend;
20191
- this.platformLocation = platformLocation;
20192
- this.config = config;
20193
- }
20194
- handle(request) {
20195
- const { href, protocol, hostname, port } = this.platformLocation;
20196
- if (this.config.useAbsoluteUrl && !isAbsoluteUrl.test(request.url) &&
20197
- isAbsoluteUrl.test(href)) {
20198
- const baseHref = this.platformLocation.getBaseHrefFromDOM() || href;
20199
- const urlPrefix = `${protocol}//${hostname}` + (port ? `:${port}` : '');
20200
- const baseUrl = new URL(baseHref, urlPrefix);
20201
- const url = new URL(request.url, baseUrl);
20202
- return this.wrap(request.clone({ url: url.toString() }));
20203
- }
20204
- return this.wrap(request);
20205
- }
20206
- delegate(request) {
20207
- return this.backend.handle(request);
20208
- }
20209
- }
20210
- function zoneWrappedInterceptorHandler(platformLocation, config) {
20211
- return new ZoneClientBackend(new ɵHttpInterceptorHandler(inject(HttpBackend), inject(EnvironmentInjector)), platformLocation, config);
20212
- }
20213
- const SERVER_HTTP_PROVIDERS = [
20214
- { provide: XhrFactory, useClass: ServerXhr }, {
20215
- provide: HttpHandler,
20216
- useFactory: zoneWrappedInterceptorHandler,
20217
- deps: [PlatformLocation, INITIAL_CONFIG]
20218
- }
20219
- ];
20220
-
20221
20125
  function parseUrl(urlStr) {
20222
20126
  const parsedUrl = url.parse(urlStr);
20223
20127
  return {
@@ -20312,10 +20216,10 @@ class ServerPlatformLocation {
20312
20216
  getState() {
20313
20217
  return undefined;
20314
20218
  }
20219
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerPlatformLocation, deps: [{ token: DOCUMENT }, { token: INITIAL_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
20220
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerPlatformLocation }); }
20315
20221
  }
20316
- ServerPlatformLocation.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerPlatformLocation, deps: [{ token: DOCUMENT }, { token: INITIAL_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
20317
- ServerPlatformLocation.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerPlatformLocation });
20318
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerPlatformLocation, decorators: [{
20222
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerPlatformLocation, decorators: [{
20319
20223
  type: Injectable
20320
20224
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
20321
20225
  type: Inject,
@@ -20349,10 +20253,10 @@ class ServerEventManagerPlugin /* extends EventManagerPlugin which is private */
20349
20253
  }
20350
20254
  return this.addEventListener(target, eventName, handler);
20351
20255
  }
20256
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
20257
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */ }); }
20352
20258
  }
20353
- ServerEventManagerPlugin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
20354
- ServerEventManagerPlugin.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */ });
20355
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */, decorators: [{
20259
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerEventManagerPlugin /* extends EventManagerPlugin which is private */, decorators: [{
20356
20260
  type: Injectable
20357
20261
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
20358
20262
  type: Inject,
@@ -20398,10 +20302,10 @@ class ServerRendererFactory2 {
20398
20302
  }
20399
20303
  begin() { }
20400
20304
  end() { }
20305
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerRendererFactory2, deps: [{ token: i1.EventManager }, { token: i0.NgZone }, { token: DOCUMENT }, { token: i1.ɵSharedStylesHost }, { token: APP_ID }], target: i0.ɵɵFactoryTarget.Injectable }); }
20306
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerRendererFactory2 }); }
20401
20307
  }
20402
- ServerRendererFactory2.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerRendererFactory2, deps: [{ token: i1.EventManager }, { token: i0.NgZone }, { token: DOCUMENT }, { token: i1.ɵSharedStylesHost }, { token: APP_ID }], target: i0.ɵɵFactoryTarget.Injectable });
20403
- ServerRendererFactory2.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerRendererFactory2 });
20404
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerRendererFactory2, decorators: [{
20308
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerRendererFactory2, decorators: [{
20405
20309
  type: Injectable
20406
20310
  }], ctorParameters: function () { return [{ type: i1.EventManager }, { type: i0.NgZone }, { type: Document, decorators: [{
20407
20311
  type: Inject,
@@ -20627,42 +20531,6 @@ function _writeStyleAttribute(element, styleMap) {
20627
20531
  }
20628
20532
  }
20629
20533
 
20630
- class ServerStylesHost extends ɵSharedStylesHost {
20631
- constructor(doc, appId) {
20632
- super();
20633
- this.appId = appId;
20634
- this.head = null;
20635
- this._styleNodes = new Set();
20636
- this.head = doc.getElementsByTagName('head')[0];
20637
- }
20638
- onStyleAdded(style) {
20639
- const adapter = ɵgetDOM();
20640
- const el = adapter.createElement('style');
20641
- el.textContent = style;
20642
- if (!!this.appId) {
20643
- el.setAttribute('ng-app', this.appId);
20644
- }
20645
- this.head.appendChild(el);
20646
- this._styleNodes.add(el);
20647
- }
20648
- ngOnDestroy() {
20649
- this._styleNodes.forEach(styleNode => styleNode.remove());
20650
- this._styleNodes.clear();
20651
- super.ngOnDestroy();
20652
- }
20653
- }
20654
- ServerStylesHost.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerStylesHost, deps: [{ token: DOCUMENT }, { token: APP_ID }], target: i0.ɵɵFactoryTarget.Injectable });
20655
- ServerStylesHost.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerStylesHost });
20656
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerStylesHost, decorators: [{
20657
- type: Injectable
20658
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
20659
- type: Inject,
20660
- args: [DOCUMENT]
20661
- }] }, { type: undefined, decorators: [{
20662
- type: Inject,
20663
- args: [APP_ID]
20664
- }] }]; } });
20665
-
20666
20534
  const TRANSFER_STATE_SERIALIZATION_PROVIDERS = [{
20667
20535
  provide: BEFORE_APP_SERIALIZED,
20668
20536
  useFactory: serializeTransferStateFactory,
@@ -20701,11 +20569,11 @@ function serializeTransferStateFactory(doc, appId, transferStore) {
20701
20569
  * this module.
20702
20570
  */
20703
20571
  class ServerTransferStateModule {
20572
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTransferStateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
20573
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTransferStateModule }); }
20574
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTransferStateModule }); }
20704
20575
  }
20705
- ServerTransferStateModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTransferStateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
20706
- ServerTransferStateModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTransferStateModule });
20707
- ServerTransferStateModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTransferStateModule });
20708
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerTransferStateModule, decorators: [{
20576
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerTransferStateModule, decorators: [{
20709
20577
  type: NgModule,
20710
20578
  args: [{}]
20711
20579
  }] });
@@ -20737,8 +20605,6 @@ const SERVER_RENDER_PROVIDERS = [
20737
20605
  useFactory: instantiateServerRendererFactory,
20738
20606
  deps: [ServerRendererFactory2, ɵAnimationEngine, NgZone]
20739
20607
  },
20740
- ServerStylesHost,
20741
- { provide: ɵSharedStylesHost, useExisting: ServerStylesHost },
20742
20608
  { provide: EVENT_MANAGER_PLUGINS, multi: true, useClass: ServerEventManagerPlugin },
20743
20609
  ];
20744
20610
  const PLATFORM_SERVER_PROVIDERS = [
@@ -20755,11 +20621,11 @@ const PLATFORM_SERVER_PROVIDERS = [
20755
20621
  * @publicApi
20756
20622
  */
20757
20623
  class ServerModule {
20624
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
20625
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerModule, imports: [HttpClientModule, NoopAnimationsModule], exports: [BrowserModule] }); }
20626
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerModule, providers: PLATFORM_SERVER_PROVIDERS, imports: [HttpClientModule, NoopAnimationsModule, BrowserModule] }); }
20758
20627
  }
20759
- ServerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
20760
- ServerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerModule, imports: [HttpClientModule, NoopAnimationsModule], exports: [BrowserModule] });
20761
- ServerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerModule, providers: PLATFORM_SERVER_PROVIDERS, imports: [HttpClientModule, NoopAnimationsModule, BrowserModule] });
20762
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: ServerModule, decorators: [{
20628
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.5", ngImport: i0, type: ServerModule, decorators: [{
20763
20629
  type: NgModule,
20764
20630
  args: [{
20765
20631
  exports: [BrowserModule],
@@ -20842,9 +20708,10 @@ function _render(platform, bootstrapPromise) {
20842
20708
  moduleOrApplicationRef :
20843
20709
  environmentInjector.get(ApplicationRef);
20844
20710
  const serverContext = sanitizeServerContext(environmentInjector.get(SERVER_CONTEXT, DEFAULT_SERVER_CONTEXT));
20845
- return applicationRef.isStable.pipe((first((isStable) => isStable)))
20846
- .toPromise()
20847
- .then(() => {
20711
+ const isStablePromise = applicationRef.isStable.pipe((first((isStable) => isStable))).toPromise();
20712
+ const pendingTasks = environmentInjector.get(ɵInitialRenderPendingTasks);
20713
+ const pendingTasksPromise = pendingTasks.whenAllTasksComplete;
20714
+ return Promise.allSettled([isStablePromise, pendingTasksPromise]).then(() => {
20848
20715
  appendServerContextInfo(serverContext, applicationRef);
20849
20716
  const platformState = platform.injector.get(PlatformState);
20850
20717
  const asyncPromises = [];
@@ -20922,22 +20789,30 @@ function renderModule(moduleType, options) {
20922
20789
  const platform = _getPlatform(platformDynamicServer, { document, url, platformProviders });
20923
20790
  return _render(platform, platform.bootstrapModule(moduleType));
20924
20791
  }
20925
- function renderApplication(rootComponentOrBootstrapFn, options) {
20926
- const { document, url, platformProviders, appId = '' } = options;
20927
- const platform = _getPlatform(platformDynamicServer, { document, url, platformProviders });
20928
- if (isBootstrapFn(rootComponentOrBootstrapFn)) {
20929
- return _render(platform, rootComponentOrBootstrapFn());
20930
- }
20931
- const appProviders = [
20932
- importProvidersFrom(BrowserModule.withServerTransition({ appId })),
20933
- importProvidersFrom(ServerModule),
20934
- ...(options.providers ?? []),
20935
- ];
20936
- return _render(platform, ɵinternalCreateApplication({ rootComponent: rootComponentOrBootstrapFn, appProviders }));
20937
- }
20938
- function isBootstrapFn(value) {
20939
- // We can differentiate between a component and a bootstrap function by reading `cmp`:
20940
- return typeof value === 'function' && !ɵgetComponentDef(value);
20792
+ /**
20793
+ * Bootstraps an instance of an Angular application and renders it to a string.
20794
+
20795
+ * ```typescript
20796
+ * const bootstrap = () => bootstrapApplication(RootComponent, appConfig);
20797
+ * const output: string = await renderApplication(bootstrap);
20798
+ * ```
20799
+ *
20800
+ * @param bootstrap A method that when invoked returns a promise that returns an `ApplicationRef`
20801
+ * instance once resolved.
20802
+ * @param options Additional configuration for the render operation:
20803
+ * - `document` - the document of the page to render, either as an HTML string or
20804
+ * as a reference to the `document` instance.
20805
+ * - `url` - the URL for the current render request.
20806
+ * - `platformProviders` - the platform level providers for the current render request.
20807
+ *
20808
+ * @returns A Promise, that returns serialized (to a string) rendered page, once resolved.
20809
+ *
20810
+ * @publicApi
20811
+ * @developerPreview
20812
+ */
20813
+ function renderApplication(bootstrap, options) {
20814
+ const platform = _getPlatform(platformDynamicServer, options);
20815
+ return _render(platform, bootstrap());
20941
20816
  }
20942
20817
 
20943
20818
  /**
@@ -20948,7 +20823,7 @@ function isBootstrapFn(value) {
20948
20823
  /**
20949
20824
  * @publicApi
20950
20825
  */
20951
- const VERSION = new Version('16.0.0-next.3');
20826
+ const VERSION = new Version('16.0.0-next.5');
20952
20827
 
20953
20828
  /// <reference types="node" />
20954
20829
  // This file only reexports content of the `src` folder. Keep it that way.