@angular-devkit/build-angular 17.0.0-next.5 → 17.0.0-next.7

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 (45) hide show
  1. package/package.json +16 -16
  2. package/src/builders/application/build-action.d.ts +1 -0
  3. package/src/builders/application/build-action.js +63 -51
  4. package/src/builders/application/execute-build.js +27 -10
  5. package/src/builders/application/i18n.d.ts +28 -0
  6. package/src/builders/application/i18n.js +139 -0
  7. package/src/builders/application/index.d.ts +3 -1
  8. package/src/builders/application/index.js +10 -2
  9. package/src/builders/application/options.d.ts +6 -0
  10. package/src/builders/application/options.js +8 -4
  11. package/src/builders/application/schema.d.ts +4 -0
  12. package/src/builders/application/schema.js +1 -1
  13. package/src/builders/application/schema.json +5 -0
  14. package/src/builders/browser-esbuild/builder-status-warnings.js +2 -9
  15. package/src/builders/dev-server/vite-server.js +29 -1
  16. package/src/builders/extract-i18n/application-extraction.js +2 -1
  17. package/src/tools/esbuild/angular/angular-host.d.ts +1 -0
  18. package/src/tools/esbuild/angular/angular-host.js +1 -1
  19. package/src/tools/esbuild/angular/compilation/aot-compilation.js +26 -11
  20. package/src/tools/esbuild/angular/compilation/jit-compilation.js +12 -5
  21. package/src/tools/esbuild/angular/compiler-plugin.js +48 -15
  22. package/src/tools/esbuild/angular/web-worker-transformer.d.ts +17 -0
  23. package/src/tools/esbuild/angular/web-worker-transformer.js +95 -0
  24. package/src/tools/esbuild/application-code-bundle.js +54 -7
  25. package/src/tools/esbuild/bundler-context.js +3 -3
  26. package/src/tools/esbuild/bundler-execution-result.d.ts +2 -2
  27. package/src/tools/esbuild/bundler-execution-result.js +1 -1
  28. package/src/tools/esbuild/i18n-inliner-worker.d.ts +37 -0
  29. package/src/tools/esbuild/i18n-inliner-worker.js +138 -0
  30. package/src/tools/esbuild/i18n-inliner.d.ts +40 -0
  31. package/src/tools/esbuild/i18n-inliner.js +119 -0
  32. package/src/tools/esbuild/i18n-locale-plugin.d.ts +18 -0
  33. package/src/tools/esbuild/i18n-locale-plugin.js +91 -0
  34. package/src/tools/esbuild/index-html-generator.d.ts +2 -2
  35. package/src/tools/esbuild/index-html-generator.js +4 -4
  36. package/src/tools/esbuild/utils.d.ts +2 -0
  37. package/src/tools/esbuild/utils.js +32 -2
  38. package/src/tools/esbuild/virtual-module-plugin.d.ts +2 -0
  39. package/src/tools/esbuild/virtual-module-plugin.js +3 -3
  40. package/src/tools/vite/i18n-locale-plugin.d.ts +18 -0
  41. package/src/tools/vite/i18n-locale-plugin.js +56 -0
  42. package/src/utils/routes-extractor/extractor.js +17 -14
  43. package/src/utils/server-rendering/main-bundle-exports.d.ts +1 -0
  44. package/src/utils/server-rendering/main-bundle-exports.js +1 -1
  45. package/src/utils/server-rendering/render-page.js +6 -2
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ var __importDefault = (this && this.__importDefault) || function (mod) {
10
+ return (mod && mod.__esModule) ? mod : { "default": mod };
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.I18nInliner = void 0;
14
+ const piscina_1 = __importDefault(require("piscina"));
15
+ const utils_1 = require("./utils");
16
+ /**
17
+ * A keyword used to indicate if a JavaScript file may require inlining of translations.
18
+ * This keyword is used to avoid processing files that would not otherwise need i18n processing.
19
+ */
20
+ const LOCALIZE_KEYWORD = '$localize';
21
+ /**
22
+ * A class that performs i18n translation inlining of JavaScript code.
23
+ * A worker pool is used to distribute the transformation actions and allow
24
+ * parallel processing. Inlining is only performed on code that contains the
25
+ * localize function (`$localize`).
26
+ */
27
+ class I18nInliner {
28
+ #workerPool;
29
+ #localizeFiles;
30
+ #unmodifiedFiles;
31
+ constructor(options, maxThreads) {
32
+ this.#unmodifiedFiles = [];
33
+ const files = new Map();
34
+ const pendingMaps = [];
35
+ for (const file of options.outputFiles) {
36
+ if (file.path.endsWith('.js') || file.path.endsWith('.mjs')) {
37
+ // Check if localizations are present
38
+ const contentBuffer = Buffer.isBuffer(file.contents)
39
+ ? file.contents
40
+ : Buffer.from(file.contents.buffer, file.contents.byteOffset, file.contents.byteLength);
41
+ const hasLocalize = contentBuffer.includes(LOCALIZE_KEYWORD);
42
+ if (hasLocalize) {
43
+ // A Blob is an immutable data structure that allows sharing the data between workers
44
+ // without copying until the data is actually used within a Worker. This is useful here
45
+ // since each file may not actually be processed in each Worker and the Blob avoids
46
+ // unneeded repeat copying of potentially large JavaScript files.
47
+ files.set(file.path, new Blob([file.contents]));
48
+ continue;
49
+ }
50
+ }
51
+ else if (file.path.endsWith('.js.map')) {
52
+ // The related JS file may not have been checked yet. To ensure that map files are not
53
+ // missed, store any pending map files and check them after all output files.
54
+ pendingMaps.push(file);
55
+ continue;
56
+ }
57
+ this.#unmodifiedFiles.push(file);
58
+ }
59
+ // Check if any pending map files should be processed by checking if the parent JS file is present
60
+ for (const file of pendingMaps) {
61
+ if (files.has(file.path.slice(0, -4))) {
62
+ files.set(file.path, new Blob([file.contents]));
63
+ }
64
+ else {
65
+ this.#unmodifiedFiles.push(file);
66
+ }
67
+ }
68
+ this.#localizeFiles = files;
69
+ this.#workerPool = new piscina_1.default({
70
+ filename: require.resolve('./i18n-inliner-worker'),
71
+ maxThreads,
72
+ // Extract options to ensure only the named options are serialized and sent to the worker
73
+ workerData: {
74
+ missingTranslation: options.missingTranslation,
75
+ shouldOptimize: options.shouldOptimize,
76
+ files,
77
+ },
78
+ });
79
+ }
80
+ /**
81
+ * Performs inlining of translations for the provided locale and translations. The files that
82
+ * are processed originate from the files passed to the class constructor and filter by presence
83
+ * of the localize function keyword.
84
+ * @param locale The string representing the locale to inline.
85
+ * @param translation The translation messages to use when inlining.
86
+ * @returns A promise that resolves to an array of OutputFiles representing a translated result.
87
+ */
88
+ async inlineForLocale(locale, translation) {
89
+ // Request inlining for each file that contains localize calls
90
+ const requests = [];
91
+ for (const filename of this.#localizeFiles.keys()) {
92
+ if (filename.endsWith('.map')) {
93
+ continue;
94
+ }
95
+ const fileRequest = this.#workerPool.run({
96
+ filename,
97
+ locale,
98
+ translation,
99
+ });
100
+ requests.push(fileRequest);
101
+ }
102
+ // Wait for all file requests to complete
103
+ const rawResults = await Promise.all(requests);
104
+ // Convert raw results to output file objects and include all unmodified files
105
+ return [
106
+ ...rawResults.flat().map(({ file, contents }) => (0, utils_1.createOutputFileFromText)(file, contents)),
107
+ ...this.#unmodifiedFiles.map((file) => (0, utils_1.cloneOutputFile)(file)),
108
+ ];
109
+ }
110
+ /**
111
+ * Stops all active transformation tasks and shuts down all workers.
112
+ * @returns A void promise that resolves when closing is complete.
113
+ */
114
+ close() {
115
+ return this.#workerPool.destroy();
116
+ }
117
+ }
118
+ exports.I18nInliner = I18nInliner;
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n-inliner.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/i18n-inliner.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 type { OutputFile } from 'esbuild';\nimport Piscina from 'piscina';\nimport { cloneOutputFile, createOutputFileFromText } from './utils';\n\n/**\n * A keyword used to indicate if a JavaScript file may require inlining of translations.\n * This keyword is used to avoid processing files that would not otherwise need i18n processing.\n */\nconst LOCALIZE_KEYWORD = '$localize';\n\n/**\n * Inlining options that should apply to all transformed code.\n */\nexport interface I18nInlinerOptions {\n  missingTranslation: 'error' | 'warning' | 'ignore';\n  outputFiles: OutputFile[];\n  shouldOptimize?: boolean;\n}\n\n/**\n * A class that performs i18n translation inlining of JavaScript code.\n * A worker pool is used to distribute the transformation actions and allow\n * parallel processing. Inlining is only performed on code that contains the\n * localize function (`$localize`).\n */\nexport class I18nInliner {\n  #workerPool: Piscina;\n  readonly #localizeFiles: ReadonlyMap<string, Blob>;\n  readonly #unmodifiedFiles: Array<OutputFile>;\n\n  constructor(options: I18nInlinerOptions, maxThreads?: number) {\n    this.#unmodifiedFiles = [];\n\n    const files = new Map<string, Blob>();\n    const pendingMaps = [];\n    for (const file of options.outputFiles) {\n      if (file.path.endsWith('.js') || file.path.endsWith('.mjs')) {\n        // Check if localizations are present\n        const contentBuffer = Buffer.isBuffer(file.contents)\n          ? file.contents\n          : Buffer.from(file.contents.buffer, file.contents.byteOffset, file.contents.byteLength);\n        const hasLocalize = contentBuffer.includes(LOCALIZE_KEYWORD);\n\n        if (hasLocalize) {\n          // A Blob is an immutable data structure that allows sharing the data between workers\n          // without copying until the data is actually used within a Worker. This is useful here\n          // since each file may not actually be processed in each Worker and the Blob avoids\n          // unneeded repeat copying of potentially large JavaScript files.\n          files.set(file.path, new Blob([file.contents]));\n\n          continue;\n        }\n      } else if (file.path.endsWith('.js.map')) {\n        // The related JS file may not have been checked yet. To ensure that map files are not\n        // missed, store any pending map files and check them after all output files.\n        pendingMaps.push(file);\n        continue;\n      }\n\n      this.#unmodifiedFiles.push(file);\n    }\n\n    // Check if any pending map files should be processed by checking if the parent JS file is present\n    for (const file of pendingMaps) {\n      if (files.has(file.path.slice(0, -4))) {\n        files.set(file.path, new Blob([file.contents]));\n      } else {\n        this.#unmodifiedFiles.push(file);\n      }\n    }\n\n    this.#localizeFiles = files;\n\n    this.#workerPool = new Piscina({\n      filename: require.resolve('./i18n-inliner-worker'),\n      maxThreads,\n      // Extract options to ensure only the named options are serialized and sent to the worker\n      workerData: {\n        missingTranslation: options.missingTranslation,\n        shouldOptimize: options.shouldOptimize,\n        files,\n      },\n    });\n  }\n\n  /**\n   * Performs inlining of translations for the provided locale and translations. The files that\n   * are processed originate from the files passed to the class constructor and filter by presence\n   * of the localize function keyword.\n   * @param locale The string representing the locale to inline.\n   * @param translation The translation messages to use when inlining.\n   * @returns A promise that resolves to an array of OutputFiles representing a translated result.\n   */\n  async inlineForLocale(\n    locale: string,\n    translation: Record<string, unknown> | undefined,\n  ): Promise<OutputFile[]> {\n    // Request inlining for each file that contains localize calls\n    const requests = [];\n    for (const filename of this.#localizeFiles.keys()) {\n      if (filename.endsWith('.map')) {\n        continue;\n      }\n\n      const fileRequest = this.#workerPool.run({\n        filename,\n        locale,\n        translation,\n      });\n      requests.push(fileRequest);\n    }\n\n    // Wait for all file requests to complete\n    const rawResults = await Promise.all(requests);\n\n    // Convert raw results to output file objects and include all unmodified files\n    return [\n      ...rawResults.flat().map(({ file, contents }) => createOutputFileFromText(file, contents)),\n      ...this.#unmodifiedFiles.map((file) => cloneOutputFile(file)),\n    ];\n  }\n\n  /**\n   * Stops all active transformation tasks and shuts down all workers.\n   * @returns A void promise that resolves when closing is complete.\n   */\n  close(): Promise<void> {\n    return this.#workerPool.destroy();\n  }\n}\n"]}
@@ -0,0 +1,18 @@
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 type { Plugin } from 'esbuild';
9
+ /**
10
+ * The base module location used to search for locale specific data.
11
+ */
12
+ export declare const LOCALE_DATA_BASE_MODULE = "@angular/common/locales/global";
13
+ /**
14
+ * Creates an esbuild plugin that resolves Angular locale data files from `@angular/common`.
15
+ *
16
+ * @returns An esbuild plugin.
17
+ */
18
+ export declare function createAngularLocaleDataPlugin(): Plugin;
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.createAngularLocaleDataPlugin = exports.LOCALE_DATA_BASE_MODULE = void 0;
11
+ /**
12
+ * The base module location used to search for locale specific data.
13
+ */
14
+ exports.LOCALE_DATA_BASE_MODULE = '@angular/common/locales/global';
15
+ /**
16
+ * Creates an esbuild plugin that resolves Angular locale data files from `@angular/common`.
17
+ *
18
+ * @returns An esbuild plugin.
19
+ */
20
+ function createAngularLocaleDataPlugin() {
21
+ return {
22
+ name: 'angular-locale-data',
23
+ setup(build) {
24
+ // If packages are configured to be external then leave the original angular locale import path.
25
+ // This happens when using the development server with caching enabled to allow Vite prebundling to work.
26
+ // There currently is no option on the esbuild resolve function to resolve while disabling the option. To
27
+ // workaround the inability to resolve the full locale location here, the Vite dev server prebundling also
28
+ // contains a plugin to allow the locales to be correctly resolved when prebundling.
29
+ // NOTE: If esbuild eventually allows controlling the external package options in a build.resolve call, this
30
+ // workaround can be removed.
31
+ if (build.initialOptions.packages === 'external') {
32
+ return;
33
+ }
34
+ build.onResolve({ filter: /^angular:locale\/data:/ }, async ({ path }) => {
35
+ // Extract the locale from the path
36
+ const originalLocale = path.split(':', 3)[2];
37
+ // Remove any private subtags since these will never match
38
+ let partialLocale = originalLocale.replace(/-x(-[a-zA-Z0-9]{1,8})+$/, '');
39
+ let exact = true;
40
+ while (partialLocale) {
41
+ const potentialPath = `${exports.LOCALE_DATA_BASE_MODULE}/${partialLocale}`;
42
+ const result = await build.resolve(potentialPath, {
43
+ kind: 'import-statement',
44
+ resolveDir: build.initialOptions.absWorkingDir,
45
+ });
46
+ if (result.path) {
47
+ if (exact) {
48
+ return result;
49
+ }
50
+ else {
51
+ return {
52
+ ...result,
53
+ warnings: [
54
+ ...result.warnings,
55
+ {
56
+ location: null,
57
+ text: `Locale data for '${originalLocale}' cannot be found. Using locale data for '${partialLocale}'.`,
58
+ },
59
+ ],
60
+ };
61
+ }
62
+ }
63
+ // Remove the last subtag and try again with a less specific locale
64
+ const parts = partialLocale.split('-');
65
+ partialLocale = parts.slice(0, -1).join('-');
66
+ exact = false;
67
+ // The locales "en" and "en-US" are considered exact to retain existing behavior
68
+ if (originalLocale === 'en-US' && partialLocale === 'en') {
69
+ exact = true;
70
+ }
71
+ }
72
+ // Not found so issue a warning and use an empty loader. Framework built-in `en-US` data will be used.
73
+ // This retains existing behavior as in the Webpack-based builder.
74
+ return {
75
+ path: originalLocale,
76
+ namespace: 'angular:locale/data',
77
+ warnings: [
78
+ {
79
+ location: null,
80
+ text: `Locale data for '${originalLocale}' cannot be found. No locale data will be included for this locale.`,
81
+ },
82
+ ],
83
+ };
84
+ });
85
+ // Locales that cannot be found will be loaded as empty content with a warning from the resolve step
86
+ build.onLoad({ filter: /./, namespace: 'angular:locale/data' }, () => ({ loader: 'empty' }));
87
+ },
88
+ };
89
+ }
90
+ exports.createAngularLocaleDataPlugin = createAngularLocaleDataPlugin;
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi1sb2NhbGUtcGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdG9vbHMvZXNidWlsZC9pMThuLWxvY2FsZS1wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7O0FBSUg7O0dBRUc7QUFDVSxRQUFBLHVCQUF1QixHQUFHLGdDQUFnQyxDQUFDO0FBRXhFOzs7O0dBSUc7QUFDSCxTQUFnQiw2QkFBNkI7SUFDM0MsT0FBTztRQUNMLElBQUksRUFBRSxxQkFBcUI7UUFDM0IsS0FBSyxDQUFDLEtBQUs7WUFDVCxnR0FBZ0c7WUFDaEcseUdBQXlHO1lBQ3pHLHlHQUF5RztZQUN6RywwR0FBMEc7WUFDMUcsb0ZBQW9GO1lBQ3BGLDRHQUE0RztZQUM1RyxtQ0FBbUM7WUFDbkMsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLFFBQVEsS0FBSyxVQUFVLEVBQUU7Z0JBQ2hELE9BQU87YUFDUjtZQUVELEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsd0JBQXdCLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO2dCQUN2RSxtQ0FBbUM7Z0JBQ25DLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUU3QywwREFBMEQ7Z0JBQzFELElBQUksYUFBYSxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMseUJBQXlCLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBRTFFLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQztnQkFDakIsT0FBTyxhQUFhLEVBQUU7b0JBQ3BCLE1BQU0sYUFBYSxHQUFHLEdBQUcsK0JBQXVCLElBQUksYUFBYSxFQUFFLENBQUM7b0JBRXBFLE1BQU0sTUFBTSxHQUFHLE1BQU0sS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUU7d0JBQ2hELElBQUksRUFBRSxrQkFBa0I7d0JBQ3hCLFVBQVUsRUFBRSxLQUFLLENBQUMsY0FBYyxDQUFDLGFBQWE7cUJBQy9DLENBQUMsQ0FBQztvQkFDSCxJQUFJLE1BQU0sQ0FBQyxJQUFJLEVBQUU7d0JBQ2YsSUFBSSxLQUFLLEVBQUU7NEJBQ1QsT0FBTyxNQUFNLENBQUM7eUJBQ2Y7NkJBQU07NEJBQ0wsT0FBTztnQ0FDTCxHQUFHLE1BQU07Z0NBQ1QsUUFBUSxFQUFFO29DQUNSLEdBQUcsTUFBTSxDQUFDLFFBQVE7b0NBQ2xCO3dDQUNFLFFBQVEsRUFBRSxJQUFJO3dDQUNkLElBQUksRUFBRSxvQkFBb0IsY0FBYyw2Q0FBNkMsYUFBYSxJQUFJO3FDQUN2RztpQ0FDRjs2QkFDRixDQUFDO3lCQUNIO3FCQUNGO29CQUVELG1FQUFtRTtvQkFDbkUsTUFBTSxLQUFLLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztvQkFDdkMsYUFBYSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUM3QyxLQUFLLEdBQUcsS0FBSyxDQUFDO29CQUNkLGdGQUFnRjtvQkFDaEYsSUFBSSxjQUFjLEtBQUssT0FBTyxJQUFJLGFBQWEsS0FBSyxJQUFJLEVBQUU7d0JBQ3hELEtBQUssR0FBRyxJQUFJLENBQUM7cUJBQ2Q7aUJBQ0Y7Z0JBRUQsc0dBQXNHO2dCQUN0RyxrRUFBa0U7Z0JBQ2xFLE9BQU87b0JBQ0wsSUFBSSxFQUFFLGNBQWM7b0JBQ3BCLFNBQVMsRUFBRSxxQkFBcUI7b0JBQ2hDLFFBQVEsRUFBRTt3QkFDUjs0QkFDRSxRQUFRLEVBQUUsSUFBSTs0QkFDZCxJQUFJLEVBQUUsb0JBQW9CLGNBQWMscUVBQXFFO3lCQUM5RztxQkFDRjtpQkFDRixDQUFDO1lBQ0osQ0FBQyxDQUFDLENBQUM7WUFFSCxvR0FBb0c7WUFDcEcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLHFCQUFxQixFQUFFLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDL0YsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDO0FBM0VELHNFQTJFQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG4vKipcbiAqIFRoZSBiYXNlIG1vZHVsZSBsb2NhdGlvbiB1c2VkIHRvIHNlYXJjaCBmb3IgbG9jYWxlIHNwZWNpZmljIGRhdGEuXG4gKi9cbmV4cG9ydCBjb25zdCBMT0NBTEVfREFUQV9CQVNFX01PRFVMRSA9ICdAYW5ndWxhci9jb21tb24vbG9jYWxlcy9nbG9iYWwnO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCByZXNvbHZlcyBBbmd1bGFyIGxvY2FsZSBkYXRhIGZpbGVzIGZyb20gYEBhbmd1bGFyL2NvbW1vbmAuXG4gKlxuICogQHJldHVybnMgQW4gZXNidWlsZCBwbHVnaW4uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBbmd1bGFyTG9jYWxlRGF0YVBsdWdpbigpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdhbmd1bGFyLWxvY2FsZS1kYXRhJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgLy8gSWYgcGFja2FnZXMgYXJlIGNvbmZpZ3VyZWQgdG8gYmUgZXh0ZXJuYWwgdGhlbiBsZWF2ZSB0aGUgb3JpZ2luYWwgYW5ndWxhciBsb2NhbGUgaW1wb3J0IHBhdGguXG4gICAgICAvLyBUaGlzIGhhcHBlbnMgd2hlbiB1c2luZyB0aGUgZGV2ZWxvcG1lbnQgc2VydmVyIHdpdGggY2FjaGluZyBlbmFibGVkIHRvIGFsbG93IFZpdGUgcHJlYnVuZGxpbmcgdG8gd29yay5cbiAgICAgIC8vIFRoZXJlIGN1cnJlbnRseSBpcyBubyBvcHRpb24gb24gdGhlIGVzYnVpbGQgcmVzb2x2ZSBmdW5jdGlvbiB0byByZXNvbHZlIHdoaWxlIGRpc2FibGluZyB0aGUgb3B0aW9uLiBUb1xuICAgICAgLy8gd29ya2Fyb3VuZCB0aGUgaW5hYmlsaXR5IHRvIHJlc29sdmUgdGhlIGZ1bGwgbG9jYWxlIGxvY2F0aW9uIGhlcmUsIHRoZSBWaXRlIGRldiBzZXJ2ZXIgcHJlYnVuZGxpbmcgYWxzb1xuICAgICAgLy8gY29udGFpbnMgYSBwbHVnaW4gdG8gYWxsb3cgdGhlIGxvY2FsZXMgdG8gYmUgY29ycmVjdGx5IHJlc29sdmVkIHdoZW4gcHJlYnVuZGxpbmcuXG4gICAgICAvLyBOT1RFOiBJZiBlc2J1aWxkIGV2ZW50dWFsbHkgYWxsb3dzIGNvbnRyb2xsaW5nIHRoZSBleHRlcm5hbCBwYWNrYWdlIG9wdGlvbnMgaW4gYSBidWlsZC5yZXNvbHZlIGNhbGwsIHRoaXNcbiAgICAgIC8vICAgICAgIHdvcmthcm91bmQgY2FuIGJlIHJlbW92ZWQuXG4gICAgICBpZiAoYnVpbGQuaW5pdGlhbE9wdGlvbnMucGFja2FnZXMgPT09ICdleHRlcm5hbCcpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBidWlsZC5vblJlc29sdmUoeyBmaWx0ZXI6IC9eYW5ndWxhcjpsb2NhbGVcXC9kYXRhOi8gfSwgYXN5bmMgKHsgcGF0aCB9KSA9PiB7XG4gICAgICAgIC8vIEV4dHJhY3QgdGhlIGxvY2FsZSBmcm9tIHRoZSBwYXRoXG4gICAgICAgIGNvbnN0IG9yaWdpbmFsTG9jYWxlID0gcGF0aC5zcGxpdCgnOicsIDMpWzJdO1xuXG4gICAgICAgIC8vIFJlbW92ZSBhbnkgcHJpdmF0ZSBzdWJ0YWdzIHNpbmNlIHRoZXNlIHdpbGwgbmV2ZXIgbWF0Y2hcbiAgICAgICAgbGV0IHBhcnRpYWxMb2NhbGUgPSBvcmlnaW5hbExvY2FsZS5yZXBsYWNlKC8teCgtW2EtekEtWjAtOV17MSw4fSkrJC8sICcnKTtcblxuICAgICAgICBsZXQgZXhhY3QgPSB0cnVlO1xuICAgICAgICB3aGlsZSAocGFydGlhbExvY2FsZSkge1xuICAgICAgICAgIGNvbnN0IHBvdGVudGlhbFBhdGggPSBgJHtMT0NBTEVfREFUQV9CQVNFX01PRFVMRX0vJHtwYXJ0aWFsTG9jYWxlfWA7XG5cbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBidWlsZC5yZXNvbHZlKHBvdGVudGlhbFBhdGgsIHtcbiAgICAgICAgICAgIGtpbmQ6ICdpbXBvcnQtc3RhdGVtZW50JyxcbiAgICAgICAgICAgIHJlc29sdmVEaXI6IGJ1aWxkLmluaXRpYWxPcHRpb25zLmFic1dvcmtpbmdEaXIsXG4gICAgICAgICAgfSk7XG4gICAgICAgICAgaWYgKHJlc3VsdC5wYXRoKSB7XG4gICAgICAgICAgICBpZiAoZXhhY3QpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgICAgLi4ucmVzdWx0LFxuICAgICAgICAgICAgICAgIHdhcm5pbmdzOiBbXG4gICAgICAgICAgICAgICAgICAuLi5yZXN1bHQud2FybmluZ3MsXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGxvY2F0aW9uOiBudWxsLFxuICAgICAgICAgICAgICAgICAgICB0ZXh0OiBgTG9jYWxlIGRhdGEgZm9yICcke29yaWdpbmFsTG9jYWxlfScgY2Fubm90IGJlIGZvdW5kLiBVc2luZyBsb2NhbGUgZGF0YSBmb3IgJyR7cGFydGlhbExvY2FsZX0nLmAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgIH07XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gUmVtb3ZlIHRoZSBsYXN0IHN1YnRhZyBhbmQgdHJ5IGFnYWluIHdpdGggYSBsZXNzIHNwZWNpZmljIGxvY2FsZVxuICAgICAgICAgIGNvbnN0IHBhcnRzID0gcGFydGlhbExvY2FsZS5zcGxpdCgnLScpO1xuICAgICAgICAgIHBhcnRpYWxMb2NhbGUgPSBwYXJ0cy5zbGljZSgwLCAtMSkuam9pbignLScpO1xuICAgICAgICAgIGV4YWN0ID0gZmFsc2U7XG4gICAgICAgICAgLy8gVGhlIGxvY2FsZXMgXCJlblwiIGFuZCBcImVuLVVTXCIgYXJlIGNvbnNpZGVyZWQgZXhhY3QgdG8gcmV0YWluIGV4aXN0aW5nIGJlaGF2aW9yXG4gICAgICAgICAgaWYgKG9yaWdpbmFsTG9jYWxlID09PSAnZW4tVVMnICYmIHBhcnRpYWxMb2NhbGUgPT09ICdlbicpIHtcbiAgICAgICAgICAgIGV4YWN0ID0gdHJ1ZTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBOb3QgZm91bmQgc28gaXNzdWUgYSB3YXJuaW5nIGFuZCB1c2UgYW4gZW1wdHkgbG9hZGVyLiBGcmFtZXdvcmsgYnVpbHQtaW4gYGVuLVVTYCBkYXRhIHdpbGwgYmUgdXNlZC5cbiAgICAgICAgLy8gVGhpcyByZXRhaW5zIGV4aXN0aW5nIGJlaGF2aW9yIGFzIGluIHRoZSBXZWJwYWNrLWJhc2VkIGJ1aWxkZXIuXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgcGF0aDogb3JpZ2luYWxMb2NhbGUsXG4gICAgICAgICAgbmFtZXNwYWNlOiAnYW5ndWxhcjpsb2NhbGUvZGF0YScsXG4gICAgICAgICAgd2FybmluZ3M6IFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgbG9jYXRpb246IG51bGwsXG4gICAgICAgICAgICAgIHRleHQ6IGBMb2NhbGUgZGF0YSBmb3IgJyR7b3JpZ2luYWxMb2NhbGV9JyBjYW5ub3QgYmUgZm91bmQuIE5vIGxvY2FsZSBkYXRhIHdpbGwgYmUgaW5jbHVkZWQgZm9yIHRoaXMgbG9jYWxlLmAsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF0sXG4gICAgICAgIH07XG4gICAgICB9KTtcblxuICAgICAgLy8gTG9jYWxlcyB0aGF0IGNhbm5vdCBiZSBmb3VuZCB3aWxsIGJlIGxvYWRlZCBhcyBlbXB0eSBjb250ZW50IHdpdGggYSB3YXJuaW5nIGZyb20gdGhlIHJlc29sdmUgc3RlcFxuICAgICAgYnVpbGQub25Mb2FkKHsgZmlsdGVyOiAvLi8sIG5hbWVzcGFjZTogJ2FuZ3VsYXI6bG9jYWxlL2RhdGEnIH0sICgpID0+ICh7IGxvYWRlcjogJ2VtcHR5JyB9KSk7XG4gICAgfSxcbiAgfTtcbn1cbiJdfQ==
@@ -5,10 +5,10 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
+ import type { OutputFile } from 'esbuild';
8
9
  import { NormalizedApplicationBuildOptions } from '../../builders/application/options';
9
10
  import { InitialFileRecord } from './bundler-context';
10
- import type { ExecutionResult } from './bundler-execution-result';
11
- export declare function generateIndexHtml(initialFiles: Map<string, InitialFileRecord>, executionResult: ExecutionResult, buildOptions: NormalizedApplicationBuildOptions): Promise<{
11
+ export declare function generateIndexHtml(initialFiles: Map<string, InitialFileRecord>, outputFiles: OutputFile[], buildOptions: NormalizedApplicationBuildOptions, lang?: string): Promise<{
12
12
  content: string;
13
13
  contentWithoutCriticalCssInlined: string;
14
14
  warnings: string[];
@@ -15,7 +15,7 @@ const node_assert_1 = __importDefault(require("node:assert"));
15
15
  const node_path_1 = __importDefault(require("node:path"));
16
16
  const index_html_generator_1 = require("../../utils/index-file/index-html-generator");
17
17
  const inline_critical_css_1 = require("../../utils/index-file/inline-critical-css");
18
- async function generateIndexHtml(initialFiles, executionResult, buildOptions) {
18
+ async function generateIndexHtml(initialFiles, outputFiles, buildOptions, lang) {
19
19
  // Analyze metafile for initial link-based hints.
20
20
  // Skip if the internal externalPackages option is enabled since this option requires
21
21
  // dev server cooperation to properly resolve and fetch imports.
@@ -43,7 +43,7 @@ async function generateIndexHtml(initialFiles, executionResult, buildOptions) {
43
43
  const readAsset = async function (filePath) {
44
44
  // Remove leading directory separator
45
45
  const relativefilePath = node_path_1.default.relative(virtualOutputPath, filePath);
46
- const file = executionResult.outputFiles.find((file) => file.path === relativefilePath);
46
+ const file = outputFiles.find((file) => file.path === relativefilePath);
47
47
  if (file) {
48
48
  return file.text;
49
49
  }
@@ -66,7 +66,7 @@ async function generateIndexHtml(initialFiles, executionResult, buildOptions) {
66
66
  indexHtmlGenerator.readAsset = readAsset;
67
67
  const transformResult = await indexHtmlGenerator.process({
68
68
  baseHref,
69
- lang: undefined,
69
+ lang,
70
70
  outputPath: virtualOutputPath,
71
71
  files: [...initialFiles].map(([file, record]) => ({
72
72
  name: record.name ?? '',
@@ -97,4 +97,4 @@ async function generateIndexHtml(initialFiles, executionResult, buildOptions) {
97
97
  };
98
98
  }
99
99
  exports.generateIndexHtml = generateIndexHtml;
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index-html-generator.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/index-html-generator.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;AAEH,8DAAiC;AACjC,0DAA6B;AAE7B,sFAAiF;AACjF,oFAAwF;AAIjF,KAAK,UAAU,iBAAiB,CACrC,YAA4C,EAC5C,eAAgC,EAChC,YAA+C;IAO/C,iDAAiD;IACjD,qFAAqF;IACrF,gEAAgE;IAChE,MAAM,KAAK,GAAG,EAAE,CAAC;IACjB,MAAM,EACJ,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,WAAW,EACX,oBAAoB,EACpB,QAAQ,GACT,GAAG,YAAY,CAAC;IAEjB,IAAA,qBAAM,EAAC,gBAAgB,EAAE,uCAAuC,CAAC,CAAC;IAElE,IAAI,CAAC,gBAAgB,EAAE;QACrB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,YAAY,EAAE;YACvC,IAAI,KAAK,CAAC,UAAU,EAAE;gBACpB,kDAAkD;gBAClD,SAAS;aACV;YACD,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE;gBAC3B,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,eAAwB,EAAE,CAAC,CAAC;aAC1D;iBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;gBACjC,gFAAgF;gBAChF,6CAA6C;gBAC7C,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,SAAkB,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;aACjE;SACF;KACF;IAED,8DAA8D;IAC9D,MAAM,iBAAiB,GAAG,GAAG,CAAC;IAC9B,MAAM,SAAS,GAAG,KAAK,WAAW,QAAgB;QAChD,qCAAqC;QACrC,MAAM,gBAAgB,GAAG,mBAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,gBAAgB,CAAC,CAAC;QACxF,IAAI,IAAI,EAAE;YACR,OAAO,IAAI,CAAC,IAAI,CAAC;SAClB;QAED,MAAM,IAAI,KAAK,CAAC,+BAA+B,gBAAgB,EAAE,CAAC,CAAC;IACrE,CAAC,CAAC;IAEF,4EAA4E;IAC5E,MAAM,kBAAkB,GAAG,IAAI,yCAAkB,CAAC;QAChD,SAAS,EAAE,gBAAgB,CAAC,KAAK;QACjC,WAAW,EAAE,gBAAgB,CAAC,cAAc;QAC5C,GAAG,EAAE,oBAAoB;QACzB,YAAY,EAAE;YACZ,GAAG,mBAAmB;YACtB,MAAM,EAAE;gBACN,GAAG,mBAAmB,CAAC,MAAM;gBAC7B,cAAc,EAAE,KAAK,EAAE,qFAAqF;aAC7G;SACF;QACD,WAAW,EAAE,WAAW;KACzB,CAAC,CAAC;IAEH,kBAAkB,CAAC,SAAS,GAAG,SAAS,CAAC;IAEzC,MAAM,eAAe,GAAG,MAAM,kBAAkB,CAAC,OAAO,CAAC;QACvD,QAAQ;QACR,IAAI,EAAE,SAAS;QACf,UAAU,EAAE,iBAAiB;QAC7B,KAAK,EAAE,CAAC,GAAG,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;YAChD,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,EAAE;YACvB,IAAI;YACJ,SAAS,EAAE,mBAAI,CAAC,OAAO,CAAC,IAAI,CAAC;SAC9B,CAAC,CAAC;QACH,KAAK;KACN,CAAC,CAAC;IAEH,MAAM,gCAAgC,GAAG,eAAe,CAAC,OAAO,CAAC;IACjE,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,cAAc,EAAE;QAC9C,OAAO;YACL,GAAG,eAAe;YAClB,gCAAgC;SACjC,CAAC;KACH;IAED,MAAM,0BAA0B,GAAG,IAAI,gDAA0B,CAAC;QAChE,MAAM,EAAE,KAAK;QACb,SAAS;KACV,CAAC,CAAC;IAEH,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,0BAA0B,CAAC,OAAO,CAC5E,gCAAgC,EAChC;QACE,UAAU,EAAE,iBAAiB;KAC9B,CACF,CAAC;IAEF,OAAO;QACL,MAAM,EAAE,CAAC,GAAG,eAAe,CAAC,MAAM,EAAE,GAAG,MAAM,CAAC;QAC9C,QAAQ,EAAE,CAAC,GAAG,eAAe,CAAC,QAAQ,EAAE,GAAG,QAAQ,CAAC;QACpD,OAAO;QACP,gCAAgC;KACjC,CAAC;AACJ,CAAC;AA7GD,8CA6GC","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 assert from 'node:assert';\nimport path from 'node:path';\nimport { NormalizedApplicationBuildOptions } from '../../builders/application/options';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { InlineCriticalCssProcessor } from '../../utils/index-file/inline-critical-css';\nimport { InitialFileRecord } from './bundler-context';\nimport type { ExecutionResult } from './bundler-execution-result';\n\nexport async function generateIndexHtml(\n  initialFiles: Map<string, InitialFileRecord>,\n  executionResult: ExecutionResult,\n  buildOptions: NormalizedApplicationBuildOptions,\n): Promise<{\n  content: string;\n  contentWithoutCriticalCssInlined: string;\n  warnings: string[];\n  errors: string[];\n}> {\n  // Analyze metafile for initial link-based hints.\n  // Skip if the internal externalPackages option is enabled since this option requires\n  // dev server cooperation to properly resolve and fetch imports.\n  const hints = [];\n  const {\n    indexHtmlOptions,\n    externalPackages,\n    optimizationOptions,\n    crossOrigin,\n    subresourceIntegrity,\n    baseHref,\n  } = buildOptions;\n\n  assert(indexHtmlOptions, 'indexHtmlOptions cannot be undefined.');\n\n  if (!externalPackages) {\n    for (const [key, value] of initialFiles) {\n      if (value.entrypoint) {\n        // Entry points are already referenced in the HTML\n        continue;\n      }\n      if (value.type === 'script') {\n        hints.push({ url: key, mode: 'modulepreload' as const });\n      } else if (value.type === 'style') {\n        // Provide an \"as\" value of \"style\" to ensure external URLs which may not have a\n        // file extension are treated as stylesheets.\n        hints.push({ url: key, mode: 'preload' as const, as: 'style' });\n      }\n    }\n  }\n\n  /** Virtual output path to support reading in-memory files. */\n  const virtualOutputPath = '/';\n  const readAsset = async function (filePath: string): Promise<string> {\n    // Remove leading directory separator\n    const relativefilePath = path.relative(virtualOutputPath, filePath);\n    const file = executionResult.outputFiles.find((file) => file.path === relativefilePath);\n    if (file) {\n      return file.text;\n    }\n\n    throw new Error(`Output file does not exist: ${relativefilePath}`);\n  };\n\n  // Create an index HTML generator that reads from the in-memory output files\n  const indexHtmlGenerator = new IndexHtmlGenerator({\n    indexPath: indexHtmlOptions.input,\n    entrypoints: indexHtmlOptions.insertionOrder,\n    sri: subresourceIntegrity,\n    optimization: {\n      ...optimizationOptions,\n      styles: {\n        ...optimizationOptions.styles,\n        inlineCritical: false, // Disable critical css inline as for SSR and SSG this will be done during rendering.\n      },\n    },\n    crossOrigin: crossOrigin,\n  });\n\n  indexHtmlGenerator.readAsset = readAsset;\n\n  const transformResult = await indexHtmlGenerator.process({\n    baseHref,\n    lang: undefined,\n    outputPath: virtualOutputPath,\n    files: [...initialFiles].map(([file, record]) => ({\n      name: record.name ?? '',\n      file,\n      extension: path.extname(file),\n    })),\n    hints,\n  });\n\n  const contentWithoutCriticalCssInlined = transformResult.content;\n  if (!optimizationOptions.styles.inlineCritical) {\n    return {\n      ...transformResult,\n      contentWithoutCriticalCssInlined,\n    };\n  }\n\n  const inlineCriticalCssProcessor = new InlineCriticalCssProcessor({\n    minify: false, // CSS has already been minified during the build.\n    readAsset,\n  });\n\n  const { content, errors, warnings } = await inlineCriticalCssProcessor.process(\n    contentWithoutCriticalCssInlined,\n    {\n      outputPath: virtualOutputPath,\n    },\n  );\n\n  return {\n    errors: [...transformResult.errors, ...errors],\n    warnings: [...transformResult.warnings, ...warnings],\n    content,\n    contentWithoutCriticalCssInlined,\n  };\n}\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index-html-generator.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/index-html-generator.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;AAGH,8DAAiC;AACjC,0DAA6B;AAE7B,sFAAiF;AACjF,oFAAwF;AAGjF,KAAK,UAAU,iBAAiB,CACrC,YAA4C,EAC5C,WAAyB,EACzB,YAA+C,EAC/C,IAAa;IAOb,iDAAiD;IACjD,qFAAqF;IACrF,gEAAgE;IAChE,MAAM,KAAK,GAAG,EAAE,CAAC;IACjB,MAAM,EACJ,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,WAAW,EACX,oBAAoB,EACpB,QAAQ,GACT,GAAG,YAAY,CAAC;IAEjB,IAAA,qBAAM,EAAC,gBAAgB,EAAE,uCAAuC,CAAC,CAAC;IAElE,IAAI,CAAC,gBAAgB,EAAE;QACrB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,YAAY,EAAE;YACvC,IAAI,KAAK,CAAC,UAAU,EAAE;gBACpB,kDAAkD;gBAClD,SAAS;aACV;YACD,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE;gBAC3B,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,eAAwB,EAAE,CAAC,CAAC;aAC1D;iBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;gBACjC,gFAAgF;gBAChF,6CAA6C;gBAC7C,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,SAAkB,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;aACjE;SACF;KACF;IAED,8DAA8D;IAC9D,MAAM,iBAAiB,GAAG,GAAG,CAAC;IAC9B,MAAM,SAAS,GAAG,KAAK,WAAW,QAAgB;QAChD,qCAAqC;QACrC,MAAM,gBAAgB,GAAG,mBAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,gBAAgB,CAAC,CAAC;QACxE,IAAI,IAAI,EAAE;YACR,OAAO,IAAI,CAAC,IAAI,CAAC;SAClB;QAED,MAAM,IAAI,KAAK,CAAC,+BAA+B,gBAAgB,EAAE,CAAC,CAAC;IACrE,CAAC,CAAC;IAEF,4EAA4E;IAC5E,MAAM,kBAAkB,GAAG,IAAI,yCAAkB,CAAC;QAChD,SAAS,EAAE,gBAAgB,CAAC,KAAK;QACjC,WAAW,EAAE,gBAAgB,CAAC,cAAc;QAC5C,GAAG,EAAE,oBAAoB;QACzB,YAAY,EAAE;YACZ,GAAG,mBAAmB;YACtB,MAAM,EAAE;gBACN,GAAG,mBAAmB,CAAC,MAAM;gBAC7B,cAAc,EAAE,KAAK,EAAE,qFAAqF;aAC7G;SACF;QACD,WAAW,EAAE,WAAW;KACzB,CAAC,CAAC;IAEH,kBAAkB,CAAC,SAAS,GAAG,SAAS,CAAC;IAEzC,MAAM,eAAe,GAAG,MAAM,kBAAkB,CAAC,OAAO,CAAC;QACvD,QAAQ;QACR,IAAI;QACJ,UAAU,EAAE,iBAAiB;QAC7B,KAAK,EAAE,CAAC,GAAG,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;YAChD,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,EAAE;YACvB,IAAI;YACJ,SAAS,EAAE,mBAAI,CAAC,OAAO,CAAC,IAAI,CAAC;SAC9B,CAAC,CAAC;QACH,KAAK;KACN,CAAC,CAAC;IAEH,MAAM,gCAAgC,GAAG,eAAe,CAAC,OAAO,CAAC;IACjE,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,cAAc,EAAE;QAC9C,OAAO;YACL,GAAG,eAAe;YAClB,gCAAgC;SACjC,CAAC;KACH;IAED,MAAM,0BAA0B,GAAG,IAAI,gDAA0B,CAAC;QAChE,MAAM,EAAE,KAAK;QACb,SAAS;KACV,CAAC,CAAC;IAEH,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,0BAA0B,CAAC,OAAO,CAC5E,gCAAgC,EAChC;QACE,UAAU,EAAE,iBAAiB;KAC9B,CACF,CAAC;IAEF,OAAO;QACL,MAAM,EAAE,CAAC,GAAG,eAAe,CAAC,MAAM,EAAE,GAAG,MAAM,CAAC;QAC9C,QAAQ,EAAE,CAAC,GAAG,eAAe,CAAC,QAAQ,EAAE,GAAG,QAAQ,CAAC;QACpD,OAAO;QACP,gCAAgC;KACjC,CAAC;AACJ,CAAC;AA9GD,8CA8GC","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 type { OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport path from 'node:path';\nimport { NormalizedApplicationBuildOptions } from '../../builders/application/options';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { InlineCriticalCssProcessor } from '../../utils/index-file/inline-critical-css';\nimport { InitialFileRecord } from './bundler-context';\n\nexport async function generateIndexHtml(\n  initialFiles: Map<string, InitialFileRecord>,\n  outputFiles: OutputFile[],\n  buildOptions: NormalizedApplicationBuildOptions,\n  lang?: string,\n): Promise<{\n  content: string;\n  contentWithoutCriticalCssInlined: string;\n  warnings: string[];\n  errors: string[];\n}> {\n  // Analyze metafile for initial link-based hints.\n  // Skip if the internal externalPackages option is enabled since this option requires\n  // dev server cooperation to properly resolve and fetch imports.\n  const hints = [];\n  const {\n    indexHtmlOptions,\n    externalPackages,\n    optimizationOptions,\n    crossOrigin,\n    subresourceIntegrity,\n    baseHref,\n  } = buildOptions;\n\n  assert(indexHtmlOptions, 'indexHtmlOptions cannot be undefined.');\n\n  if (!externalPackages) {\n    for (const [key, value] of initialFiles) {\n      if (value.entrypoint) {\n        // Entry points are already referenced in the HTML\n        continue;\n      }\n      if (value.type === 'script') {\n        hints.push({ url: key, mode: 'modulepreload' as const });\n      } else if (value.type === 'style') {\n        // Provide an \"as\" value of \"style\" to ensure external URLs which may not have a\n        // file extension are treated as stylesheets.\n        hints.push({ url: key, mode: 'preload' as const, as: 'style' });\n      }\n    }\n  }\n\n  /** Virtual output path to support reading in-memory files. */\n  const virtualOutputPath = '/';\n  const readAsset = async function (filePath: string): Promise<string> {\n    // Remove leading directory separator\n    const relativefilePath = path.relative(virtualOutputPath, filePath);\n    const file = outputFiles.find((file) => file.path === relativefilePath);\n    if (file) {\n      return file.text;\n    }\n\n    throw new Error(`Output file does not exist: ${relativefilePath}`);\n  };\n\n  // Create an index HTML generator that reads from the in-memory output files\n  const indexHtmlGenerator = new IndexHtmlGenerator({\n    indexPath: indexHtmlOptions.input,\n    entrypoints: indexHtmlOptions.insertionOrder,\n    sri: subresourceIntegrity,\n    optimization: {\n      ...optimizationOptions,\n      styles: {\n        ...optimizationOptions.styles,\n        inlineCritical: false, // Disable critical css inline as for SSR and SSG this will be done during rendering.\n      },\n    },\n    crossOrigin: crossOrigin,\n  });\n\n  indexHtmlGenerator.readAsset = readAsset;\n\n  const transformResult = await indexHtmlGenerator.process({\n    baseHref,\n    lang,\n    outputPath: virtualOutputPath,\n    files: [...initialFiles].map(([file, record]) => ({\n      name: record.name ?? '',\n      file,\n      extension: path.extname(file),\n    })),\n    hints,\n  });\n\n  const contentWithoutCriticalCssInlined = transformResult.content;\n  if (!optimizationOptions.styles.inlineCritical) {\n    return {\n      ...transformResult,\n      contentWithoutCriticalCssInlined,\n    };\n  }\n\n  const inlineCriticalCssProcessor = new InlineCriticalCssProcessor({\n    minify: false, // CSS has already been minified during the build.\n    readAsset,\n  });\n\n  const { content, errors, warnings } = await inlineCriticalCssProcessor.process(\n    contentWithoutCriticalCssInlined,\n    {\n      outputPath: virtualOutputPath,\n    },\n  );\n\n  return {\n    errors: [...transformResult.errors, ...errors],\n    warnings: [...transformResult.warnings, ...warnings],\n    content,\n    contentWithoutCriticalCssInlined,\n  };\n}\n"]}
@@ -28,6 +28,8 @@ export declare function writeResultFiles(outputFiles: OutputFile[], assetFiles:
28
28
  destination: string;
29
29
  }[] | undefined, outputPath: string): Promise<void>;
30
30
  export declare function createOutputFileFromText(path: string, text: string): OutputFile;
31
+ export declare function createOutputFileFromData(path: string, data: Uint8Array): OutputFile;
32
+ export declare function cloneOutputFile(file: OutputFile): OutputFile;
31
33
  /**
32
34
  * Transform browserlists result to esbuild target.
33
35
  * @see https://esbuild.github.io/api/#target
@@ -10,7 +10,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
10
10
  return (mod && mod.__esModule) ? mod : { "default": mod };
11
11
  };
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
- exports.transformSupportedBrowsersToTargets = exports.createOutputFileFromText = exports.writeResultFiles = exports.getFeatureSupport = exports.logMessages = exports.withNoProgress = exports.withSpinner = exports.calculateEstimatedTransferSizes = exports.logBuildStats = void 0;
13
+ exports.transformSupportedBrowsersToTargets = exports.cloneOutputFile = exports.createOutputFileFromData = exports.createOutputFileFromText = exports.writeResultFiles = exports.getFeatureSupport = exports.logMessages = exports.withNoProgress = exports.withSpinner = exports.calculateEstimatedTransferSizes = exports.logBuildStats = void 0;
14
14
  const esbuild_1 = require("esbuild");
15
15
  const node_crypto_1 = require("node:crypto");
16
16
  const node_fs_1 = require("node:fs");
@@ -180,6 +180,36 @@ function createOutputFileFromText(path, text) {
180
180
  };
181
181
  }
182
182
  exports.createOutputFileFromText = createOutputFileFromText;
183
+ function createOutputFileFromData(path, data) {
184
+ return {
185
+ path,
186
+ get text() {
187
+ return Buffer.from(data.buffer, data.byteOffset, data.byteLength).toString('utf-8');
188
+ },
189
+ get hash() {
190
+ return (0, node_crypto_1.createHash)('sha256').update(data).digest('hex');
191
+ },
192
+ get contents() {
193
+ return data;
194
+ },
195
+ };
196
+ }
197
+ exports.createOutputFileFromData = createOutputFileFromData;
198
+ function cloneOutputFile(file) {
199
+ return {
200
+ path: file.path,
201
+ get text() {
202
+ return file.text;
203
+ },
204
+ get hash() {
205
+ return file.hash;
206
+ },
207
+ get contents() {
208
+ return file.contents;
209
+ },
210
+ };
211
+ }
212
+ exports.cloneOutputFile = cloneOutputFile;
183
213
  /**
184
214
  * Transform browserlists result to esbuild target.
185
215
  * @see https://esbuild.github.io/api/#target
@@ -224,4 +254,4 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
224
254
  return transformed;
225
255
  }
226
256
  exports.transformSupportedBrowsersToTargets = transformSupportedBrowsersToTargets;
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/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 { BuilderContext } from '@angular-devkit/architect';\nimport { BuildOptions, Metafile, OutputFile, PartialMessage, formatMessages } from 'esbuild';\nimport { createHash } from 'node:crypto';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { Spinner } from '../../utils/spinner';\nimport { BundleStats, generateBuildStatsTable } from '../webpack/utils/stats';\nimport { InitialFileRecord } from './bundler-context';\n\nconst compressAsync = promisify(brotliCompress);\n\nexport function logBuildStats(\n  context: BuilderContext,\n  metafile: Metafile,\n  initial: Map<string, InitialFileRecord>,\n  estimatedTransferSizes?: Map<string, number>,\n): void {\n  const stats: BundleStats[] = [];\n  for (const [file, output] of Object.entries(metafile.outputs)) {\n    // Only display JavaScript and CSS files\n    if (!file.endsWith('.js') && !file.endsWith('.css')) {\n      continue;\n    }\n    // Skip internal component resources\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    if ((output as any)['ng-component']) {\n      continue;\n    }\n\n    stats.push({\n      initial: initial.has(file),\n      stats: [\n        file,\n        initial.get(file)?.name ?? '-',\n        output.bytes,\n        estimatedTransferSizes?.get(file) ?? '-',\n      ],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, !!estimatedTransferSizes, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nexport async function calculateEstimatedTransferSizes(\n  outputFiles: OutputFile[],\n): Promise<Map<string, number>> {\n  const sizes = new Map<string, number>();\n  const pendingCompression = [];\n\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n\nexport async function withSpinner<T>(text: string, action: () => T | Promise<T>): Promise<T> {\n  const spinner = new Spinner(text);\n  spinner.start();\n\n  try {\n    return await action();\n  } finally {\n    spinner.stop();\n  }\n}\n\nexport async function withNoProgress<T>(test: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\nexport async function logMessages(\n  context: BuilderContext,\n  { errors, warnings }: { errors?: PartialMessage[]; warnings?: PartialMessage[] },\n): Promise<void> {\n  if (warnings?.length) {\n    const warningMessages = await formatMessages(warnings, { kind: 'warning', color: true });\n    context.logger.warn(warningMessages.join('\\n'));\n  }\n\n  if (errors?.length) {\n    const errorMessages = await formatMessages(errors, { kind: 'error', color: true });\n    context.logger.error(errorMessages.join('\\n'));\n  }\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nexport function getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await, async generators, and for await...of to a Zone.js supported form.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nexport async function writeResultFiles(\n  outputFiles: OutputFile[],\n  assetFiles: { source: string; destination: string }[] | undefined,\n  outputPath: string,\n) {\n  const directoryExists = new Set<string>();\n  await Promise.all(\n    outputFiles.map(async (file) => {\n      // Ensure output subdirectories exist\n      const basePath = path.dirname(file.path);\n      if (basePath && !directoryExists.has(basePath)) {\n        await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n        directoryExists.add(basePath);\n      }\n      // Write file contents\n      await fs.writeFile(path.join(outputPath, file.path), file.contents);\n    }),\n  );\n\n  if (assetFiles?.length) {\n    await Promise.all(\n      assetFiles.map(async ({ source, destination }) => {\n        // Ensure output subdirectories exist\n        const basePath = path.dirname(destination);\n        if (basePath && !directoryExists.has(basePath)) {\n          await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n          directoryExists.add(basePath);\n        }\n        // Copy file contents\n        await fs.copyFile(source, path.join(outputPath, destination), fsConstants.COPYFILE_FICLONE);\n      }),\n    );\n  }\n}\n\nexport function createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get hash() {\n      return createHash('sha256').update(this.text).digest('hex');\n    },\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\n/**\n * Transform browserlists result to esbuild target.\n * @see https://esbuild.github.io/api/#target\n */\nexport function transformSupportedBrowsersToTargets(supportedBrowsers: string[]): string[] {\n  const transformed: string[] = [];\n\n  // https://esbuild.github.io/api/#target\n  const esBuildSupportedBrowsers = new Set([\n    'chrome',\n    'edge',\n    'firefox',\n    'ie',\n    'ios',\n    'node',\n    'opera',\n    'safari',\n  ]);\n\n  for (const browser of supportedBrowsers) {\n    let [browserName, version] = browser.toLowerCase().split(' ');\n\n    // browserslist uses the name `ios_saf` for iOS Safari whereas esbuild uses `ios`\n    if (browserName === 'ios_saf') {\n      browserName = 'ios';\n    }\n\n    // browserslist uses ranges `15.2-15.3` versions but only the lowest is required\n    // to perform minimum supported feature checks. esbuild also expects a single version.\n    [version] = version.split('-');\n\n    if (esBuildSupportedBrowsers.has(browserName)) {\n      if (browserName === 'safari' && version === 'tp') {\n        // esbuild only supports numeric versions so `TP` is converted to a high number (999) since\n        // a Technology Preview (TP) of Safari is assumed to support all currently known features.\n        version = '999';\n      } else if (!version.includes('.')) {\n        // A lone major version is considered by esbuild to include all minor versions. However,\n        // browserslist does not and is also inconsistent in its `.0` version naming. For example,\n        // Safari 15.0 is named `safari 15` but Safari 16.0 is named `safari 16.0`.\n        version += '.0';\n      }\n\n      transformed.push(browserName + version);\n    }\n  }\n\n  return transformed;\n}\n"]}
257
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/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 { BuilderContext } from '@angular-devkit/architect';\nimport { BuildOptions, Metafile, OutputFile, PartialMessage, formatMessages } from 'esbuild';\nimport { createHash } from 'node:crypto';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { Spinner } from '../../utils/spinner';\nimport { BundleStats, generateBuildStatsTable } from '../webpack/utils/stats';\nimport { InitialFileRecord } from './bundler-context';\n\nconst compressAsync = promisify(brotliCompress);\n\nexport function logBuildStats(\n  context: BuilderContext,\n  metafile: Metafile,\n  initial: Map<string, InitialFileRecord>,\n  estimatedTransferSizes?: Map<string, number>,\n): void {\n  const stats: BundleStats[] = [];\n  for (const [file, output] of Object.entries(metafile.outputs)) {\n    // Only display JavaScript and CSS files\n    if (!file.endsWith('.js') && !file.endsWith('.css')) {\n      continue;\n    }\n    // Skip internal component resources\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    if ((output as any)['ng-component']) {\n      continue;\n    }\n\n    stats.push({\n      initial: initial.has(file),\n      stats: [\n        file,\n        initial.get(file)?.name ?? '-',\n        output.bytes,\n        estimatedTransferSizes?.get(file) ?? '-',\n      ],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, !!estimatedTransferSizes, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nexport async function calculateEstimatedTransferSizes(\n  outputFiles: OutputFile[],\n): Promise<Map<string, number>> {\n  const sizes = new Map<string, number>();\n  const pendingCompression = [];\n\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n\nexport async function withSpinner<T>(text: string, action: () => T | Promise<T>): Promise<T> {\n  const spinner = new Spinner(text);\n  spinner.start();\n\n  try {\n    return await action();\n  } finally {\n    spinner.stop();\n  }\n}\n\nexport async function withNoProgress<T>(test: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\nexport async function logMessages(\n  context: BuilderContext,\n  { errors, warnings }: { errors?: PartialMessage[]; warnings?: PartialMessage[] },\n): Promise<void> {\n  if (warnings?.length) {\n    const warningMessages = await formatMessages(warnings, { kind: 'warning', color: true });\n    context.logger.warn(warningMessages.join('\\n'));\n  }\n\n  if (errors?.length) {\n    const errorMessages = await formatMessages(errors, { kind: 'error', color: true });\n    context.logger.error(errorMessages.join('\\n'));\n  }\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nexport function getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await, async generators, and for await...of to a Zone.js supported form.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nexport async function writeResultFiles(\n  outputFiles: OutputFile[],\n  assetFiles: { source: string; destination: string }[] | undefined,\n  outputPath: string,\n) {\n  const directoryExists = new Set<string>();\n  await Promise.all(\n    outputFiles.map(async (file) => {\n      // Ensure output subdirectories exist\n      const basePath = path.dirname(file.path);\n      if (basePath && !directoryExists.has(basePath)) {\n        await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n        directoryExists.add(basePath);\n      }\n      // Write file contents\n      await fs.writeFile(path.join(outputPath, file.path), file.contents);\n    }),\n  );\n\n  if (assetFiles?.length) {\n    await Promise.all(\n      assetFiles.map(async ({ source, destination }) => {\n        // Ensure output subdirectories exist\n        const basePath = path.dirname(destination);\n        if (basePath && !directoryExists.has(basePath)) {\n          await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n          directoryExists.add(basePath);\n        }\n        // Copy file contents\n        await fs.copyFile(source, path.join(outputPath, destination), fsConstants.COPYFILE_FICLONE);\n      }),\n    );\n  }\n}\n\nexport function createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get hash() {\n      return createHash('sha256').update(this.text).digest('hex');\n    },\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nexport function createOutputFileFromData(path: string, data: Uint8Array): OutputFile {\n  return {\n    path,\n    get text() {\n      return Buffer.from(data.buffer, data.byteOffset, data.byteLength).toString('utf-8');\n    },\n    get hash() {\n      return createHash('sha256').update(data).digest('hex');\n    },\n    get contents() {\n      return data;\n    },\n  };\n}\n\nexport function cloneOutputFile(file: OutputFile): OutputFile {\n  return {\n    path: file.path,\n    get text() {\n      return file.text;\n    },\n    get hash() {\n      return file.hash;\n    },\n    get contents() {\n      return file.contents;\n    },\n  };\n}\n\n/**\n * Transform browserlists result to esbuild target.\n * @see https://esbuild.github.io/api/#target\n */\nexport function transformSupportedBrowsersToTargets(supportedBrowsers: string[]): string[] {\n  const transformed: string[] = [];\n\n  // https://esbuild.github.io/api/#target\n  const esBuildSupportedBrowsers = new Set([\n    'chrome',\n    'edge',\n    'firefox',\n    'ie',\n    'ios',\n    'node',\n    'opera',\n    'safari',\n  ]);\n\n  for (const browser of supportedBrowsers) {\n    let [browserName, version] = browser.toLowerCase().split(' ');\n\n    // browserslist uses the name `ios_saf` for iOS Safari whereas esbuild uses `ios`\n    if (browserName === 'ios_saf') {\n      browserName = 'ios';\n    }\n\n    // browserslist uses ranges `15.2-15.3` versions but only the lowest is required\n    // to perform minimum supported feature checks. esbuild also expects a single version.\n    [version] = version.split('-');\n\n    if (esBuildSupportedBrowsers.has(browserName)) {\n      if (browserName === 'safari' && version === 'tp') {\n        // esbuild only supports numeric versions so `TP` is converted to a high number (999) since\n        // a Technology Preview (TP) of Safari is assumed to support all currently known features.\n        version = '999';\n      } else if (!version.includes('.')) {\n        // A lone major version is considered by esbuild to include all minor versions. However,\n        // browserslist does not and is also inconsistent in its `.0` version naming. For example,\n        // Safari 15.0 is named `safari 15` but Safari 16.0 is named `safari 16.0`.\n        version += '.0';\n      }\n\n      transformed.push(browserName + version);\n    }\n  }\n\n  return transformed;\n}\n"]}
@@ -19,6 +19,8 @@ export interface VirtualModulePluginOptions {
19
19
  transformPath?: (path: string) => string;
20
20
  /** Method to provide the module content. */
21
21
  loadContent: (args: OnLoadArgs, build: PluginBuild) => ReturnType<Parameters<PluginBuild['onLoad']>[1]>;
22
+ /** Restrict to only entry points. Defaults to `true`. */
23
+ entryPointOnly?: boolean;
22
24
  }
23
25
  /**
24
26
  * Creates an esbuild plugin that generated virtual modules.
@@ -14,12 +14,12 @@ exports.createVirtualModulePlugin = void 0;
14
14
  * @returns An esbuild plugin.
15
15
  */
16
16
  function createVirtualModulePlugin(options) {
17
- const { namespace, external, transformPath: pathTransformer, loadContent } = options;
17
+ const { namespace, external, transformPath: pathTransformer, loadContent, entryPointOnly = true, } = options;
18
18
  return {
19
19
  name: namespace.replace(/[/:]/g, '-'),
20
20
  setup(build) {
21
21
  build.onResolve({ filter: new RegExp('^' + namespace) }, ({ kind, path }) => {
22
- if (kind !== 'entry-point') {
22
+ if (entryPointOnly && kind !== 'entry-point') {
23
23
  return null;
24
24
  }
25
25
  return {
@@ -40,4 +40,4 @@ function createVirtualModulePlugin(options) {
40
40
  };
41
41
  }
42
42
  exports.createVirtualModulePlugin = createVirtualModulePlugin;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlydHVhbC1tb2R1bGUtcGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdG9vbHMvZXNidWlsZC92aXJ0dWFsLW1vZHVsZS1wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7O0FBc0JIOzs7O0dBSUc7QUFDSCxTQUFnQix5QkFBeUIsQ0FBQyxPQUFtQztJQUMzRSxNQUFNLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxHQUFHLE9BQU8sQ0FBQztJQUVyRixPQUFPO1FBQ0wsSUFBSSxFQUFFLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQztRQUNyQyxLQUFLLENBQUMsS0FBSztZQUNULEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsSUFBSSxNQUFNLENBQUMsR0FBRyxHQUFHLFNBQVMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO2dCQUMxRSxJQUFJLElBQUksS0FBSyxhQUFhLEVBQUU7b0JBQzFCLE9BQU8sSUFBSSxDQUFDO2lCQUNiO2dCQUVELE9BQU87b0JBQ0wsSUFBSSxFQUFFLGVBQWUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLElBQUk7b0JBQ3JDLFNBQVM7aUJBQ1YsQ0FBQztZQUNKLENBQUMsQ0FBQyxDQUFDO1lBRUgsSUFBSSxRQUFRLEVBQUU7Z0JBQ1osS0FBSyxDQUFDLFNBQVMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUU7b0JBQ3ZELE9BQU87d0JBQ0wsSUFBSTt3QkFDSixRQUFRLEVBQUUsSUFBSTtxQkFDZixDQUFDO2dCQUNKLENBQUMsQ0FBQyxDQUFDO2FBQ0o7WUFFRCxLQUFLLENBQUMsTUFBTSxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQy9FLENBQUM7S0FDRixDQUFDO0FBQ0osQ0FBQztBQTdCRCw4REE2QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBPbkxvYWRBcmdzLCBQbHVnaW4sIFBsdWdpbkJ1aWxkIH0gZnJvbSAnZXNidWlsZCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgdGhlIGNyZWF0ZVZpcnR1YWxNb2R1bGVQbHVnaW5cbiAqIEBzZWUgY3JlYXRlVmlydHVhbE1vZHVsZVBsdWdpblxuICovXG5leHBvcnQgaW50ZXJmYWNlIFZpcnR1YWxNb2R1bGVQbHVnaW5PcHRpb25zIHtcbiAgLyoqIE5hbWVzcGFjZS4gRXhhbXBsZTogYGFuZ3VsYXI6cG9seWZpbGxzYC4gKi9cbiAgbmFtZXNwYWNlOiBzdHJpbmc7XG4gIC8qKiBJZiB0aGUgZ2VuZXJhdGVkIG1vZHVsZSBzaG91bGQgYmUgbWFya2VkIGFzIGV4dGVybmFsLiAqL1xuICBleHRlcm5hbD86IGJvb2xlYW47XG4gIC8qKiBNZXRob2QgdG8gdHJhbnNmb3JtIHRoZSBvblJlc29sdmUgcGF0aC4gKi9cbiAgdHJhbnNmb3JtUGF0aD86IChwYXRoOiBzdHJpbmcpID0+IHN0cmluZztcbiAgLyoqIE1ldGhvZCB0byBwcm92aWRlIHRoZSBtb2R1bGUgY29udGVudC4gKi9cbiAgbG9hZENvbnRlbnQ6IChcbiAgICBhcmdzOiBPbkxvYWRBcmdzLFxuICAgIGJ1aWxkOiBQbHVnaW5CdWlsZCxcbiAgKSA9PiBSZXR1cm5UeXBlPFBhcmFtZXRlcnM8UGx1Z2luQnVpbGRbJ29uTG9hZCddPlsxXT47XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IGdlbmVyYXRlZCB2aXJ0dWFsIG1vZHVsZXMuXG4gKlxuICogQHJldHVybnMgQW4gZXNidWlsZCBwbHVnaW4uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVWaXJ0dWFsTW9kdWxlUGx1Z2luKG9wdGlvbnM6IFZpcnR1YWxNb2R1bGVQbHVnaW5PcHRpb25zKTogUGx1Z2luIHtcbiAgY29uc3QgeyBuYW1lc3BhY2UsIGV4dGVybmFsLCB0cmFuc2Zvcm1QYXRoOiBwYXRoVHJhbnNmb3JtZXIsIGxvYWRDb250ZW50IH0gPSBvcHRpb25zO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogbmFtZXNwYWNlLnJlcGxhY2UoL1svOl0vZywgJy0nKSxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25SZXNvbHZlKHsgZmlsdGVyOiBuZXcgUmVnRXhwKCdeJyArIG5hbWVzcGFjZSkgfSwgKHsga2luZCwgcGF0aCB9KSA9PiB7XG4gICAgICAgIGlmIChraW5kICE9PSAnZW50cnktcG9pbnQnKSB7XG4gICAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHBhdGg6IHBhdGhUcmFuc2Zvcm1lcj8uKHBhdGgpID8/IHBhdGgsXG4gICAgICAgICAgbmFtZXNwYWNlLFxuICAgICAgICB9O1xuICAgICAgfSk7XG5cbiAgICAgIGlmIChleHRlcm5hbCkge1xuICAgICAgICBidWlsZC5vblJlc29sdmUoeyBmaWx0ZXI6IC8uLywgbmFtZXNwYWNlIH0sICh7IHBhdGggfSkgPT4ge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBwYXRoLFxuICAgICAgICAgICAgZXh0ZXJuYWw6IHRydWUsXG4gICAgICAgICAgfTtcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIGJ1aWxkLm9uTG9hZCh7IGZpbHRlcjogLy4vLCBuYW1lc3BhY2UgfSwgKGFyZ3MpID0+IGxvYWRDb250ZW50KGFyZ3MsIGJ1aWxkKSk7XG4gICAgfSxcbiAgfTtcbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlydHVhbC1tb2R1bGUtcGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdG9vbHMvZXNidWlsZC92aXJ0dWFsLW1vZHVsZS1wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7O0FBd0JIOzs7O0dBSUc7QUFDSCxTQUFnQix5QkFBeUIsQ0FBQyxPQUFtQztJQUMzRSxNQUFNLEVBQ0osU0FBUyxFQUNULFFBQVEsRUFDUixhQUFhLEVBQUUsZUFBZSxFQUM5QixXQUFXLEVBQ1gsY0FBYyxHQUFHLElBQUksR0FDdEIsR0FBRyxPQUFPLENBQUM7SUFFWixPQUFPO1FBQ0wsSUFBSSxFQUFFLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQztRQUNyQyxLQUFLLENBQUMsS0FBSztZQUNULEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsSUFBSSxNQUFNLENBQUMsR0FBRyxHQUFHLFNBQVMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO2dCQUMxRSxJQUFJLGNBQWMsSUFBSSxJQUFJLEtBQUssYUFBYSxFQUFFO29CQUM1QyxPQUFPLElBQUksQ0FBQztpQkFDYjtnQkFFRCxPQUFPO29CQUNMLElBQUksRUFBRSxlQUFlLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJO29CQUNyQyxTQUFTO2lCQUNWLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztZQUVILElBQUksUUFBUSxFQUFFO2dCQUNaLEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO29CQUN2RCxPQUFPO3dCQUNMLElBQUk7d0JBQ0osUUFBUSxFQUFFLElBQUk7cUJBQ2YsQ0FBQztnQkFDSixDQUFDLENBQUMsQ0FBQzthQUNKO1lBRUQsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUMvRSxDQUFDO0tBQ0YsQ0FBQztBQUNKLENBQUM7QUFuQ0QsOERBbUNDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB0eXBlIHsgT25Mb2FkQXJncywgUGx1Z2luLCBQbHVnaW5CdWlsZCB9IGZyb20gJ2VzYnVpbGQnO1xuXG4vKipcbiAqIE9wdGlvbnMgZm9yIHRoZSBjcmVhdGVWaXJ0dWFsTW9kdWxlUGx1Z2luXG4gKiBAc2VlIGNyZWF0ZVZpcnR1YWxNb2R1bGVQbHVnaW5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWaXJ0dWFsTW9kdWxlUGx1Z2luT3B0aW9ucyB7XG4gIC8qKiBOYW1lc3BhY2UuIEV4YW1wbGU6IGBhbmd1bGFyOnBvbHlmaWxsc2AuICovXG4gIG5hbWVzcGFjZTogc3RyaW5nO1xuICAvKiogSWYgdGhlIGdlbmVyYXRlZCBtb2R1bGUgc2hvdWxkIGJlIG1hcmtlZCBhcyBleHRlcm5hbC4gKi9cbiAgZXh0ZXJuYWw/OiBib29sZWFuO1xuICAvKiogTWV0aG9kIHRvIHRyYW5zZm9ybSB0aGUgb25SZXNvbHZlIHBhdGguICovXG4gIHRyYW5zZm9ybVBhdGg/OiAocGF0aDogc3RyaW5nKSA9PiBzdHJpbmc7XG4gIC8qKiBNZXRob2QgdG8gcHJvdmlkZSB0aGUgbW9kdWxlIGNvbnRlbnQuICovXG4gIGxvYWRDb250ZW50OiAoXG4gICAgYXJnczogT25Mb2FkQXJncyxcbiAgICBidWlsZDogUGx1Z2luQnVpbGQsXG4gICkgPT4gUmV0dXJuVHlwZTxQYXJhbWV0ZXJzPFBsdWdpbkJ1aWxkWydvbkxvYWQnXT5bMV0+O1xuICAvKiogUmVzdHJpY3QgdG8gb25seSBlbnRyeSBwb2ludHMuIERlZmF1bHRzIHRvIGB0cnVlYC4gKi9cbiAgZW50cnlQb2ludE9ubHk/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBnZW5lcmF0ZWQgdmlydHVhbCBtb2R1bGVzLlxuICpcbiAqIEByZXR1cm5zIEFuIGVzYnVpbGQgcGx1Z2luLlxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVmlydHVhbE1vZHVsZVBsdWdpbihvcHRpb25zOiBWaXJ0dWFsTW9kdWxlUGx1Z2luT3B0aW9ucyk6IFBsdWdpbiB7XG4gIGNvbnN0IHtcbiAgICBuYW1lc3BhY2UsXG4gICAgZXh0ZXJuYWwsXG4gICAgdHJhbnNmb3JtUGF0aDogcGF0aFRyYW5zZm9ybWVyLFxuICAgIGxvYWRDb250ZW50LFxuICAgIGVudHJ5UG9pbnRPbmx5ID0gdHJ1ZSxcbiAgfSA9IG9wdGlvbnM7XG5cbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBuYW1lc3BhY2UucmVwbGFjZSgvWy86XS9nLCAnLScpLFxuICAgIHNldHVwKGJ1aWxkKTogdm9pZCB7XG4gICAgICBidWlsZC5vblJlc29sdmUoeyBmaWx0ZXI6IG5ldyBSZWdFeHAoJ14nICsgbmFtZXNwYWNlKSB9LCAoeyBraW5kLCBwYXRoIH0pID0+IHtcbiAgICAgICAgaWYgKGVudHJ5UG9pbnRPbmx5ICYmIGtpbmQgIT09ICdlbnRyeS1wb2ludCcpIHtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgcGF0aDogcGF0aFRyYW5zZm9ybWVyPy4ocGF0aCkgPz8gcGF0aCxcbiAgICAgICAgICBuYW1lc3BhY2UsXG4gICAgICAgIH07XG4gICAgICB9KTtcblxuICAgICAgaWYgKGV4dGVybmFsKSB7XG4gICAgICAgIGJ1aWxkLm9uUmVzb2x2ZSh7IGZpbHRlcjogLy4vLCBuYW1lc3BhY2UgfSwgKHsgcGF0aCB9KSA9PiB7XG4gICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHBhdGgsXG4gICAgICAgICAgICBleHRlcm5hbDogdHJ1ZSxcbiAgICAgICAgICB9O1xuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgYnVpbGQub25Mb2FkKHsgZmlsdGVyOiAvLi8sIG5hbWVzcGFjZSB9LCAoYXJncykgPT4gbG9hZENvbnRlbnQoYXJncywgYnVpbGQpKTtcbiAgICB9LFxuICB9O1xufVxuIl19
@@ -0,0 +1,18 @@
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 type { Plugin } from 'vite';
9
+ /**
10
+ * The base module location used to search for locale specific data.
11
+ */
12
+ export declare const LOCALE_DATA_BASE_MODULE = "@angular/common/locales/global";
13
+ /**
14
+ * Creates a Vite plugin that resolves Angular locale data files from `@angular/common`.
15
+ *
16
+ * @returns A Vite plugin.
17
+ */
18
+ export declare function createAngularLocaleDataPlugin(): Plugin;