@angular-devkit/build-angular 16.1.0-next.1 → 16.1.0-rc.0

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 (44) hide show
  1. package/package.json +22 -22
  2. package/src/builders/browser/schema.js +6 -6
  3. package/src/builders/browser-esbuild/angular/aot-compilation.js +5 -5
  4. package/src/builders/browser-esbuild/esbuild.d.ts +9 -3
  5. package/src/builders/browser-esbuild/esbuild.js +39 -11
  6. package/src/builders/browser-esbuild/global-scripts.js +47 -63
  7. package/src/builders/browser-esbuild/global-styles.js +14 -23
  8. package/src/builders/browser-esbuild/index.js +58 -36
  9. package/src/builders/browser-esbuild/options.d.ts +6 -0
  10. package/src/builders/browser-esbuild/options.js +3 -2
  11. package/src/builders/browser-esbuild/schema.js +6 -6
  12. package/src/builders/browser-esbuild/stylesheets/bundle-options.js +15 -20
  13. package/src/builders/browser-esbuild/stylesheets/css-language.d.ts +9 -0
  14. package/src/builders/browser-esbuild/stylesheets/css-language.js +16 -0
  15. package/src/builders/browser-esbuild/stylesheets/less-language.d.ts +9 -0
  16. package/src/builders/browser-esbuild/stylesheets/less-language.js +127 -0
  17. package/src/builders/browser-esbuild/stylesheets/sass-language.d.ts +10 -0
  18. package/src/builders/browser-esbuild/stylesheets/sass-language.js +169 -0
  19. package/src/builders/browser-esbuild/stylesheets/{css-plugin.d.ts → stylesheet-plugin-factory.d.ts} +17 -9
  20. package/src/builders/browser-esbuild/stylesheets/stylesheet-plugin-factory.js +218 -0
  21. package/src/builders/browser-esbuild/virtual-module-plugin.d.ts +28 -0
  22. package/src/builders/browser-esbuild/virtual-module-plugin.js +43 -0
  23. package/src/builders/dev-server/load-proxy-config.js +3 -3
  24. package/src/builders/dev-server/vite-server.d.ts +1 -1
  25. package/src/builders/dev-server/vite-server.js +41 -8
  26. package/src/builders/extract-i18n/schema.js +2 -2
  27. package/src/builders/jest/test-files.d.ts +2 -3
  28. package/src/builders/jest/test-files.js +8 -9
  29. package/src/builders/karma/find-tests-plugin.js +4 -8
  30. package/src/builders/karma/schema.js +2 -2
  31. package/src/builders/server/schema.js +4 -4
  32. package/src/utils/bundle-calculator.js +2 -2
  33. package/src/utils/copy-assets.js +15 -43
  34. package/src/utils/index-file/augment-index-html.d.ts +4 -0
  35. package/src/utils/index-file/augment-index-html.js +29 -3
  36. package/src/utils/index-file/index-html-generator.d.ts +5 -0
  37. package/src/utils/index-file/index-html-generator.js +3 -2
  38. package/src/webpack/plugins/typescript.js +3 -4
  39. package/src/webpack/utils/helpers.js +4 -5
  40. package/src/builders/browser-esbuild/stylesheets/css-plugin.js +0 -166
  41. package/src/builders/browser-esbuild/stylesheets/less-plugin.d.ts +0 -15
  42. package/src/builders/browser-esbuild/stylesheets/less-plugin.js +0 -144
  43. package/src/builders/browser-esbuild/stylesheets/sass-plugin.d.ts +0 -16
  44. package/src/builders/browser-esbuild/stylesheets/sass-plugin.js +0 -188
@@ -57,7 +57,8 @@ const global_styles_1 = require("./global-styles");
57
57
  const license_extractor_1 = require("./license-extractor");
58
58
  const options_1 = require("./options");
59
59
  const sourcemap_ignorelist_plugin_1 = require("./sourcemap-ignorelist-plugin");
60
- const sass_plugin_1 = require("./stylesheets/sass-plugin");
60
+ const sass_language_1 = require("./stylesheets/sass-language");
61
+ const virtual_module_plugin_1 = require("./virtual-module-plugin");
61
62
  const compressAsync = (0, node_util_1.promisify)(node_zlib_1.brotliCompress);
