@angular-devkit/build-angular 17.0.0-next.6 → 17.0.0-next.8

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 (90) hide show
  1. package/package.json +16 -16
  2. package/src/builders/application/build-action.d.ts +3 -0
  3. package/src/builders/application/build-action.js +68 -53
  4. package/src/builders/application/execute-build.js +41 -23
  5. package/src/builders/application/i18n.d.ts +4 -1
  6. package/src/builders/application/i18n.js +34 -4
  7. package/src/builders/application/index.d.ts +6 -4
  8. package/src/builders/application/index.js +11 -13
  9. package/src/builders/application/options.d.ts +7 -0
  10. package/src/builders/application/options.js +5 -2
  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 -7
  15. package/src/builders/browser-esbuild/index.d.ts +2 -2
  16. package/src/builders/browser-esbuild/index.js +45 -3
  17. package/src/builders/dev-server/builder.js +2 -2
  18. package/src/builders/dev-server/load-proxy-config.js +3 -2
  19. package/src/builders/dev-server/options.d.ts +1 -1
  20. package/src/builders/dev-server/options.js +4 -3
  21. package/src/builders/dev-server/schema.d.ts +8 -1
  22. package/src/builders/dev-server/schema.js +1 -1
  23. package/src/builders/dev-server/schema.json +7 -1
  24. package/src/builders/dev-server/vite-server.d.ts +2 -1
  25. package/src/builders/dev-server/vite-server.js +30 -5
  26. package/src/builders/dev-server/webpack-server.js +2 -2
  27. package/src/builders/extract-i18n/application-extraction.js +3 -3
  28. package/src/builders/extract-i18n/builder.js +4 -3
  29. package/src/builders/extract-i18n/options.d.ts +1 -1
  30. package/src/builders/extract-i18n/options.js +4 -3
  31. package/src/builders/extract-i18n/schema.d.ts +8 -1
  32. package/src/builders/extract-i18n/schema.js +1 -1
  33. package/src/builders/extract-i18n/schema.json +7 -1
  34. package/src/builders/extract-i18n/webpack-extraction.js +2 -2
  35. package/src/builders/jest/index.js +2 -2
  36. package/src/builders/protractor/index.js +2 -2
  37. package/src/tools/esbuild/angular/compilation/aot-compilation.js +16 -7
  38. package/src/tools/esbuild/angular/compilation-state.d.ts +15 -0
  39. package/src/tools/esbuild/angular/compilation-state.js +43 -0
  40. package/src/tools/esbuild/angular/compiler-plugin.d.ts +2 -12
  41. package/src/tools/esbuild/angular/compiler-plugin.js +34 -52
  42. package/src/tools/esbuild/angular/component-stylesheets.d.ts +47 -0
  43. package/src/tools/esbuild/angular/component-stylesheets.js +147 -0
  44. package/src/tools/esbuild/angular/jit-plugin-callbacks.d.ts +2 -5
  45. package/src/tools/esbuild/angular/jit-plugin-callbacks.js +11 -6
  46. package/src/tools/esbuild/angular/source-file-cache.d.ts +19 -0
  47. package/src/tools/esbuild/angular/source-file-cache.js +67 -0
  48. package/src/tools/esbuild/angular/uri.d.ts +1 -1
  49. package/src/tools/esbuild/application-code-bundle.d.ts +1 -1
  50. package/src/tools/esbuild/application-code-bundle.js +68 -10
  51. package/src/tools/esbuild/budget-stats.d.ts +19 -0
  52. package/src/tools/esbuild/budget-stats.js +55 -0
  53. package/src/tools/esbuild/bundler-context.d.ts +12 -1
  54. package/src/tools/esbuild/bundler-context.js +29 -3
  55. package/src/tools/esbuild/bundler-execution-result.d.ts +9 -6
  56. package/src/tools/esbuild/bundler-execution-result.js +6 -3
  57. package/src/tools/esbuild/compiler-plugin-options.d.ts +2 -1
  58. package/src/tools/esbuild/compiler-plugin-options.js +2 -1
  59. package/src/tools/esbuild/global-styles.js +2 -1
  60. package/src/tools/esbuild/i18n-inliner.d.ts +3 -3
  61. package/src/tools/esbuild/i18n-inliner.js +13 -4
  62. package/src/tools/esbuild/index-html-generator.d.ts +2 -3
  63. package/src/tools/esbuild/index-html-generator.js +5 -2
  64. package/src/tools/esbuild/stylesheets/bundle-options.d.ts +2 -24
  65. package/src/tools/esbuild/stylesheets/bundle-options.js +3 -105
  66. package/src/tools/esbuild/utils.d.ts +12 -6
  67. package/src/tools/esbuild/utils.js +85 -34
  68. package/src/utils/build-options.d.ts +1 -1
  69. package/src/utils/build-options.js +1 -1
  70. package/src/utils/bundle-calculator.d.ts +16 -3
  71. package/src/utils/bundle-calculator.js +21 -10
  72. package/src/utils/routes-extractor/extractor.js +3 -4
  73. package/src/utils/server-rendering/{esm-in-memory-file-loader.d.ts → esm-in-memory-loader/loader-hooks.d.ts} +1 -0
  74. package/src/utils/server-rendering/esm-in-memory-loader/loader-hooks.js +82 -0
  75. package/src/utils/server-rendering/esm-in-memory-loader/node-18-utils.d.ts +10 -0
  76. package/src/utils/server-rendering/esm-in-memory-loader/node-18-utils.js +39 -0
  77. package/src/utils/server-rendering/esm-in-memory-loader/register-hooks.d.ts +8 -0
  78. package/src/utils/server-rendering/esm-in-memory-loader/register-hooks.js +16 -0
  79. package/src/utils/server-rendering/main-bundle-exports.d.ts +1 -0
  80. package/src/utils/server-rendering/main-bundle-exports.js +1 -1
  81. package/src/utils/server-rendering/prerender.d.ts +2 -2
  82. package/src/utils/server-rendering/prerender.js +10 -18
  83. package/src/utils/server-rendering/render-page.js +6 -2
  84. package/src/utils/server-rendering/render-worker.d.ts +1 -1
  85. package/src/utils/server-rendering/render-worker.js +1 -1
  86. package/src/utils/server-rendering/routes-extractor-worker.d.ts +1 -1
  87. package/src/utils/server-rendering/routes-extractor-worker.js +1 -1
  88. package/src/utils/service-worker.d.ts +2 -2
  89. package/src/utils/service-worker.js +5 -2
  90. package/src/utils/server-rendering/esm-in-memory-file-loader.js +0 -76
