@angular-devkit/build-angular 16.0.0-next.6 → 16.0.0-next.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,27 +1,28 @@
1
1
  {
2
2
  "name": "@angular-devkit/build-angular",
3
- "version": "16.0.0-next.6",
3
+ "version": "16.0.0-next.7",
4
4
  "description": "Angular Webpack Build Facade",
5
5
  "main": "src/index.js",
6
6
  "typings": "src/index.d.ts",
7
7
  "builders": "builders.json",
8
8
  "dependencies": {
9
9
  "@ampproject/remapping": "2.2.0",
10
- "@angular-devkit/architect": "0.1600.0-next.6",
11
- "@angular-devkit/build-webpack": "0.1600.0-next.6",
12
- "@angular-devkit/core": "16.0.0-next.6",
13
- "@babel/core": "7.21.3",
14
- "@babel/generator": "7.21.3",
10
+ "@angular-devkit/architect": "0.1600.0-next.7",
11
+ "@angular-devkit/build-webpack": "0.1600.0-next.7",
12
+ "@angular-devkit/core": "16.0.0-next.7",
13
+ "@babel/core": "7.21.4",
14
+ "@babel/generator": "7.21.4",
15
15
  "@babel/helper-annotate-as-pure": "7.18.6",
16
16
  "@babel/helper-split-export-declaration": "7.18.6",
17
17
  "@babel/plugin-proposal-async-generator-functions": "7.20.7",
18
18
  "@babel/plugin-transform-async-to-generator": "7.20.7",
19
- "@babel/plugin-transform-runtime": "7.21.0",
20
- "@babel/preset-env": "7.20.2",
19
+ "@babel/plugin-transform-runtime": "7.21.4",
20
+ "@babel/preset-env": "7.21.4",
21
21
  "@babel/runtime": "7.21.0",
22
22
  "@babel/template": "7.20.7",
23
23
  "@discoveryjs/json-ext": "0.5.7",
24
- "@ngtools/webpack": "16.0.0-next.6",
24
+ "@ngtools/webpack": "16.0.0-next.7",
25
+ "@vitejs/plugin-basic-ssl": "1.0.1",
25
26
  "ansi-colors": "4.1.3",
26
27
  "autoprefixer": "10.4.14",
27
28
  "babel-loader": "9.1.2",
@@ -32,7 +33,7 @@
32
33
  "copy-webpack-plugin": "11.0.0",
33
34
  "critters": "0.0.16",
34
35
  "css-loader": "6.7.3",
35
- "esbuild-wasm": "0.17.12",
36
+ "esbuild-wasm": "0.17.15",
36
37
  "glob": "8.1.0",
37
38
  "https-proxy-agent": "5.0.1",
38
39
  "inquirer": "8.2.4",
@@ -49,26 +50,27 @@
49
50
  "parse5-html-rewriting-stream": "7.0.0",
50
51
  "piscina": "3.2.0",
51
52
  "postcss": "8.4.21",
52
- "postcss-loader": "7.1.0",
53
+ "postcss-loader": "7.2.3",
53
54
  "resolve-url-loader": "5.0.0",
54
55
  "rxjs": "7.8.0",
55
- "sass": "1.59.3",
56
- "sass-loader": "13.2.1",
56
+ "sass": "1.60.0",
57
+ "sass-loader": "13.2.2",
57
58
  "semver": "7.3.8",
58
59
  "source-map-loader": "4.0.1",
59
60
  "source-map-support": "0.5.21",
60
- "terser": "5.16.6",
61
+ "terser": "5.16.8",
61
62
  "text-table": "0.2.0",
62
63
  "tree-kill": "1.2.2",
63
64
  "tslib": "2.5.0",
64
- "webpack": "5.76.2",
65
+ "vite": "4.2.1",
66
+ "webpack": "5.77.0",
65
67
  "webpack-dev-middleware": "6.0.2",
66
- "webpack-dev-server": "4.13.1",
68
+ "webpack-dev-server": "4.13.2",
67
69
  "webpack-merge": "5.8.0",
68
70
  "webpack-subresource-integrity": "5.1.0"
69
71
  },
70
72
  "optionalDependencies": {
71
- "esbuild": "0.17.12"
73
+ "esbuild": "0.17.15"
72
74
  },
73
75
  "peerDependencies": {
74
76
  "@angular/compiler-cli": "^16.0.0-next.0",
@@ -77,7 +77,7 @@ function createCssPlugin(options) {
77
77
  // Add a load callback to support inline Component styles
78
78
  build.onLoad({ filter: /^css;/, namespace: 'angular:styles/component' }, async (args) => {
79
79
  const data = options.inlineComponentData?.[args.path];
80
- (0, node_assert_1.default)(data, `component style name should always be found [${args.path}]`);
80
+ (0, node_assert_1.default)(typeof data === 'string', `component style name should always be found [${args.path}]`);
81
81
  const [, , filePath] = args.path.split(';', 3);
82
82
  return compileString(data, filePath, postcssProcessor, options);
83
83
  });
@@ -161,4 +161,4 @@ async function compileString(data, filename, postcssProcessor, options) {
161
161
  throw error;
162
162
  }
163
163
  }
164
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"css-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/css-plugin.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 createAutoPrefixerPlugin from 'autoprefixer';\nimport type { OnLoadResult, Plugin, PluginBuild } from 'esbuild';\nimport assert from 'node:assert';\nimport { readFile } from 'node:fs/promises';\n\n/**\n * The lazy-loaded instance of the postcss stylesheet postprocessor.\n * It is only imported and initialized if postcss is needed.\n */\nlet postcss: typeof import('postcss')['default'] | undefined;\n\n/**\n * An object containing the plugin options to use when processing CSS stylesheets.\n */\nexport interface CssPluginOptions {\n  /**\n   * Controls the use and creation of sourcemaps when processing the stylesheets.\n   * If true, sourcemap processing is enabled; if false, disabled.\n   */\n  sourcemap: boolean;\n  /**\n   * Optional component data for any inline styles from Component decorator `styles` fields.\n   * The key is an internal angular resource URI and the value is the stylesheet content.\n   */\n  inlineComponentData?: Record<string, string>;\n  /**\n   * The browsers to support in browserslist format when processing stylesheets.\n   * Some postcss plugins such as autoprefixer require the raw browserslist information instead\n   * of the esbuild formatted target.\n   */\n  browsers: string[];\n\n  tailwindConfiguration?: { file: string; package: string };\n}\n\n/**\n * Creates an esbuild plugin to process CSS stylesheets.\n * @param options An object containing the plugin options.\n * @returns An esbuild Plugin instance.\n */\nexport function createCssPlugin(options: CssPluginOptions): Plugin {\n  return {\n    name: 'angular-css',\n    async setup(build: PluginBuild): Promise<void> {\n      const autoprefixer = createAutoPrefixerPlugin({\n        overrideBrowserslist: options.browsers,\n        ignoreUnknownVersions: true,\n      });\n\n      // Autoprefixer currently does not contain a method to check if autoprefixer is required\n      // based on the provided list of browsers. However, it does contain a method that returns\n      // informational text that can be used as a replacement. The text \"Awesome!\" will be present\n      // when autoprefixer determines no actions are needed.\n      // ref: https://github.com/postcss/autoprefixer/blob/e2f5c26ff1f3eaca95a21873723ce1cdf6e59f0e/lib/info.js#L118\n      const autoprefixerInfo = autoprefixer.info({ from: build.initialOptions.absWorkingDir });\n      const skipAutoprefixer = autoprefixerInfo.includes('Awesome!');\n\n      if (skipAutoprefixer && !options.tailwindConfiguration) {\n        return;\n      }\n\n      postcss ??= (await import('postcss')).default;\n      const postcssProcessor = postcss();\n      if (options.tailwindConfiguration) {\n        const tailwind = await import(options.tailwindConfiguration.package);\n        postcssProcessor.use(tailwind.default({ config: options.tailwindConfiguration.file }));\n      }\n      if (!skipAutoprefixer) {\n        postcssProcessor.use(autoprefixer);\n      }\n\n      // Add a load callback to support inline Component styles\n      build.onLoad({ filter: /^css;/, namespace: 'angular:styles/component' }, async (args) => {\n        const data = options.inlineComponentData?.[args.path];\n        assert(data, `component style name should always be found [${args.path}]`);\n\n        const [, , filePath] = args.path.split(';', 3);\n\n        return compileString(data, filePath, postcssProcessor, options);\n      });\n\n      // Add a load callback to support files from disk\n      build.onLoad({ filter: /\\.css$/ }, async (args) => {\n        const data = await readFile(args.path, 'utf-8');\n\n        return compileString(data, args.path, postcssProcessor, options);\n      });\n    },\n  };\n}\n\n/**\n * Compiles the provided CSS stylesheet data using a provided postcss processor and provides an\n * esbuild load result that can be used directly by an esbuild Plugin.\n * @param data The stylesheet content to process.\n * @param filename The name of the file that contains the data.\n * @param postcssProcessor A postcss processor instance to use.\n * @param options The plugin options to control the processing.\n * @returns An esbuild OnLoaderResult object with the processed content, warnings, and/or errors.\n */\nasync function compileString(\n  data: string,\n  filename: string,\n  postcssProcessor: import('postcss').Processor,\n  options: CssPluginOptions,\n): Promise<OnLoadResult> {\n  try {\n    const result = await postcssProcessor.process(data, {\n      from: filename,\n      to: filename,\n      map: options.sourcemap && {\n        inline: true,\n        sourcesContent: true,\n      },\n    });\n\n    const rawWarnings = result.warnings();\n    let warnings;\n    if (rawWarnings.length > 0) {\n      const lineMappings = new Map<string, string[] | null>();\n      warnings = rawWarnings.map((warning) => {\n        const file = warning.node.source?.input.file;\n        if (file === undefined) {\n          return { text: warning.text };\n        }\n\n        let lines = lineMappings.get(file);\n        if (lines === undefined) {\n          lines = warning.node.source?.input.css.split(/\\r?\\n/);\n          lineMappings.set(file, lines ?? null);\n        }\n\n        return {\n          text: warning.text,\n          location: {\n            file,\n            line: warning.line,\n            column: warning.column - 1,\n            lineText: lines?.[warning.line - 1],\n          },\n        };\n      });\n    }\n\n    return {\n      contents: result.css,\n      loader: 'css',\n      warnings,\n    };\n  } catch (error) {\n    postcss ??= (await import('postcss')).default;\n    if (error instanceof postcss.CssSyntaxError) {\n      const lines = error.source?.split(/\\r?\\n/);\n\n      return {\n        errors: [\n          {\n            text: error.reason,\n            location: {\n              file: error.file,\n              line: error.line,\n              column: error.column && error.column - 1,\n              lineText: error.line === undefined ? undefined : lines?.[error.line - 1],\n            },\n          },\n        ],\n      };\n    }\n\n    throw error;\n  }\n}\n"]}
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"css-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/css-plugin.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 createAutoPrefixerPlugin from 'autoprefixer';\nimport type { OnLoadResult, Plugin, PluginBuild } from 'esbuild';\nimport assert from 'node:assert';\nimport { readFile } from 'node:fs/promises';\n\n/**\n * The lazy-loaded instance of the postcss stylesheet postprocessor.\n * It is only imported and initialized if postcss is needed.\n */\nlet postcss: typeof import('postcss')['default'] | undefined;\n\n/**\n * An object containing the plugin options to use when processing CSS stylesheets.\n */\nexport interface CssPluginOptions {\n  /**\n   * Controls the use and creation of sourcemaps when processing the stylesheets.\n   * If true, sourcemap processing is enabled; if false, disabled.\n   */\n  sourcemap: boolean;\n  /**\n   * Optional component data for any inline styles from Component decorator `styles` fields.\n   * The key is an internal angular resource URI and the value is the stylesheet content.\n   */\n  inlineComponentData?: Record<string, string>;\n  /**\n   * The browsers to support in browserslist format when processing stylesheets.\n   * Some postcss plugins such as autoprefixer require the raw browserslist information instead\n   * of the esbuild formatted target.\n   */\n  browsers: string[];\n\n  tailwindConfiguration?: { file: string; package: string };\n}\n\n/**\n * Creates an esbuild plugin to process CSS stylesheets.\n * @param options An object containing the plugin options.\n * @returns An esbuild Plugin instance.\n */\nexport function createCssPlugin(options: CssPluginOptions): Plugin {\n  return {\n    name: 'angular-css',\n    async setup(build: PluginBuild): Promise<void> {\n      const autoprefixer = createAutoPrefixerPlugin({\n        overrideBrowserslist: options.browsers,\n        ignoreUnknownVersions: true,\n      });\n\n      // Autoprefixer currently does not contain a method to check if autoprefixer is required\n      // based on the provided list of browsers. However, it does contain a method that returns\n      // informational text that can be used as a replacement. The text \"Awesome!\" will be present\n      // when autoprefixer determines no actions are needed.\n      // ref: https://github.com/postcss/autoprefixer/blob/e2f5c26ff1f3eaca95a21873723ce1cdf6e59f0e/lib/info.js#L118\n      const autoprefixerInfo = autoprefixer.info({ from: build.initialOptions.absWorkingDir });\n      const skipAutoprefixer = autoprefixerInfo.includes('Awesome!');\n\n      if (skipAutoprefixer && !options.tailwindConfiguration) {\n        return;\n      }\n\n      postcss ??= (await import('postcss')).default;\n      const postcssProcessor = postcss();\n      if (options.tailwindConfiguration) {\n        const tailwind = await import(options.tailwindConfiguration.package);\n        postcssProcessor.use(tailwind.default({ config: options.tailwindConfiguration.file }));\n      }\n      if (!skipAutoprefixer) {\n        postcssProcessor.use(autoprefixer);\n      }\n\n      // Add a load callback to support inline Component styles\n      build.onLoad({ filter: /^css;/, namespace: 'angular:styles/component' }, async (args) => {\n        const data = options.inlineComponentData?.[args.path];\n        assert(\n          typeof data === 'string',\n          `component style name should always be found [${args.path}]`,\n        );\n\n        const [, , filePath] = args.path.split(';', 3);\n\n        return compileString(data, filePath, postcssProcessor, options);\n      });\n\n      // Add a load callback to support files from disk\n      build.onLoad({ filter: /\\.css$/ }, async (args) => {\n        const data = await readFile(args.path, 'utf-8');\n\n        return compileString(data, args.path, postcssProcessor, options);\n      });\n    },\n  };\n}\n\n/**\n * Compiles the provided CSS stylesheet data using a provided postcss processor and provides an\n * esbuild load result that can be used directly by an esbuild Plugin.\n * @param data The stylesheet content to process.\n * @param filename The name of the file that contains the data.\n * @param postcssProcessor A postcss processor instance to use.\n * @param options The plugin options to control the processing.\n * @returns An esbuild OnLoaderResult object with the processed content, warnings, and/or errors.\n */\nasync function compileString(\n  data: string,\n  filename: string,\n  postcssProcessor: import('postcss').Processor,\n  options: CssPluginOptions,\n): Promise<OnLoadResult> {\n  try {\n    const result = await postcssProcessor.process(data, {\n      from: filename,\n      to: filename,\n      map: options.sourcemap && {\n        inline: true,\n        sourcesContent: true,\n      },\n    });\n\n    const rawWarnings = result.warnings();\n    let warnings;\n    if (rawWarnings.length > 0) {\n      const lineMappings = new Map<string, string[] | null>();\n      warnings = rawWarnings.map((warning) => {\n        const file = warning.node.source?.input.file;\n        if (file === undefined) {\n          return { text: warning.text };\n        }\n\n        let lines = lineMappings.get(file);\n        if (lines === undefined) {\n          lines = warning.node.source?.input.css.split(/\\r?\\n/);\n          lineMappings.set(file, lines ?? null);\n        }\n\n        return {\n          text: warning.text,\n          location: {\n            file,\n            line: warning.line,\n            column: warning.column - 1,\n            lineText: lines?.[warning.line - 1],\n          },\n        };\n      });\n    }\n\n    return {\n      contents: result.css,\n      loader: 'css',\n      warnings,\n    };\n  } catch (error) {\n    postcss ??= (await import('postcss')).default;\n    if (error instanceof postcss.CssSyntaxError) {\n      const lines = error.source?.split(/\\r?\\n/);\n\n      return {\n        errors: [\n          {\n            text: error.reason,\n            location: {\n              file: error.file,\n              line: error.line,\n              column: error.column && error.column - 1,\n              lineText: error.line === undefined ? undefined : lines?.[error.line - 1],\n            },\n          },\n        ],\n      };\n    }\n\n    throw error;\n  }\n}\n"]}
@@ -10,8 +10,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
10
10
  exports.logExperimentalWarnings = void 0;
