@angular-devkit/build-angular 16.0.0-next.3 → 16.0.0-next.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +20 -20
- package/src/babel/plugins/adjust-static-class-members.js +2 -2
- package/src/builders/app-shell/render-worker.js +20 -12
- package/src/builders/browser-esbuild/css-plugin.d.ts +39 -0
- package/src/builders/browser-esbuild/css-plugin.js +164 -0
- package/src/builders/browser-esbuild/index.js +61 -46
- package/src/builders/browser-esbuild/options.d.ts +4 -0
- package/src/builders/browser-esbuild/options.js +50 -34
- package/src/builders/browser-esbuild/stylesheets.d.ts +5 -0
- package/src/builders/browser-esbuild/stylesheets.js +14 -27
- package/src/builders/server/platform-server-exports-loader.js +2 -2
- package/src/utils/copy-assets.d.ts +4 -1
- package/src/utils/copy-assets.js +4 -1
- package/src/utils/index-file/index-html-generator.js +13 -2
- package/src/utils/index-file/style-nonce.d.ts +12 -0
- package/src/utils/index-file/style-nonce.js +54 -0
- package/src/utils/service-worker.d.ts +20 -4
- package/src/utils/service-worker.js +63 -30
- package/src/webpack/configs/common.js +8 -1
|
@@ -6,29 +6,6 @@
|
|
|
6
6
|
* Use of this source code is governed by an MIT-style license that can be
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
12
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
13
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
14
|
-
}
|
|
15
|
-
Object.defineProperty(o, k2, desc);
|
|
16
|
-
}) : (function(o, m, k, k2) {
|
|
17
|
-
if (k2 === undefined) k2 = k;
|
|
18
|
-
o[k2] = m[k];
|
|
19
|
-
}));
|
|
20
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
-
}) : function(o, v) {
|
|
23
|
-
o["default"] = v;
|
|
24
|
-
});
|
|
25
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
-
if (mod && mod.__esModule) return mod;
|
|
27
|
-
var result = {};
|
|
28
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
-
__setModuleDefault(result, mod);
|
|
30
|
-
return result;
|
|
31
|
-
};
|
|
32
9
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
10
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
11
|
};
|
|
@@ -36,8 +13,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
13
|
exports.buildEsbuildBrowser = void 0;
|
|
37
14
|
const architect_1 = require("@angular-devkit/architect");
|
|
38
15
|
const node_assert_1 = __importDefault(require("node:assert"));
|
|
39
|
-
const
|
|
40
|
-
const
|
|
16
|
+
const node_fs_1 = require("node:fs");
|
|
17
|
+
const promises_1 = __importDefault(require("node:fs/promises"));
|
|
18
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
41
19
|
const utils_1 = require("../../utils");
|
|
42
20
|
const copy_assets_1 = require("../../utils/copy-assets");
|
|
43
21
|
const error_1 = require("../../utils/error");
|
|
@@ -85,15 +63,16 @@ class ExecutionResult {
|
|
|
85
63
|
async function execute(options, context, rebuildState) {
|
|
86
64
|
const startTime = process.hrtime.bigint();
|
|
87
65
|
const { projectRoot, workspaceRoot, optimizationOptions, outputPath, assets, serviceWorkerOptions, indexHtmlOptions, } = options;
|
|
88
|
-
const
|
|
66
|
+
const browsers = (0, supported_browsers_1.getSupportedBrowsers)(projectRoot, context.logger);
|
|
67
|
+
const target = (0, esbuild_targets_1.transformSupportedBrowsersToTargets)(browsers);
|
|
89
68
|
// Reuse rebuild state or create new bundle contexts for code and global stylesheets
|
|
90
69
|
const codeBundleCache = options.watch
|
|
91
70
|
? rebuildState?.codeBundleCache ?? new compiler_plugin_1.SourceFileCache()
|
|
92
71
|
: undefined;
|
|
93
72
|
const codeBundleContext = rebuildState?.codeRebuild ??
|
|
94
|
-
new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createCodeBundleOptions(options, target, codeBundleCache));
|
|
73
|
+
new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createCodeBundleOptions(options, target, browsers, codeBundleCache));
|
|
95
74
|
const globalStylesBundleContext = rebuildState?.globalStylesRebuild ??
|
|
96
|
-
new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createGlobalStylesBundleOptions(options, target));
|
|
75
|
+
new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createGlobalStylesBundleOptions(options, target, browsers));
|
|
97
76
|
const [codeResults, styleResults] = await Promise.all([
|
|
98
77
|
// Execute esbuild to bundle the application code
|
|
99
78
|
codeBundleContext.bundle(),
|
|
@@ -142,12 +121,12 @@ async function execute(options, context, rebuildState) {
|
|
|
142
121
|
const virtualOutputPath = '/';
|
|
143
122
|
indexHtmlGenerator.readAsset = async function (filePath) {
|
|
144
123
|
// Remove leading directory separator
|
|
145
|
-
const relativefilePath =
|
|
124
|
+
const relativefilePath = node_path_1.default.relative(virtualOutputPath, filePath);
|
|
146
125
|
const file = outputFiles.find((file) => file.path === relativefilePath);
|
|
147
126
|
if (file) {
|
|
148
127
|
return file.text;
|
|
149
128
|
}
|
|
150
|
-
throw new Error(`Output file does not exist: ${
|
|
129
|
+
throw new Error(`Output file does not exist: ${node_path_1.default}`);
|
|
151
130
|
};
|
|
152
131
|
const { content, warnings, errors } = await indexHtmlGenerator.process({
|
|
153
132
|
baseHref: options.baseHref,
|
|
@@ -164,34 +143,66 @@ async function execute(options, context, rebuildState) {
|
|
|
164
143
|
outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));
|
|
165
144
|
}
|
|
166
145
|
// Copy assets
|
|
146
|
+
let assetFiles;
|
|
167
147
|
if (assets) {
|
|
168
|
-
|
|
148
|
+
// The webpack copy assets helper is used with no base paths defined. This prevents the helper
|
|
149
|
+
// from directly writing to disk. This should eventually be replaced with a more optimized helper.
|
|
150
|
+
assetFiles = await (0, copy_assets_1.copyAssets)(assets, [], workspaceRoot);
|
|
169
151
|
}
|
|
170
|
-
// Write output files
|
|
171
|
-
await Promise.all(outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)));
|
|
172
152
|
// Write metafile if stats option is enabled
|
|
173
153
|
if (options.stats) {
|
|
174
|
-
|
|
154
|
+
outputFiles.push(createOutputFileFromText('stats.json', JSON.stringify(metafile, null, 2)));
|
|
175
155
|
}
|
|
176
156
|
// Extract and write licenses for used packages
|
|
177
157
|
if (options.extractLicenses) {
|
|
178
|
-
|
|
158
|
+
outputFiles.push(createOutputFileFromText('3rdpartylicenses.txt', await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot)));
|
|
179
159
|
}
|
|
180
160
|
// Augment the application with service worker support
|
|
181
|
-
// TODO: This should eventually operate on the in-memory files prior to writing the output files
|
|
182
161
|
if (serviceWorkerOptions) {
|
|
183
162
|
try {
|
|
184
|
-
await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorkerOptions,
|
|
163
|
+
const serviceWorkerResult = await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorkerOptions, options.baseHref || '/', outputFiles, assetFiles || []);
|
|
164
|
+
outputFiles.push(createOutputFileFromText('ngsw.json', serviceWorkerResult.manifest));
|
|
165
|
+
assetFiles ?? (assetFiles = []);
|
|
166
|
+
assetFiles.push(...serviceWorkerResult.assetFiles);
|
|
185
167
|
}
|
|
186
168
|
catch (error) {
|
|
187
169
|
context.logger.error(error instanceof Error ? error.message : `${error}`);
|
|
188
170
|
return new ExecutionResult(false, codeBundleContext, globalStylesBundleContext, codeBundleCache);
|
|
189
171
|
}
|
|
190
172
|
}
|
|
173
|
+
// Write output files
|
|
174
|
+
await writeResultFiles(outputFiles, assetFiles, outputPath);
|
|
191
175
|
const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;
|
|
192
176
|
context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);
|
|
193
177
|
return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);
|
|
194
178
|
}
|
|
179
|
+
async function writeResultFiles(outputFiles, assetFiles, outputPath) {
|
|
180
|
+
const directoryExists = new Set();
|
|
181
|
+
await Promise.all(outputFiles.map(async (file) => {
|
|
182
|
+
// Ensure output subdirectories exist
|
|
183
|
+
const basePath = node_path_1.default.dirname(file.path);
|
|
184
|
+
if (basePath && !directoryExists.has(basePath)) {
|
|
185
|
+
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
186
|
+
directoryExists.add(basePath);
|
|
187
|
+
}
|
|
188
|
+
// Write file contents
|
|
189
|
+
await promises_1.default.writeFile(node_path_1.default.join(outputPath, file.path), file.contents);
|
|
190
|
+
}));
|
|
191
|
+
if (assetFiles?.length) {
|
|
192
|
+
await Promise.all(assetFiles.map(async ({ source, destination }) => {
|
|
193
|
+
// Ensure output subdirectories exist
|
|
194
|
+
const basePath = node_path_1.default.dirname(destination);
|
|
195
|
+
if (basePath && !directoryExists.has(basePath)) {
|
|
196
|
+
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
197
|
+
directoryExists.add(basePath);
|
|
198
|
+
}
|
|
199
|
+
// Copy file contents
|
|
200
|
+
await promises_1.default.copyFile(source, node_path_1.default.join(outputPath, destination),
|
|
201
|
+
// This is not yet available from `fs/promises` in Node.js v16.13
|
|
202
|
+
node_fs_1.constants.COPYFILE_FICLONE);
|
|
203
|
+
}));
|
|
204
|
+
}
|
|
205
|
+
}
|
|
195
206
|
function createOutputFileFromText(path, text) {
|
|
196
207
|
return {
|
|
197
208
|
path,
|
|
@@ -201,8 +212,8 @@ function createOutputFileFromText(path, text) {
|
|
|
201
212
|
},
|
|
202
213
|
};
|
|
203
214
|
}
|
|
204
|
-
function createCodeBundleOptions(options, target, sourceFileCache) {
|
|
205
|
-
const { workspaceRoot, entryPoints, optimizationOptions, sourcemapOptions, tsconfig, outputNames, fileReplacements, externalDependencies, preserveSymlinks, stylePreprocessorOptions, advancedOptimizations, inlineStyleLanguage, jit, } = options;
|
|
215
|
+
function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
|
|
216
|
+
const { workspaceRoot, entryPoints, optimizationOptions, sourcemapOptions, tsconfig, outputNames, fileReplacements, externalDependencies, preserveSymlinks, stylePreprocessorOptions, advancedOptimizations, inlineStyleLanguage, jit, tailwindConfiguration, } = options;
|
|
206
217
|
return {
|
|
207
218
|
absWorkingDir: workspaceRoot,
|
|
208
219
|
bundle: true,
|
|
@@ -254,6 +265,8 @@ function createCodeBundleOptions(options, target, sourceFileCache) {
|
|
|
254
265
|
externalDependencies,
|
|
255
266
|
target,
|
|
256
267
|
inlineStyleLanguage,
|
|
268
|
+
browsers,
|
|
269
|
+
tailwindConfiguration,
|
|
257
270
|
}),
|
|
258
271
|
],
|
|
259
272
|
define: {
|
|
@@ -315,8 +328,8 @@ function getFeatureSupport(target) {
|
|
|
315
328
|
}
|
|
316
329
|
return supported;
|
|
317
330
|
}
|
|
318
|
-
function createGlobalStylesBundleOptions(options, target) {
|
|
319
|
-
const { workspaceRoot, optimizationOptions, sourcemapOptions, outputNames, globalStyles, preserveSymlinks, externalDependencies, stylePreprocessorOptions,
|
|
331
|
+
function createGlobalStylesBundleOptions(options, target, browsers) {
|
|
332
|
+
const { workspaceRoot, optimizationOptions, sourcemapOptions, outputNames, globalStyles, preserveSymlinks, externalDependencies, stylePreprocessorOptions, tailwindConfiguration, } = options;
|
|
320
333
|
const buildOptions = (0, stylesheets_1.createStylesheetBundleOptions)({
|
|
321
334
|
workspaceRoot,
|
|
322
335
|
optimization: !!optimizationOptions.styles.minify,
|
|
@@ -326,6 +339,8 @@ function createGlobalStylesBundleOptions(options, target) {
|
|
|
326
339
|
externalDependencies,
|
|
327
340
|
outputNames,
|
|
328
341
|
includePaths: stylePreprocessorOptions?.includePaths,
|
|
342
|
+
browsers,
|
|
343
|
+
tailwindConfiguration,
|
|
329
344
|
});
|
|
330
345
|
buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';
|
|
331
346
|
const namespace = 'angular:styles/global';
|
|
@@ -381,7 +396,7 @@ async function* buildEsbuildBrowser(initialOptions, context) {
|
|
|
381
396
|
}
|
|
382
397
|
// Create output directory if needed
|
|
383
398
|
try {
|
|
384
|
-
await
|
|
399
|
+
await promises_1.default.mkdir(normalizedOptions.outputPath, { recursive: true });
|
|
385
400
|
}
|
|
386
401
|
catch (e) {
|
|
387
402
|
(0, error_1.assertIsError)(e);
|
|
@@ -416,9 +431,9 @@ async function* buildEsbuildBrowser(initialOptions, context) {
|
|
|
416
431
|
watcher.add(normalizedOptions.projectRoot);
|
|
417
432
|
// Watch workspace root node modules
|
|
418
433
|
// Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
|
|
419
|
-
watcher.add(
|
|
420
|
-
watcher.add(
|
|
421
|
-
watcher.add(
|
|
434
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, 'node_modules'));
|
|
435
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));
|
|
436
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));
|
|
422
437
|
// Wait for changes and rebuild as needed
|
|
423
438
|
try {
|
|
424
439
|
for await (const changes of watcher) {
|
|
@@ -440,4 +455,4 @@ async function* buildEsbuildBrowser(initialOptions, context) {
|
|
|
440
455
|
}
|
|
441
456
|
exports.buildEsbuildBrowser = buildEsbuildBrowser;
|
|
442
457
|
exports.default = (0, architect_1.createBuilder)(buildEsbuildBrowser);
|
|
443
|
-
//# 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, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { deleteOutputDir } from '../../utils';\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 { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\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 { ChangedFiles, createWatcher } 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  constructor(\n    private success: boolean,\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  get output() {\n    return {\n      success: this.success,\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.all([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    outputPath,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const target = transformSupportedBrowsersToTargets(\n    getSupportedBrowsers(projectRoot, context.logger),\n  );\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, codeBundleCache),\n    );\n  const globalStylesBundleContext =\n    rebuildState?.globalStylesRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalStylesBundleOptions(options, target),\n    );\n\n  const [codeResults, styleResults] = 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  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  // Return if the bundling failed to generate output files or there are errors\n  if (codeResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Return if the global stylesheet bundling has errors\n  if (styleResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\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[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  const outputFiles: OutputFile[] = [...codeResults.outputFiles, ...styleResults.outputFiles];\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\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 = 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    outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));\n  }\n\n  // Copy assets\n  if (assets) {\n    await copyAssets(assets, [outputPath], workspaceRoot);\n  }\n\n  // Write output files\n  await Promise.all(\n    outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)),\n  );\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    await fs.writeFile(path.join(outputPath, 'stats.json'), JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    await fs.writeFile(\n      path.join(outputPath, '3rdpartylicenses.txt'),\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  // TODO: This should eventually operate on the in-memory files prior to writing the output files\n  if (serviceWorkerOptions) {\n    try {\n      await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\n        outputPath,\n        options.baseHref || '/',\n      );\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return new ExecutionResult(\n        false,\n        codeBundleContext,\n        globalStylesBundleContext,\n        codeBundleCache,\n      );\n    }\n  }\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);\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  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n    jit,\n  } = options;\n\n  return {\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        },\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\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): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    watch,\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  });\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\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param initialOptions 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  initialOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n): AsyncIterable<BuilderOutput> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(initialOptions, 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, initialOptions);\n\n  // Clean output path if enabled\n  if (initialOptions.deleteOutputPath) {\n    deleteOutputDir(normalizedOptions.workspaceRoot, initialOptions.outputPath);\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  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n    yield result.output;\n\n    // Finish if watch mode is not enabled\n    if (!initialOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!initialOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof initialOptions.poll === 'number',\n    interval: initialOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (initialOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n      yield result.output;\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"]}
|
|
458
|
+
//# 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":";AAAA;;;;;;GAMG;;;;;;AAEH,yDAAyF;AAEzF,8DAAiC;AACjC,qCAAmD;AACnD,gEAAkC;AAClC,0DAA6B;AAC7B,uCAA8C;AAC9C,yDAAqD;AACrD,6CAAkD;AAClD,iEAAkF;AAElF,sFAAiF;AACjF,+DAAgF;AAChF,uEAAsE;AACtE,yDAA0D;AAC1D,uDAA0E;AAC1E,uCAAwD;AACxD,mEAAkE;AAClE,2DAAsD;AACtD,uCAAuE;AACvE,+CAAuD;AAEvD,+CAA8D;AAC9D,uCAAwD;AASxD;;GAEG;AACH,MAAM,eAAe;IACnB,YACU,OAAgB,EAChB,WAA4B,EAC5B,mBAAoC,EACpC,eAAiC;QAHjC,YAAO,GAAP,OAAO,CAAS;QAChB,gBAAW,GAAX,WAAW,CAAiB;QAC5B,wBAAmB,GAAnB,mBAAmB,CAAiB;QACpC,oBAAe,GAAf,eAAe,CAAkB;IACxC,CAAC;IAEJ,IAAI,MAAM;QACR,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,WAAyB;QAC1C,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC,GAAG,WAAW,CAAC,QAAQ,EAAE,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;QAEpF,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;YAC7C,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,WAAW;SACZ,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,IAAI,CAAC,mBAAmB,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC;CACF;AAED,KAAK,UAAU,OAAO,CACpB,OAAiC,EACjC,OAAuB,EACvB,YAA2B;IAE3B,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;IAE1C,MAAM,EACJ,WAAW,EACX,aAAa,EACb,mBAAmB,EACnB,UAAU,EACV,MAAM,EACN,oBAAoB,EACpB,gBAAgB,GACjB,GAAG,OAAO,CAAC;IAEZ,MAAM,QAAQ,GAAG,IAAA,yCAAoB,EAAC,WAAW,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACnE,MAAM,MAAM,GAAG,IAAA,qDAAmC,EAAC,QAAQ,CAAC,CAAC;IAE7D,oFAAoF;IACpF,MAAM,eAAe,GAAG,OAAO,CAAC,KAAK;QACnC,CAAC,CAAC,YAAY,EAAE,eAAe,IAAI,IAAI,iCAAe,EAAE;QACxD,CAAC,CAAC,SAAS,CAAC;IACd,MAAM,iBAAiB,GACrB,YAAY,EAAE,WAAW;QACzB,IAAI,wBAAc,CAChB,aAAa,EACb,CAAC,CAAC,OAAO,CAAC,KAAK,EACf,uBAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,eAAe,CAAC,CACpE,CAAC;IACJ,MAAM,yBAAyB,GAC7B,YAAY,EAAE,mBAAmB;QACjC,IAAI,wBAAc,CAChB,aAAa,EACb,CAAC,CAAC,OAAO,CAAC,KAAK,EACf,+BAA+B,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,CAAC,CAC3D,CAAC;IAEJ,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACpD,iDAAiD;QACjD,iBAAiB,CAAC,MAAM,EAAE;QAC1B,mDAAmD;QACnD,yBAAyB,CAAC,MAAM,EAAE;KACnC,CAAC,CAAC;IAEH,wDAAwD;IACxD,MAAM,IAAA,qBAAW,EAAC,OAAO,EAAE;QACzB,MAAM,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC,MAAM,IAAI,EAAE,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QACvE,QAAQ,EAAE,CAAC,GAAG,WAAW,CAAC,QAAQ,EAAE,GAAG,YAAY,CAAC,QAAQ,CAAC;KAC9D,CAAC,CAAC;IAEH,6EAA6E;IAC7E,IAAI,WAAW,CAAC,MAAM,EAAE;QACtB,OAAO,IAAI,eAAe,CACxB,KAAK,EACL,iBAAiB,EACjB,yBAAyB,EACzB,eAAe,CAChB,CAAC;KACH;IAED,sDAAsD;IACtD,IAAI,YAAY,CAAC,MAAM,EAAE;QACvB,OAAO,IAAI,eAAe,CACxB,KAAK,EACL,iBAAiB,EACjB,yBAAyB,EACzB,eAAe,CAChB,CAAC;KACH;IAED,yCAAyC;IACzC,YAAY,CAAC,YAAY,GAAG,YAAY,CAAC,YAAY,CAAC,MAAM,CAC1D,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,EAAE,OAAO,CACjF,CAAC;IAEF,oCAAoC;IACpC,MAAM,YAAY,GAAe,CAAC,GAAG,WAAW,CAAC,YAAY,EAAE,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;IAC7F,MAAM,WAAW,GAAiB,CAAC,GAAG,WAAW,CAAC,WAAW,EAAE,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5F,2FAA2F;IAC3F,MAAM,QAAQ,GAAG;QACf,MAAM,EAAE,EAAE,GAAG,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE;QAC7E,OAAO,EAAE,EAAE,GAAG,WAAW,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,YAAY,CAAC,QAAQ,EAAE,OAAO,EAAE;KACjF,CAAC;IAEF,iEAAiE;IACjE,IAAI,mBAAmB,CAAC,OAAO,EAAE;QAC/B,MAAM,QAAQ,GAAG,IAAA,uCAAoB,EAAC,QAAQ,EAAE,OAAO,CAAC,2BAA2B,CAAC,CAAC;QACrF,MAAM,IAAA,qBAAW,EAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;KACpD;IAED,2BAA2B;IAC3B,IAAI,gBAAgB,EAAE;QACpB,4EAA4E;QAC5E,MAAM,kBAAkB,GAAG,IAAI,yCAAkB,CAAC;YAChD,SAAS,EAAE,gBAAgB,CAAC,KAAK;YACjC,WAAW,EAAE,gBAAgB,CAAC,cAAc;YAC5C,GAAG,EAAE,OAAO,CAAC,oBAAoB;YACjC,YAAY,EAAE,mBAAmB;YACjC,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;QAEH,8DAA8D;QAC9D,MAAM,iBAAiB,GAAG,GAAG,CAAC;QAC9B,kBAAkB,CAAC,SAAS,GAAG,KAAK,WAAW,QAAgB;YAC7D,qCAAqC;YACrC,MAAM,gBAAgB,GAAG,mBAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;YACpE,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,gBAAgB,CAAC,CAAC;YACxE,IAAI,IAAI,EAAE;gBACR,OAAO,IAAI,CAAC,IAAI,CAAC;aAClB;YAED,MAAM,IAAI,KAAK,CAAC,+BAA+B,mBAAI,EAAE,CAAC,CAAC;QACzD,CAAC,CAAC;QAEF,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,kBAAkB,CAAC,OAAO,CAAC;YACrE,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,IAAI,EAAE,SAAS;YACf,UAAU,EAAE,iBAAiB;YAC7B,KAAK,EAAE,YAAY;SACpB,CAAC,CAAC;QAEH,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SAC7B;QACD,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;YAC9B,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;QAED,WAAW,CAAC,IAAI,CAAC,wBAAwB,CAAC,gBAAgB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;KAC9E;IAED,cAAc;IACd,IAAI,UAAU,CAAC;IACf,IAAI,MAAM,EAAE;QACV,8FAA8F;QAC9F,kGAAkG;QAClG,UAAU,GAAG,MAAM,IAAA,wBAAU,EAAC,MAAM,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC;KAC1D;IAED,4CAA4C;IAC5C,IAAI,OAAO,CAAC,KAAK,EAAE;QACjB,WAAW,CAAC,IAAI,CAAC,wBAAwB,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;KAC7F;IAED,+CAA+C;IAC/C,IAAI,OAAO,CAAC,eAAe,EAAE;QAC3B,WAAW,CAAC,IAAI,CACd,wBAAwB,CACtB,sBAAsB,EACtB,MAAM,IAAA,mCAAe,EAAC,QAAQ,EAAE,aAAa,CAAC,CAC/C,CACF,CAAC;KACH;IAED,sDAAsD;IACtD,IAAI,oBAAoB,EAAE;QACxB,IAAI;YACF,MAAM,mBAAmB,GAAG,MAAM,IAAA,mDAAkC,EAClE,aAAa,EACb,oBAAoB,EACpB,OAAO,CAAC,QAAQ,IAAI,GAAG,EACvB,WAAW,EACX,UAAU,IAAI,EAAE,CACjB,CAAC;YACF,WAAW,CAAC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC;YACtF,UAAU,KAAV,UAAU,GAAK,EAAE,EAAC;YAClB,UAAU,CAAC,IAAI,CAAC,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;SACpD;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC;YAE1E,OAAO,IAAI,eAAe,CACxB,KAAK,EACL,iBAAiB,EACjB,yBAAyB,EACzB,eAAe,CAChB,CAAC;SACH;KACF;IAED,qBAAqB;IACrB,MAAM,gBAAgB,CAAC,WAAW,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;IAE5D,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,SAAS,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACxE,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAEnE,OAAO,IAAI,eAAe,CAAC,IAAI,EAAE,iBAAiB,EAAE,yBAAyB,EAAE,eAAe,CAAC,CAAC;AAClG,CAAC;AAED,KAAK,UAAU,gBAAgB,CAC7B,WAAyB,EACzB,UAAiE,EACjE,UAAkB;IAElB,MAAM,eAAe,GAAG,IAAI,GAAG,EAAU,CAAC;IAC1C,MAAM,OAAO,CAAC,GAAG,CACf,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QAC7B,qCAAqC;QACrC,MAAM,QAAQ,GAAG,mBAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,IAAI,QAAQ,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC9C,MAAM,kBAAE,CAAC,KAAK,CAAC,mBAAI,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACrE,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAC/B;QACD,sBAAsB;QACtB,MAAM,kBAAE,CAAC,SAAS,CAAC,mBAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtE,CAAC,CAAC,CACH,CAAC;IAEF,IAAI,UAAU,EAAE,MAAM,EAAE;QACtB,MAAM,OAAO,CAAC,GAAG,CACf,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,EAAE,EAAE;YAC/C,qCAAqC;YACrC,MAAM,QAAQ,GAAG,mBAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC3C,IAAI,QAAQ,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;gBAC9C,MAAM,kBAAE,CAAC,KAAK,CAAC,mBAAI,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;gBACrE,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;aAC/B;YACD,qBAAqB;YACrB,MAAM,kBAAE,CAAC,QAAQ,CACf,MAAM,EACN,mBAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC;YAClC,iEAAiE;YACjE,mBAAW,CAAC,gBAAgB,CAC7B,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;KACH;AACH,CAAC;AAED,SAAS,wBAAwB,CAAC,IAAY,EAAE,IAAY;IAC1D,OAAO;QACL,IAAI;QACJ,IAAI;QACJ,IAAI,QAAQ;YACV,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACzC,CAAC;KACF,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB,CAC9B,OAAiC,EACjC,MAAgB,EAChB,QAAkB,EAClB,eAAiC;IAEjC,MAAM,EACJ,aAAa,EACb,WAAW,EACX,mBAAmB,EACnB,gBAAgB,EAChB,QAAQ,EACR,WAAW,EACX,gBAAgB,EAChB,oBAAoB,EACpB,gBAAgB,EAChB,wBAAwB,EACxB,qBAAqB,EACrB,mBAAmB,EACnB,GAAG,EACH,qBAAqB,GACtB,GAAG,OAAO,CAAC;IAEZ,OAAO;QACL,aAAa,EAAE,aAAa;QAC5B,MAAM,EAAE,IAAI;QACZ,MAAM,EAAE,KAAK;QACb,WAAW;QACX,UAAU,EAAE,WAAW,CAAC,OAAO;QAC/B,UAAU,EAAE,WAAW,CAAC,KAAK;QAC7B,MAAM;QACN,SAAS,EAAE,iBAAiB,CAAC,MAAM,CAAC;QACpC,UAAU,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC;QACnD,UAAU,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;QAC1C,iBAAiB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC;QACjD,QAAQ,EAAE,IAAI;QACd,aAAa,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK;QACvD,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;QAC9C,MAAM,EAAE,mBAAmB,CAAC,OAAO;QACnC,IAAI,EAAE,CAAC,YAAY,CAAC;QACpB,MAAM,EAAE,aAAa;QACrB,SAAS,EAAE,gBAAgB,CAAC,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;QACpF,SAAS,EAAE,IAAI;QACf,QAAQ;QACR,QAAQ,EAAE,oBAAoB;QAC9B,KAAK,EAAE,KAAK;QACZ,QAAQ,EAAE,SAAS;QACnB,gBAAgB;QAChB,OAAO,EAAE;YACP,IAAA,sCAAoB;YAClB,gBAAgB;YAChB;gBACE,SAAS,EAAE,CAAC,CAAC,gBAAgB,CAAC,OAAO;gBACrC,oBAAoB,EAAE,gBAAgB,CAAC,MAAM;gBAC7C,QAAQ;gBACR,GAAG;gBACH,qBAAqB;gBACrB,gBAAgB;gBAChB,eAAe;aAChB;YACD,+BAA+B;YAC/B;gBACE,aAAa;gBACb,YAAY,EAAE,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,MAAM;gBACjD,SAAS;gBACP,+EAA+E;gBAC/E,mFAAmF;gBACnF,2BAA2B;gBAC3B,CAAC,CAAC,gBAAgB,CAAC,MAAM,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAC3E,WAAW;gBACX,YAAY,EAAE,wBAAwB,EAAE,YAAY;gBACpD,oBAAoB;gBACpB,MAAM;gBACN,mBAAmB;gBACnB,QAAQ;gBACR,qBAAqB;aACtB,CACF;SACF;QACD,MAAM,EAAE;YACN,gGAAgG;YAChG,+FAA+F;YAC/F,2CAA2C;YAC3C,GAAG,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YACvE,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;SACpC;KACF,CAAC;AACJ,CAAC;AAED;;;;;GAKG;AACH,SAAS,iBAAiB,CAAC,MAAgB;IACzC,MAAM,SAAS,GAA4B;QACzC,sFAAsF;QACtF,oGAAoG;QACpG,mGAAmG;QACnG,kDAAkD;QAClD,uGAAuG;QACvG,aAAa,EAAE,KAAK;QACpB,qGAAqG;QACrG,oGAAoG;QACpG,8EAA8E;QAC9E,0EAA0E;QAC1E,oBAAoB,EAAE,KAAK;KAC5B,CAAC;IAEF,sEAAsE;IACtE,mFAAmF;IACnF,wFAAwF;IACxF,IAAI,wBAAwB,GAAG,KAAK,CAAC;IACrC,KAAK,MAAM,OAAO,IAAI,MAAM,EAAE;QAC5B,IAAI,YAAY,CAAC;QACjB,IAAI,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAC7B,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SAC5C;aAAM,IAAI,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YACvC,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SAC5C;aAAM;YACL,SAAS;SACV;QACD,0FAA0F;QAC1F,iFAAiF;QACjF,IAAI,YAAY,KAAK,EAAE,IAAI,YAAY,KAAK,EAAE,EAAE;YAC9C,wBAAwB,GAAG,IAAI,CAAC;YAChC,MAAM;SACP;KACF;IACD,yFAAyF;IACzF,gDAAgD;IAChD,IAAI,wBAAwB,EAAE;QAC5B,SAAS,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC;QACjC,SAAS,CAAC,oBAAoB,CAAC,GAAG,KAAK,CAAC;KACzC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,+BAA+B,CACtC,OAAiC,EACjC,MAAgB,EAChB,QAAkB;IAElB,MAAM,EACJ,aAAa,EACb,mBAAmB,EACnB,gBAAgB,EAChB,WAAW,EACX,YAAY,EACZ,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,qBAAqB,GACtB,GAAG,OAAO,CAAC;IAEZ,MAAM,YAAY,GAAG,IAAA,2CAA6B,EAAC;QACjD,aAAa;QACb,YAAY,EAAE,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,MAAM;QACjD,SAAS,EAAE,CAAC,CAAC,gBAAgB,CAAC,MAAM;QACpC,gBAAgB;QAChB,MAAM;QACN,oBAAoB;QACpB,WAAW;QACX,YAAY,EAAE,wBAAwB,EAAE,YAAY;QACpD,QAAQ;QACR,qBAAqB;KACtB,CAAC,CAAC;IACH,YAAY,CAAC,aAAa,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;IAEtE,MAAM,SAAS,GAAG,uBAAuB,CAAC;IAC1C,YAAY,CAAC,WAAW,GAAG,EAAE,CAAC;IAC9B,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,YAAY,EAAE;QACnC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,GAAG,SAAS,IAAI,IAAI,EAAE,CAAC;KACzD;IAED,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC;QAC3B,IAAI,EAAE,uBAAuB;QAC7B,KAAK,CAAC,KAAK;YACT,KAAK,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,0BAA0B,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE;gBAC/D,IAAI,IAAI,CAAC,IAAI,KAAK,aAAa,EAAE;oBAC/B,OAAO,IAAI,CAAC;iBACb;gBAED,OAAO;oBACL,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;oBAChC,SAAS;iBACV,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE;gBAChD,MAAM,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC;gBACzE,IAAA,qBAAM,EAAC,KAAK,EAAE,6CAA6C,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBAEzE,OAAO;oBACL,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,YAAY,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;oBAClF,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,aAAa;iBAC1B,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;KACF,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC;AACtB,CAAC;AAED;;;;;;GAMG;AACI,KAAK,SAAS,CAAC,CAAC,mBAAmB,CACxC,cAAqC,EACrC,OAAuB;IAEvB,4DAA4D;IAC5D,IAAA,+CAAuB,EAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAEjD,qDAAqD;IACrD,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC;IAC5C,IAAI,CAAC,WAAW,EAAE;QAChB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,kEAAkE,CAAC,CAAC;QAEzF,OAAO;KACR;IAED,MAAM,iBAAiB,GAAG,MAAM,IAAA,0BAAgB,EAAC,OAAO,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC;IAEvF,+BAA+B;IAC/B,IAAI,cAAc,CAAC,gBAAgB,EAAE;QACnC,IAAA,uBAAe,EAAC,iBAAiB,CAAC,aAAa,EAAE,cAAc,CAAC,UAAU,CAAC,CAAC;KAC7E;IAED,oCAAoC;IACpC,IAAI;QACF,MAAM,kBAAE,CAAC,KAAK,CAAC,iBAAiB,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;KACnE;IAAC,OAAO,CAAC,EAAE;QACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;QACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,qCAAqC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;QAExE,OAAO;KACR;IAED,gBAAgB;IAChB,IAAI,MAAuB,CAAC;IAC5B,IAAI;QACF,MAAM,GAAG,MAAM,OAAO,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC;QACnD,MAAM,MAAM,CAAC,MAAM,CAAC;QAEpB,sCAAsC;QACtC,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE;YACzB,OAAO;SACR;KACF;YAAS;QACR,mDAAmD;QACnD,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE;YACzB,IAAA,oCAAsB,GAAE,CAAC;SAC1B;KACF;IAED,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;IAExE,kBAAkB;IAClB,MAAM,OAAO,GAAG,IAAA,uBAAa,EAAC;QAC5B,OAAO,EAAE,OAAO,cAAc,CAAC,IAAI,KAAK,QAAQ;QAChD,QAAQ,EAAE,cAAc,CAAC,IAAI;QAC7B,qEAAqE;QACrE,OAAO,EAAE,CAAC,iBAAiB,CAAC,UAAU,EAAE,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC;KACjF,CAAC,CAAC;IAEH,uCAAuC;IACvC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;IAE3C,oCAAoC;IACpC,4EAA4E;IAC5E,OAAO,CAAC,GAAG,CAAC,mBAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC,CAAC;IACxE,OAAO,CAAC,GAAG,CAAC,mBAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC,CAAC;IACpE,OAAO,CAAC,GAAG,CAAC,mBAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC,CAAC;IAE1E,yCAAyC;IACzC,IAAI;QACF,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,OAAO,EAAE;YACnC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAC;YAEvD,IAAI,cAAc,CAAC,OAAO,EAAE;gBAC1B,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;aAC9C;YAED,MAAM,GAAG,MAAM,OAAO,CAAC,iBAAiB,EAAE,OAAO,EAAE,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;YACvF,MAAM,MAAM,CAAC,MAAM,CAAC;SACrB;KACF;YAAS;QACR,mBAAmB;QACnB,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;QACtB,oCAAoC;QACpC,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;QACvB,IAAA,oCAAsB,GAAE,CAAC;KAC1B;AACH,CAAC;AAvFD,kDAuFC;AAED,kBAAe,IAAA,yBAAa,EAAC,mBAAmB,CAAC,CAAC","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, 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 { deleteOutputDir } from '../../utils';\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 { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\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 { ChangedFiles, createWatcher } 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  constructor(\n    private success: boolean,\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  get output() {\n    return {\n      success: this.success,\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.all([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    outputPath,\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 [codeResults, styleResults] = 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  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  // Return if the bundling failed to generate output files or there are errors\n  if (codeResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Return if the global stylesheet bundling has errors\n  if (styleResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\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[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  const outputFiles: OutputFile[] = [...codeResults.outputFiles, ...styleResults.outputFiles];\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\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 = 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    outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));\n  }\n\n  // Copy assets\n  let assetFiles;\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    assetFiles = await copyAssets(assets, [], workspaceRoot);\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    outputFiles.push(createOutputFileFromText('stats.json', JSON.stringify(metafile, null, 2)));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    outputFiles.push(\n      createOutputFileFromText(\n        '3rdpartylicenses.txt',\n        await extractLicenses(metafile, workspaceRoot),\n      ),\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        outputFiles,\n        assetFiles || [],\n      );\n      outputFiles.push(createOutputFileFromText('ngsw.json', serviceWorkerResult.manifest));\n      assetFiles ??= [];\n      assetFiles.push(...serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return new ExecutionResult(\n        false,\n        codeBundleContext,\n        globalStylesBundleContext,\n        codeBundleCache,\n      );\n    }\n  }\n\n  // Write output files\n  await writeResultFiles(outputFiles, assetFiles, outputPath);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);\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(\n          source,\n          path.join(outputPath, destination),\n          // This is not yet available from `fs/promises` in Node.js v16.13\n          fsConstants.COPYFILE_FICLONE,\n        );\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    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  return {\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\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\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param initialOptions 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  initialOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n): AsyncIterable<BuilderOutput> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(initialOptions, 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, initialOptions);\n\n  // Clean output path if enabled\n  if (initialOptions.deleteOutputPath) {\n    deleteOutputDir(normalizedOptions.workspaceRoot, initialOptions.outputPath);\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  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n    yield result.output;\n\n    // Finish if watch mode is not enabled\n    if (!initialOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!initialOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof initialOptions.poll === 'number',\n    interval: initialOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (initialOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n      yield result.output;\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"]}
|
|
@@ -59,4 +59,8 @@ export declare function normalizeOptions(context: BuilderContext, projectName: s
|
|
|
59
59
|
output: string;
|
|
60
60
|
insertionOrder: import("../../utils/package-chunk-sort").EntryPointsType[];
|
|
61
61
|
} | undefined;
|
|
62
|
+
tailwindConfiguration: {
|
|
63
|
+
file: string;
|
|
64
|
+
package: string;
|
|
65
|
+
} | undefined;
|
|
62
66
|
}>;
|