package/package.json CHANGED
@@ -1,29 +1,29 @@
1
1
  {
2
2
  "name": "@angular-devkit/build-angular",
3
- "version": "17.0.0-next.6",
3
+ "version": "17.0.0-next.8",
4
4
  "description": "Angular Webpack Build Facade",
5
5
  "main": "src/index.js",
6
6
  "typings": "src/index.d.ts",
7
7
  "builders": "builders.json",
8
8
  "dependencies": {
9
9
  "@ampproject/remapping": "2.2.1",
10
- "@angular-devkit/architect": "0.1700.0-next.6",
11
- "@angular-devkit/build-webpack": "0.1700.0-next.6",
12
- "@angular-devkit/core": "17.0.0-next.6",
13
- "@babel/core": "7.22.17",
14
- "@babel/generator": "7.22.15",
10
+ "@angular-devkit/architect": "0.1700.0-next.8",
11
+ "@angular-devkit/build-webpack": "0.1700.0-next.8",
12
+ "@angular-devkit/core": "17.0.0-next.8",
13
+ "@babel/core": "7.23.0",
14
+ "@babel/generator": "7.23.0",
15
15
  "@babel/helper-annotate-as-pure": "7.22.5",
16
16
  "@babel/helper-split-export-declaration": "7.22.6",
17
17
  "@babel/plugin-transform-async-generator-functions": "7.22.15",
18
18
  "@babel/plugin-transform-async-to-generator": "7.22.5",
19
19
  "@babel/plugin-transform-runtime": "7.22.15",
20
- "@babel/preset-env": "7.22.15",
21
- "@babel/runtime": "7.22.15",
20
+ "@babel/preset-env": "7.22.20",
21
+ "@babel/runtime": "7.23.1",
22
22
  "@discoveryjs/json-ext": "0.5.7",
23
- "@ngtools/webpack": "17.0.0-next.6",
23
+ "@ngtools/webpack": "17.0.0-next.8",
24
24
  "@vitejs/plugin-basic-ssl": "1.0.1",
25
25
  "ansi-colors": "4.1.3",
26
- "autoprefixer": "10.4.15",
26
+ "autoprefixer": "10.4.16",
27
27
  "babel-loader": "9.1.3",
28
28
  "babel-plugin-istanbul": "6.1.1",
29
29
  "browserslist": "^4.21.5",
@@ -32,7 +32,7 @@
32
32
  "copy-webpack-plugin": "11.0.0",
33
33
  "critters": "0.0.20",
34
34
  "css-loader": "6.8.1",
35
- "esbuild-wasm": "0.19.3",
35
+ "esbuild-wasm": "0.19.4",
36
36
  "fast-glob": "3.3.1",
37
37
  "https-proxy-agent": "7.0.2",
38
38
  "http-proxy-middleware": "2.0.6",
@@ -43,7 +43,7 @@
43
43
  "less-loader": "11.1.0",
44
44
  "license-webpack-plugin": "4.0.2",
45
45
  "loader-utils": "3.2.1",
46
- "magic-string": "0.30.3",
46
+ "magic-string": "0.30.4",
47
47
  "mini-css-extract-plugin": "2.7.6",
48
48
  "mrmime": "1.0.1",
49
49
  "open": "8.4.2",
@@ -51,7 +51,7 @@
51
51
  "parse5-html-rewriting-stream": "7.0.0",
52
52
  "picomatch": "2.3.1",
53
53
  "piscina": "4.1.0",
54
- "postcss": "8.4.29",
54
+ "postcss": "8.4.31",
55
55
  "postcss-loader": "7.3.3",
56
56
  "resolve-url-loader": "5.0.0",
57
57
  "rxjs": "7.8.1",
@@ -60,11 +60,11 @@
60
60
  "semver": "7.5.4",
61
61
  "source-map-loader": "4.0.1",
62
62
  "source-map-support": "0.5.21",
63
- "terser": "5.19.4",
63
+ "terser": "5.21.0",
64
64
  "text-table": "0.2.0",
65
65
  "tree-kill": "1.2.2",
66
66
  "tslib": "2.6.2",
67
- "vite": "4.4.9",
67
+ "vite": "4.4.11",
68
68
  "webpack": "5.88.2",
69
69
  "webpack-dev-middleware": "6.1.1",
70
70
  "webpack-dev-server": "4.15.1",
@@ -72,7 +72,7 @@
72
72
  "webpack-subresource-integrity": "5.1.0"
73
73
  },
74
74
  "optionalDependencies": {
75
- "esbuild": "0.19.3"
75
+ "esbuild": "0.19.4"
76
76
  },
77
77
  "peerDependencies": {
78
78
  "@angular/compiler-cli": "^17.0.0 || ^17.0.0-next.0",
@@ -7,6 +7,7 @@
7
7
  */
8
8
  import { BuilderOutput } from '@angular-devkit/architect';
9
9
  import type { logging } from '@angular-devkit/core';
10
+ import { BuildOutputFile } from '../../tools/esbuild/bundler-context';
10
11
  import { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';
11
12
  import { NormalizedCachedOptions } from '../../utils/normalize-cache';
12
13
  export declare function runEsBuildBuildAction(action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>, options: {
@@ -16,9 +17,11 @@ export declare function runEsBuildBuildAction(action: (rebuildState?: RebuildSta
16
17
  logger: logging.LoggerApi;
17
18
  cacheOptions: NormalizedCachedOptions;
18
19
  writeToFileSystem?: boolean;
20
+ writeToFileSystemFilter?: (file: BuildOutputFile) => boolean;
19
21
  watch?: boolean;
20
22
  verbose?: boolean;
21
23
  progress?: boolean;
22
24
  deleteOutputPath?: boolean;
23
25
  poll?: number;
26
+ signal?: AbortSignal;
24
27
  }): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput>;
@@ -40,7 +40,7 @@ const sass_language_1 = require("../../tools/esbuild/stylesheets/sass-language")
40
40
  const utils_1 = require("../../tools/esbuild/utils");
41
41
  const error_1 = require("../../utils/error");
42
42
  async function* runEsBuildBuildAction(action, options) {
43
- const { writeToFileSystem = true, watch, poll, logger, deleteOutputPath, cacheOptions, outputPath, verbose, projectRoot, workspaceRoot, progress, } = options;
43
+ const { writeToFileSystemFilter, writeToFileSystem = true, watch, poll, logger, deleteOutputPath, cacheOptions, outputPath, verbose, projectRoot, workspaceRoot, progress, } = options;
44
44
  if (writeToFileSystem) {
45
45
  // Clean output path if enabled
46
46
  if (deleteOutputPath) {
@@ -65,20 +65,6 @@ async function* runEsBuildBuildAction(action, options) {
65
65
  let result;
66
66
  try {
67
67
  result = await withProgress('Building...', () => action());
68
- if (writeToFileSystem) {
69
- // Write output files
70
- await (0, utils_1.writeResultFiles)(result.outputFiles, result.assetFiles, outputPath);
71
- yield result.output;
72
- }
73
- else {
74
- // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
75
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
76
- yield result.outputWithFiles;
77
- }
78
- // Finish if watch mode is not enabled
79
- if (!watch) {
80
- return;
81
- }
82
68
  }
83
69
  finally {
84
70
  // Ensure Sass workers are shutdown if not watching
@@ -86,46 +72,72 @@ async function* runEsBuildBuildAction(action, options) {
86
72
  (0, sass_language_1.shutdownSassWorkerPool)();
87
73
  }
88
74
  }
89
- if (progress) {
90
- logger.info('Watch mode enabled. Watching for file changes...');
75
+ // Setup watcher if watch mode enabled
76
+ let watcher;
77
+ if (watch) {
78
+ if (progress) {
79
+ logger.info('Watch mode enabled. Watching for file changes...');
80
+ }
81
+ // Setup a watcher
82
+ const { createWatcher } = await Promise.resolve().then(() => __importStar(require('../../tools/esbuild/watcher')));
83
+ watcher = createWatcher({
84
+ polling: typeof poll === 'number',
85
+ interval: poll,
86
+ ignored: [
87
+ // Ignore the output and cache paths to avoid infinite rebuild cycles
88
+ outputPath,
89
+ cacheOptions.basePath,
90
+ // Ignore all node modules directories to avoid excessive file watchers.
91
+ // Package changes are handled below by watching manifest and lock files.
92
+ '**/node_modules/**',
93
+ '**/.*/**',
94
+ ],
95
+ });
96
+ // Setup abort support
97
+ options.signal?.addEventListener('abort', () => void watcher?.close());
98
+ // Temporarily watch the entire project
99
+ watcher.add(projectRoot);
100
+ // Watch workspace for package manager changes
101
+ const packageWatchFiles = [
102
+ // manifest can affect module resolution
103
+ 'package.json',
104
+ // npm lock file
105
+ 'package-lock.json',
106
+ // pnpm lock file
107
+ 'pnpm-lock.yaml',
108
+ // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
109
+ 'yarn.lock',
110
+ '.pnp.cjs',
111
+ '.pnp.data.json',
112
+ ];
113
+ watcher.add(packageWatchFiles.map((file) => node_path_1.default.join(workspaceRoot, file)));
114
+ // Watch locations provided by the initial build result
115
+ watcher.add(result.watchFiles);
116
+ }
117
+ // Output the first build results after setting up the watcher to ensure that any code executed
118
+ // higher in the iterator call stack will trigger the watcher. This is particularly relevant for
119
+ // unit tests which execute the builder and modify the file system programmatically.
120
+ if (writeToFileSystem) {
121
+ // Write output files
122
+ await (0, utils_1.writeResultFiles)(result.outputFiles, result.assetFiles, outputPath);
123
+ yield result.output;
124
+ }
125
+ else {
126
+ // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
127
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
128
+ yield result.outputWithFiles;
129
+ }
130
+ // Finish if watch mode is not enabled
131
+ if (!watcher) {
132
+ return;
91
133
  }
92
- // Setup a watcher
93
- const { createWatcher } = await Promise.resolve().then(() => __importStar(require('../../tools/esbuild/watcher')));
94
- const watcher = createWatcher({
95
- polling: typeof poll === 'number',
96
- interval: poll,
97
- ignored: [
98
- // Ignore the output and cache paths to avoid infinite rebuild cycles
99
- outputPath,
100
- cacheOptions.basePath,
101
- // Ignore all node modules directories to avoid excessive file watchers.
102
- // Package changes are handled below by watching manifest and lock files.
103
- '**/node_modules/**',
104
- '**/.*/**',
105
- ],
106
- });
107
- // Temporarily watch the entire project
108
- watcher.add(projectRoot);
109
- // Watch workspace for package manager changes
110
- const packageWatchFiles = [
111
- // manifest can affect module resolution
112
- 'package.json',
113
- // npm lock file
114
- 'package-lock.json',
115
- // pnpm lock file
116
- 'pnpm-lock.yaml',
117
- // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
118
- 'yarn.lock',
119
- '.pnp.cjs',
120
- '.pnp.data.json',
121
- ];
122
- watcher.add(packageWatchFiles.map((file) => node_path_1.default.join(workspaceRoot, file)));
123
- // Watch locations provided by the initial build result
124
- let previousWatchFiles = new Set(result.watchFiles);
125
- watcher.add(result.watchFiles);
126
134
  // Wait for changes and rebuild as needed
135
+ let previousWatchFiles = new Set(result.watchFiles);
127
136
  try {
128
137
  for await (const changes of watcher) {
138
+ if (options.signal?.aborted) {
139
+ break;
140
+ }
129
141
  if (verbose) {
130
142
  logger.info(changes.toDebugString());
131
143
  }
@@ -139,7 +151,10 @@ async function* runEsBuildBuildAction(action, options) {
139
151
  previousWatchFiles = newWatchFiles;
140
152
  if (writeToFileSystem) {
141
153
  // Write output files
142
- await (0, utils_1.writeResultFiles)(result.outputFiles, result.assetFiles, outputPath);
154
+ const filesToWrite = writeToFileSystemFilter
155
+ ? result.outputFiles.filter(writeToFileSystemFilter)
156
+ : result.outputFiles;
157
+ await (0, utils_1.writeResultFiles)(filesToWrite, result.assetFiles, outputPath);
143
158
  yield result.output;
144
159
  }
145
160
  else {
@@ -156,4 +171,4 @@ async function* runEsBuildBuildAction(action, options) {
156
171
  }
157
172
  }
158
173
  exports.runEsBuildBuildAction = runEsBuildBuildAction;
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-action.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/build-action.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIH,gEAAkC;AAClC,0DAA6B;AAE7B,iFAAuF;AACvF,qDAA0F;AAC1F,6CAAkD;AAG3C,KAAK,SAAS,CAAC,CAAC,qBAAqB,CAC1C,MAAmF,EACnF,OAYC;IAED,MAAM,EACJ,iBAAiB,GAAG,IAAI,EACxB,KAAK,EACL,IAAI,EACJ,MAAM,EACN,gBAAgB,EAChB,YAAY,EACZ,UAAU,EACV,OAAO,EACP,WAAW,EACX,aAAa,EACb,QAAQ,GACT,GAAG,OAAO,CAAC;IAEZ,IAAI,iBAAiB,EAAE;QACrB,+BAA+B;QAC/B,IAAI,gBAAgB,EAAE;YACpB,IAAI,UAAU,KAAK,aAAa,EAAE;gBAChC,MAAM,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAC;gBAElE,OAAO;aACR;YAED,MAAM,kBAAE,CAAC,EAAE,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;SAC1E;QAED,oCAAoC;QACpC,IAAI;YACF,MAAM,kBAAE,CAAC,KAAK,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;SACjD;QAAC,OAAO,CAAC,EAAE;YACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;YACjB,MAAM,CAAC,KAAK,CAAC,qCAAqC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;YAEhE,OAAO;SACR;KACF;IAED,MAAM,YAAY,GAAuB,QAAQ,CAAC,CAAC,CAAC,mBAAW,CAAC,CAAC,CAAC,sBAAc,CAAC;IAEjF,gBAAgB;IAChB,IAAI,MAAuB,CAAC;IAC5B,IAAI;QACF,MAAM,GAAG,MAAM,YAAY,CAAC,aAAa,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;QAE3D,IAAI,iBAAiB,EAAE;YACrB,qBAAqB;YACrB,MAAM,IAAA,wBAAgB,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAE1E,MAAM,MAAM,CAAC,MAAM,CAAC;SACrB;aAAM;YACL,gFAAgF;YAChF,8DAA8D;YAC9D,MAAM,MAAM,CAAC,eAAsB,CAAC;SACrC;QAED,sCAAsC;QACtC,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;KACF;YAAS;QACR,mDAAmD;QACnD,IAAI,CAAC,KAAK,EAAE;YACV,IAAA,sCAAsB,GAAE,CAAC;SAC1B;KACF;IAED,IAAI,QAAQ,EAAE;QACZ,MAAM,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;KACjE;IAED,kBAAkB;IAClB,MAAM,EAAE,aAAa,EAAE,GAAG,wDAAa,6BAA6B,GAAC,CAAC;IACtE,MAAM,OAAO,GAAG,aAAa,CAAC;QAC5B,OAAO,EAAE,OAAO,IAAI,KAAK,QAAQ;QACjC,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE;YACP,qEAAqE;YACrE,UAAU;YACV,YAAY,CAAC,QAAQ;YACrB,wEAAwE;YACxE,yEAAyE;YACzE,oBAAoB;YACpB,UAAU;SACX;KACF,CAAC,CAAC;IAEH,uCAAuC;IACvC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAEzB,8CAA8C;IAC9C,MAAM,iBAAiB,GAAG;QACxB,wCAAwC;QACxC,cAAc;QACd,gBAAgB;QAChB,mBAAmB;QACnB,iBAAiB;QACjB,gBAAgB;QAChB,4FAA4F;QAC5F,WAAW;QACX,UAAU;QACV,gBAAgB;KACjB,CAAC;IAEF,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,mBAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAE7E,uDAAuD;IACvD,IAAI,kBAAkB,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACpD,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAE/B,yCAAyC;IACzC,IAAI;QACF,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,OAAO,EAAE;YACnC,IAAI,OAAO,EAAE;gBACX,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;aACtC;YAED,MAAM,GAAG,MAAM,YAAY,CAAC,iCAAiC,EAAE,GAAG,EAAE,CAClE,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAC3C,CAAC;YAEF,6DAA6D;YAC7D,wBAAwB;YACxB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACzF,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACjD,2BAA2B;YAC3B,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,kBAAkB,CAAC,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAC7F,kBAAkB,GAAG,aAAa,CAAC;YAEnC,IAAI,iBAAiB,EAAE;gBACrB,qBAAqB;gBACrB,MAAM,IAAA,wBAAgB,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;gBAE1E,MAAM,MAAM,CAAC,MAAM,CAAC;aACrB;iBAAM;gBACL,gFAAgF;gBAChF,8DAA8D;gBAC9D,MAAM,MAAM,CAAC,eAAsB,CAAC;aACrC;SACF;KACF;YAAS;QACR,yDAAyD;QACzD,MAAM,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAE9D,IAAA,sCAAsB,GAAE,CAAC;KAC1B;AACH,CAAC;AAjKD,sDAiKC","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 { BuilderOutput } from '@angular-devkit/architect';\nimport type { logging } from '@angular-devkit/core';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { shutdownSassWorkerPool } from '../../tools/esbuild/stylesheets/sass-language';\nimport { withNoProgress, withSpinner, writeResultFiles } from '../../tools/esbuild/utils';\nimport { assertIsError } from '../../utils/error';\nimport { NormalizedCachedOptions } from '../../utils/normalize-cache';\n\nexport async function* runEsBuildBuildAction(\n  action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>,\n  options: {\n    workspaceRoot: string;\n    projectRoot: string;\n    outputPath: string;\n    logger: logging.LoggerApi;\n    cacheOptions: NormalizedCachedOptions;\n    writeToFileSystem?: boolean;\n    watch?: boolean;\n    verbose?: boolean;\n    progress?: boolean;\n    deleteOutputPath?: boolean;\n    poll?: number;\n  },\n): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput> {\n  const {\n    writeToFileSystem = true,\n    watch,\n    poll,\n    logger,\n    deleteOutputPath,\n    cacheOptions,\n    outputPath,\n    verbose,\n    projectRoot,\n    workspaceRoot,\n    progress,\n  } = options;\n\n  if (writeToFileSystem) {\n    // Clean output path if enabled\n    if (deleteOutputPath) {\n      if (outputPath === workspaceRoot) {\n        logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = progress ? withSpinner : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => action());\n\n    if (writeToFileSystem) {\n      // Write output files\n      await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n      yield result.output;\n    } else {\n      // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      yield result.outputWithFiles as any;\n    }\n\n    // Finish if watch mode is not enabled\n    if (!watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  if (progress) {\n    logger.info('Watch mode enabled. Watching for file changes...');\n  }\n\n  // Setup a watcher\n  const { createWatcher } = await import('../../tools/esbuild/watcher');\n  const watcher = createWatcher({\n    polling: typeof poll === 'number',\n    interval: poll,\n    ignored: [\n      // Ignore the output and cache paths to avoid infinite rebuild cycles\n      outputPath,\n      cacheOptions.basePath,\n      // Ignore all node modules directories to avoid excessive file watchers.\n      // Package changes are handled below by watching manifest and lock files.\n      '**/node_modules/**',\n      '**/.*/**',\n    ],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(projectRoot);\n\n  // Watch workspace for package manager changes\n  const packageWatchFiles = [\n    // manifest can affect module resolution\n    'package.json',\n    // npm lock file\n    'package-lock.json',\n    // pnpm lock file\n    'pnpm-lock.yaml',\n    // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n    'yarn.lock',\n    '.pnp.cjs',\n    '.pnp.data.json',\n  ];\n\n  watcher.add(packageWatchFiles.map((file) => path.join(workspaceRoot, file)));\n\n  // Watch locations provided by the initial build result\n  let previousWatchFiles = new Set(result.watchFiles);\n  watcher.add(result.watchFiles);\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (verbose) {\n        logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        action(result.createRebuildState(changes)),\n      );\n\n      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (writeToFileSystem) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n        yield result.output;\n      } else {\n        // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        yield result.outputWithFiles as any;\n      }\n    }\n  } finally {\n    // Stop the watcher and cleanup incremental rebuild state\n    await Promise.allSettled([watcher.close(), result.dispose()]);\n\n    shutdownSassWorkerPool();\n  }\n}\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-action.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/build-action.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 { BuilderOutput } from '@angular-devkit/architect';\nimport type { logging } from '@angular-devkit/core';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { BuildOutputFile } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { shutdownSassWorkerPool } from '../../tools/esbuild/stylesheets/sass-language';\nimport { withNoProgress, withSpinner, writeResultFiles } from '../../tools/esbuild/utils';\nimport { assertIsError } from '../../utils/error';\nimport { NormalizedCachedOptions } from '../../utils/normalize-cache';\n\nexport async function* runEsBuildBuildAction(\n  action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>,\n  options: {\n    workspaceRoot: string;\n    projectRoot: string;\n    outputPath: string;\n    logger: logging.LoggerApi;\n    cacheOptions: NormalizedCachedOptions;\n    writeToFileSystem?: boolean;\n    writeToFileSystemFilter?: (file: BuildOutputFile) => boolean;\n    watch?: boolean;\n    verbose?: boolean;\n    progress?: boolean;\n    deleteOutputPath?: boolean;\n    poll?: number;\n    signal?: AbortSignal;\n  },\n): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput> {\n  const {\n    writeToFileSystemFilter,\n    writeToFileSystem = true,\n    watch,\n    poll,\n    logger,\n    deleteOutputPath,\n    cacheOptions,\n    outputPath,\n    verbose,\n    projectRoot,\n    workspaceRoot,\n    progress,\n  } = options;\n\n  if (writeToFileSystem) {\n    // Clean output path if enabled\n    if (deleteOutputPath) {\n      if (outputPath === workspaceRoot) {\n        logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = progress ? withSpinner : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => action());\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  // Setup watcher if watch mode enabled\n  let watcher: import('../../tools/esbuild/watcher').BuildWatcher | undefined;\n  if (watch) {\n    if (progress) {\n      logger.info('Watch mode enabled. Watching for file changes...');\n    }\n\n    // Setup a watcher\n    const { createWatcher } = await import('../../tools/esbuild/watcher');\n    watcher = createWatcher({\n      polling: typeof poll === 'number',\n      interval: poll,\n      ignored: [\n        // Ignore the output and cache paths to avoid infinite rebuild cycles\n        outputPath,\n        cacheOptions.basePath,\n        // Ignore all node modules directories to avoid excessive file watchers.\n        // Package changes are handled below by watching manifest and lock files.\n        '**/node_modules/**',\n        '**/.*/**',\n      ],\n    });\n\n    // Setup abort support\n    options.signal?.addEventListener('abort', () => void watcher?.close());\n\n    // Temporarily watch the entire project\n    watcher.add(projectRoot);\n\n    // Watch workspace for package manager changes\n    const packageWatchFiles = [\n      // manifest can affect module resolution\n      'package.json',\n      // npm lock file\n      'package-lock.json',\n      // pnpm lock file\n      'pnpm-lock.yaml',\n      // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n      'yarn.lock',\n      '.pnp.cjs',\n      '.pnp.data.json',\n    ];\n\n    watcher.add(packageWatchFiles.map((file) => path.join(workspaceRoot, file)));\n\n    // Watch locations provided by the initial build result\n    watcher.add(result.watchFiles);\n  }\n\n  // Output the first build results after setting up the watcher to ensure that any code executed\n  // higher in the iterator call stack will trigger the watcher. This is particularly relevant for\n  // unit tests which execute the builder and modify the file system programmatically.\n  if (writeToFileSystem) {\n    // Write output files\n    await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n    yield result.output;\n  } else {\n    // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    yield result.outputWithFiles as any;\n  }\n\n  // Finish if watch mode is not enabled\n  if (!watcher) {\n    return;\n  }\n\n  // Wait for changes and rebuild as needed\n  let previousWatchFiles = new Set(result.watchFiles);\n  try {\n    for await (const changes of watcher) {\n      if (options.signal?.aborted) {\n        break;\n      }\n\n      if (verbose) {\n        logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        action(result.createRebuildState(changes)),\n      );\n\n      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (writeToFileSystem) {\n        // Write output files\n        const filesToWrite = writeToFileSystemFilter\n          ? result.outputFiles.filter(writeToFileSystemFilter)\n          : result.outputFiles;\n        await writeResultFiles(filesToWrite, result.assetFiles, outputPath);\n\n        yield result.output;\n      } else {\n        // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        yield result.outputWithFiles as any;\n      }\n    }\n  } finally {\n    // Stop the watcher and cleanup incremental rebuild state\n    await Promise.allSettled([watcher.close(), result.dispose()]);\n\n    shutdownSassWorkerPool();\n  }\n}\n"]}
@@ -12,8 +12,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
13
  exports.executeBuild = void 0;
14
14
  const node_assert_1 = __importDefault(require("node:assert"));
15
- const compiler_plugin_1 = require("../../tools/esbuild/angular/compiler-plugin");
15
+ const source_file_cache_1 = require("../../tools/esbuild/angular/source-file-cache");
16
16
  const application_code_bundle_1 = require("../../tools/esbuild/application-code-bundle");
17
+ const budget_stats_1 = require("../../tools/esbuild/budget-stats");
17
18
  const bundler_context_1 = require("../../tools/esbuild/bundler-context");
18
19
  const bundler_execution_result_1 = require("../../tools/esbuild/bundler-execution-result");
19
20
  const commonjs_checker_1 = require("../../tools/esbuild/commonjs-checker");
@@ -22,6 +23,7 @@ const global_styles_1 = require("../../tools/esbuild/global-styles");
22
23
  const index_html_generator_1 = require("../../tools/esbuild/index-html-generator");
23
24
  const license_extractor_1 = require("../../tools/esbuild/license-extractor");
24
25
  const utils_1 = require("../../tools/esbuild/utils");
26
+ const bundle_calculator_1 = require("../../utils/bundle-calculator");
25
27
  const copy_assets_1 = require("../../utils/copy-assets");
26
28
  const environment_options_1 = require("../../utils/environment-options");
27
29
  const prerender_1 = require("../../utils/server-rendering/prerender");
@@ -42,7 +44,7 @@ async function executeBuild(options, context, rebuildState) {
42
44
  // Reuse rebuild state or create new bundle contexts for code and global stylesheets
43
45
  let bundlerContexts = rebuildState?.rebuildContexts;
44
46
  const codeBundleCache = rebuildState?.codeBundleCache ??
45
- new compiler_plugin_1.SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);
47
+ new source_file_cache_1.SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);
46
48
  if (bundlerContexts === undefined) {
47
49
  bundlerContexts = [];
48
50
  // Browser application code
@@ -66,11 +68,10 @@ async function executeBuild(options, context, rebuildState) {
66
68
  }
67
69
  }
68
70
  // Server application code
69
- if (serverEntryPoint) {
70
- bundlerContexts.push(new bundler_context_1.BundlerContext(workspaceRoot, !!options.watch, (0, application_code_bundle_1.createServerCodeBundleOptions)(options,
71
- // NOTE: earlier versions of Node.js are not supported due to unsafe promise patching.
72
- // See: https://github.com/angular/angular/pull/50552#issue-1737967592
73
- [...target, 'node18.13'], codeBundleCache), () => false));
71
+ // Skip server build when non of the features are enabled.
72
+ if (serverEntryPoint && (prerenderOptions || appShellOptions || ssrOptions)) {
73
+ const nodeTargets = (0, utils_1.getSupportedNodeTargets)();
74
+ bundlerContexts.push(new bundler_context_1.BundlerContext(workspaceRoot, !!options.watch, (0, application_code_bundle_1.createServerCodeBundleOptions)(options, [...target, ...nodeTargets], codeBundleCache), () => false));
74
75
  }
75
76
  }
76
77
  const bundlingResult = await bundler_context_1.BundlerContext.bundleAll(bundlerContexts);
@@ -106,57 +107,74 @@ async function executeBuild(options, context, rebuildState) {
106
107
  options.i18nOptions.hasDefinedSourceLocale ? options.i18nOptions.sourceLocale : undefined);
107
108
  indexContentOutputNoCssInlining = contentWithoutCriticalCssInlined;
108
109
  printWarningsAndErrorsToConsole(context, warnings, errors);
109
- executionResult.addOutputFile(indexHtmlOptions.output, content);
110
+ executionResult.addOutputFile(indexHtmlOptions.output, content, bundler_context_1.BuildOutputFileType.Browser);
110
111
  if (ssrOptions) {
111
- executionResult.addOutputFile('index.server.html', contentWithoutCriticalCssInlined);
112
+ executionResult.addOutputFile('index.server.html', contentWithoutCriticalCssInlined, bundler_context_1.BuildOutputFileType.Server);
112
113
  }
113
114
  }
114
115
  // Pre-render (SSG) and App-shell
115
- if (prerenderOptions || appShellOptions) {
116
+ // If localization is enabled, prerendering is handled in the inlining process.
117
+ if ((prerenderOptions || appShellOptions) && !options.i18nOptions.shouldInline) {
116
118
  (0, node_assert_1.default)(indexContentOutputNoCssInlining, 'The "index" option is required when using the "ssg" or "appShell" options.');
117
119
  const { output, warnings, errors } = await (0, prerender_1.prerenderPages)(workspaceRoot, appShellOptions, prerenderOptions, executionResult.outputFiles, indexContentOutputNoCssInlining, optimizationOptions.styles.inlineCritical, environment_options_1.maxWorkers, verbose);
118
120
  printWarningsAndErrorsToConsole(context, warnings, errors);
119
121
  for (const [path, content] of Object.entries(output)) {
120
- executionResult.addOutputFile(path, content);
122
+ executionResult.addOutputFile(path, content, bundler_context_1.BuildOutputFileType.Browser);
121
123
  }
122
124
  }
123
125
  // Copy assets
124
126
  if (assets) {
125
127
  // The webpack copy assets helper is used with no base paths defined. This prevents the helper
126
128
  // from directly writing to disk. This should eventually be replaced with a more optimized helper.
127
- executionResult.assetFiles.push(...(await (0, copy_assets_1.copyAssets)(assets, [], workspaceRoot)));
128
- }
129
- // Write metafile if stats option is enabled
130
- if (options.stats) {
131
- executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));
129
+ executionResult.addAssets(await (0, copy_assets_1.copyAssets)(assets, [], workspaceRoot));
132
130
  }
133
131
  // Extract and write licenses for used packages
134
132
  if (options.extractLicenses) {
135
- executionResult.addOutputFile('3rdpartylicenses.txt', await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot));
133
+ executionResult.addOutputFile('3rdpartylicenses.txt', await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot), bundler_context_1.BuildOutputFileType.Root);
136
134
  }
137
135
  // Augment the application with service worker support
138
- if (serviceWorker) {
136
+ // If localization is enabled, service worker is handled in the inlining process.
137
+ if (serviceWorker && !options.i18nOptions.shouldInline) {
139
138
  try {
140
139
  const serviceWorkerResult = await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorker, options.baseHref || '/', executionResult.outputFiles, executionResult.assetFiles);
141
- executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);
142
- executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);
140
+ executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest, bundler_context_1.BuildOutputFileType.Browser);
141
+ executionResult.addAssets(serviceWorkerResult.assetFiles);
143
142
  }
144
143
  catch (error) {
145
144
  context.logger.error(error instanceof Error ? error.message : `${error}`);
146
145
  return executionResult;
147
146
  }
148
147
  }
148
+ // Analyze files for bundle budget failures if present
149
+ let budgetFailures;
150
+ if (options.budgets) {
151
+ const compatStats = (0, budget_stats_1.generateBudgetStats)(metafile, initialFiles);
152
+ budgetFailures = [...(0, bundle_calculator_1.checkBudgets)(options.budgets, compatStats, true)];
153
+ for (const { severity, message } of budgetFailures) {
154
+ if (severity === 'error') {
155
+ context.logger.error(message);
156
+ }
157
+ else {
158
+ context.logger.warn(message);
159
+ }
160
+ }
161
+ }
149
162
  // Calculate estimated transfer size if scripts are optimized
150
163
  let estimatedTransferSizes;
151
164
  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {
152
165
  estimatedTransferSizes = await (0, utils_1.calculateEstimatedTransferSizes)(executionResult.outputFiles);
153
166
  }
154
- (0, utils_1.logBuildStats)(context, metafile, initialFiles, estimatedTransferSizes);
167
+ (0, utils_1.logBuildStats)(context, metafile, initialFiles, budgetFailures, estimatedTransferSizes);
155
168
  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;
156
169
  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);
157
170
  // Perform i18n translation inlining if enabled
158
171
  if (options.i18nOptions.shouldInline) {
159
- await (0, i18n_1.inlineI18n)(options, executionResult, initialFiles);
172
+ const { errors, warnings } = await (0, i18n_1.inlineI18n)(options, executionResult, initialFiles);
173
+ printWarningsAndErrorsToConsole(context, warnings, errors);
174
+ }
175
+ // Write metafile if stats option is enabled
176
+ if (options.stats) {
177
+ executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2), bundler_context_1.BuildOutputFileType.Root);
160
178
  }
161
179
  return executionResult;
162
180
  }
@@ -169,4 +187,4 @@ function printWarningsAndErrorsToConsole(context, warnings, errors) {
169
187
  context.logger.warn(warning);
170
188
  }
171
189
  }
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execute-build.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/execute-build.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 assert from 'node:assert';\nimport { SourceFileCache } from '../../tools/esbuild/angular/compiler-plugin';\nimport {\n  createBrowserCodeBundleOptions,\n  createServerCodeBundleOptions,\n} from '../../tools/esbuild/application-code-bundle';\nimport { BundlerContext } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { checkCommonJSModules } from '../../tools/esbuild/commonjs-checker';\nimport { createGlobalScriptsBundleOptions } from '../../tools/esbuild/global-scripts';\nimport { createGlobalStylesBundleOptions } from '../../tools/esbuild/global-styles';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { extractLicenses } from '../../tools/esbuild/license-extractor';\nimport {\n  calculateEstimatedTransferSizes,\n  logBuildStats,\n  logMessages,\n  transformSupportedBrowsersToTargets,\n} from '../../tools/esbuild/utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { prerenderPages } from '../../utils/server-rendering/prerender';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { inlineI18n, loadActiveTranslations } from './i18n';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n// eslint-disable-next-line max-lines-per-function\nexport async function executeBuild(\n  options: NormalizedApplicationBuildOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    serviceWorker,\n    optimizationOptions,\n    serverEntryPoint,\n    assets,\n    indexHtmlOptions,\n    cacheOptions,\n    prerenderOptions,\n    appShellOptions,\n    ssrOptions,\n    verbose,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Load active translations if inlining\n  // TODO: Integrate into watch mode and only load changed translations\n  if (options.i18nOptions.shouldInline) {\n    await loadActiveTranslations(context, options.i18nOptions);\n  }\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Browser application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createBrowserCodeBundleOptions(options, target, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Server application code\n    if (serverEntryPoint) {\n      bundlerContexts.push(\n        new BundlerContext(\n          workspaceRoot,\n          !!options.watch,\n          createServerCodeBundleOptions(\n            options,\n            // NOTE: earlier versions of Node.js are not supported due to unsafe promise patching.\n            // See: https://github.com/angular/angular/pull/50552#issue-1737967592\n            [...target, 'node18.13'],\n            codeBundleCache,\n          ),\n          () => false,\n        ),\n      );\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  const { metafile, initialFiles, outputFiles } = bundlingResult;\n\n  executionResult.outputFiles.push(...outputFiles);\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  /**\n   * Index HTML content without CSS inlining to be used for server rendering (AppShell, SSG and SSR).\n   *\n   * NOTE: we don't perform critical CSS inlining as this will be done during server rendering.\n   */\n  let indexContentOutputNoCssInlining: string | undefined;\n\n  // Generate index HTML file\n  // If localization is enabled, index generation is handled in the inlining process.\n  // NOTE: Localization with SSR is not currently supported.\n  if (indexHtmlOptions && !options.i18nOptions.shouldInline) {\n    const { content, contentWithoutCriticalCssInlined, errors, warnings } = await generateIndexHtml(\n      initialFiles,\n      executionResult.outputFiles,\n      {\n        ...options,\n        optimizationOptions,\n      },\n      // Set lang attribute to the defined source locale if present\n      options.i18nOptions.hasDefinedSourceLocale ? options.i18nOptions.sourceLocale : undefined,\n    );\n\n    indexContentOutputNoCssInlining = contentWithoutCriticalCssInlined;\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    executionResult.addOutputFile(indexHtmlOptions.output, content);\n\n    if (ssrOptions) {\n      executionResult.addOutputFile('index.server.html', contentWithoutCriticalCssInlined);\n    }\n  }\n\n  // Pre-render (SSG) and App-shell\n  if (prerenderOptions || appShellOptions) {\n    assert(\n      indexContentOutputNoCssInlining,\n      'The \"index\" option is required when using the \"ssg\" or \"appShell\" options.',\n    );\n\n    const { output, warnings, errors } = await prerenderPages(\n      workspaceRoot,\n      appShellOptions,\n      prerenderOptions,\n      executionResult.outputFiles,\n      indexContentOutputNoCssInlining,\n      optimizationOptions.styles.inlineCritical,\n      maxWorkers,\n      verbose,\n    );\n\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    for (const [path, content] of Object.entries(output)) {\n      executionResult.addOutputFile(path, content);\n    }\n  }\n\n  // Copy assets\n  if (assets) {\n    // The webpack copy assets helper is used with no base paths defined. This prevents the helper\n    // from directly writing to disk. This should eventually be replaced with a more optimized helper.\n    executionResult.assetFiles.push(...(await copyAssets(assets, [], workspaceRoot)));\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    executionResult.addOutputFile(\n      '3rdpartylicenses.txt',\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  if (serviceWorker) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorker,\n        options.baseHref || '/',\n        executionResult.outputFiles,\n        executionResult.assetFiles,\n      );\n      executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);\n      executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return executionResult;\n    }\n  }\n\n  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n\n  logBuildStats(context, metafile, initialFiles, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  // Perform i18n translation inlining if enabled\n  if (options.i18nOptions.shouldInline) {\n    await inlineI18n(options, executionResult, initialFiles);\n  }\n\n  return executionResult;\n}\n\nfunction printWarningsAndErrorsToConsole(\n  context: BuilderContext,\n  warnings: string[],\n  errors: string[],\n): void {\n  for (const error of errors) {\n    context.logger.error(error);\n  }\n  for (const warning of warnings) {\n    context.logger.warn(warning);\n  }\n}\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execute-build.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/execute-build.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 assert from 'node:assert';\nimport { SourceFileCache } from '../../tools/esbuild/angular/source-file-cache';\nimport {\n  createBrowserCodeBundleOptions,\n  createServerCodeBundleOptions,\n} from '../../tools/esbuild/application-code-bundle';\nimport { generateBudgetStats } from '../../tools/esbuild/budget-stats';\nimport { BuildOutputFileType, BundlerContext } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { checkCommonJSModules } from '../../tools/esbuild/commonjs-checker';\nimport { createGlobalScriptsBundleOptions } from '../../tools/esbuild/global-scripts';\nimport { createGlobalStylesBundleOptions } from '../../tools/esbuild/global-styles';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { extractLicenses } from '../../tools/esbuild/license-extractor';\nimport {\n  calculateEstimatedTransferSizes,\n  getSupportedNodeTargets,\n  logBuildStats,\n  logMessages,\n  transformSupportedBrowsersToTargets,\n} from '../../tools/esbuild/utils';\nimport { checkBudgets } from '../../utils/bundle-calculator';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { prerenderPages } from '../../utils/server-rendering/prerender';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { inlineI18n, loadActiveTranslations } from './i18n';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n// eslint-disable-next-line max-lines-per-function\nexport async function executeBuild(\n  options: NormalizedApplicationBuildOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    serviceWorker,\n    optimizationOptions,\n    serverEntryPoint,\n    assets,\n    indexHtmlOptions,\n    cacheOptions,\n    prerenderOptions,\n    appShellOptions,\n    ssrOptions,\n    verbose,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Load active translations if inlining\n  // TODO: Integrate into watch mode and only load changed translations\n  if (options.i18nOptions.shouldInline) {\n    await loadActiveTranslations(context, options.i18nOptions);\n  }\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Browser application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createBrowserCodeBundleOptions(options, target, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Server application code\n    // Skip server build when non of the features are enabled.\n    if (serverEntryPoint && (prerenderOptions || appShellOptions || ssrOptions)) {\n      const nodeTargets = getSupportedNodeTargets();\n      bundlerContexts.push(\n        new BundlerContext(\n          workspaceRoot,\n          !!options.watch,\n          createServerCodeBundleOptions(options, [...target, ...nodeTargets], codeBundleCache),\n          () => false,\n        ),\n      );\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  const { metafile, initialFiles, outputFiles } = bundlingResult;\n\n  executionResult.outputFiles.push(...outputFiles);\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  /**\n   * Index HTML content without CSS inlining to be used for server rendering (AppShell, SSG and SSR).\n   *\n   * NOTE: we don't perform critical CSS inlining as this will be done during server rendering.\n   */\n  let indexContentOutputNoCssInlining: string | undefined;\n\n  // Generate index HTML file\n  // If localization is enabled, index generation is handled in the inlining process.\n  // NOTE: Localization with SSR is not currently supported.\n  if (indexHtmlOptions && !options.i18nOptions.shouldInline) {\n    const { content, contentWithoutCriticalCssInlined, errors, warnings } = await generateIndexHtml(\n      initialFiles,\n      executionResult.outputFiles,\n      {\n        ...options,\n        optimizationOptions,\n      },\n      // Set lang attribute to the defined source locale if present\n      options.i18nOptions.hasDefinedSourceLocale ? options.i18nOptions.sourceLocale : undefined,\n    );\n\n    indexContentOutputNoCssInlining = contentWithoutCriticalCssInlined;\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    executionResult.addOutputFile(indexHtmlOptions.output, content, BuildOutputFileType.Browser);\n\n    if (ssrOptions) {\n      executionResult.addOutputFile(\n        'index.server.html',\n        contentWithoutCriticalCssInlined,\n        BuildOutputFileType.Server,\n      );\n    }\n  }\n\n  // Pre-render (SSG) and App-shell\n  // If localization is enabled, prerendering is handled in the inlining process.\n  if ((prerenderOptions || appShellOptions) && !options.i18nOptions.shouldInline) {\n    assert(\n      indexContentOutputNoCssInlining,\n      'The \"index\" option is required when using the \"ssg\" or \"appShell\" options.',\n    );\n\n    const { output, warnings, errors } = await prerenderPages(\n      workspaceRoot,\n      appShellOptions,\n      prerenderOptions,\n      executionResult.outputFiles,\n      indexContentOutputNoCssInlining,\n      optimizationOptions.styles.inlineCritical,\n      maxWorkers,\n      verbose,\n    );\n\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    for (const [path, content] of Object.entries(output)) {\n      executionResult.addOutputFile(path, content, BuildOutputFileType.Browser);\n    }\n  }\n\n  // Copy assets\n  if (assets) {\n    // The webpack copy assets helper is used with no base paths defined. This prevents the helper\n    // from directly writing to disk. This should eventually be replaced with a more optimized helper.\n    executionResult.addAssets(await copyAssets(assets, [], workspaceRoot));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    executionResult.addOutputFile(\n      '3rdpartylicenses.txt',\n      await extractLicenses(metafile, workspaceRoot),\n      BuildOutputFileType.Root,\n    );\n  }\n\n  // Augment the application with service worker support\n  // If localization is enabled, service worker is handled in the inlining process.\n  if (serviceWorker && !options.i18nOptions.shouldInline) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorker,\n        options.baseHref || '/',\n        executionResult.outputFiles,\n        executionResult.assetFiles,\n      );\n      executionResult.addOutputFile(\n        'ngsw.json',\n        serviceWorkerResult.manifest,\n        BuildOutputFileType.Browser,\n      );\n      executionResult.addAssets(serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return executionResult;\n    }\n  }\n\n  // Analyze files for bundle budget failures if present\n  let budgetFailures;\n  if (options.budgets) {\n    const compatStats = generateBudgetStats(metafile, initialFiles);\n    budgetFailures = [...checkBudgets(options.budgets, compatStats, true)];\n    for (const { severity, message } of budgetFailures) {\n      if (severity === 'error') {\n        context.logger.error(message);\n      } else {\n        context.logger.warn(message);\n      }\n    }\n  }\n\n  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n\n  logBuildStats(context, metafile, initialFiles, budgetFailures, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  // Perform i18n translation inlining if enabled\n  if (options.i18nOptions.shouldInline) {\n    const { errors, warnings } = await inlineI18n(options, executionResult, initialFiles);\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    executionResult.addOutputFile(\n      'stats.json',\n      JSON.stringify(metafile, null, 2),\n      BuildOutputFileType.Root,\n    );\n  }\n\n  return executionResult;\n}\n\nfunction printWarningsAndErrorsToConsole(\n  context: BuilderContext,\n  warnings: string[],\n  errors: string[],\n): void {\n  for (const error of errors) {\n    context.logger.error(error);\n  }\n  for (const warning of warnings) {\n    context.logger.warn(warning);\n  }\n}\n"]}
@@ -16,7 +16,10 @@ import { NormalizedApplicationBuildOptions } from './options';
16
16
  * @param executionResult The result of an executed build.
17
17
  * @param initialFiles A map containing initial file information for the executed build.
18
18
  */
19
- export declare function inlineI18n(options: NormalizedApplicationBuildOptions, executionResult: ExecutionResult, initialFiles: Map<string, InitialFileRecord>): Promise<void>;
19
+ export declare function inlineI18n(options: NormalizedApplicationBuildOptions, executionResult: ExecutionResult, initialFiles: Map<string, InitialFileRecord>): Promise<{
20
+ errors: string[];
21
+ warnings: string[];
22
+ }>;
20
23
  /**
21
24
  * Loads all active translations using the translation loaders from the `@angular/localize` package.
22
25
  * @param context The architect builder context for the current build.