11
11
  const UNSUPPORTED_OPTIONS = [
12
12
  'budgets',
13
- 'progress',
14
- 'scripts',
15
13
  // * i18n support
16
14
  'localize',
17
15
  // The following two have no effect when localize is not enabled
@@ -46,4 +44,4 @@ function logExperimentalWarnings(options, context) {
46
44
  }
47
45
  }
48
46
  exports.logExperimentalWarnings = logExperimentalWarnings;
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwZXJpbWVudGFsLXdhcm5pbmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2V4cGVyaW1lbnRhbC13YXJuaW5ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFLSCxNQUFNLG1CQUFtQixHQUF1QztJQUM5RCxTQUFTO0lBQ1QsVUFBVTtJQUNWLFNBQVM7SUFFVCxpQkFBaUI7SUFDakIsVUFBVTtJQUNWLGdFQUFnRTtJQUNoRSw4QkFBOEI7SUFDOUIsNEJBQTRCO0lBRTVCLGVBQWU7SUFDZixXQUFXO0lBRVgsZ0NBQWdDO0lBQ2hDLGlCQUFpQjtJQUVqQixxQ0FBcUM7SUFDckMsYUFBYTtJQUNiLGFBQWE7SUFDYixtQkFBbUI7Q0FDcEIsQ0FBQztBQUVGLFNBQWdCLHVCQUF1QixDQUFDLE9BQThCLEVBQUUsT0FBdUI7SUFDN0YsaURBQWlEO0lBQ2pELE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUNqQix3RkFBd0YsQ0FDekYsQ0FBQztJQUVGLDZCQUE2QjtJQUM3QixzRkFBc0Y7SUFDdEYsS0FBSyxNQUFNLGlCQUFpQixJQUFJLG1CQUFtQixFQUFFO1FBQ25ELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRXpDLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxLQUFLLEtBQUssS0FBSyxFQUFFO1lBQzFDLFNBQVM7U0FDVjtRQUNELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUM5QyxTQUFTO1NBQ1Y7UUFDRCxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDaEUsU0FBUztTQUNWO1FBRUQsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ2pCLFFBQVEsaUJBQWlCLHFGQUFxRixDQUMvRyxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBekJELDBEQXlCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgeyBCdWlsZGVyQ29udGV4dCB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9hcmNoaXRlY3QnO1xuaW1wb3J0IHsgU2NoZW1hIGFzIEJyb3dzZXJCdWlsZGVyT3B0aW9ucyB9IGZyb20gJy4uL2Jyb3dzZXIvc2NoZW1hJztcblxuY29uc3QgVU5TVVBQT1JURURfT1BUSU9OUzogQXJyYXk8a2V5b2YgQnJvd3NlckJ1aWxkZXJPcHRpb25zPiA9IFtcbiAgJ2J1ZGdldHMnLFxuICAncHJvZ3Jlc3MnLFxuICAnc2NyaXB0cycsXG5cbiAgLy8gKiBpMThuIHN1cHBvcnRcbiAgJ2xvY2FsaXplJyxcbiAgLy8gVGhlIGZvbGxvd2luZyB0d28gaGF2ZSBubyBlZmZlY3Qgd2hlbiBsb2NhbGl6ZSBpcyBub3QgZW5hYmxlZFxuICAvLyAnaTE4bkR1cGxpY2F0ZVRyYW5zbGF0aW9uJyxcbiAgLy8gJ2kxOG5NaXNzaW5nVHJhbnNsYXRpb24nLFxuXG4gIC8vICogRGVwcmVjYXRlZFxuICAnZGVwbG95VXJsJyxcblxuICAvLyAqIEFsd2F5cyBlbmFibGVkIHdpdGggZXNidWlsZFxuICAvLyAnY29tbW9uQ2h1bmsnLFxuXG4gIC8vICogQ3VycmVudGx5IHVuc3VwcG9ydGVkIGJ5IGVzYnVpbGRcbiAgJ25hbWVkQ2h1bmtzJyxcbiAgJ3ZlbmRvckNodW5rJyxcbiAgJ3dlYldvcmtlclRzQ29uZmlnJyxcbl07XG5cbmV4cG9ydCBmdW5jdGlvbiBsb2dFeHBlcmltZW50YWxXYXJuaW5ncyhvcHRpb25zOiBCcm93c2VyQnVpbGRlck9wdGlvbnMsIGNvbnRleHQ6IEJ1aWxkZXJDb250ZXh0KSB7XG4gIC8vIFdhcm4gYWJvdXQgZXhwZXJpbWVudGFsIHN0YXR1cyBvZiB0aGlzIGJ1aWxkZXJcbiAgY29udGV4dC5sb2dnZXIud2FybihcbiAgICBgVGhlIGVzYnVpbGQgYnJvd3NlciBhcHBsaWNhdGlvbiBidWlsZGVyICgnYnJvd3Nlci1lc2J1aWxkJykgaXMgY3VycmVudGx5IGV4cGVyaW1lbnRhbC5gLFxuICApO1xuXG4gIC8vIFZhbGlkYXRlIHN1cHBvcnRlZCBvcHRpb25zXG4gIC8vIEN1cnJlbnRseSBvbmx5IGEgc3Vic2V0IG9mIHRoZSBXZWJwYWNrLWJhc2VkIGJyb3dzZXIgYnVpbGRlciBvcHRpb25zIGFyZSBzdXBwb3J0ZWQuXG4gIGZvciAoY29uc3QgdW5zdXBwb3J0ZWRPcHRpb24gb2YgVU5TVVBQT1JURURfT1BUSU9OUykge1xuICAgIGNvbnN0IHZhbHVlID0gb3B0aW9uc1t1bnN1cHBvcnRlZE9wdGlvbl07XG5cbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCB8fCB2YWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkgJiYgdmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgT2JqZWN0LmtleXModmFsdWUpLmxlbmd0aCA9PT0gMCkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgY29udGV4dC5sb2dnZXIud2FybihcbiAgICAgIGBUaGUgJyR7dW5zdXBwb3J0ZWRPcHRpb259JyBvcHRpb24gaXMgY3VycmVudGx5IHVuc3VwcG9ydGVkIGJ5IHRoaXMgZXhwZXJpbWVudGFsIGJ1aWxkZXIgYW5kIHdpbGwgYmUgaWdub3JlZC5gLFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwZXJpbWVudGFsLXdhcm5pbmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2V4cGVyaW1lbnRhbC13YXJuaW5ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFLSCxNQUFNLG1CQUFtQixHQUF1QztJQUM5RCxTQUFTO0lBRVQsaUJBQWlCO0lBQ2pCLFVBQVU7SUFDVixnRUFBZ0U7SUFDaEUsOEJBQThCO0lBQzlCLDRCQUE0QjtJQUU1QixlQUFlO0lBQ2YsV0FBVztJQUVYLGdDQUFnQztJQUNoQyxpQkFBaUI7SUFFakIscUNBQXFDO0lBQ3JDLGFBQWE7SUFDYixhQUFhO0lBQ2IsbUJBQW1CO0NBQ3BCLENBQUM7QUFFRixTQUFnQix1QkFBdUIsQ0FBQyxPQUE4QixFQUFFLE9BQXVCO0lBQzdGLGlEQUFpRDtJQUNqRCxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDakIsd0ZBQXdGLENBQ3pGLENBQUM7SUFFRiw2QkFBNkI7SUFDN0Isc0ZBQXNGO0lBQ3RGLEtBQUssTUFBTSxpQkFBaUIsSUFBSSxtQkFBbUIsRUFBRTtRQUNuRCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUV6QyxJQUFJLEtBQUssS0FBSyxTQUFTLElBQUksS0FBSyxLQUFLLEtBQUssRUFBRTtZQUMxQyxTQUFTO1NBQ1Y7UUFDRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDOUMsU0FBUztTQUNWO1FBQ0QsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ2hFLFNBQVM7U0FDVjtRQUVELE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUNqQixRQUFRLGlCQUFpQixxRkFBcUYsQ0FDL0csQ0FBQztLQUNIO0FBQ0gsQ0FBQztBQXpCRCwwREF5QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHsgQnVpbGRlckNvbnRleHQgfSBmcm9tICdAYW5ndWxhci1kZXZraXQvYXJjaGl0ZWN0JztcbmltcG9ydCB7IFNjaGVtYSBhcyBCcm93c2VyQnVpbGRlck9wdGlvbnMgfSBmcm9tICcuLi9icm93c2VyL3NjaGVtYSc7XG5cbmNvbnN0IFVOU1VQUE9SVEVEX09QVElPTlM6IEFycmF5PGtleW9mIEJyb3dzZXJCdWlsZGVyT3B0aW9ucz4gPSBbXG4gICdidWRnZXRzJyxcblxuICAvLyAqIGkxOG4gc3VwcG9ydFxuICAnbG9jYWxpemUnLFxuICAvLyBUaGUgZm9sbG93aW5nIHR3byBoYXZlIG5vIGVmZmVjdCB3aGVuIGxvY2FsaXplIGlzIG5vdCBlbmFibGVkXG4gIC8vICdpMThuRHVwbGljYXRlVHJhbnNsYXRpb24nLFxuICAvLyAnaTE4bk1pc3NpbmdUcmFuc2xhdGlvbicsXG5cbiAgLy8gKiBEZXByZWNhdGVkXG4gICdkZXBsb3lVcmwnLFxuXG4gIC8vICogQWx3YXlzIGVuYWJsZWQgd2l0aCBlc2J1aWxkXG4gIC8vICdjb21tb25DaHVuaycsXG5cbiAgLy8gKiBDdXJyZW50bHkgdW5zdXBwb3J0ZWQgYnkgZXNidWlsZFxuICAnbmFtZWRDaHVua3MnLFxuICAndmVuZG9yQ2h1bmsnLFxuICAnd2ViV29ya2VyVHNDb25maWcnLFxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIGxvZ0V4cGVyaW1lbnRhbFdhcm5pbmdzKG9wdGlvbnM6IEJyb3dzZXJCdWlsZGVyT3B0aW9ucywgY29udGV4dDogQnVpbGRlckNvbnRleHQpIHtcbiAgLy8gV2FybiBhYm91dCBleHBlcmltZW50YWwgc3RhdHVzIG9mIHRoaXMgYnVpbGRlclxuICBjb250ZXh0LmxvZ2dlci53YXJuKFxuICAgIGBUaGUgZXNidWlsZCBicm93c2VyIGFwcGxpY2F0aW9uIGJ1aWxkZXIgKCdicm93c2VyLWVzYnVpbGQnKSBpcyBjdXJyZW50bHkgZXhwZXJpbWVudGFsLmAsXG4gICk7XG5cbiAgLy8gVmFsaWRhdGUgc3VwcG9ydGVkIG9wdGlvbnNcbiAgLy8gQ3VycmVudGx5IG9ubHkgYSBzdWJzZXQgb2YgdGhlIFdlYnBhY2stYmFzZWQgYnJvd3NlciBidWlsZGVyIG9wdGlvbnMgYXJlIHN1cHBvcnRlZC5cbiAgZm9yIChjb25zdCB1bnN1cHBvcnRlZE9wdGlvbiBvZiBVTlNVUFBPUlRFRF9PUFRJT05TKSB7XG4gICAgY29uc3QgdmFsdWUgPSBvcHRpb25zW3Vuc3VwcG9ydGVkT3B0aW9uXTtcblxuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlID09PSBmYWxzZSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuICAgIGlmIChBcnJheS5pc0FycmF5KHZhbHVlKSAmJiB2YWx1ZS5sZW5ndGggPT09IDApIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiBPYmplY3Qua2V5cyh2YWx1ZSkubGVuZ3RoID09PSAwKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb250ZXh0LmxvZ2dlci53YXJuKFxuICAgICAgYFRoZSAnJHt1bnN1cHBvcnRlZE9wdGlvbn0nIG9wdGlvbiBpcyBjdXJyZW50bHkgdW5zdXBwb3J0ZWQgYnkgdGhpcyBleHBlcmltZW50YWwgYnVpbGRlciBhbmQgd2lsbCBiZSBpZ25vcmVkLmAsXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,16 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import type { BuildOptions } from 'esbuild';
9
+ import { NormalizedBrowserOptions } from './options';
10
+ /**
11
+ * Create an esbuild 'build' options object for all global scripts defined in the user provied
12
+ * build options.
13
+ * @param options The builder's user-provider normalized options.
14
+ * @returns An esbuild BuildOptions object.
15
+ */
16
+ export declare function createGlobalScriptsBundleOptions(options: NormalizedBrowserOptions): BuildOptions;
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ var desc = Object.getOwnPropertyDescriptor(m, k);
12
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
13
+ desc = { enumerable: true, get: function() { return m[k]; } };
14
+ }
15
+ Object.defineProperty(o, k2, desc);
16
+ }) : (function(o, m, k, k2) {
17
+ if (k2 === undefined) k2 = k;
18
+ o[k2] = m[k];
19
+ }));
20
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
21
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
22
+ }) : function(o, v) {
23
+ o["default"] = v;
24
+ });
25
+ var __importStar = (this && this.__importStar) || function (mod) {
26
+ if (mod && mod.__esModule) return mod;
27
+ var result = {};
28
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
29
+ __setModuleDefault(result, mod);
30
+ return result;
31
+ };
32
+ var __importDefault = (this && this.__importDefault) || function (mod) {
33
+ return (mod && mod.__esModule) ? mod : { "default": mod };
34
+ };
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.createGlobalScriptsBundleOptions = void 0;
37
+ const magic_string_1 = __importStar(require("magic-string"));
38
+ const node_assert_1 = __importDefault(require("node:assert"));
39
+ const promises_1 = require("node:fs/promises");
40
+ /**
41
+ * Create an esbuild 'build' options object for all global scripts defined in the user provied
42
+ * build options.
43
+ * @param options The builder's user-provider normalized options.
44
+ * @returns An esbuild BuildOptions object.
45
+ */
46
+ function createGlobalScriptsBundleOptions(options) {
47
+ const { globalScripts, optimizationOptions, outputNames, preserveSymlinks, sourcemapOptions, workspaceRoot, } = options;
48
+ const namespace = 'angular:script/global';
49
+ const entryPoints = {};
50
+ for (const { name } of globalScripts) {
51
+ entryPoints[name] = `${namespace}:${name}`;
52
+ }
53
+ return {
54
+ absWorkingDir: workspaceRoot,
55
+ bundle: false,
56
+ splitting: false,
57
+ entryPoints,
58
+ entryNames: outputNames.bundles,
59
+ assetNames: outputNames.media,
60
+ mainFields: ['script', 'browser', 'main'],
61
+ conditions: ['script'],
62
+ resolveExtensions: ['.mjs', '.js'],
63
+ logLevel: options.verbose ? 'debug' : 'silent',
64
+ metafile: true,
65
+ minify: optimizationOptions.scripts,
66
+ outdir: workspaceRoot,
67
+ sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),
68
+ write: false,
69
+ platform: 'neutral',
70
+ preserveSymlinks,
71
+ plugins: [
72
+ {
73
+ name: 'angular-global-scripts',
74
+ setup(build) {
75
+ build.onResolve({ filter: /^angular:script\/global:/ }, (args) => {
76
+ if (args.kind !== 'entry-point') {
77
+ return null;
78
+ }
79
+ return {
80
+ // Add the `js` extension here so that esbuild generates an output file with the extension
81
+ path: args.path.slice(namespace.length + 1) + '.js',
82
+ namespace,
83
+ };
84
+ });
85
+ // All references within a global script should be considered external. This maintains the runtime
86
+ // behavior of the script as if it were added directly to a script element for referenced imports.
87
+ build.onResolve({ filter: /./, namespace }, ({ path }) => {
88
+ return {
89
+ path,
90
+ external: true,
91
+ };
92
+ });
93
+ build.onLoad({ filter: /./, namespace }, async (args) => {
94
+ const files = globalScripts.find(({ name }) => name === args.path.slice(0, -3))?.files;
95
+ (0, node_assert_1.default)(files, `Invalid operation: global scripts name not found [${args.path}]`);
96
+ // Global scripts are concatenated using magic-string instead of bundled via esbuild.
97
+ const bundleContent = new magic_string_1.Bundle();
98
+ for (const filename of files) {
99
+ const resolveResult = await build.resolve(filename, {
100
+ kind: 'entry-point',
101
+ resolveDir: workspaceRoot,
102
+ });
103
+ if (resolveResult.errors.length) {
104
+ // Remove resolution failure notes about marking as external since it doesn't apply
105
+ // to global scripts.
106
+ resolveResult.errors.forEach((error) => (error.notes = []));
107
+ return {
108
+ errors: resolveResult.errors,
109
+ warnings: resolveResult.warnings,
110
+ };
111
+ }
112
+ const fileContent = await (0, promises_1.readFile)(resolveResult.path, 'utf-8');
113
+ bundleContent.addSource(new magic_string_1.default(fileContent, { filename }));
114
+ }
115
+ return {
116
+ contents: bundleContent.toString(),
117
+ loader: 'js',
118
+ };
119
+ });
120
+ },
121
+ },
122
+ ],
123
+ };
124
+ }
125
+ exports.createGlobalScriptsBundleOptions = createGlobalScriptsBundleOptions;
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-scripts.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/global-scripts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport type { BuildOptions } from 'esbuild';\nimport MagicString, { Bundle } from 'magic-string';\nimport assert from 'node:assert';\nimport { readFile } from 'node:fs/promises';\nimport { NormalizedBrowserOptions } from './options';\n\n/**\n * Create an esbuild 'build' options object for all global scripts defined in the user provied\n * build options.\n * @param options The builder's user-provider normalized options.\n * @returns An esbuild BuildOptions object.\n */\nexport function createGlobalScriptsBundleOptions(options: NormalizedBrowserOptions): BuildOptions {\n  const {\n    globalScripts,\n    optimizationOptions,\n    outputNames,\n    preserveSymlinks,\n    sourcemapOptions,\n    workspaceRoot,\n  } = options;\n\n  const namespace = 'angular:script/global';\n  const entryPoints: Record<string, string> = {};\n  for (const { name } of globalScripts) {\n    entryPoints[name] = `${namespace}:${name}`;\n  }\n\n  return {\n    absWorkingDir: workspaceRoot,\n    bundle: false,\n    splitting: false,\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    mainFields: ['script', 'browser', 'main'],\n    conditions: ['script'],\n    resolveExtensions: ['.mjs', '.js'],\n    logLevel: options.verbose ? 'debug' : 'silent',\n    metafile: true,\n    minify: optimizationOptions.scripts,\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    write: false,\n    platform: 'neutral',\n    preserveSymlinks,\n    plugins: [\n      {\n        name: 'angular-global-scripts',\n        setup(build) {\n          build.onResolve({ filter: /^angular:script\\/global:/ }, (args) => {\n            if (args.kind !== 'entry-point') {\n              return null;\n            }\n\n            return {\n              // Add the `js` extension here so that esbuild generates an output file with the extension\n              path: args.path.slice(namespace.length + 1) + '.js',\n              namespace,\n            };\n          });\n          // All references within a global script should be considered external. This maintains the runtime\n          // behavior of the script as if it were added directly to a script element for referenced imports.\n          build.onResolve({ filter: /./, namespace }, ({ path }) => {\n            return {\n              path,\n              external: true,\n            };\n          });\n          build.onLoad({ filter: /./, namespace }, async (args) => {\n            const files = globalScripts.find(({ name }) => name === args.path.slice(0, -3))?.files;\n            assert(files, `Invalid operation: global scripts name not found [${args.path}]`);\n\n            // Global scripts are concatenated using magic-string instead of bundled via esbuild.\n            const bundleContent = new Bundle();\n            for (const filename of files) {\n              const resolveResult = await build.resolve(filename, {\n                kind: 'entry-point',\n                resolveDir: workspaceRoot,\n              });\n\n              if (resolveResult.errors.length) {\n                // Remove resolution failure notes about marking as external since it doesn't apply\n                // to global scripts.\n                resolveResult.errors.forEach((error) => (error.notes = []));\n\n                return {\n                  errors: resolveResult.errors,\n                  warnings: resolveResult.warnings,\n                };\n              }\n\n              const fileContent = await readFile(resolveResult.path, 'utf-8');\n              bundleContent.addSource(new MagicString(fileContent, { filename }));\n            }\n\n            return {\n              contents: bundleContent.toString(),\n              loader: 'js',\n            };\n          });\n        },\n      },\n    ],\n  };\n}\n"]}
@@ -19,6 +19,10 @@ export declare function buildEsbuildBrowser(userOptions: BrowserBuilderOptions,
19
19
  write?: boolean;
20
20
  }): AsyncIterable<BuilderOutput & {
21
21
  outputFiles?: OutputFile[];
22
+ assetFiles?: {
23
+ source: string;
24
+ destination: string;
25
+ }[];
22
26
  }>;
23
27
  declare const _default: import("../../../../architect/src/internal").Builder<BrowserBuilderOptions & import("../../../../core/src").JsonObject>;
24
28
  export default _default;