62
63
  /**
63
64
  * Represents the result of a single builder execute call.
@@ -117,7 +118,7 @@ async function execute(options, context, rebuildState) {
117
118
  for (const initial of [true, false]) {
118
119
  const bundleOptions = (0, global_styles_1.createGlobalStylesBundleOptions)(options, target, browsers, initial, codeBundleCache?.loadResultCache);
119
120
  if (bundleOptions) {
120
- bundlerContexts.push(new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, bundleOptions));
121
+ bundlerContexts.push(new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial));
121
122
  }
122
123
  }
123
124
  }
@@ -126,7 +127,7 @@ async function execute(options, context, rebuildState) {
126
127
  for (const initial of [true, false]) {
127
128
  const bundleOptions = (0, global_scripts_1.createGlobalScriptsBundleOptions)(options, initial);
128
129
  if (bundleOptions) {
129
- bundlerContexts.push(new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, bundleOptions));
130
+ bundlerContexts.push(new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial));
130
131
  }
131
132
  }
132
133
  }
@@ -139,11 +140,6 @@ async function execute(options, context, rebuildState) {
139
140
  if (bundlingResult.errors) {
140
141
  return executionResult;
141
142
  }
142
- // Filter global stylesheet initial files. Currently all initial CSS files are from the global styles option.
143
- if (options.globalStyles.length > 0) {
144
- bundlingResult.initialFiles = bundlingResult.initialFiles.filter(({ file, name }) => !file.endsWith('.css') ||
145
- options.globalStyles.find((style) => style.name === name)?.initial);
146
- }
147
143
  const { metafile, initialFiles, outputFiles } = bundlingResult;
148
144
  executionResult.outputFiles.push(...outputFiles);
149
145
  // Check metafile for CommonJS module usage if optimizing scripts
@@ -176,7 +172,11 @@ async function execute(options, context, rebuildState) {
176
172
  baseHref: options.baseHref,
177
173
  lang: undefined,
178
174
  outputPath: virtualOutputPath,
179
- files: initialFiles,
175
+ files: [...initialFiles].map(([file, record]) => ({
176
+ name: record.name ?? '',
177
+ file,
178
+ extension: node_path_1.default.extname(file),
179
+ })),
180
180
  });
181
181
  for (const error of errors) {
182
182
  context.logger.error(error);
@@ -325,6 +325,41 @@ function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
325
325
  'ngJitMode': jit ? 'true' : 'false',
326
326
  },
327
327
  };
328
+ if (options.externalPackages) {
329
+ // Add a plugin that marks any resolved path as external if it is within a node modules directory.
330
+ // This is used instead of the esbuild `packages` option to avoid marking bare specifiers that use
331
+ // tsconfig path mapping to resolve to a workspace relative path. This is common for monorepos that
332
+ // contain libraries that are built along with the application. These libraries should not be considered
333
+ // external even though the imports appear to be packages.
334
+ const EXTERNAL_PACKAGE_RESOLUTION = Symbol('EXTERNAL_PACKAGE_RESOLUTION');
335
+ buildOptions.plugins ?? (buildOptions.plugins = []);
336
+ buildOptions.plugins.push({
337
+ name: 'angular-external-packages',
338
+ setup(build) {
339
+ build.onResolve({ filter: /./ }, async (args) => {
340
+ if (args.pluginData?.[EXTERNAL_PACKAGE_RESOLUTION]) {
341
+ return null;
342
+ }
343
+ const { importer, kind, resolveDir, namespace, pluginData = {} } = args;
344
+ pluginData[EXTERNAL_PACKAGE_RESOLUTION] = true;
345
+ const result = await build.resolve(args.path, {
346
+ importer,
347
+ kind,
348
+ namespace,
349
+ pluginData,
350
+ resolveDir,
351
+ });
352
+ if (result.path && /[\\/]node_modules[\\/]/.test(result.path)) {
353
+ return {
354
+ path: args.path,
355
+ external: true,
356
+ };
357
+ }
358
+ return result;
359
+ });
360
+ },
361
+ });
362
+ }
328
363
  const polyfills = options.polyfills ? [...options.polyfills] : [];
329
364
  if (jit) {
330
365
  polyfills.push('@angular/compiler');
@@ -335,27 +370,14 @@ function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
335
370
  ...buildOptions.entryPoints,
336
371
  ['polyfills']: namespace,
337
372
  };
338
- buildOptions.plugins?.unshift({
339
- name: 'angular-polyfills',
340
- setup(build) {
341
- build.onResolve({ filter: /^angular:polyfills$/ }, (args) => {
342
- if (args.kind !== 'entry-point') {
343
- return null;
344
- }
345
- return {
346
- path: 'entry',
347
- namespace,
348
- };
349
- });
350
- build.onLoad({ filter: /./, namespace }, () => {
351
- return {
352
- contents: polyfills.map((file) => `import '${file.replace(/\\/g, '/')}';`).join('\n'),
353
- loader: 'js',
354
- resolveDir: workspaceRoot,
355
- };
356
- });
357
- },
358
- });
373
+ buildOptions.plugins?.unshift((0, virtual_module_plugin_1.createVirtualModulePlugin)({
374
+ namespace,
375
+ loadContent: () => ({
376
+ contents: polyfills.map((file) => `import '${file.replace(/\\/g, '/')}';`).join('\n'),
377
+ loader: 'js',
378
+ resolveDir: workspaceRoot,
379
+ }),
380
+ }));
359
381
  }
360
382
  return buildOptions;
361
383
  }
@@ -506,7 +528,7 @@ async function* buildEsbuildBrowserInternal(userOptions, context, infrastructure
506
528
  finally {
507
529
  // Ensure Sass workers are shutdown if not watching
508
530
  if (!userOptions.watch) {
509
- (0, sass_plugin_1.shutdownSassWorkerPool)();
531
+ (0, sass_language_1.shutdownSassWorkerPool)();
510
532
  }
511
533
  }
512
534
  if (normalizedOptions.progress) {
@@ -524,6 +546,7 @@ async function* buildEsbuildBrowserInternal(userOptions, context, infrastructure
524
546
  // Ignore all node modules directories to avoid excessive file watchers.
525
547
  // Package changes are handled below by watching manifest and lock files.
526
548
  '**/node_modules/**',
549
+ '**/.*/**',
527
550
  ],
528
551
  });
529
552
  // Temporarily watch the entire project
@@ -576,13 +599,12 @@ async function* buildEsbuildBrowserInternal(userOptions, context, infrastructure
576
599
  await watcher.close();
577
600
  // Cleanup incremental rebuild state
578
601
  await result.dispose();
579
- (0, sass_plugin_1.shutdownSassWorkerPool)();
602
+ (0, sass_language_1.shutdownSassWorkerPool)();
580
603
  }
581
604
  }
582
605
  exports.buildEsbuildBrowserInternal = buildEsbuildBrowserInternal;
583
606
  exports.default = (0, architect_1.createBuilder)(buildEsbuildBrowser);
584
- function logBuildStats(context, metafile, initialFiles, estimatedTransferSizes) {
585
- const initial = new Map(initialFiles.map((info) => [info.file, info.name]));
607
+ function logBuildStats(context, metafile, initial, estimatedTransferSizes) {
586
608
  const stats = [];
587
609
  for (const [file, output] of Object.entries(metafile.outputs)) {
588
610
  // Only display JavaScript and CSS files
@@ -598,7 +620,7 @@ function logBuildStats(context, metafile, initialFiles, estimatedTransferSizes)
598
620
  initial: initial.has(file),
599
621
  stats: [
600
622
  file,
601
- initial.get(file) ?? '-',
623
+ initial.get(file)?.name ?? '-',
602
624
  output.bytes,
603
625
  estimatedTransferSizes?.get(file) ?? '-',
604
626
  ],
@@ -626,4 +648,4 @@ async function calculateEstimatedTransferSizes(outputFiles) {
626
648
  await Promise.all(pendingCompression);
627
649
  return sizes;
628
650
  }
629
- //# 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 { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { 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 { logBuilderStatusWarnings } from './builder-status-warnings';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { createGlobalScriptsBundleOptions } from './global-scripts';\nimport { createGlobalStylesBundleOptions } from './global-styles';\nimport { extractLicenses } from './license-extractor';\nimport { BrowserEsbuildOptions, NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createSourcemapIngorelistPlugin } from './sourcemap-ignorelist-plugin';\nimport { shutdownSassWorkerPool } from './stylesheets/sass-plugin';\nimport type { ChangedFiles } from './watcher';\n\nconst compressAsync = promisify(brotliCompress);\n\ninterface RebuildState {\n  rebuildContexts: 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 rebuildContexts: 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  get watchFiles() {\n    return this.codeBundleCache?.referencedFiles ?? [];\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      rebuildContexts: this.rebuildContexts,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.allSettled(this.rebuildContexts.map((context) => context.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    cacheOptions,\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  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createCodeBundleOptions(options, target, browsers, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          browsers,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(new BundlerContext(workspaceRoot, !!options.watch, bundleOptions));\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(new BundlerContext(workspaceRoot, !!options.watch, bundleOptions));\n        }\n      }\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  // 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  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n  logBuildStats(context, metafile, initialFiles, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  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    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    outExtension,\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    outExtension: outExtension ? { '.js': `.${outExtension}` } : undefined,\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      createSourcemapIngorelistPlugin(),\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          preserveSymlinks,\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  const polyfills = options.polyfills ? [...options.polyfills] : [];\n  if (jit) {\n    polyfills.push('@angular/compiler');\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    // esbuild currently has a defect involving self-referencing a class within a static code block or\n    // static field initializer. This is not an issue for projects that use the default browserslist as these\n    // elements are an ES2022 feature which is not support by all browsers in the default list. However, if a\n    // custom browserslist is used that only has newer browsers than the static code elements may be present.\n    // This issue is compounded by the default usage of the tsconfig `\"useDefineForClassFields\": false` option\n    // present in generated CLI projects which causes static code blocks to be used instead of static fields.\n    // esbuild currently unconditionally downlevels all static fields in top-level classes so to workaround the\n    // Angular issue only static code blocks are disabled here.\n    // For more details: https://github.com/evanw/esbuild/issues/2950\n    'class-static-blocks': 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\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 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  return buildEsbuildBrowserInternal(userOptions, context, infrastructureSettings);\n}\n\n/**\n * Internal version of the main execution function for the esbuild-based application builder.\n * Exposes some additional \"private\" options in addition to those exposed by the schema.\n * @param userOptions The browser-esbuild 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* buildEsbuildBrowserInternal(\n  userOptions: BrowserEsbuildOptions,\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 status of builder and options\n  logBuilderStatusWarnings(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  // Watch locations provided by the initial build result\n  let previousWatchFiles = new Set(result.watchFiles);\n  watcher.add(result.watchFiles);\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (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      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (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(\n  context: BuilderContext,\n  metafile: Metafile,\n  initialFiles: FileInfo[],\n  estimatedTransferSizes?: Map<string, number>,\n) {\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: [\n        file,\n        initial.get(file) ?? '-',\n        output.bytes,\n        estimatedTransferSizes?.get(file) ?? '-',\n      ],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, !!estimatedTransferSizes, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nasync function calculateEstimatedTransferSizes(outputFiles: OutputFile[]) {\n  const sizes = new Map<string, number>();\n\n  const pendingCompression = [];\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n"]}
651
+ //# 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 { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\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 { logBuilderStatusWarnings } from './builder-status-warnings';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { BundlerContext, InitialFileRecord, logMessages } from './esbuild';\nimport { createGlobalScriptsBundleOptions } from './global-scripts';\nimport { createGlobalStylesBundleOptions } from './global-styles';\nimport { extractLicenses } from './license-extractor';\nimport { BrowserEsbuildOptions, NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createSourcemapIngorelistPlugin } from './sourcemap-ignorelist-plugin';\nimport { shutdownSassWorkerPool } from './stylesheets/sass-language';\nimport { createVirtualModulePlugin } from './virtual-module-plugin';\nimport type { ChangedFiles } from './watcher';\n\nconst compressAsync = promisify(brotliCompress);\n\ninterface RebuildState {\n  rebuildContexts: 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 rebuildContexts: 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  get watchFiles() {\n    return this.codeBundleCache?.referencedFiles ?? [];\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      rebuildContexts: this.rebuildContexts,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.allSettled(this.rebuildContexts.map((context) => context.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    cacheOptions,\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  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createCodeBundleOptions(options, target, browsers, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          browsers,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  const { metafile, initialFiles, outputFiles } = bundlingResult;\n\n  executionResult.outputFiles.push(...outputFiles);\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  // 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].map(([file, record]) => ({\n        name: record.name ?? '',\n        file,\n        extension: path.extname(file),\n      })),\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  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n  logBuildStats(context, metafile, initialFiles, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  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    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    outExtension,\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    outExtension: outExtension ? { '.js': `.${outExtension}` } : undefined,\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      createSourcemapIngorelistPlugin(),\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          preserveSymlinks,\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 (options.externalPackages) {\n    // Add a plugin that marks any resolved path as external if it is within a node modules directory.\n    // This is used instead of the esbuild `packages` option to avoid marking bare specifiers that use\n    // tsconfig path mapping to resolve to a workspace relative path. This is common for monorepos that\n    // contain libraries that are built along with the application. These libraries should not be considered\n    // external even though the imports appear to be packages.\n    const EXTERNAL_PACKAGE_RESOLUTION = Symbol('EXTERNAL_PACKAGE_RESOLUTION');\n    buildOptions.plugins ??= [];\n    buildOptions.plugins.push({\n      name: 'angular-external-packages',\n      setup(build) {\n        build.onResolve({ filter: /./ }, async (args) => {\n          if (args.pluginData?.[EXTERNAL_PACKAGE_RESOLUTION]) {\n            return null;\n          }\n\n          const { importer, kind, resolveDir, namespace, pluginData = {} } = args;\n          pluginData[EXTERNAL_PACKAGE_RESOLUTION] = true;\n\n          const result = await build.resolve(args.path, {\n            importer,\n            kind,\n            namespace,\n            pluginData,\n            resolveDir,\n          });\n\n          if (result.path && /[\\\\/]node_modules[\\\\/]/.test(result.path)) {\n            return {\n              path: args.path,\n              external: true,\n            };\n          }\n\n          return result;\n        });\n      },\n    });\n  }\n\n  const polyfills = options.polyfills ? [...options.polyfills] : [];\n  if (jit) {\n    polyfills.push('@angular/compiler');\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      createVirtualModulePlugin({\n        namespace,\n        loadContent: () => ({\n          contents: polyfills.map((file) => `import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'js',\n          resolveDir: workspaceRoot,\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    // esbuild currently has a defect involving self-referencing a class within a static code block or\n    // static field initializer. This is not an issue for projects that use the default browserslist as these\n    // elements are an ES2022 feature which is not support by all browsers in the default list. However, if a\n    // custom browserslist is used that only has newer browsers than the static code elements may be present.\n    // This issue is compounded by the default usage of the tsconfig `\"useDefineForClassFields\": false` option\n    // present in generated CLI projects which causes static code blocks to be used instead of static fields.\n    // esbuild currently unconditionally downlevels all static fields in top-level classes so to workaround the\n    // Angular issue only static code blocks are disabled here.\n    // For more details: https://github.com/evanw/esbuild/issues/2950\n    'class-static-blocks': 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\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 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  return buildEsbuildBrowserInternal(userOptions, context, infrastructureSettings);\n}\n\n/**\n * Internal version of the main execution function for the esbuild-based application builder.\n * Exposes some additional \"private\" options in addition to those exposed by the schema.\n * @param userOptions The browser-esbuild 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* buildEsbuildBrowserInternal(\n  userOptions: BrowserEsbuildOptions,\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 status of builder and options\n  logBuilderStatusWarnings(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\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  // Watch locations provided by the initial build result\n  let previousWatchFiles = new Set(result.watchFiles);\n  watcher.add(result.watchFiles);\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (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      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (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(\n  context: BuilderContext,\n  metafile: Metafile,\n  initial: Map<string, InitialFileRecord>,\n  estimatedTransferSizes?: Map<string, number>,\n) {\n  const stats: BundleStats[] = [];\n  for (const [file, output] of Object.entries(metafile.outputs)) {\n    // Only display JavaScript and CSS files\n    if (!file.endsWith('.js') && !file.endsWith('.css')) {\n      continue;\n    }\n    // Skip internal component resources\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    if ((output as any)['ng-component']) {\n      continue;\n    }\n\n    stats.push({\n      initial: initial.has(file),\n      stats: [\n        file,\n        initial.get(file)?.name ?? '-',\n        output.bytes,\n        estimatedTransferSizes?.get(file) ?? '-',\n      ],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, !!estimatedTransferSizes, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nasync function calculateEstimatedTransferSizes(outputFiles: OutputFile[]) {\n  const sizes = new Map<string, number>();\n\n  const pendingCompression = [];\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n"]}
@@ -19,6 +19,11 @@ interface InternalOptions {
19
19
  entryPoints?: Set<string>;
20
20
  /** File extension to use for the generated output files. */
