@angular-devkit/build-angular 16.0.0-rc.0 → 16.0.0-rc.1

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 (34) hide show
  1. package/package.json +12 -12
  2. package/src/builders/browser-esbuild/angular/angular-compilation.d.ts +3 -1
  3. package/src/builders/browser-esbuild/angular/angular-compilation.js +16 -1
  4. package/src/builders/browser-esbuild/angular/aot-compilation.d.ts +2 -1
  5. package/src/builders/browser-esbuild/angular/aot-compilation.js +6 -3
  6. package/src/builders/browser-esbuild/angular/compiler-plugin.d.ts +3 -0
  7. package/src/builders/browser-esbuild/angular/compiler-plugin.js +53 -55
  8. package/src/builders/browser-esbuild/angular/jit-compilation.d.ts +3 -1
  9. package/src/builders/browser-esbuild/angular/jit-compilation.js +6 -3
  10. package/src/builders/browser-esbuild/angular/jit-plugin-callbacks.d.ts +2 -1
  11. package/src/builders/browser-esbuild/angular/jit-plugin-callbacks.js +3 -3
  12. package/src/builders/browser-esbuild/angular/worker-compilation.d.ts +21 -0
  13. package/src/builders/browser-esbuild/angular/worker-compilation.js +45 -0
  14. package/src/builders/browser-esbuild/angular/worker.d.ts +0 -0
  15. package/src/builders/browser-esbuild/angular/worker.js +2 -0
  16. package/src/builders/browser-esbuild/esbuild.d.ts +12 -10
  17. package/src/builders/browser-esbuild/esbuild.js +50 -8
  18. package/src/builders/browser-esbuild/index.js +31 -45
  19. package/src/builders/browser-esbuild/javascript-transformer-worker.js +8 -3
  20. package/src/builders/browser-esbuild/javascript-transformer.js +4 -2
  21. package/src/builders/browser-esbuild/load-result-cache.d.ts +18 -0
  22. package/src/builders/browser-esbuild/load-result-cache.js +51 -0
  23. package/src/builders/browser-esbuild/options.js +3 -19
  24. package/src/builders/browser-esbuild/sass-plugin.d.ts +2 -1
  25. package/src/builders/browser-esbuild/sass-plugin.js +24 -8
  26. package/src/builders/browser-esbuild/stylesheet-plugin.d.ts +0 -0
  27. package/src/builders/browser-esbuild/stylesheet-plugin.js +46 -0
  28. package/src/builders/browser-esbuild/stylesheets.d.ts +3 -2
  29. package/src/builders/browser-esbuild/stylesheets.js +5 -5
  30. package/src/builders/server/index.js +23 -2
  31. package/src/utils/tailwind.d.ts +8 -0
  32. package/src/utils/tailwind.js +35 -0
  33. package/src/webpack/configs/styles.d.ts +1 -1
  34. package/src/webpack/configs/styles.js +7 -23
@@ -0,0 +1,45 @@
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 __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
10
+ if (kind === "m") throw new TypeError("Private method is not writable");
11
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
12
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
13
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
14
+ };
15
+ var __importDefault = (this && this.__importDefault) || function (mod) {
16
+ return (mod && mod.__esModule) ? mod : { "default": mod };
17
+ };
18
+ var _WorkerCompilation_worker;
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ exports.WorkerCompilation = void 0;
21
+ const piscina_1 = __importDefault(require("piscina"));
22
+ const angular_compilation_1 = require("./angular-compilation");
23
+ class WorkerCompilation extends angular_compilation_1.AngularCompilation {
24
+ constructor() {
25
+ super();
26
+ _WorkerCompilation_worker.set(this, void 0);
27
+ __classPrivateFieldSet(this, _WorkerCompilation_worker, new piscina_1.default({
28
+ filename: require.resolve('./worker'),
29
+ maxThreads: 1,
30
+ idleTimeout: Infinity,
31
+ }), "f");
32
+ }
33
+ initialize(tsconfig, hostOptions, compilerOptionsTransformer) {
34
+ throw new Error('Method not implemented.');
35
+ }
36
+ collectDiagnostics() {
37
+ throw new Error('Method not implemented.');
38
+ }
39
+ createFileEmitter() {
40
+ throw new Error('Method not implemented.');
41
+ }
42
+ }
43
+ exports.WorkerCompilation = WorkerCompilation;
44
+ _WorkerCompilation_worker = new WeakMap();
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2VyLWNvbXBpbGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2FuZ3VsYXIvd29ya2VyLWNvbXBpbGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7Ozs7QUFHSCxzREFBOEI7QUFFOUIsK0RBQXdFO0FBR3hFLE1BQWEsaUJBQWtCLFNBQVEsd0NBQWtCO0lBR3ZEO1FBQ0UsS0FBSyxFQUFFLENBQUM7UUFIViw0Q0FBaUI7UUFLZix1QkFBQSxJQUFJLDZCQUFXLElBQUksaUJBQU8sQ0FBQztZQUN6QixRQUFRLEVBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUM7WUFDckMsVUFBVSxFQUFFLENBQUM7WUFDYixXQUFXLEVBQUUsUUFBUTtTQUN0QixDQUFDLE1BQUEsQ0FBQztJQUNMLENBQUM7SUFFUSxVQUFVLENBQ2pCLFFBQWdCLEVBQ2hCLFdBQStCLEVBQy9CLDBCQUVhO1FBRWIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFDUSxrQkFBa0I7UUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFDUSxpQkFBaUI7UUFFeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7Q0FDRjtBQTdCRCw4Q0E2QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHsgQ29tcGlsZXJPcHRpb25zIH0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXItY2xpJztcbmltcG9ydCBQaXNjaW5hIGZyb20gJ3Bpc2NpbmEnO1xuaW1wb3J0IHsgRGlhZ25vc3RpYywgU291cmNlRmlsZSB9IGZyb20gJ3R5cGVzY3JpcHQnO1xuaW1wb3J0IHsgQW5ndWxhckNvbXBpbGF0aW9uLCBGaWxlRW1pdHRlciB9IGZyb20gJy4vYW5ndWxhci1jb21waWxhdGlvbic7XG5pbXBvcnQgeyBBbmd1bGFySG9zdE9wdGlvbnMgfSBmcm9tICcuL2FuZ3VsYXItaG9zdCc7XG5cbmV4cG9ydCBjbGFzcyBXb3JrZXJDb21waWxhdGlvbiBleHRlbmRzIEFuZ3VsYXJDb21waWxhdGlvbiB7XG4gICN3b3JrZXI6IFBpc2NpbmE7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIHRoaXMuI3dvcmtlciA9IG5ldyBQaXNjaW5hKHtcbiAgICAgIGZpbGVuYW1lOiByZXF1aXJlLnJlc29sdmUoJy4vd29ya2VyJyksXG4gICAgICBtYXhUaHJlYWRzOiAxLFxuICAgICAgaWRsZVRpbWVvdXQ6IEluZmluaXR5LFxuICAgIH0pO1xuICB9XG5cbiAgb3ZlcnJpZGUgaW5pdGlhbGl6ZShcbiAgICB0c2NvbmZpZzogc3RyaW5nLFxuICAgIGhvc3RPcHRpb25zOiBBbmd1bGFySG9zdE9wdGlvbnMsXG4gICAgY29tcGlsZXJPcHRpb25zVHJhbnNmb3JtZXI/OlxuICAgICAgfCAoKGNvbXBpbGVyT3B0aW9uczogQ29tcGlsZXJPcHRpb25zKSA9PiBDb21waWxlck9wdGlvbnMpXG4gICAgICB8IHVuZGVmaW5lZCxcbiAgKTogUHJvbWlzZTx7IGFmZmVjdGVkRmlsZXM6IFJlYWRvbmx5U2V0PFNvdXJjZUZpbGU+OyBjb21waWxlck9wdGlvbnM6IENvbXBpbGVyT3B0aW9ucyB9PiB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIG92ZXJyaWRlIGNvbGxlY3REaWFnbm9zdGljcygpOiBJdGVyYWJsZTxEaWFnbm9zdGljPiB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIG92ZXJyaWRlIGNyZWF0ZUZpbGVFbWl0dGVyKFxuICApOiBGaWxlRW1pdHRlciB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2FuZ3VsYXIvd29ya2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIiXX0=
@@ -8,6 +8,16 @@
8
8
  import { BuilderContext } from '@angular-devkit/architect';
9
9
  import { BuildFailure, BuildOptions, Message, Metafile, OutputFile, PartialMessage } from 'esbuild';
10
10
  import { FileInfo } from '../../utils/index-file/augment-index-html';
11
+ export type BundleContextResult = {
12
+ errors: Message[];
13
+ warnings: Message[];
14
+ } | {
15
+ errors: undefined;
16
+ warnings: Message[];
17
+ metafile: Metafile;
18
+ outputFiles: OutputFile[];
19
+ initialFiles: FileInfo[];
20
+ };
11
21
  /**
12
22
  * Determines if an unknown value is an esbuild BuildFailure error object thrown by esbuild.
13
23
  * @param value A potential esbuild BuildFailure error object.
@@ -19,6 +29,7 @@ export declare class BundlerContext {
19
29
  private workspaceRoot;
20
30
  private incremental;
21
31
  constructor(workspaceRoot: string, incremental: boolean, options: BuildOptions);
32
+ static bundleAll(contexts: Iterable<BundlerContext>): Promise<BundleContextResult>;
22
33
  /**
23
34
  * Executes the esbuild build function and normalizes the build result in the event of a
24
35
  * build failure that results in no output being generated.
@@ -28,16 +39,7 @@ export declare class BundlerContext {
28
39
  * @returns If output files are generated, the full esbuild BuildResult; if not, the
29
40
  * warnings and errors for the attempted build.
30
41
  */