21
21
  outExtension?: 'js' | 'mjs';
22
+ /**
23
+ * Indicates whether all node packages should be marked as external.
24
+ * Currently used by the dev-server to support prebundling.
25
+ */
26
+ externalPackages?: boolean;
22
27
  }
23
28
  /** Full set of options for `browser-esbuild` builder. */
24
29
  export type BrowserEsbuildOptions = Omit<BrowserBuilderOptions & InternalOptions, 'main'> & {
@@ -48,6 +53,7 @@ export declare function normalizeOptions(context: BuilderContext, projectName: s
48
53
  polyfills: string[] | undefined;
49
54
  poll: number | undefined;
50
55
  progress: boolean;
56
+ externalPackages: boolean | undefined;
51
57
  preserveSymlinks: boolean;
52
58
  stylePreprocessorOptions: import("./schema").StylePreprocessorOptions | undefined;
53
59
  subresourceIntegrity: boolean | undefined;
@@ -116,7 +116,7 @@ async function normalizeOptions(context, projectName, options) {
116
116
  };
117
117
  }
118
118
  // Initial options to keep
119
- const { allowedCommonJsDependencies, aot, baseHref, buildOptimizer, crossOrigin, externalDependencies, extractLicenses, inlineStyleLanguage = 'css', outExtension, poll, polyfills, preserveSymlinks, statsJson, stylePreprocessorOptions, subresourceIntegrity, verbose, watch, progress, } = options;
119
+ const { allowedCommonJsDependencies, aot, baseHref, buildOptimizer, crossOrigin, externalDependencies, extractLicenses, inlineStyleLanguage = 'css', outExtension, poll, polyfills, preserveSymlinks, statsJson, stylePreprocessorOptions, subresourceIntegrity, verbose, watch, progress, externalPackages, } = options;
120
120
  // Return all the normalized options
121
121
  return {
122
122
  advancedOptimizations: buildOptimizer,
@@ -132,6 +132,7 @@ async function normalizeOptions(context, projectName, options) {
132
132
  polyfills: polyfills === undefined || Array.isArray(polyfills) ? polyfills : [polyfills],
133
133
  poll,
134
134
  progress: progress ?? true,
135
+ externalPackages,
135
136
  // If not explicitly set, default to the Node.js process argument
136
137
  preserveSymlinks: preserveSymlinks ?? process.execArgv.includes('--preserve-symlinks'),
137
138
  stylePreprocessorOptions,
@@ -226,4 +227,4 @@ function normalizeDirectoryPath(path) {
226
227
  }
227
228
  return path;
228
229
  }
229
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/options.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 { createRequire } from 'node:module';\nimport path from 'node:path';\nimport { normalizeAssetPatterns, normalizeOptimization, normalizeSourceMaps } from '../../utils';\nimport { normalizeCacheOptions } from '../../utils/normalize-cache';\nimport { generateEntryPoints } from '../../utils/package-chunk-sort';\nimport { findTailwindConfigurationFile } from '../../utils/tailwind';\nimport { getIndexInputFile, getIndexOutputFile } from '../../utils/webpack-browser-config';\nimport { globalScriptsByBundleName, normalizeGlobalStyles } from '../../webpack/utils/helpers';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from './schema';\n\nexport type NormalizedBrowserOptions = Awaited<ReturnType<typeof normalizeOptions>>;\n\n/** Internal options hidden from builder schema but available when invoked programmatically. */\ninterface InternalOptions {\n  /**\n   * Entry points to use for the compilation. Incompatible with `main`, which must not be provided. May be relative or absolute paths.\n   * If given a relative path, it is resolved relative to the current workspace and will generate an output at the same relative location\n   * in the output directory. If given an absolute path, the output will be generated in the root of the output directory with the same base\n   * name.\n   */\n  entryPoints?: Set<string>;\n\n  /** File extension to use for the generated output files. */\n  outExtension?: 'js' | 'mjs';\n}\n\n/** Full set of options for `browser-esbuild` builder. */\nexport type BrowserEsbuildOptions = Omit<BrowserBuilderOptions & InternalOptions, 'main'> & {\n  // `main` can be `undefined` if `entryPoints` is used.\n  main?: string;\n};\n\n/**\n * Normalize the user provided options by creating full paths for all path based options\n * and converting multi-form options into a single form that can be directly used\n * by the build process.\n *\n * @param context The context for current builder execution.\n * @param projectName The name of the project for the current execution.\n * @param options An object containing the options to use for the build.\n * @returns An object containing normalized options required to perform the build.\n */\nexport async function normalizeOptions(\n  context: BuilderContext,\n  projectName: string,\n  options: BrowserEsbuildOptions,\n) {\n  const workspaceRoot = context.workspaceRoot;\n  const projectMetadata = await context.getProjectMetadata(projectName);\n  const projectRoot = normalizeDirectoryPath(\n    path.join(workspaceRoot, (projectMetadata.root as string | undefined) ?? ''),\n  );\n  const projectSourceRoot = normalizeDirectoryPath(\n    path.join(workspaceRoot, (projectMetadata.sourceRoot as string | undefined) ?? 'src'),\n  );\n\n  // Gather persistent caching option and provide a project specific cache location\n  const cacheOptions = normalizeCacheOptions(projectMetadata, workspaceRoot);\n  cacheOptions.path = path.join(cacheOptions.path, projectName);\n\n  const entryPoints = normalizeEntryPoints(workspaceRoot, options.main, options.entryPoints);\n  const tsconfig = path.join(workspaceRoot, options.tsConfig);\n  const outputPath = normalizeDirectoryPath(path.join(workspaceRoot, options.outputPath));\n  const optimizationOptions = normalizeOptimization(options.optimization);\n  const sourcemapOptions = normalizeSourceMaps(options.sourceMap ?? false);\n  const assets = options.assets?.length\n    ? normalizeAssetPatterns(options.assets, workspaceRoot, projectRoot, projectSourceRoot)\n    : undefined;\n\n  const outputNames = {\n    bundles:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Bundles\n        ? '[name].[hash]'\n        : '[name]',\n    media:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Media\n        ? '[name].[hash]'\n        : '[name]',\n  };\n  if (options.resourcesOutputPath) {\n    outputNames.media = path.join(options.resourcesOutputPath, outputNames.media);\n  }\n\n  let fileReplacements: Record<string, string> | undefined;\n  if (options.fileReplacements) {\n    for (const replacement of options.fileReplacements) {\n      fileReplacements ??= {};\n      fileReplacements[path.join(workspaceRoot, replacement.replace)] = path.join(\n        workspaceRoot,\n        replacement.with,\n      );\n    }\n  }\n\n  const globalStyles: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.styles?.length) {\n    const { entryPoints: stylesheetEntrypoints, noInjectNames } = normalizeGlobalStyles(\n      options.styles || [],\n    );\n    for (const [name, files] of Object.entries(stylesheetEntrypoints)) {\n      globalStyles.push({ name, files, initial: !noInjectNames.includes(name) });\n    }\n  }\n\n  const globalScripts: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.scripts?.length) {\n    for (const { bundleName, paths, inject } of globalScriptsByBundleName(options.scripts)) {\n      globalScripts.push({ name: bundleName, files: paths, initial: inject });\n    }\n  }\n\n  let tailwindConfiguration: { file: string; package: string } | undefined;\n  const tailwindConfigurationPath = await findTailwindConfigurationFile(workspaceRoot, projectRoot);\n  if (tailwindConfigurationPath) {\n    // Create a node resolver at the project root as a directory\n    const resolver = createRequire(projectRoot + '/');\n    try {\n      tailwindConfiguration = {\n        file: tailwindConfigurationPath,\n        package: resolver.resolve('tailwindcss'),\n      };\n    } catch {\n      const relativeTailwindConfigPath = path.relative(workspaceRoot, tailwindConfigurationPath);\n      context.logger.warn(\n        `Tailwind CSS configuration file found (${relativeTailwindConfigPath})` +\n          ` but the 'tailwindcss' package is not installed.` +\n          ` To enable Tailwind CSS, please install the 'tailwindcss' package.`,\n      );\n    }\n  }\n\n  let serviceWorkerOptions;\n  if (options.serviceWorker) {\n    // If ngswConfigPath is not specified, the default is 'ngsw-config.json' within the project root\n    serviceWorkerOptions = options.ngswConfigPath\n      ? path.join(workspaceRoot, options.ngswConfigPath)\n      : path.join(projectRoot, 'ngsw-config.json');\n  }\n\n  let indexHtmlOptions;\n  if (options.index) {\n    indexHtmlOptions = {\n      input: path.join(workspaceRoot, getIndexInputFile(options.index)),\n      // The output file will be created within the configured output path\n      output: getIndexOutputFile(options.index),\n      // TODO: Use existing information from above to create the insertion order\n      insertionOrder: generateEntryPoints({\n        scripts: options.scripts ?? [],\n        styles: options.styles ?? [],\n      }),\n    };\n  }\n\n  // Initial options to keep\n  const {\n    allowedCommonJsDependencies,\n    aot,\n    baseHref,\n    buildOptimizer,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage = 'css',\n    outExtension,\n    poll,\n    polyfills,\n    preserveSymlinks,\n    statsJson,\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    progress,\n  } = options;\n\n  // Return all the normalized options\n  return {\n    advancedOptimizations: buildOptimizer,\n    allowedCommonJsDependencies,\n    baseHref,\n    cacheOptions,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage,\n    jit: !aot,\n    stats: !!statsJson,\n    polyfills: polyfills === undefined || Array.isArray(polyfills) ? polyfills : [polyfills],\n    poll,\n    progress: progress ?? true,\n    // If not explicitly set, default to the Node.js process argument\n    preserveSymlinks: preserveSymlinks ?? process.execArgv.includes('--preserve-symlinks'),\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    outputPath,\n    outExtension,\n    sourcemapOptions,\n    tsconfig,\n    projectRoot,\n    assets,\n    outputNames,\n    fileReplacements,\n    globalStyles,\n    globalScripts,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n    tailwindConfiguration,\n  };\n}\n\n/**\n * Normalize entry point options. To maintain compatibility with the legacy browser builder, we need a single `main` option which defines a\n * single entry point. However, we also want to support multiple entry points as an internal option. The two options are mutually exclusive\n * and if `main` is provided it will be used as the sole entry point. If `entryPoints` are provided, they will be used as the set of entry\n * points.\n *\n * @param workspaceRoot Path to the root of the Angular workspace.\n * @param main The `main` option pointing at the application entry point. While required per the schema file, it may be omitted by\n *     programmatic usages of `browser-esbuild`.\n * @param entryPoints Set of entry points to use if provided.\n * @returns An object mapping entry point names to their file paths.\n */\nfunction normalizeEntryPoints(\n  workspaceRoot: string,\n  main: string | undefined,\n  entryPoints: Set<string> = new Set(),\n): Record<string, string> {\n  if (main === '') {\n    throw new Error('`main` option cannot be an empty string.');\n  }\n\n  // `main` and `entryPoints` are mutually exclusive.\n  if (main && entryPoints.size > 0) {\n    throw new Error('Only one of `main` or `entryPoints` may be provided.');\n  }\n  if (!main && entryPoints.size === 0) {\n    // Schema should normally reject this case, but programmatic usages of the builder might make this mistake.\n    throw new Error('Either `main` or at least one `entryPoints` value must be provided.');\n  }\n\n  // Schema types force `main` to always be provided, but it may be omitted when the builder is invoked programmatically.\n  if (main) {\n    // Use `main` alone.\n    return { 'main': path.join(workspaceRoot, main) };\n  } else {\n    // Use `entryPoints` alone.\n    const entryPointPaths: Record<string, string> = {};\n    for (const entryPoint of entryPoints) {\n      const parsedEntryPoint = path.parse(entryPoint);\n\n      // Use the input file path without an extension as the \"name\" of the entry point dictating its output location.\n      // Relative entry points are generated at the same relative path in the output directory.\n      // Absolute entry points are always generated with the same file name in the root of the output directory. This includes absolute\n      // paths pointing at files actually within the workspace root.\n      const entryPointName = path.isAbsolute(entryPoint)\n        ? parsedEntryPoint.name\n        : path.join(parsedEntryPoint.dir, parsedEntryPoint.name);\n\n      // Get the full file path to the entry point input.\n      const entryPointPath = path.isAbsolute(entryPoint)\n        ? entryPoint\n        : path.join(workspaceRoot, entryPoint);\n\n      // Check for conflicts with previous entry points.\n      const existingEntryPointPath = entryPointPaths[entryPointName];\n      if (existingEntryPointPath) {\n        throw new Error(\n          `\\`${existingEntryPointPath}\\` and \\`${entryPointPath}\\` both output to the same location \\`${entryPointName}\\`.` +\n            ' Rename or move one of the files to fix the conflict.',\n        );\n      }\n\n      entryPointPaths[entryPointName] = entryPointPath;\n    }\n\n    return entryPointPaths;\n  }\n}\n\n/**\n * Normalize a directory path string.\n * Currently only removes a trailing slash if present.\n * @param path A path string.\n * @returns A normalized path string.\n */\nfunction normalizeDirectoryPath(path: string): string {\n  const last = path[path.length - 1];\n  if (last === '/' || last === '\\\\') {\n    return path.slice(0, -1);\n  }\n\n  return path;\n}\n"]}
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/options.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 { createRequire } from 'node:module';\nimport path from 'node:path';\nimport { normalizeAssetPatterns, normalizeOptimization, normalizeSourceMaps } from '../../utils';\nimport { normalizeCacheOptions } from '../../utils/normalize-cache';\nimport { generateEntryPoints } from '../../utils/package-chunk-sort';\nimport { findTailwindConfigurationFile } from '../../utils/tailwind';\nimport { getIndexInputFile, getIndexOutputFile } from '../../utils/webpack-browser-config';\nimport { globalScriptsByBundleName, normalizeGlobalStyles } from '../../webpack/utils/helpers';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from './schema';\n\nexport type NormalizedBrowserOptions = Awaited<ReturnType<typeof normalizeOptions>>;\n\n/** Internal options hidden from builder schema but available when invoked programmatically. */\ninterface InternalOptions {\n  /**\n   * Entry points to use for the compilation. Incompatible with `main`, which must not be provided. May be relative or absolute paths.\n   * If given a relative path, it is resolved relative to the current workspace and will generate an output at the same relative location\n   * in the output directory. If given an absolute path, the output will be generated in the root of the output directory with the same base\n   * name.\n   */\n  entryPoints?: Set<string>;\n\n  /** File extension to use for the generated output files. */\n  outExtension?: 'js' | 'mjs';\n\n  /**\n   * Indicates whether all node packages should be marked as external.\n   * Currently used by the dev-server to support prebundling.\n   */\n  externalPackages?: boolean;\n}\n\n/** Full set of options for `browser-esbuild` builder. */\nexport type BrowserEsbuildOptions = Omit<BrowserBuilderOptions & InternalOptions, 'main'> & {\n  // `main` can be `undefined` if `entryPoints` is used.\n  main?: string;\n};\n\n/**\n * Normalize the user provided options by creating full paths for all path based options\n * and converting multi-form options into a single form that can be directly used\n * by the build process.\n *\n * @param context The context for current builder execution.\n * @param projectName The name of the project for the current execution.\n * @param options An object containing the options to use for the build.\n * @returns An object containing normalized options required to perform the build.\n */\nexport async function normalizeOptions(\n  context: BuilderContext,\n  projectName: string,\n  options: BrowserEsbuildOptions,\n) {\n  const workspaceRoot = context.workspaceRoot;\n  const projectMetadata = await context.getProjectMetadata(projectName);\n  const projectRoot = normalizeDirectoryPath(\n    path.join(workspaceRoot, (projectMetadata.root as string | undefined) ?? ''),\n  );\n  const projectSourceRoot = normalizeDirectoryPath(\n    path.join(workspaceRoot, (projectMetadata.sourceRoot as string | undefined) ?? 'src'),\n  );\n\n  // Gather persistent caching option and provide a project specific cache location\n  const cacheOptions = normalizeCacheOptions(projectMetadata, workspaceRoot);\n  cacheOptions.path = path.join(cacheOptions.path, projectName);\n\n  const entryPoints = normalizeEntryPoints(workspaceRoot, options.main, options.entryPoints);\n  const tsconfig = path.join(workspaceRoot, options.tsConfig);\n  const outputPath = normalizeDirectoryPath(path.join(workspaceRoot, options.outputPath));\n  const optimizationOptions = normalizeOptimization(options.optimization);\n  const sourcemapOptions = normalizeSourceMaps(options.sourceMap ?? false);\n  const assets = options.assets?.length\n    ? normalizeAssetPatterns(options.assets, workspaceRoot, projectRoot, projectSourceRoot)\n    : undefined;\n\n  const outputNames = {\n    bundles:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Bundles\n        ? '[name].[hash]'\n        : '[name]',\n    media:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Media\n        ? '[name].[hash]'\n        : '[name]',\n  };\n  if (options.resourcesOutputPath) {\n    outputNames.media = path.join(options.resourcesOutputPath, outputNames.media);\n  }\n\n  let fileReplacements: Record<string, string> | undefined;\n  if (options.fileReplacements) {\n    for (const replacement of options.fileReplacements) {\n      fileReplacements ??= {};\n      fileReplacements[path.join(workspaceRoot, replacement.replace)] = path.join(\n        workspaceRoot,\n        replacement.with,\n      );\n    }\n  }\n\n  const globalStyles: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.styles?.length) {\n    const { entryPoints: stylesheetEntrypoints, noInjectNames } = normalizeGlobalStyles(\n      options.styles || [],\n    );\n    for (const [name, files] of Object.entries(stylesheetEntrypoints)) {\n      globalStyles.push({ name, files, initial: !noInjectNames.includes(name) });\n    }\n  }\n\n  const globalScripts: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.scripts?.length) {\n    for (const { bundleName, paths, inject } of globalScriptsByBundleName(options.scripts)) {\n      globalScripts.push({ name: bundleName, files: paths, initial: inject });\n    }\n  }\n\n  let tailwindConfiguration: { file: string; package: string } | undefined;\n  const tailwindConfigurationPath = await findTailwindConfigurationFile(workspaceRoot, projectRoot);\n  if (tailwindConfigurationPath) {\n    // Create a node resolver at the project root as a directory\n    const resolver = createRequire(projectRoot + '/');\n    try {\n      tailwindConfiguration = {\n        file: tailwindConfigurationPath,\n        package: resolver.resolve('tailwindcss'),\n      };\n    } catch {\n      const relativeTailwindConfigPath = path.relative(workspaceRoot, tailwindConfigurationPath);\n      context.logger.warn(\n        `Tailwind CSS configuration file found (${relativeTailwindConfigPath})` +\n          ` but the 'tailwindcss' package is not installed.` +\n          ` To enable Tailwind CSS, please install the 'tailwindcss' package.`,\n      );\n    }\n  }\n\n  let serviceWorkerOptions;\n  if (options.serviceWorker) {\n    // If ngswConfigPath is not specified, the default is 'ngsw-config.json' within the project root\n    serviceWorkerOptions = options.ngswConfigPath\n      ? path.join(workspaceRoot, options.ngswConfigPath)\n      : path.join(projectRoot, 'ngsw-config.json');\n  }\n\n  let indexHtmlOptions;\n  if (options.index) {\n    indexHtmlOptions = {\n      input: path.join(workspaceRoot, getIndexInputFile(options.index)),\n      // The output file will be created within the configured output path\n      output: getIndexOutputFile(options.index),\n      // TODO: Use existing information from above to create the insertion order\n      insertionOrder: generateEntryPoints({\n        scripts: options.scripts ?? [],\n        styles: options.styles ?? [],\n      }),\n    };\n  }\n\n  // Initial options to keep\n  const {\n    allowedCommonJsDependencies,\n    aot,\n    baseHref,\n    buildOptimizer,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage = 'css',\n    outExtension,\n    poll,\n    polyfills,\n    preserveSymlinks,\n    statsJson,\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    progress,\n    externalPackages,\n  } = options;\n\n  // Return all the normalized options\n  return {\n    advancedOptimizations: buildOptimizer,\n    allowedCommonJsDependencies,\n    baseHref,\n    cacheOptions,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage,\n    jit: !aot,\n    stats: !!statsJson,\n    polyfills: polyfills === undefined || Array.isArray(polyfills) ? polyfills : [polyfills],\n    poll,\n    progress: progress ?? true,\n    externalPackages,\n    // If not explicitly set, default to the Node.js process argument\n    preserveSymlinks: preserveSymlinks ?? process.execArgv.includes('--preserve-symlinks'),\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    outputPath,\n    outExtension,\n    sourcemapOptions,\n    tsconfig,\n    projectRoot,\n    assets,\n    outputNames,\n    fileReplacements,\n    globalStyles,\n    globalScripts,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n    tailwindConfiguration,\n  };\n}\n\n/**\n * Normalize entry point options. To maintain compatibility with the legacy browser builder, we need a single `main` option which defines a\n * single entry point. However, we also want to support multiple entry points as an internal option. The two options are mutually exclusive\n * and if `main` is provided it will be used as the sole entry point. If `entryPoints` are provided, they will be used as the set of entry\n * points.\n *\n * @param workspaceRoot Path to the root of the Angular workspace.\n * @param main The `main` option pointing at the application entry point. While required per the schema file, it may be omitted by\n *     programmatic usages of `browser-esbuild`.\n * @param entryPoints Set of entry points to use if provided.\n * @returns An object mapping entry point names to their file paths.\n */\nfunction normalizeEntryPoints(\n  workspaceRoot: string,\n  main: string | undefined,\n  entryPoints: Set<string> = new Set(),\n): Record<string, string> {\n  if (main === '') {\n    throw new Error('`main` option cannot be an empty string.');\n  }\n\n  // `main` and `entryPoints` are mutually exclusive.\n  if (main && entryPoints.size > 0) {\n    throw new Error('Only one of `main` or `entryPoints` may be provided.');\n  }\n  if (!main && entryPoints.size === 0) {\n    // Schema should normally reject this case, but programmatic usages of the builder might make this mistake.\n    throw new Error('Either `main` or at least one `entryPoints` value must be provided.');\n  }\n\n  // Schema types force `main` to always be provided, but it may be omitted when the builder is invoked programmatically.\n  if (main) {\n    // Use `main` alone.\n    return { 'main': path.join(workspaceRoot, main) };\n  } else {\n    // Use `entryPoints` alone.\n    const entryPointPaths: Record<string, string> = {};\n    for (const entryPoint of entryPoints) {\n      const parsedEntryPoint = path.parse(entryPoint);\n\n      // Use the input file path without an extension as the \"name\" of the entry point dictating its output location.\n      // Relative entry points are generated at the same relative path in the output directory.\n      // Absolute entry points are always generated with the same file name in the root of the output directory. This includes absolute\n      // paths pointing at files actually within the workspace root.\n      const entryPointName = path.isAbsolute(entryPoint)\n        ? parsedEntryPoint.name\n        : path.join(parsedEntryPoint.dir, parsedEntryPoint.name);\n\n      // Get the full file path to the entry point input.\n      const entryPointPath = path.isAbsolute(entryPoint)\n        ? entryPoint\n        : path.join(workspaceRoot, entryPoint);\n\n      // Check for conflicts with previous entry points.\n      const existingEntryPointPath = entryPointPaths[entryPointName];\n      if (existingEntryPointPath) {\n        throw new Error(\n          `\\`${existingEntryPointPath}\\` and \\`${entryPointPath}\\` both output to the same location \\`${entryPointName}\\`.` +\n            ' Rename or move one of the files to fix the conflict.',\n        );\n      }\n\n      entryPointPaths[entryPointName] = entryPointPath;\n    }\n\n    return entryPointPaths;\n  }\n}\n\n/**\n * Normalize a directory path string.\n * Currently only removes a trailing slash if present.\n * @param path A path string.\n * @returns A normalized path string.\n */\nfunction normalizeDirectoryPath(path: string): string {\n  const last = path[path.length - 1];\n  if (last === '/' || last === '\\\\') {\n    return path.slice(0, -1);\n  }\n\n  return path;\n}\n"]}