31
- bundle(): Promise<{
32
- errors: Message[];
33
- warnings: Message[];
34
- } | {
35
- errors: undefined;
36
- warnings: Message[];
37
- metafile: Metafile;
38
- outputFiles: OutputFile[];
39
- initialFiles: FileInfo[];
40
- }>;
42
+ bundle(): Promise<BundleContextResult>;
41
43
  /**
42
44
  * Disposes incremental build resources present in the context.
43
45
  *
@@ -43,6 +43,43 @@ class BundlerContext {
43
43
  write: false,
44
44
  }, "f");
45
45
  }
46
+ static async bundleAll(contexts) {
47
+ const individualResults = await Promise.all([...contexts].map((context) => context.bundle()));
48
+ // Return directly if only one result
49
+ if (individualResults.length === 1) {
50
+ return individualResults[0];
51
+ }
52
+ let errors;
53
+ const warnings = [];
54
+ const metafile = { inputs: {}, outputs: {} };
55
+ const initialFiles = [];
56
+ const outputFiles = [];
57
+ for (const result of individualResults) {
58
+ warnings.push(...result.warnings);
59
+ if (result.errors) {
60
+ errors ?? (errors = []);
61
+ errors.push(...result.errors);
62
+ continue;
63
+ }
64
+ // Combine metafiles used for the stats option as well as bundle budgets and console output
65
+ if (result.metafile) {
66
+ metafile.inputs = { ...metafile.inputs, ...result.metafile.inputs };
67
+ metafile.outputs = { ...metafile.outputs, ...result.metafile.outputs };
68
+ }
69
+ initialFiles.push(...result.initialFiles);
70
+ outputFiles.push(...result.outputFiles);
71
+ }
72
+ if (errors !== undefined) {
73
+ return { errors, warnings };
74
+ }
75
+ return {
76
+ errors,
77
+ warnings,
78
+ metafile,
79
+ initialFiles,
80
+ outputFiles,
81
+ };
82
+ }
46
83
  /**
47
84
  * Executes the esbuild build function and normalizes the build result in the event of a
48
85
  * build failure that results in no output being generated.
@@ -94,13 +131,18 @@ class BundlerContext {
94
131
  const entryPoint = result.metafile?.outputs[relativeFilePath]?.entryPoint;
95
132
  outputFile.path = relativeFilePath;
96
133
  if (entryPoint) {
97
- // An entryPoint value indicates an initial file
98
- initialFiles.push({
99
- file: outputFile.path,
100
- // The first part of the filename is the name of file (e.g., "polyfills" for "polyfills.7S5G3MDY.js")
101
- name: (0, node_path_1.basename)(outputFile.path).split('.')[0],
102
- extension: (0, node_path_1.extname)(outputFile.path),
103
- });
134
+ // The first part of the filename is the name of file (e.g., "polyfills" for "polyfills.7S5G3MDY.js")
135
+ const name = (0, node_path_1.basename)(outputFile.path).split('.', 1)[0];
136
+ // Only entrypoints with an entry in the options are initial files.
137
+ // Dynamic imports also have an entryPoint value in the meta file.
138
+ if (__classPrivateFieldGet(this, _BundlerContext_esbuildOptions, "f").entryPoints?.[name]) {
139
+ // An entryPoint value indicates an initial file
140
+ initialFiles.push({
141
+ file: outputFile.path,
142
+ name,
143
+ extension: (0, node_path_1.extname)(outputFile.path),
144
+ });
145
+ }
104
146
  }
105
147
  }
106
148
  // Return the successful build results
@@ -133,4 +175,4 @@ async function logMessages(context, { errors, warnings }) {
133
175
  }
134
176
  }
135
177
  exports.logMessages = logMessages;
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/esbuild.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;AAGH,qCAWiB;AACjB,yCAAwD;AAGxD;;;;GAIG;AACH,SAAgB,gBAAgB,CAAC,KAAc;IAC7C,OAAO,CAAC,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,QAAQ,IAAI,KAAK,IAAI,UAAU,IAAI,KAAK,CAAC;AAC1F,CAAC;AAFD,4CAEC;AAED,MAAa,cAAc;IAIzB,YAAoB,aAAqB,EAAU,WAAoB,EAAE,OAAqB;QAA1E,kBAAa,GAAb,aAAa,CAAQ;QAAU,gBAAW,GAAX,WAAW,CAAS;QAHvE,iDAAiE;QACjE,iDAAiE;QAG/D,uBAAA,IAAI,kCAAmB;YACrB,GAAG,OAAO;YACV,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,KAAK;SACb,MAAA,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,MAAM;QAUV,IAAI,MAAM,CAAC;QACX,IAAI;YACF,IAAI,uBAAA,IAAI,sCAAgB,EAAE;gBACxB,uDAAuD;gBACvD,MAAM,GAAG,MAAM,uBAAA,IAAI,sCAAgB,CAAC,OAAO,EAAE,CAAC;aAC/C;iBAAM,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC3B,mEAAmE;gBACnE,6CAA6C;gBAC7C,uBAAA,IAAI,kCAAmB,MAAM,IAAA,iBAAO,EAAC,uBAAA,IAAI,sCAAgB,CAAC,MAAA,CAAC;gBAC3D,MAAM,GAAG,MAAM,uBAAA,IAAI,sCAAgB,CAAC,OAAO,EAAE,CAAC;aAC/C;iBAAM;gBACL,qDAAqD;gBACrD,MAAM,GAAG,MAAM,IAAA,eAAK,EAAC,uBAAA,IAAI,sCAAgB,CAAC,CAAC;aAC5C;SACF;QAAC,OAAO,OAAO,EAAE;YAChB,wEAAwE;YACxE,IAAI,gBAAgB,CAAC,OAAO,CAAC,EAAE;gBAC7B,OAAO,OAAO,CAAC;aAChB;iBAAM;gBACL,MAAM,OAAO,CAAC;aACf;SACF;QAED,6CAA6C;QAC7C,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;YACxB,OAAO;gBACL,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,QAAQ,EAAE,MAAM,CAAC,QAAQ;aAC1B,CAAC;SACH;QAED,yBAAyB;QACzB,MAAM,YAAY,GAAe,EAAE,CAAC;QACpC,KAAK,MAAM,UAAU,IAAI,MAAM,CAAC,WAAW,EAAE;YAC3C,uGAAuG;YACvG,MAAM,gBAAgB,GAAG,IAAA,oBAAQ,EAAC,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;YACvE,MAAM,UAAU,GAAG,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,CAAC,EAAE,UAAU,CAAC;YAE1E,UAAU,CAAC,IAAI,GAAG,gBAAgB,CAAC;YAEnC,IAAI,UAAU,EAAE;gBACd,gDAAgD;gBAChD,YAAY,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,UAAU,CAAC,IAAI;oBACrB,qGAAqG;oBACrG,IAAI,EAAE,IAAA,oBAAQ,EAAC,UAAU,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;oBAC7C,SAAS,EAAE,IAAA,mBAAO,EAAC,UAAU,CAAC,IAAI,CAAC;iBACpC,CAAC,CAAC;aACJ;SACF;QAED,sCAAsC;QACtC,OAAO,EAAE,GAAG,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IACxD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,OAAO;QACX,IAAI;YACF,OAAO,uBAAA,IAAI,sCAAgB,EAAE,OAAO,EAAE,CAAC;SACxC;gBAAS;YACR,uBAAA,IAAI,kCAAmB,SAAS,MAAA,CAAC;SAClC;IACH,CAAC;CACF;AAlGD,wCAkGC;;AAEM,KAAK,UAAU,WAAW,CAC/B,OAAuB,EACvB,EAAE,MAAM,EAAE,QAAQ,EAA8D;IAEhF,IAAI,QAAQ,EAAE,MAAM,EAAE;QACpB,MAAM,eAAe,GAAG,MAAM,IAAA,wBAAc,EAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACzF,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KACjD;IAED,IAAI,MAAM,EAAE,MAAM,EAAE;QAClB,MAAM,aAAa,GAAG,MAAM,IAAA,wBAAc,EAAC,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACnF,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KAChD;AACH,CAAC;AAbD,kCAaC","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 {\n  BuildContext,\n  BuildFailure,\n  BuildOptions,\n  Message,\n  Metafile,\n  OutputFile,\n  PartialMessage,\n  build,\n  context,\n  formatMessages,\n} from 'esbuild';\nimport { basename, extname, relative } from 'node:path';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\n\n/**\n * Determines if an unknown value is an esbuild BuildFailure error object thrown by esbuild.\n * @param value A potential esbuild BuildFailure error object.\n * @returns `true` if the object is determined to be a BuildFailure object; otherwise, `false`.\n */\nexport function isEsBuildFailure(value: unknown): value is BuildFailure {\n  return !!value && typeof value === 'object' && 'errors' in value && 'warnings' in value;\n}\n\nexport class BundlerContext {\n  #esbuildContext?: BuildContext<{ metafile: true; write: false }>;\n  #esbuildOptions: BuildOptions & { metafile: true; write: false };\n\n  constructor(private workspaceRoot: string, private incremental: boolean, options: BuildOptions) {\n    this.#esbuildOptions = {\n      ...options,\n      metafile: true,\n      write: false,\n    };\n  }\n\n  /**\n   * Executes the esbuild build function and normalizes the build result in the event of a\n   * build failure that results in no output being generated.\n   * All builds use the `write` option with a value of `false` to allow for the output files\n   * build result array to be populated.\n   *\n   * @returns If output files are generated, the full esbuild BuildResult; if not, the\n   * warnings and errors for the attempted build.\n   */\n  async bundle(): Promise<\n    | { errors: Message[]; warnings: Message[] }\n    | {\n        errors: undefined;\n        warnings: Message[];\n        metafile: Metafile;\n        outputFiles: OutputFile[];\n        initialFiles: FileInfo[];\n      }\n  > {\n    let result;\n    try {\n      if (this.#esbuildContext) {\n        // Rebuild using the existing incremental build context\n        result = await this.#esbuildContext.rebuild();\n      } else if (this.incremental) {\n        // Create an incremental build context and perform the first build.\n        // Context creation does not perform a build.\n        this.#esbuildContext = await context(this.#esbuildOptions);\n        result = await this.#esbuildContext.rebuild();\n      } else {\n        // For non-incremental builds, perform a single build\n        result = await build(this.#esbuildOptions);\n      }\n    } catch (failure) {\n      // Build failures will throw an exception which contains errors/warnings\n      if (isEsBuildFailure(failure)) {\n        return failure;\n      } else {\n        throw failure;\n      }\n    }\n\n    // Return if the build encountered any errors\n    if (result.errors.length) {\n      return {\n        errors: result.errors,\n        warnings: result.warnings,\n      };\n    }\n\n    // Find all initial files\n    const initialFiles: FileInfo[] = [];\n    for (const outputFile of result.outputFiles) {\n      // Entries in the metafile are relative to the `absWorkingDir` option which is set to the workspaceRoot\n      const relativeFilePath = relative(this.workspaceRoot, outputFile.path);\n      const entryPoint = result.metafile?.outputs[relativeFilePath]?.entryPoint;\n\n      outputFile.path = relativeFilePath;\n\n      if (entryPoint) {\n        // An entryPoint value indicates an initial file\n        initialFiles.push({\n          file: outputFile.path,\n          // The first part of the filename is the name of file (e.g., \"polyfills\" for \"polyfills.7S5G3MDY.js\")\n          name: basename(outputFile.path).split('.')[0],\n          extension: extname(outputFile.path),\n        });\n      }\n    }\n\n    // Return the successful build results\n    return { ...result, initialFiles, errors: undefined };\n  }\n\n  /**\n   * Disposes incremental build resources present in the context.\n   *\n   * @returns A promise that resolves when disposal is complete.\n   */\n  async dispose(): Promise<void> {\n    try {\n      return this.#esbuildContext?.dispose();\n    } finally {\n      this.#esbuildContext = undefined;\n    }\n  }\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"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/esbuild.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 {\n  BuildContext,\n  BuildFailure,\n  BuildOptions,\n  Message,\n  Metafile,\n  OutputFile,\n  PartialMessage,\n  build,\n  context,\n  formatMessages,\n} from 'esbuild';\nimport { basename, extname, relative } from 'node:path';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\n\nexport type BundleContextResult =\n  | { errors: Message[]; warnings: Message[] }\n  | {\n      errors: undefined;\n      warnings: Message[];\n      metafile: Metafile;\n      outputFiles: OutputFile[];\n      initialFiles: FileInfo[];\n    };\n\n/**\n * Determines if an unknown value is an esbuild BuildFailure error object thrown by esbuild.\n * @param value A potential esbuild BuildFailure error object.\n * @returns `true` if the object is determined to be a BuildFailure object; otherwise, `false`.\n */\nexport function isEsBuildFailure(value: unknown): value is BuildFailure {\n  return !!value && typeof value === 'object' && 'errors' in value && 'warnings' in value;\n}\n\nexport class BundlerContext {\n  #esbuildContext?: BuildContext<{ metafile: true; write: false }>;\n  #esbuildOptions: BuildOptions & { metafile: true; write: false };\n\n  constructor(private workspaceRoot: string, private incremental: boolean, options: BuildOptions) {\n    this.#esbuildOptions = {\n      ...options,\n      metafile: true,\n      write: false,\n    };\n  }\n\n  static async bundleAll(contexts: Iterable<BundlerContext>): Promise<BundleContextResult> {\n    const individualResults = await Promise.all([...contexts].map((context) => context.bundle()));\n\n    // Return directly if only one result\n    if (individualResults.length === 1) {\n      return individualResults[0];\n    }\n\n    let errors: Message[] | undefined;\n    const warnings: Message[] = [];\n    const metafile: Metafile = { inputs: {}, outputs: {} };\n    const initialFiles = [];\n    const outputFiles = [];\n    for (const result of individualResults) {\n      warnings.push(...result.warnings);\n      if (result.errors) {\n        errors ??= [];\n        errors.push(...result.errors);\n        continue;\n      }\n\n      // Combine metafiles used for the stats option as well as bundle budgets and console output\n      if (result.metafile) {\n        metafile.inputs = { ...metafile.inputs, ...result.metafile.inputs };\n        metafile.outputs = { ...metafile.outputs, ...result.metafile.outputs };\n      }\n\n      initialFiles.push(...result.initialFiles);\n      outputFiles.push(...result.outputFiles);\n    }\n\n    if (errors !== undefined) {\n      return { errors, warnings };\n    }\n\n    return {\n      errors,\n      warnings,\n      metafile,\n      initialFiles,\n      outputFiles,\n    };\n  }\n\n  /**\n   * Executes the esbuild build function and normalizes the build result in the event of a\n   * build failure that results in no output being generated.\n   * All builds use the `write` option with a value of `false` to allow for the output files\n   * build result array to be populated.\n   *\n   * @returns If output files are generated, the full esbuild BuildResult; if not, the\n   * warnings and errors for the attempted build.\n   */\n  async bundle(): Promise<BundleContextResult> {\n    let result;\n    try {\n      if (this.#esbuildContext) {\n        // Rebuild using the existing incremental build context\n        result = await this.#esbuildContext.rebuild();\n      } else if (this.incremental) {\n        // Create an incremental build context and perform the first build.\n        // Context creation does not perform a build.\n        this.#esbuildContext = await context(this.#esbuildOptions);\n        result = await this.#esbuildContext.rebuild();\n      } else {\n        // For non-incremental builds, perform a single build\n        result = await build(this.#esbuildOptions);\n      }\n    } catch (failure) {\n      // Build failures will throw an exception which contains errors/warnings\n      if (isEsBuildFailure(failure)) {\n        return failure;\n      } else {\n        throw failure;\n      }\n    }\n\n    // Return if the build encountered any errors\n    if (result.errors.length) {\n      return {\n        errors: result.errors,\n        warnings: result.warnings,\n      };\n    }\n\n    // Find all initial files\n    const initialFiles: FileInfo[] = [];\n    for (const outputFile of result.outputFiles) {\n      // Entries in the metafile are relative to the `absWorkingDir` option which is set to the workspaceRoot\n      const relativeFilePath = relative(this.workspaceRoot, outputFile.path);\n      const entryPoint = result.metafile?.outputs[relativeFilePath]?.entryPoint;\n\n      outputFile.path = relativeFilePath;\n\n      if (entryPoint) {\n        // The first part of the filename is the name of file (e.g., \"polyfills\" for \"polyfills.7S5G3MDY.js\")\n        const name = basename(outputFile.path).split('.', 1)[0];\n\n        // Only entrypoints with an entry in the options are initial files.\n        // Dynamic imports also have an entryPoint value in the meta file.\n        if ((this.#esbuildOptions.entryPoints as Record<string, string>)?.[name]) {\n          // An entryPoint value indicates an initial file\n          initialFiles.push({\n            file: outputFile.path,\n            name,\n            extension: extname(outputFile.path),\n          });\n        }\n      }\n    }\n\n    // Return the successful build results\n    return { ...result, initialFiles, errors: undefined };\n  }\n\n  /**\n   * Disposes incremental build resources present in the context.\n   *\n   * @returns A promise that resolves when disposal is complete.\n   */\n  async dispose(): Promise<void> {\n    try {\n      return this.#esbuildContext?.dispose();\n    } finally {\n      this.#esbuildContext = undefined;\n    }\n  }\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"]}
@@ -101,57 +101,42 @@ async function execute(options, context, rebuildState) {
101
101
  const browsers = (0, supported_browsers_1.getSupportedBrowsers)(projectRoot, context.logger);
102
102
  const target = (0, esbuild_targets_1.transformSupportedBrowsersToTargets)(browsers);
103
103
  // Reuse rebuild state or create new bundle contexts for code and global stylesheets
104
+ const bundlerContexts = [];
105
+ // Application code
104
106
  const codeBundleCache = options.watch
105
107
  ? rebuildState?.codeBundleCache ?? new compiler_plugin_1.SourceFileCache()
106
108
  : undefined;
107
109
  const codeBundleContext = rebuildState?.codeRebuild ??
108
110
  new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createCodeBundleOptions(options, target, browsers, codeBundleCache));
109
- const globalStylesBundleContext = rebuildState?.globalStylesRebuild ??
110
- new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createGlobalStylesBundleOptions(options, target, browsers));
111
- const globalScriptsBundleContext = new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, (0, global_scripts_1.createGlobalScriptsBundleOptions)(options));
112
- const [codeResults, styleResults, scriptResults] = await Promise.all([
113
- // Execute esbuild to bundle the application code
114
- codeBundleContext.bundle(),
115
- // Execute esbuild to bundle the global stylesheets
116
- globalStylesBundleContext.bundle(),
117
- globalScriptsBundleContext.bundle(),
118
- ]);
111
+ bundlerContexts.push(codeBundleContext);
112
+ // Global Stylesheets
113
+ let globalStylesBundleContext;
114
+ if (options.globalStyles.length > 0) {
115
+ globalStylesBundleContext =
116
+ rebuildState?.globalStylesRebuild ??
117
+ new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createGlobalStylesBundleOptions(options, target, browsers, codeBundleCache?.loadResultCache));
118
+ bundlerContexts.push(globalStylesBundleContext);
119
+ }
120
+ // Global Scripts
121
+ if (options.globalScripts.length > 0) {
122
+ const globalScriptsBundleContext = new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, (0, global_scripts_1.createGlobalScriptsBundleOptions)(options));
123
+ bundlerContexts.push(globalScriptsBundleContext);
124
+ }
125
+ const bundlingResult = await esbuild_1.BundlerContext.bundleAll(bundlerContexts);
119
126
  // Log all warnings and errors generated during bundling
120
- await (0, esbuild_1.logMessages)(context, {
121
- errors: [
122
- ...(codeResults.errors || []),
123
- ...(styleResults.errors || []),
124
- ...(scriptResults.errors || []),
125
- ],
126
- warnings: [...codeResults.warnings, ...styleResults.warnings, ...scriptResults.warnings],
127
- });
127
+ await (0, esbuild_1.logMessages)(context, bundlingResult);
128
128
  const executionResult = new ExecutionResult(codeBundleContext, globalStylesBundleContext, codeBundleCache);
129
129
  // Return if the bundling has errors
130
- if (codeResults.errors || styleResults.errors || scriptResults.errors) {
130
+ if (bundlingResult.errors) {
131
131
  return executionResult;
132
132
  }
133
- // Filter global stylesheet initial files
134
- styleResults.initialFiles = styleResults.initialFiles.filter(({ name }) => options.globalStyles.find((style) => style.name === name)?.initial);
135
- // Combine the bundling output files
136
- const initialFiles = [
137
- ...codeResults.initialFiles,
138
- ...styleResults.initialFiles,
139
- ...scriptResults.initialFiles,
140
- ];
141
- executionResult.outputFiles.push(...codeResults.outputFiles, ...styleResults.outputFiles, ...scriptResults.outputFiles);
142
- // Combine metafiles used for the stats option as well as bundle budgets and console output
143
- const metafile = {
144
- inputs: {
145
- ...codeResults.metafile?.inputs,
146
- ...styleResults.metafile?.inputs,
147
- ...scriptResults.metafile?.inputs,
148
- },
149
- outputs: {
150
- ...codeResults.metafile?.outputs,
151
- ...styleResults.metafile?.outputs,
152
- ...scriptResults.metafile?.outputs,
153
- },
154
- };
133
+ // Filter global stylesheet initial files. Currently all initial CSS files are from the global styles option.
134
+ if (options.globalStyles.length > 0) {
135
+ bundlingResult.initialFiles = bundlingResult.initialFiles.filter(({ file, name }) => !file.endsWith('.css') ||
136
+ options.globalStyles.find((style) => style.name === name)?.initial);
137
+ }
138
+ const { metafile, initialFiles, outputFiles } = bundlingResult;
139
+ executionResult.outputFiles.push(...outputFiles);
155
140
  // Check metafile for CommonJS module usage if optimizing scripts
156
141
  if (optimizationOptions.scripts) {
157
142
  const messages = (0, commonjs_checker_1.checkCommonJSModules)(metafile, options.allowedCommonJsDependencies);
@@ -295,6 +280,7 @@ function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
295
280
  advancedOptimizations,
296
281
  fileReplacements,
297
282
  sourceFileCache,
283
+ loadResultCache: sourceFileCache?.loadResultCache,
298
284
  },
299
285
  // Component stylesheet options
300
286
  {
@@ -402,7 +388,7 @@ function getFeatureSupport(target) {
402
388
  }
403
389
  return supported;
404
390
  }
405
- function createGlobalStylesBundleOptions(options, target, browsers) {
391
+ function createGlobalStylesBundleOptions(options, target, browsers, cache) {
406
392
  const { workspaceRoot, optimizationOptions, sourcemapOptions, outputNames, globalStyles, preserveSymlinks, externalDependencies, stylePreprocessorOptions, tailwindConfiguration, } = options;
407
393
  const buildOptions = (0, stylesheets_1.createStylesheetBundleOptions)({
408
394
  workspaceRoot,
@@ -415,7 +401,7 @@ function createGlobalStylesBundleOptions(options, target, browsers) {
415
401
  includePaths: stylePreprocessorOptions?.includePaths,
416
402
  browsers,
417
403
  tailwindConfiguration,
418
- });
404
+ }, cache);
419
405
  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';
420
406
  const namespace = 'angular:styles/global';
421
407
  buildOptions.entryPoints = {};
@@ -603,10 +589,10 @@ function logBuildStats(context, metafile, initialFiles) {
603
589
  }
604
590
  stats.push({
605
591
  initial: initial.has(file),
606
- stats: [file, initial.get(file) ?? '', output.bytes, ''],
592
+ stats: [file, initial.get(file) ?? '-', output.bytes, ''],
607
593
  });
608
594
  }
609
595
  const tableText = (0, stats_1.generateBuildStatsTable)(stats, true, true, false, undefined);
610
596
  context.logger.info('\n' + tableText + '\n');
611
597
  }
612
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.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, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildOptions, Metafile, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { Spinner } from '../../utils/spinner';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { BundleStats, generateBuildStatsTable } from '../../webpack/utils/stats';\nimport { SourceFileCache, createCompilerPlugin } from './angular/compiler-plugin';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { createGlobalScriptsBundleOptions } from './global-scripts';\nimport { extractLicenses } from './license-extractor';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport type { ChangedFiles } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BundlerContext;\n  globalStylesRebuild?: BundlerContext;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  readonly outputFiles: OutputFile[] = [];\n  readonly assetFiles: { source: string; destination: string }[] = [];\n\n  constructor(\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  addOutputFile(path: string, content: string): void {\n    this.outputFiles.push(createOutputFileFromText(path, content));\n  }\n\n  get output() {\n    return {\n      success: this.outputFiles.length > 0,\n    };\n  }\n\n  get outputWithFiles() {\n    return {\n      success: this.outputFiles.length > 0,\n      outputFiles: this.outputFiles,\n      assetFiles: this.assetFiles,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.allSettled([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n  const codeBundleContext =\n    rebuildState?.codeRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createCodeBundleOptions(options, target, browsers, codeBundleCache),\n    );\n  const globalStylesBundleContext =\n    rebuildState?.globalStylesRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalStylesBundleOptions(options, target, browsers),\n    );\n\n  const globalScriptsBundleContext = new BundlerContext(\n    workspaceRoot,\n    !!options.watch,\n    createGlobalScriptsBundleOptions(options),\n  );\n\n  const [codeResults, styleResults, scriptResults] = await Promise.all([\n    // Execute esbuild to bundle the application code\n    codeBundleContext.bundle(),\n    // Execute esbuild to bundle the global stylesheets\n    globalStylesBundleContext.bundle(),\n    globalScriptsBundleContext.bundle(),\n  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [\n      ...(codeResults.errors || []),\n      ...(styleResults.errors || []),\n      ...(scriptResults.errors || []),\n    ],\n    warnings: [...codeResults.warnings, ...styleResults.warnings, ...scriptResults.warnings],\n  });\n\n  const executionResult = new ExecutionResult(\n    codeBundleContext,\n    globalStylesBundleContext,\n    codeBundleCache,\n  );\n\n  // Return if the bundling has errors\n  if (codeResults.errors || styleResults.errors || scriptResults.errors) {\n    return executionResult;\n  }\n\n  // Filter global stylesheet initial files\n  styleResults.initialFiles = styleResults.initialFiles.filter(\n    ({ name }) => options.globalStyles.find((style) => style.name === name)?.initial,\n  );\n\n  // Combine the bundling output files\n  const initialFiles: FileInfo[] = [\n    ...codeResults.initialFiles,\n    ...styleResults.initialFiles,\n    ...scriptResults.initialFiles,\n  ];\n  executionResult.outputFiles.push(\n    ...codeResults.outputFiles,\n    ...styleResults.outputFiles,\n    ...scriptResults.outputFiles,\n  );\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: {\n      ...codeResults.metafile?.inputs,\n      ...styleResults.metafile?.inputs,\n      ...scriptResults.metafile?.inputs,\n    },\n    outputs: {\n      ...codeResults.metafile?.outputs,\n      ...styleResults.metafile?.outputs,\n      ...scriptResults.metafile?.outputs,\n    },\n  };\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  // Generate index HTML file\n  if (indexHtmlOptions) {\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: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.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: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\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    executionResult.addOutputFile(indexHtmlOptions.output, content);\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 (serviceWorkerOptions) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\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  logBuildStats(context, metafile, initialFiles);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return executionResult;\n}\n\nasync 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\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    polyfills,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n    jit,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions: BuildOptions = {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    legalComments: options.extractLicenses ? 'none' : 'eof',\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          jit,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n          browsers,\n          tailwindConfiguration,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      'ngJitMode': jit ? 'true' : 'false',\n    },\n  };\n\n  if (polyfills?.length) {\n    const namespace = 'angular:polyfills';\n    buildOptions.entryPoints = {\n      ...buildOptions.entryPoints,\n      ['polyfills']: namespace,\n    };\n\n    buildOptions.plugins?.unshift({\n      name: 'angular-polyfills',\n      setup(build) {\n        build.onResolve({ filter: /^angular:polyfills$/ }, (args) => {\n          if (args.kind !== 'entry-point') {\n            return null;\n          }\n\n          return {\n            path: 'entry',\n            namespace,\n          };\n        });\n        build.onLoad({ filter: /./, namespace }, () => {\n          return {\n            contents: polyfills.map((file) => `import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n            loader: 'js',\n            resolveDir: workspaceRoot,\n          };\n        });\n      },\n    });\n  }\n\n  return buildOptions;\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 */\nfunction 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 and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\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\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions({\n    workspaceRoot,\n    optimization: !!optimizationOptions.styles.minify,\n    sourcemap: !!sourcemapOptions.styles,\n    preserveSymlinks,\n    target,\n    externalDependencies,\n    outputNames,\n    includePaths: stylePreprocessorOptions?.includePaths,\n    browsers,\n    tailwindConfiguration,\n  });\n  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\nasync 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\nasync function withNoProgress<T>(test: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param userOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  userOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n  infrastructureSettings?: {\n    write?: boolean;\n  },\n): AsyncIterable<\n  BuilderOutput & {\n    outputFiles?: OutputFile[];\n    assetFiles?: { source: string; destination: string }[];\n  }\n> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(userOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, userOptions);\n  // Writing the result to the filesystem is the default behavior\n  const shouldWriteResult = infrastructureSettings?.write !== false;\n\n  if (shouldWriteResult) {\n    // Clean output path if enabled\n    if (userOptions.deleteOutputPath) {\n      if (normalizedOptions.outputPath === normalizedOptions.workspaceRoot) {\n        context.logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(normalizedOptions.outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      context.logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = normalizedOptions.progress\n    ? withSpinner\n    : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => execute(normalizedOptions, context));\n\n    if (shouldWriteResult) {\n      // Write output files\n      await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.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 (!userOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!userOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  if (normalizedOptions.progress) {\n    context.logger.info('Watch mode enabled. Watching for file changes...');\n  }\n\n  // Setup a watcher\n  const { createWatcher } = await import('./watcher');\n  const watcher = createWatcher({\n    polling: typeof userOptions.poll === 'number',\n    interval: userOptions.poll,\n    ignored: [\n      // Ignore the output and cache paths to avoid infinite rebuild cycles\n      normalizedOptions.outputPath,\n      normalizedOptions.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  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.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  watcher.add(packageWatchFiles.map((file) => path.join(normalizedOptions.workspaceRoot, file)));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (userOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        execute(normalizedOptions, context, result.createRebuildState(changes)),\n      );\n\n      if (shouldWriteResult) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.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\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    await result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n\nfunction logBuildStats(context: BuilderContext, metafile: Metafile, initialFiles: FileInfo[]) {\n  const initial = new Map(initialFiles.map((info) => [info.file, info.name]));\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: [file, initial.get(file) ?? '', output.bytes, ''],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, false, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n"]}
598
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.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, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildOptions, Metafile, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { Spinner } from '../../utils/spinner';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { BundleStats, generateBuildStatsTable } from '../../webpack/utils/stats';\nimport { SourceFileCache, createCompilerPlugin } from './angular/compiler-plugin';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { createGlobalScriptsBundleOptions } from './global-scripts';\nimport { extractLicenses } from './license-extractor';\nimport { LoadResultCache } from './load-result-cache';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport type { ChangedFiles } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BundlerContext;\n  globalStylesRebuild?: BundlerContext;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  readonly outputFiles: OutputFile[] = [];\n  readonly assetFiles: { source: string; destination: string }[] = [];\n\n  constructor(\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  addOutputFile(path: string, content: string): void {\n    this.outputFiles.push(createOutputFileFromText(path, content));\n  }\n\n  get output() {\n    return {\n      success: this.outputFiles.length > 0,\n    };\n  }\n\n  get outputWithFiles() {\n    return {\n      success: this.outputFiles.length > 0,\n      outputFiles: this.outputFiles,\n      assetFiles: this.assetFiles,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.allSettled([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  const bundlerContexts = [];\n\n  // Application code\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n  const codeBundleContext =\n    rebuildState?.codeRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createCodeBundleOptions(options, target, browsers, codeBundleCache),\n    );\n  bundlerContexts.push(codeBundleContext);\n  // Global Stylesheets\n  let globalStylesBundleContext;\n  if (options.globalStyles.length > 0) {\n    globalStylesBundleContext =\n      rebuildState?.globalStylesRebuild ??\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createGlobalStylesBundleOptions(\n          options,\n          target,\n          browsers,\n          codeBundleCache?.loadResultCache,\n        ),\n      );\n    bundlerContexts.push(globalStylesBundleContext);\n  }\n  // Global Scripts\n  if (options.globalScripts.length > 0) {\n    const globalScriptsBundleContext = new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalScriptsBundleOptions(options),\n    );\n    bundlerContexts.push(globalScriptsBundleContext);\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(\n    codeBundleContext,\n    globalStylesBundleContext,\n    codeBundleCache,\n  );\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  // Filter global stylesheet initial files. Currently all initial CSS files are from the global styles option.\n  if (options.globalStyles.length > 0) {\n    bundlingResult.initialFiles = bundlingResult.initialFiles.filter(\n      ({ file, name }) =>\n        !file.endsWith('.css') ||\n        options.globalStyles.find((style) => style.name === name)?.initial,\n    );\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  // Generate index HTML file\n  if (indexHtmlOptions) {\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: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.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: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\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    executionResult.addOutputFile(indexHtmlOptions.output, content);\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 (serviceWorkerOptions) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\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  logBuildStats(context, metafile, initialFiles);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return executionResult;\n}\n\nasync 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\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    polyfills,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n    jit,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions: BuildOptions = {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    legalComments: options.extractLicenses ? 'none' : 'eof',\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          jit,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n          loadResultCache: sourceFileCache?.loadResultCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n          browsers,\n          tailwindConfiguration,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      'ngJitMode': jit ? 'true' : 'false',\n    },\n  };\n\n  if (polyfills?.length) {\n    const namespace = 'angular:polyfills';\n    buildOptions.entryPoints = {\n      ...buildOptions.entryPoints,\n      ['polyfills']: namespace,\n    };\n\n    buildOptions.plugins?.unshift({\n      name: 'angular-polyfills',\n      setup(build) {\n        build.onResolve({ filter: /^angular:polyfills$/ }, (args) => {\n          if (args.kind !== 'entry-point') {\n            return null;\n          }\n\n          return {\n            path: 'entry',\n            namespace,\n          };\n        });\n        build.onLoad({ filter: /./, namespace }, () => {\n          return {\n            contents: polyfills.map((file) => `import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n            loader: 'js',\n            resolveDir: workspaceRoot,\n          };\n        });\n      },\n    });\n  }\n\n  return buildOptions;\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 */\nfunction 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 and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\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\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n  cache?: LoadResultCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions(\n    {\n      workspaceRoot,\n      optimization: !!optimizationOptions.styles.minify,\n      sourcemap: !!sourcemapOptions.styles,\n      preserveSymlinks,\n      target,\n      externalDependencies,\n      outputNames,\n      includePaths: stylePreprocessorOptions?.includePaths,\n      browsers,\n      tailwindConfiguration,\n    },\n    cache,\n  );\n  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\nasync 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\nasync function withNoProgress<T>(test: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param userOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  userOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n  infrastructureSettings?: {\n    write?: boolean;\n  },\n): AsyncIterable<\n  BuilderOutput & {\n    outputFiles?: OutputFile[];\n    assetFiles?: { source: string; destination: string }[];\n  }\n> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(userOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, userOptions);\n  // Writing the result to the filesystem is the default behavior\n  const shouldWriteResult = infrastructureSettings?.write !== false;\n\n  if (shouldWriteResult) {\n    // Clean output path if enabled\n    if (userOptions.deleteOutputPath) {\n      if (normalizedOptions.outputPath === normalizedOptions.workspaceRoot) {\n        context.logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(normalizedOptions.outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      context.logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = normalizedOptions.progress\n    ? withSpinner\n    : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => execute(normalizedOptions, context));\n\n    if (shouldWriteResult) {\n      // Write output files\n      await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.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 (!userOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!userOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  if (normalizedOptions.progress) {\n    context.logger.info('Watch mode enabled. Watching for file changes...');\n  }\n\n  // Setup a watcher\n  const { createWatcher } = await import('./watcher');\n  const watcher = createWatcher({\n    polling: typeof userOptions.poll === 'number',\n    interval: userOptions.poll,\n    ignored: [\n      // Ignore the output and cache paths to avoid infinite rebuild cycles\n      normalizedOptions.outputPath,\n      normalizedOptions.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  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.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  watcher.add(packageWatchFiles.map((file) => path.join(normalizedOptions.workspaceRoot, file)));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (userOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        execute(normalizedOptions, context, result.createRebuildState(changes)),\n      );\n\n      if (shouldWriteResult) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.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\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    await result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n\nfunction logBuildStats(context: BuilderContext, metafile: Metafile, initialFiles: FileInfo[]) {\n  const initial = new Map(initialFiles.map((info) => [info.file, info.name]));\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: [file, initial.get(file) ?? '-', output.bytes, ''],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, false, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n"]}