@angular-devkit/build-angular 16.0.0 → 16.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -30,11 +30,13 @@ var __importStar = (this && this.__importStar) || function (mod) {
30
30
  return result;
31
31
  };
32
32
  Object.defineProperty(exports, "__esModule", { value: true });
33
- exports.loadProxyConfiguration = void 0;
33
+ exports.normalizeProxyConfiguration = exports.loadProxyConfiguration = void 0;
34
+ const glob_1 = require("glob");
34
35
  const node_fs_1 = require("node:fs");
35
36
  const promises_1 = require("node:fs/promises");
36
37
  const node_path_1 = require("node:path");
37
38
  const node_url_1 = require("node:url");
39
+ const picomatch_1 = require("picomatch");
38
40
  const error_1 = require("../../utils/error");
39
41
  const load_esm_1 = require("../../utils/load-esm");
40
42
  async function loadProxyConfiguration(root, proxyConfig) {
@@ -87,6 +89,21 @@ async function loadProxyConfiguration(root, proxyConfig) {
87
89
  }
88
90
  }
89
91
  exports.loadProxyConfiguration = loadProxyConfiguration;
92
+ /**
93
+ * Converts glob patterns to regular expressions to support Vite's proxy option.
94
+ * @param proxy A proxy configuration object.
95
+ */
96
+ function normalizeProxyConfiguration(proxy) {
97
+ // TODO: Consider upstreaming glob support
98
+ for (const key of Object.keys(proxy)) {
99
+ if ((0, glob_1.hasMagic)(key)) {
100
+ const { output } = (0, picomatch_1.parse)(key);
101
+ proxy[`^${output}$`] = proxy[key];
102
+ delete proxy[key];
103
+ }
104
+ }
105
+ }
106
+ exports.normalizeProxyConfiguration = normalizeProxyConfiguration;
90
107
  /**
91
108
  * Calculates the line and column for an error offset in the content of a JSON file.
92
109
  * @param location The offset error location from the beginning of the content.
@@ -110,4 +127,4 @@ function getJsonErrorLineColumn(offset, content) {
110
127
  }
111
128
  return { line, column: offset - position + 1 };
112
129
  }
113
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1wcm94eS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy9idWlsZGVycy9kZXYtc2VydmVyL2xvYWQtcHJveHktY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgscUNBQXFDO0FBQ3JDLCtDQUE0QztBQUM1Qyx5Q0FBNkM7QUFDN0MsdUNBQXlDO0FBQ3pDLDZDQUFrRDtBQUNsRCxtREFBcUQ7QUFFOUMsS0FBSyxVQUFVLHNCQUFzQixDQUFDLElBQVksRUFBRSxXQUErQjtJQUN4RixJQUFJLENBQUMsV0FBVyxFQUFFO1FBQ2hCLE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsTUFBTSxTQUFTLEdBQUcsSUFBQSxtQkFBTyxFQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztJQUU3QyxJQUFJLENBQUMsSUFBQSxvQkFBVSxFQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLFNBQVMsa0JBQWtCLENBQUMsQ0FBQztLQUMxRTtJQUVELFFBQVEsSUFBQSxtQkFBTyxFQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzFCLEtBQUssT0FBTyxDQUFDLENBQUM7WUFDWixNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUEsbUJBQVEsRUFBQyxTQUFTLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFFbkQsTUFBTSxFQUFFLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxHQUFHLHdEQUFhLGNBQWMsR0FBQyxDQUFDO1lBQ3BFLE1BQU0sV0FBVyxHQUF3QyxFQUFFLENBQUM7WUFDNUQsTUFBTSxrQkFBa0IsR0FBRyxLQUFLLENBQUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7WUFFckYsSUFBSSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDMUIsSUFBSSxZQUFZLEdBQUcsNEJBQTRCLFNBQVMseUJBQXlCLENBQUM7Z0JBQ2xGLEtBQUssTUFBTSxVQUFVLElBQUksV0FBVyxFQUFFO29CQUNwQyxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxHQUFHLHNCQUFzQixDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7b0JBQzVFLFlBQVksSUFBSSxNQUFNLElBQUksS0FBSyxNQUFNLEtBQUssbUJBQW1CLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7aUJBQ25GO2dCQUNELE1BQU0sSUFBSSxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDL0I7WUFFRCxPQUFPLGtCQUFrQixDQUFDO1NBQzNCO1FBQ0QsS0FBSyxNQUFNO1lBQ1Qsa0ZBQWtGO1lBQ2xGLHlGQUF5RjtZQUN6RixzQ0FBc0M7WUFDdEMsT0FBTyxDQUFDLE1BQU0sSUFBQSx3QkFBYSxFQUF1QixJQUFBLHdCQUFhLEVBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztRQUN2RixLQUFLLE1BQU07WUFDVCxPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUM1QjtZQUNFLDRDQUE0QztZQUM1QyxxREFBcUQ7WUFDckQsSUFBSTtnQkFDRixPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQzthQUMzQjtZQUFDLE9BQU8sQ0FBQyxFQUFFO2dCQUNWLElBQUEscUJBQWEsRUFBQyxDQUFDLENBQUMsQ0FBQztnQkFDakIsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLGlCQUFpQixFQUFFO29CQUNoQyxrRkFBa0Y7b0JBQ2xGLHlGQUF5RjtvQkFDekYsc0NBQXNDO29CQUN0QyxPQUFPLENBQUMsTUFBTSxJQUFBLHdCQUFhLEVBQXVCLElBQUEsd0JBQWEsRUFBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO2lCQUN0RjtnQkFFRCxNQUFNLENBQUMsQ0FBQzthQUNUO0tBQ0o7QUFDSCxDQUFDO0FBdERELHdEQXNEQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBUyxzQkFBc0IsQ0FBQyxNQUFjLEVBQUUsT0FBZTtJQUM3RCxJQUFJLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDaEIsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDO0tBQy9CO0lBRUQsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBQ2IsSUFBSSxRQUFRLEdBQUcsQ0FBQyxDQUFDO0lBQ2pCLGlEQUFpRDtJQUNqRCxPQUFPLElBQUksRUFBRTtRQUNYLEVBQUUsSUFBSSxDQUFDO1FBRVAsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDcEQsSUFBSSxXQUFXLEtBQUssQ0FBQyxDQUFDLElBQUksV0FBVyxHQUFHLE1BQU0sRUFBRTtZQUM5QyxNQUFNO1NBQ1A7UUFFRCxRQUFRLEdBQUcsV0FBVyxHQUFHLENBQUMsQ0FBQztLQUM1QjtJQUVELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE1BQU0sR0FBRyxRQUFRLEdBQUcsQ0FBQyxFQUFFLENBQUM7QUFDakQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSAnbm9kZTpmcyc7XG5pbXBvcnQgeyByZWFkRmlsZSB9IGZyb20gJ25vZGU6ZnMvcHJvbWlzZXMnO1xuaW1wb3J0IHsgZXh0bmFtZSwgcmVzb2x2ZSB9IGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQgeyBwYXRoVG9GaWxlVVJMIH0gZnJvbSAnbm9kZTp1cmwnO1xuaW1wb3J0IHsgYXNzZXJ0SXNFcnJvciB9IGZyb20gJy4uLy4uL3V0aWxzL2Vycm9yJztcbmltcG9ydCB7IGxvYWRFc21Nb2R1bGUgfSBmcm9tICcuLi8uLi91dGlscy9sb2FkLWVzbSc7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBsb2FkUHJveHlDb25maWd1cmF0aW9uKHJvb3Q6IHN0cmluZywgcHJveHlDb25maWc6IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICBpZiAoIXByb3h5Q29uZmlnKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IHByb3h5UGF0aCA9IHJlc29sdmUocm9vdCwgcHJveHlDb25maWcpO1xuXG4gIGlmICghZXhpc3RzU3luYyhwcm94eVBhdGgpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBQcm94eSBjb25maWd1cmF0aW9uIGZpbGUgJHtwcm94eVBhdGh9IGRvZXMgbm90IGV4aXN0LmApO1xuICB9XG5cbiAgc3dpdGNoIChleHRuYW1lKHByb3h5UGF0aCkpIHtcbiAgICBjYXNlICcuanNvbic6IHtcbiAgICAgIGNvbnN0IGNvbnRlbnQgPSBhd2FpdCByZWFkRmlsZShwcm94eVBhdGgsICd1dGYtOCcpO1xuXG4gICAgICBjb25zdCB7IHBhcnNlLCBwcmludFBhcnNlRXJyb3JDb2RlIH0gPSBhd2FpdCBpbXBvcnQoJ2pzb25jLXBhcnNlcicpO1xuICAgICAgY29uc3QgcGFyc2VFcnJvcnM6IGltcG9ydCgnanNvbmMtcGFyc2VyJykuUGFyc2VFcnJvcltdID0gW107XG4gICAgICBjb25zdCBwcm94eUNvbmZpZ3VyYXRpb24gPSBwYXJzZShjb250ZW50LCBwYXJzZUVycm9ycywgeyBhbGxvd1RyYWlsaW5nQ29tbWE6IHRydWUgfSk7XG5cbiAgICAgIGlmIChwYXJzZUVycm9ycy5sZW5ndGggPiAwKSB7XG4gICAgICAgIGxldCBlcnJvck1lc3NhZ2UgPSBgUHJveHkgY29uZmlndXJhdGlvbiBmaWxlICR7cHJveHlQYXRofSBjb250YWlucyBwYXJzZSBlcnJvcnM6YDtcbiAgICAgICAgZm9yIChjb25zdCBwYXJzZUVycm9yIG9mIHBhcnNlRXJyb3JzKSB7XG4gICAgICAgICAgY29uc3QgeyBsaW5lLCBjb2x1bW4gfSA9IGdldEpzb25FcnJvckxpbmVDb2x1bW4ocGFyc2VFcnJvci5vZmZzZXQsIGNvbnRlbnQpO1xuICAgICAgICAgIGVycm9yTWVzc2FnZSArPSBgXFxuWyR7bGluZX0sICR7Y29sdW1ufV0gJHtwcmludFBhcnNlRXJyb3JDb2RlKHBhcnNlRXJyb3IuZXJyb3IpfWA7XG4gICAgICAgIH1cbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGVycm9yTWVzc2FnZSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBwcm94eUNvbmZpZ3VyYXRpb247XG4gICAgfVxuICAgIGNhc2UgJy5tanMnOlxuICAgICAgLy8gTG9hZCB0aGUgRVNNIGNvbmZpZ3VyYXRpb24gZmlsZSB1c2luZyB0aGUgVHlwZVNjcmlwdCBkeW5hbWljIGltcG9ydCB3b3JrYXJvdW5kLlxuICAgICAgLy8gT25jZSBUeXBlU2NyaXB0IHByb3ZpZGVzIHN1cHBvcnQgZm9yIGtlZXBpbmcgdGhlIGR5bmFtaWMgaW1wb3J0IHRoaXMgd29ya2Fyb3VuZCBjYW4gYmVcbiAgICAgIC8vIGNoYW5nZWQgdG8gYSBkaXJlY3QgZHluYW1pYyBpbXBvcnQuXG4gICAgICByZXR1cm4gKGF3YWl0IGxvYWRFc21Nb2R1bGU8eyBkZWZhdWx0OiB1bmtub3duIH0+KHBhdGhUb0ZpbGVVUkwocHJveHlQYXRoKSkpLmRlZmF1bHQ7XG4gICAgY2FzZSAnLmNqcyc6XG4gICAgICByZXR1cm4gcmVxdWlyZShwcm94eVBhdGgpO1xuICAgIGRlZmF1bHQ6XG4gICAgICAvLyBUaGUgZmlsZSBjb3VsZCBiZSBlaXRoZXIgQ29tbW9uSlMgb3IgRVNNLlxuICAgICAgLy8gQ29tbW9uSlMgaXMgdHJpZWQgZmlyc3QgdGhlbiBFU00gaWYgbG9hZGluZyBmYWlscy5cbiAgICAgIHRyeSB7XG4gICAgICAgIHJldHVybiByZXF1aXJlKHByb3h5UGF0aCk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGFzc2VydElzRXJyb3IoZSk7XG4gICAgICAgIGlmIChlLmNvZGUgPT09ICdFUlJfUkVRVUlSRV9FU00nKSB7XG4gICAgICAgICAgLy8gTG9hZCB0aGUgRVNNIGNvbmZpZ3VyYXRpb24gZmlsZSB1c2luZyB0aGUgVHlwZVNjcmlwdCBkeW5hbWljIGltcG9ydCB3b3JrYXJvdW5kLlxuICAgICAgICAgIC8vIE9uY2UgVHlwZVNjcmlwdCBwcm92aWRlcyBzdXBwb3J0IGZvciBrZWVwaW5nIHRoZSBkeW5hbWljIGltcG9ydCB0aGlzIHdvcmthcm91bmQgY2FuIGJlXG4gICAgICAgICAgLy8gY2hhbmdlZCB0byBhIGRpcmVjdCBkeW5hbWljIGltcG9ydC5cbiAgICAgICAgICByZXR1cm4gKGF3YWl0IGxvYWRFc21Nb2R1bGU8eyBkZWZhdWx0OiB1bmtub3duIH0+KHBhdGhUb0ZpbGVVUkwocHJveHlQYXRoKSkpLmRlZmF1bHQ7XG4gICAgICAgIH1cblxuICAgICAgICB0aHJvdyBlO1xuICAgICAgfVxuICB9XG59XG5cbi8qKlxuICogQ2FsY3VsYXRlcyB0aGUgbGluZSBhbmQgY29sdW1uIGZvciBhbiBlcnJvciBvZmZzZXQgaW4gdGhlIGNvbnRlbnQgb2YgYSBKU09OIGZpbGUuXG4gKiBAcGFyYW0gbG9jYXRpb24gVGhlIG9mZnNldCBlcnJvciBsb2NhdGlvbiBmcm9tIHRoZSBiZWdpbm5pbmcgb2YgdGhlIGNvbnRlbnQuXG4gKiBAcGFyYW0gY29udGVudCBUaGUgZnVsbCBjb250ZW50IG9mIHRoZSBmaWxlIGNvbnRhaW5pbmcgdGhlIGVycm9yLlxuICogQHJldHVybnMgQW4gb2JqZWN0IGNvbnRhaW5pbmcgdGhlIGxpbmUgYW5kIGNvbHVtblxuICovXG5mdW5jdGlvbiBnZXRKc29uRXJyb3JMaW5lQ29sdW1uKG9mZnNldDogbnVtYmVyLCBjb250ZW50OiBzdHJpbmcpIHtcbiAgaWYgKG9mZnNldCA9PT0gMCkge1xuICAgIHJldHVybiB7IGxpbmU6IDEsIGNvbHVtbjogMSB9O1xuICB9XG5cbiAgbGV0IGxpbmUgPSAwO1xuICBsZXQgcG9zaXRpb24gPSAwO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc3RhbnQtY29uZGl0aW9uXG4gIHdoaWxlICh0cnVlKSB7XG4gICAgKytsaW5lO1xuXG4gICAgY29uc3QgbmV4dE5ld2xpbmUgPSBjb250ZW50LmluZGV4T2YoJ1xcbicsIHBvc2l0aW9uKTtcbiAgICBpZiAobmV4dE5ld2xpbmUgPT09IC0xIHx8IG5leHROZXdsaW5lID4gb2Zmc2V0KSB7XG4gICAgICBicmVhaztcbiAgICB9XG5cbiAgICBwb3NpdGlvbiA9IG5leHROZXdsaW5lICsgMTtcbiAgfVxuXG4gIHJldHVybiB7IGxpbmUsIGNvbHVtbjogb2Zmc2V0IC0gcG9zaXRpb24gKyAxIH07XG59XG4iXX0=
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-proxy-config.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/dev-server/load-proxy-config.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 { hasMagic as isDynamicPattern } from 'glob';\nimport { existsSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { extname, resolve } from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport { parse as parseGlob } from 'picomatch';\nimport { assertIsError } from '../../utils/error';\nimport { loadEsmModule } from '../../utils/load-esm';\n\nexport async function loadProxyConfiguration(root: string, proxyConfig: string | undefined) {\n  if (!proxyConfig) {\n    return undefined;\n  }\n\n  const proxyPath = resolve(root, proxyConfig);\n\n  if (!existsSync(proxyPath)) {\n    throw new Error(`Proxy configuration file ${proxyPath} does not exist.`);\n  }\n\n  switch (extname(proxyPath)) {\n    case '.json': {\n      const content = await readFile(proxyPath, 'utf-8');\n\n      const { parse, printParseErrorCode } = await import('jsonc-parser');\n      const parseErrors: import('jsonc-parser').ParseError[] = [];\n      const proxyConfiguration = parse(content, parseErrors, { allowTrailingComma: true });\n\n      if (parseErrors.length > 0) {\n        let errorMessage = `Proxy configuration file ${proxyPath} contains parse errors:`;\n        for (const parseError of parseErrors) {\n          const { line, column } = getJsonErrorLineColumn(parseError.offset, content);\n          errorMessage += `\\n[${line}, ${column}] ${printParseErrorCode(parseError.error)}`;\n        }\n        throw new Error(errorMessage);\n      }\n\n      return proxyConfiguration;\n    }\n    case '.mjs':\n      // Load the ESM configuration file using the TypeScript dynamic import workaround.\n      // Once TypeScript provides support for keeping the dynamic import this workaround can be\n      // changed to a direct dynamic import.\n      return (await loadEsmModule<{ default: unknown }>(pathToFileURL(proxyPath))).default;\n    case '.cjs':\n      return require(proxyPath);\n    default:\n      // The file could be either CommonJS or ESM.\n      // CommonJS is tried first then ESM if loading fails.\n      try {\n        return require(proxyPath);\n      } catch (e) {\n        assertIsError(e);\n        if (e.code === 'ERR_REQUIRE_ESM') {\n          // Load the ESM configuration file using the TypeScript dynamic import workaround.\n          // Once TypeScript provides support for keeping the dynamic import this workaround can be\n          // changed to a direct dynamic import.\n          return (await loadEsmModule<{ default: unknown }>(pathToFileURL(proxyPath))).default;\n        }\n\n        throw e;\n      }\n  }\n}\n\n/**\n * Converts glob patterns to regular expressions to support Vite's proxy option.\n * @param proxy A proxy configuration object.\n */\nexport function normalizeProxyConfiguration(proxy: Record<string, unknown>) {\n  // TODO: Consider upstreaming glob support\n  for (const key of Object.keys(proxy)) {\n    if (isDynamicPattern(key)) {\n      const { output } = parseGlob(key);\n      proxy[`^${output}$`] = proxy[key];\n      delete proxy[key];\n    }\n  }\n}\n\n/**\n * Calculates the line and column for an error offset in the content of a JSON file.\n * @param location The offset error location from the beginning of the content.\n * @param content The full content of the file containing the error.\n * @returns An object containing the line and column\n */\nfunction getJsonErrorLineColumn(offset: number, content: string) {\n  if (offset === 0) {\n    return { line: 1, column: 1 };\n  }\n\n  let line = 0;\n  let position = 0;\n  // eslint-disable-next-line no-constant-condition\n  while (true) {\n    ++line;\n\n    const nextNewline = content.indexOf('\\n', position);\n    if (nextNewline === -1 || nextNewline > offset) {\n      break;\n    }\n\n    position = nextNewline + 1;\n  }\n\n  return { line, column: offset - position + 1 };\n}\n"]}
@@ -55,6 +55,9 @@ async function* serveWithVite(serverOptions, builderName, context) {
55
55
  poll: serverOptions.poll,
56
56
  verbose: serverOptions.verbose,
57
57
  }, builderName));
58
+ if (serverOptions.servePath === undefined && browserOptions.baseHref !== undefined) {
59
+ serverOptions.servePath = browserOptions.baseHref;
60
+ }
58
61
  let server;
59
62
  let listeningAddress;
60
63
  const generatedFiles = new Map();
@@ -154,6 +157,9 @@ function analyzeResultFiles(resultFiles, generatedFiles) {
154
157
  }
155
158
  async function setupServer(serverOptions, outputFiles, assets) {
156
159
  const proxy = await (0, load_proxy_config_1.loadProxyConfiguration)(serverOptions.workspaceRoot, serverOptions.proxyConfig);
160
+ if (proxy) {
161
+ (0, load_proxy_config_1.normalizeProxyConfiguration)(proxy);
162
+ }
157
163
  const configuration = {
158
164
  configFile: false,
159
165
  envFile: false,
@@ -166,6 +172,7 @@ async function setupServer(serverOptions, outputFiles, assets) {
166
172
  css: {
167
173
  devSourcemap: true,
168
174
  },
175
+ base: serverOptions.servePath,
169
176
  server: {
170
177
  port: serverOptions.port,
171
178
  strictPort: true,
@@ -217,9 +224,16 @@ async function setupServer(serverOptions, outputFiles, assets) {
217
224
  // Parse the incoming request.
218
225
  // The base of the URL is unused but required to parse the URL.
219
226
  const parsedUrl = new URL(req.url, 'http://localhost');
220
- const extension = node_path_1.default.extname(parsedUrl.pathname);
227
+ let pathname = parsedUrl.pathname;
228
+ if (serverOptions.servePath && pathname.startsWith(serverOptions.servePath)) {
229
+ pathname = pathname.slice(serverOptions.servePath.length);
230
+ if (pathname[0] !== '/') {
231
+ pathname = '/' + pathname;
232
+ }
233
+ }
234
+ const extension = node_path_1.default.extname(pathname);
221
235
  // Rewrite all build assets to a vite raw fs URL
222
- const assetSourcePath = assets.get(parsedUrl.pathname);
236
+ const assetSourcePath = assets.get(pathname);
223
237
  if (assetSourcePath !== undefined) {
224
238
  req.url = `/@fs/${assetSourcePath}`;
225
239
  next();
@@ -229,7 +243,7 @@ async function setupServer(serverOptions, outputFiles, assets) {
229
243
  // Global stylesheets (CSS files) are currently considered resources to workaround
230
244
  // dev server sourcemap issues with stylesheets.
231
245
  if (extension !== '.html') {
232
- const outputFile = outputFiles.get(parsedUrl.pathname);
246
+ const outputFile = outputFiles.get(pathname);
233
247
  if (outputFile) {
234
248
  const mimeType = (0, mrmime_1.lookup)(extension);
235
249
  if (mimeType) {
@@ -248,11 +262,25 @@ async function setupServer(serverOptions, outputFiles, assets) {
248
262
  // Returning a function, installs middleware after the main transform middleware but
249
263
  // before the built-in HTML middleware
250
264
  return () => server.middlewares.use(function angularIndexMiddleware(req, res, next) {
251
- if (req.url === '/' || req.url === `/index.html`) {
265
+ if (!req.url) {
266
+ next();
267
+ return;
268
+ }
269
+ // Parse the incoming request.
270
+ // The base of the URL is unused but required to parse the URL.
271
+ const parsedUrl = new URL(req.url, 'http://localhost');
272
+ let pathname = parsedUrl.pathname;
273
+ if (serverOptions.servePath && pathname.startsWith(serverOptions.servePath)) {
274
+ pathname = pathname.slice(serverOptions.servePath.length);
275
+ if (pathname[0] !== '/') {
276
+ pathname = '/' + pathname;
277
+ }
278
+ }
279
+ if (pathname === '/' || pathname === `/index.html`) {
252
280
  const rawHtml = outputFiles.get('/index.html')?.contents;
253
281
  if (rawHtml) {
254
282
  server
255
- .transformIndexHtml(req.url, Buffer.from(rawHtml).toString('utf-8'), req.originalUrl)
283
+ .transformIndexHtml(req.url, Buffer.from(rawHtml).toString('utf-8'))
256
284
  .then((processedHtml) => {
257
285
  res.setHeader('Content-Type', 'text/html');
258
286
  res.setHeader('Cache-Control', 'no-cache');
@@ -293,4 +321,4 @@ async function setupServer(serverOptions, outputFiles, assets) {
293
321
  return configuration;
294
322
  }
295
323
  exports.setupServer = setupServer;
296
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vite-server.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/dev-server/vite-server.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 { BuilderContext } from '@angular-devkit/architect';\nimport type { json } from '@angular-devkit/core';\nimport type { OutputFile } from 'esbuild';\nimport { lookup as lookupMimeType } from 'mrmime';\nimport assert from 'node:assert';\nimport { BinaryLike, createHash } from 'node:crypto';\nimport { readFile } from 'node:fs/promises';\nimport type { AddressInfo } from 'node:net';\nimport path from 'node:path';\nimport { InlineConfig, ViteDevServer, createServer, normalizePath } from 'vite';\nimport { buildEsbuildBrowser } from '../browser-esbuild';\nimport type { Schema as BrowserBuilderOptions } from '../browser-esbuild/schema';\nimport { loadProxyConfiguration } from './load-proxy-config';\nimport type { NormalizedDevServerOptions } from './options';\nimport type { DevServerBuilderOutput } from './webpack-server';\n\ninterface OutputFileRecord {\n  contents: Uint8Array;\n  size: number;\n  hash?: Buffer;\n  updated: boolean;\n}\n\nfunction hashContent(contents: BinaryLike): Buffer {\n  // TODO: Consider xxhash\n  return createHash('sha256').update(contents).digest();\n}\n\nexport async function* serveWithVite(\n  serverOptions: NormalizedDevServerOptions,\n  builderName: string,\n  context: BuilderContext,\n): AsyncIterableIterator<DevServerBuilderOutput> {\n  // Get the browser configuration from the target name.\n  const rawBrowserOptions = (await context.getTargetOptions(\n    serverOptions.browserTarget,\n  )) as json.JsonObject & BrowserBuilderOptions;\n\n  const browserOptions = (await context.validateOptions(\n    {\n      ...rawBrowserOptions,\n      watch: serverOptions.watch,\n      poll: serverOptions.poll,\n      verbose: serverOptions.verbose,\n    } as json.JsonObject & BrowserBuilderOptions,\n    builderName,\n  )) as json.JsonObject & BrowserBuilderOptions;\n\n  let server: ViteDevServer | undefined;\n  let listeningAddress: AddressInfo | undefined;\n  const generatedFiles = new Map<string, OutputFileRecord>();\n  const assetFiles = new Map<string, string>();\n  // TODO: Switch this to an architect schedule call when infrastructure settings are supported\n  for await (const result of buildEsbuildBrowser(browserOptions, context, { write: false })) {\n    assert(result.outputFiles, 'Builder did not provide result files.');\n\n    // Analyze result files for changes\n    analyzeResultFiles(result.outputFiles, generatedFiles);\n\n    assetFiles.clear();\n    if (result.assetFiles) {\n      for (const asset of result.assetFiles) {\n        assetFiles.set('/' + normalizePath(asset.destination), asset.source);\n      }\n    }\n\n    if (server) {\n      // Invalidate any updated files\n      for (const [file, record] of generatedFiles) {\n        if (record.updated) {\n          const updatedModules = server.moduleGraph.getModulesByFile(file);\n          updatedModules?.forEach((m) => server?.moduleGraph.invalidateModule(m));\n        }\n      }\n\n      // Send reload command to clients\n      if (serverOptions.liveReload) {\n        context.logger.info('Reloading client(s)...');\n\n        server.ws.send({\n          type: 'full-reload',\n          path: '*',\n        });\n      }\n    } else {\n      // Setup server and start listening\n      const serverConfiguration = await setupServer(serverOptions, generatedFiles, assetFiles);\n      server = await createServer(serverConfiguration);\n\n      await server.listen();\n      listeningAddress = server.httpServer?.address() as AddressInfo;\n\n      // log connection information\n      server.printUrls();\n    }\n\n    // TODO: adjust output typings to reflect both development servers\n    yield { success: true, port: listeningAddress?.port } as unknown as DevServerBuilderOutput;\n  }\n\n  if (server) {\n    let deferred: () => void;\n    context.addTeardown(async () => {\n      await server?.close();\n      deferred?.();\n    });\n    await new Promise<void>((resolve) => (deferred = resolve));\n  }\n}\n\nfunction analyzeResultFiles(\n  resultFiles: OutputFile[],\n  generatedFiles: Map<string, OutputFileRecord>,\n) {\n  const seen = new Set<string>(['/index.html']);\n  for (const file of resultFiles) {\n    const filePath = '/' + normalizePath(file.path);\n    seen.add(filePath);\n\n    // Skip analysis of sourcemaps\n    if (filePath.endsWith('.map')) {\n      generatedFiles.set(filePath, {\n        contents: file.contents,\n        size: file.contents.byteLength,\n        updated: false,\n      });\n\n      continue;\n    }\n\n    let fileHash: Buffer | undefined;\n    const existingRecord = generatedFiles.get(filePath);\n    if (existingRecord && existingRecord.size === file.contents.byteLength) {\n      // Only hash existing file when needed\n      if (existingRecord.hash === undefined) {\n        existingRecord.hash = hashContent(existingRecord.contents);\n      }\n\n      // Compare against latest result output\n      fileHash = hashContent(file.contents);\n      if (fileHash.equals(existingRecord.hash)) {\n        // Same file\n        existingRecord.updated = false;\n        continue;\n      }\n    }\n\n    generatedFiles.set(filePath, {\n      contents: file.contents,\n      size: file.contents.byteLength,\n      hash: fileHash,\n      updated: true,\n    });\n  }\n\n  // Clear stale output files\n  for (const file of generatedFiles.keys()) {\n    if (!seen.has(file)) {\n      generatedFiles.delete(file);\n    }\n  }\n}\n\nexport async function setupServer(\n  serverOptions: NormalizedDevServerOptions,\n  outputFiles: Map<string, OutputFileRecord>,\n  assets: Map<string, string>,\n): Promise<InlineConfig> {\n  const proxy = await loadProxyConfiguration(\n    serverOptions.workspaceRoot,\n    serverOptions.proxyConfig,\n  );\n\n  const configuration: InlineConfig = {\n    configFile: false,\n    envFile: false,\n    cacheDir: path.join(serverOptions.cacheOptions.path, 'vite'),\n    root: serverOptions.workspaceRoot,\n    publicDir: false,\n    esbuild: false,\n    mode: 'development',\n    appType: 'spa',\n    css: {\n      devSourcemap: true,\n    },\n    server: {\n      port: serverOptions.port,\n      strictPort: true,\n      host: serverOptions.host,\n      open: serverOptions.open,\n      headers: serverOptions.headers,\n      proxy,\n      // Currently does not appear to be a way to disable file watching directly so ignore all files\n      watch: {\n        ignored: ['**/*'],\n      },\n    },\n    plugins: [\n      {\n        name: 'vite:angular-memory',\n        // Ensures plugin hooks run before built-in Vite hooks\n        enforce: 'pre',\n        async resolveId(source, importer) {\n          if (importer && source.startsWith('.')) {\n            // Remove query if present\n            const [importerFile] = importer.split('?', 1);\n\n            source = normalizePath(path.join(path.dirname(importerFile), source));\n          }\n\n          const [file] = source.split('?', 1);\n          if (outputFiles.has(file)) {\n            return source;\n          }\n        },\n        load(id) {\n          const [file] = id.split('?', 1);\n          const codeContents = outputFiles.get(file)?.contents;\n          if (codeContents === undefined) {\n            return;\n          }\n\n          const mapContents = outputFiles.get(file + '.map')?.contents;\n\n          return {\n            // Remove source map URL comments from the code if a sourcemap is present.\n            // Vite will inline and add an additional sourcemap URL for the sourcemap.\n            code: Buffer.from(codeContents).toString('utf-8'),\n            map: mapContents && Buffer.from(mapContents).toString('utf-8'),\n          };\n        },\n        configureServer(server) {\n          // Assets and resources get handled first\n          server.middlewares.use(function angularAssetsMiddleware(req, res, next) {\n            if (req.url === undefined || res.writableEnded) {\n              return;\n            }\n\n            // Parse the incoming request.\n            // The base of the URL is unused but required to parse the URL.\n            const parsedUrl = new URL(req.url, 'http://localhost');\n            const extension = path.extname(parsedUrl.pathname);\n\n            // Rewrite all build assets to a vite raw fs URL\n            const assetSourcePath = assets.get(parsedUrl.pathname);\n            if (assetSourcePath !== undefined) {\n              req.url = `/@fs/${assetSourcePath}`;\n              next();\n\n              return;\n            }\n\n            // Resource files are handled directly.\n            // Global stylesheets (CSS files) are currently considered resources to workaround\n            // dev server sourcemap issues with stylesheets.\n            if (extension !== '.html') {\n              const outputFile = outputFiles.get(parsedUrl.pathname);\n              if (outputFile) {\n                const mimeType = lookupMimeType(extension);\n                if (mimeType) {\n                  res.setHeader('Content-Type', mimeType);\n                }\n                res.setHeader('Cache-Control', 'no-cache');\n                if (serverOptions.headers) {\n                  Object.entries(serverOptions.headers).forEach(([name, value]) =>\n                    res.setHeader(name, value),\n                  );\n                }\n                res.end(outputFile.contents);\n\n                return;\n              }\n            }\n\n            next();\n          });\n\n          // Returning a function, installs middleware after the main transform middleware but\n          // before the built-in HTML middleware\n          return () =>\n            server.middlewares.use(function angularIndexMiddleware(req, res, next) {\n              if (req.url === '/' || req.url === `/index.html`) {\n                const rawHtml = outputFiles.get('/index.html')?.contents;\n                if (rawHtml) {\n                  server\n                    .transformIndexHtml(\n                      req.url,\n                      Buffer.from(rawHtml).toString('utf-8'),\n                      req.originalUrl,\n                    )\n                    .then((processedHtml) => {\n                      res.setHeader('Content-Type', 'text/html');\n                      res.setHeader('Cache-Control', 'no-cache');\n                      if (serverOptions.headers) {\n                        Object.entries(serverOptions.headers).forEach(([name, value]) =>\n                          res.setHeader(name, value),\n                        );\n                      }\n                      res.end(processedHtml);\n                    })\n                    .catch((error) => next(error));\n\n                  return;\n                }\n              }\n\n              next();\n            });\n        },\n      },\n    ],\n    optimizeDeps: {\n      // TODO: Consider enabling for known safe dependencies (@angular/* ?)\n      disabled: true,\n    },\n  };\n\n  if (serverOptions.ssl) {\n    if (serverOptions.sslCert && serverOptions.sslKey) {\n      // server configuration is defined above\n      // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n      configuration.server!.https = {\n        cert: await readFile(serverOptions.sslCert),\n        key: await readFile(serverOptions.sslKey),\n      };\n    } else {\n      const { default: basicSslPlugin } = await import('@vitejs/plugin-basic-ssl');\n      configuration.plugins ??= [];\n      configuration.plugins.push(basicSslPlugin());\n    }\n  }\n\n  return configuration;\n}\n"]}
324
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vite-server.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/dev-server/vite-server.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 { BuilderContext } from '@angular-devkit/architect';\nimport type { json } from '@angular-devkit/core';\nimport type { OutputFile } from 'esbuild';\nimport { lookup as lookupMimeType } from 'mrmime';\nimport assert from 'node:assert';\nimport { BinaryLike, createHash } from 'node:crypto';\nimport { readFile } from 'node:fs/promises';\nimport type { AddressInfo } from 'node:net';\nimport path from 'node:path';\nimport { InlineConfig, ViteDevServer, createServer, normalizePath } from 'vite';\nimport { buildEsbuildBrowser } from '../browser-esbuild';\nimport type { Schema as BrowserBuilderOptions } from '../browser-esbuild/schema';\nimport { loadProxyConfiguration, normalizeProxyConfiguration } from './load-proxy-config';\nimport type { NormalizedDevServerOptions } from './options';\nimport type { DevServerBuilderOutput } from './webpack-server';\n\ninterface OutputFileRecord {\n  contents: Uint8Array;\n  size: number;\n  hash?: Buffer;\n  updated: boolean;\n}\n\nfunction hashContent(contents: BinaryLike): Buffer {\n  // TODO: Consider xxhash\n  return createHash('sha256').update(contents).digest();\n}\n\nexport async function* serveWithVite(\n  serverOptions: NormalizedDevServerOptions,\n  builderName: string,\n  context: BuilderContext,\n): AsyncIterableIterator<DevServerBuilderOutput> {\n  // Get the browser configuration from the target name.\n  const rawBrowserOptions = (await context.getTargetOptions(\n    serverOptions.browserTarget,\n  )) as json.JsonObject & BrowserBuilderOptions;\n\n  const browserOptions = (await context.validateOptions(\n    {\n      ...rawBrowserOptions,\n      watch: serverOptions.watch,\n      poll: serverOptions.poll,\n      verbose: serverOptions.verbose,\n    } as json.JsonObject & BrowserBuilderOptions,\n    builderName,\n  )) as json.JsonObject & BrowserBuilderOptions;\n\n  if (serverOptions.servePath === undefined && browserOptions.baseHref !== undefined) {\n    serverOptions.servePath = browserOptions.baseHref;\n  }\n\n  let server: ViteDevServer | undefined;\n  let listeningAddress: AddressInfo | undefined;\n  const generatedFiles = new Map<string, OutputFileRecord>();\n  const assetFiles = new Map<string, string>();\n  // TODO: Switch this to an architect schedule call when infrastructure settings are supported\n  for await (const result of buildEsbuildBrowser(browserOptions, context, { write: false })) {\n    assert(result.outputFiles, 'Builder did not provide result files.');\n\n    // Analyze result files for changes\n    analyzeResultFiles(result.outputFiles, generatedFiles);\n\n    assetFiles.clear();\n    if (result.assetFiles) {\n      for (const asset of result.assetFiles) {\n        assetFiles.set('/' + normalizePath(asset.destination), asset.source);\n      }\n    }\n\n    if (server) {\n      // Invalidate any updated files\n      for (const [file, record] of generatedFiles) {\n        if (record.updated) {\n          const updatedModules = server.moduleGraph.getModulesByFile(file);\n          updatedModules?.forEach((m) => server?.moduleGraph.invalidateModule(m));\n        }\n      }\n\n      // Send reload command to clients\n      if (serverOptions.liveReload) {\n        context.logger.info('Reloading client(s)...');\n\n        server.ws.send({\n          type: 'full-reload',\n          path: '*',\n        });\n      }\n    } else {\n      // Setup server and start listening\n      const serverConfiguration = await setupServer(serverOptions, generatedFiles, assetFiles);\n      server = await createServer(serverConfiguration);\n\n      await server.listen();\n      listeningAddress = server.httpServer?.address() as AddressInfo;\n\n      // log connection information\n      server.printUrls();\n    }\n\n    // TODO: adjust output typings to reflect both development servers\n    yield { success: true, port: listeningAddress?.port } as unknown as DevServerBuilderOutput;\n  }\n\n  if (server) {\n    let deferred: () => void;\n    context.addTeardown(async () => {\n      await server?.close();\n      deferred?.();\n    });\n    await new Promise<void>((resolve) => (deferred = resolve));\n  }\n}\n\nfunction analyzeResultFiles(\n  resultFiles: OutputFile[],\n  generatedFiles: Map<string, OutputFileRecord>,\n) {\n  const seen = new Set<string>(['/index.html']);\n  for (const file of resultFiles) {\n    const filePath = '/' + normalizePath(file.path);\n    seen.add(filePath);\n\n    // Skip analysis of sourcemaps\n    if (filePath.endsWith('.map')) {\n      generatedFiles.set(filePath, {\n        contents: file.contents,\n        size: file.contents.byteLength,\n        updated: false,\n      });\n\n      continue;\n    }\n\n    let fileHash: Buffer | undefined;\n    const existingRecord = generatedFiles.get(filePath);\n    if (existingRecord && existingRecord.size === file.contents.byteLength) {\n      // Only hash existing file when needed\n      if (existingRecord.hash === undefined) {\n        existingRecord.hash = hashContent(existingRecord.contents);\n      }\n\n      // Compare against latest result output\n      fileHash = hashContent(file.contents);\n      if (fileHash.equals(existingRecord.hash)) {\n        // Same file\n        existingRecord.updated = false;\n        continue;\n      }\n    }\n\n    generatedFiles.set(filePath, {\n      contents: file.contents,\n      size: file.contents.byteLength,\n      hash: fileHash,\n      updated: true,\n    });\n  }\n\n  // Clear stale output files\n  for (const file of generatedFiles.keys()) {\n    if (!seen.has(file)) {\n      generatedFiles.delete(file);\n    }\n  }\n}\n\nexport async function setupServer(\n  serverOptions: NormalizedDevServerOptions,\n  outputFiles: Map<string, OutputFileRecord>,\n  assets: Map<string, string>,\n): Promise<InlineConfig> {\n  const proxy = await loadProxyConfiguration(\n    serverOptions.workspaceRoot,\n    serverOptions.proxyConfig,\n  );\n  if (proxy) {\n    normalizeProxyConfiguration(proxy);\n  }\n\n  const configuration: InlineConfig = {\n    configFile: false,\n    envFile: false,\n    cacheDir: path.join(serverOptions.cacheOptions.path, 'vite'),\n    root: serverOptions.workspaceRoot,\n    publicDir: false,\n    esbuild: false,\n    mode: 'development',\n    appType: 'spa',\n    css: {\n      devSourcemap: true,\n    },\n    base: serverOptions.servePath,\n    server: {\n      port: serverOptions.port,\n      strictPort: true,\n      host: serverOptions.host,\n      open: serverOptions.open,\n      headers: serverOptions.headers,\n      proxy,\n      // Currently does not appear to be a way to disable file watching directly so ignore all files\n      watch: {\n        ignored: ['**/*'],\n      },\n    },\n    plugins: [\n      {\n        name: 'vite:angular-memory',\n        // Ensures plugin hooks run before built-in Vite hooks\n        enforce: 'pre',\n        async resolveId(source, importer) {\n          if (importer && source.startsWith('.')) {\n            // Remove query if present\n            const [importerFile] = importer.split('?', 1);\n\n            source = normalizePath(path.join(path.dirname(importerFile), source));\n          }\n\n          const [file] = source.split('?', 1);\n          if (outputFiles.has(file)) {\n            return source;\n          }\n        },\n        load(id) {\n          const [file] = id.split('?', 1);\n          const codeContents = outputFiles.get(file)?.contents;\n          if (codeContents === undefined) {\n            return;\n          }\n\n          const mapContents = outputFiles.get(file + '.map')?.contents;\n\n          return {\n            // Remove source map URL comments from the code if a sourcemap is present.\n            // Vite will inline and add an additional sourcemap URL for the sourcemap.\n            code: Buffer.from(codeContents).toString('utf-8'),\n            map: mapContents && Buffer.from(mapContents).toString('utf-8'),\n          };\n        },\n        configureServer(server) {\n          // Assets and resources get handled first\n          server.middlewares.use(function angularAssetsMiddleware(req, res, next) {\n            if (req.url === undefined || res.writableEnded) {\n              return;\n            }\n\n            // Parse the incoming request.\n            // The base of the URL is unused but required to parse the URL.\n            const parsedUrl = new URL(req.url, 'http://localhost');\n            let pathname = parsedUrl.pathname;\n            if (serverOptions.servePath && pathname.startsWith(serverOptions.servePath)) {\n              pathname = pathname.slice(serverOptions.servePath.length);\n              if (pathname[0] !== '/') {\n                pathname = '/' + pathname;\n              }\n            }\n            const extension = path.extname(pathname);\n\n            // Rewrite all build assets to a vite raw fs URL\n            const assetSourcePath = assets.get(pathname);\n            if (assetSourcePath !== undefined) {\n              req.url = `/@fs/${assetSourcePath}`;\n              next();\n\n              return;\n            }\n\n            // Resource files are handled directly.\n            // Global stylesheets (CSS files) are currently considered resources to workaround\n            // dev server sourcemap issues with stylesheets.\n            if (extension !== '.html') {\n              const outputFile = outputFiles.get(pathname);\n              if (outputFile) {\n                const mimeType = lookupMimeType(extension);\n                if (mimeType) {\n                  res.setHeader('Content-Type', mimeType);\n                }\n                res.setHeader('Cache-Control', 'no-cache');\n                if (serverOptions.headers) {\n                  Object.entries(serverOptions.headers).forEach(([name, value]) =>\n                    res.setHeader(name, value),\n                  );\n                }\n                res.end(outputFile.contents);\n\n                return;\n              }\n            }\n\n            next();\n          });\n\n          // Returning a function, installs middleware after the main transform middleware but\n          // before the built-in HTML middleware\n          return () =>\n            server.middlewares.use(function angularIndexMiddleware(req, res, next) {\n              if (!req.url) {\n                next();\n\n                return;\n              }\n\n              // Parse the incoming request.\n              // The base of the URL is unused but required to parse the URL.\n              const parsedUrl = new URL(req.url, 'http://localhost');\n              let pathname = parsedUrl.pathname;\n              if (serverOptions.servePath && pathname.startsWith(serverOptions.servePath)) {\n                pathname = pathname.slice(serverOptions.servePath.length);\n                if (pathname[0] !== '/') {\n                  pathname = '/' + pathname;\n                }\n              }\n              if (pathname === '/' || pathname === `/index.html`) {\n                const rawHtml = outputFiles.get('/index.html')?.contents;\n                if (rawHtml) {\n                  server\n                    .transformIndexHtml(req.url, Buffer.from(rawHtml).toString('utf-8'))\n                    .then((processedHtml) => {\n                      res.setHeader('Content-Type', 'text/html');\n                      res.setHeader('Cache-Control', 'no-cache');\n                      if (serverOptions.headers) {\n                        Object.entries(serverOptions.headers).forEach(([name, value]) =>\n                          res.setHeader(name, value),\n                        );\n                      }\n                      res.end(processedHtml);\n                    })\n                    .catch((error) => next(error));\n\n                  return;\n                }\n              }\n\n              next();\n            });\n        },\n      },\n    ],\n    optimizeDeps: {\n      // TODO: Consider enabling for known safe dependencies (@angular/* ?)\n      disabled: true,\n    },\n  };\n\n  if (serverOptions.ssl) {\n    if (serverOptions.sslCert && serverOptions.sslKey) {\n      // server configuration is defined above\n      // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n      configuration.server!.https = {\n        cert: await readFile(serverOptions.sslCert),\n        key: await readFile(serverOptions.sslKey),\n      };\n    } else {\n      const { default: basicSslPlugin } = await import('@vitejs/plugin-basic-ssl');\n      configuration.plugins ??= [];\n      configuration.plugins.push(basicSslPlugin());\n    }\n  }\n\n  return configuration;\n}\n"]}
@@ -345,13 +345,6 @@ async function getCommonConfig(wco) {
345
345
  {
346
346
  loader: require.resolve('../../babel/webpack-loader'),
347
347
  options: {
348
- assumptions: {
349
- // Use `setPublicClassFields: true` to avoid decrease bundle sizes
350
- // when targetting ES2022+ with `useDefineForClassFields: true`.
351
- // This is because ervery property of the class will otherwise be wrapped in a `_defineProperty`.
352
- // This is not needed for TypeScript as TS itself will emit the right declaration of class properties.
353
- setPublicClassFields: true,
354
- },
355
348
  cacheDirectory: (cache.enabled && path.join(cache.path, 'babel-webpack')) || false,
356
349
  aot: buildOptions.aot,
357
350
  optimize: buildOptions.buildOptimizer,
@@ -424,4 +417,4 @@ async function getCommonConfig(wco) {
424
417
  };
425
418
  }
426
419
  exports.getCommonConfig = getCommonConfig;
427
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/webpack/configs/common.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,8CAA4D;AAC5D,8EAAoD;AACpD,2CAA6B;AAC7B,qCAMiB;AACjB,iFAA2E;AAG3E,yEAA8D;AAC9D,mDAAqD;AACrD,wCAMoB;AACpB,8EAAyE;AACzE,wEAAmE;AACnE,sEAAkE;AAClE,gEAA4D;AAC5D,0EAAqE;AACrE,sDAAwD;AACxD,gFAA0E;AAC1E,8CAQ0B;AAE1B,MAAM,YAAY,GAAG,wBAAwB,CAAC;AAE9C,kDAAkD;AAC3C,KAAK,UAAU,eAAe,CAAC,GAAyB;IAC7D,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,GAAG,CAAC;IACjG,MAAM,EACJ,KAAK,EACL,YAAY,EACZ,WAAW,GAAG,MAAM,EACpB,QAAQ,GAAG,SAAS,EACpB,GAAG,GAAG,IAAI,EACV,mBAAmB,GAAG,EAAE,EACxB,IAAI,EACJ,SAAS,EAAE,EACT,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,gBAAgB,EACzB,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,eAAe,GACxB,EACD,YAAY,EAAE,EAAE,MAAM,EAAE,kBAAkB,EAAE,OAAO,EAAE,mBAAmB,EAAE,EAC1E,WAAW,EACX,WAAW,EACX,oBAAoB,EACpB,OAAO,EACP,IAAI,EACJ,iBAAiB,EACjB,oBAAoB,GAAG,EAAE,EACzB,2BAA2B,GAC5B,GAAG,YAAY,CAAC;IAEjB,MAAM,gBAAgB,GAAG,YAAY,CAAC,QAAQ,KAAK,QAAQ,CAAC;IAC5D,MAAM,YAAY,GAA0C,EAAE,CAAC;IAC/D,MAAM,UAAU,GAAkB,EAAE,CAAC;IACrC,MAAM,WAAW,GAA2B,EAAE,CAAC;IAE/C,mFAAmF;IACnF,yFAAyF;IACzF,sCAAsC;IACtC,MAAM,EACJ,sBAAsB,EACtB,+BAA+B,EAC/B,OAAO,EAAE,UAAU,GACpB,GAAG,MAAM,IAAA,wBAAa,EAAyC,uBAAuB,CAAC,CAAC;IAEzF,2BAA2B;IAC3B,MAAM,UAAU,GAAG,IAAA,6BAAmB,EAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IAEnE,IAAI,YAAY,CAAC,QAAQ,EAAE;QACzB,YAAY,CAAC,IAAI,CAAC,IAAI,gCAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;KACjD;IAED,MAAM,6BAA6B,GAAG,wBAAwB,CAAC;IAC/D,MAAM,eAAe,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAClD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,mBAAmB,IAAI,CAAC,KAAK,6BAA6B,CACxE,CAAC;IAEF,IAAI,eAAe,EAAE;QACnB,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;KACvD;IAED,IAAI,YAAY,CAAC,IAAI,EAAE;QACrB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;QACvD,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;YACtC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACpC;aAAM;YACL,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAClC;KACF;IAED,IAAI,gBAAgB,EAAE;QACpB,0EAA0E;QAC1E,YAAY,CAAC,IAAI,CAAC,IAAI,kCAAwB,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAEvE,IAAI,IAAA,mCAAyB,EAAC,GAAG,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;YAC7E,mGAAmG;YACnG,0CAA0C;YAC1C,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC;SAC9D;KACF;IAED,MAAM,SAAS,GAAG,CAAC,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,GAAG,EAAE;QACR,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;KACrC;IAED,IAAI,SAAS,CAAC,MAAM,EAAE;QACpB,oHAAoH;QACpH,wEAAwE;QACxE,4FAA4F;QAC5F,eAAe;QACf,mGAAmG;QACnG,4GAA4G;QAC5G,oBAAoB;QACpB,sHAAsH;QACtH,oHAAoH;QACpH,sDAAsD;QACtD,mEAAmE;QACnE,MAAM,qBAAqB,GAAG,iBAAiB,CAAC;QAChD,MAAM,4BAA4B,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,qBAAqB,CAAC,CAAC;QAE1F,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,EAAE;YAC3C,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,4BAA4B,CAAC,CAAC;SAChE;aAAM;YACL,WAAW,CAAC,WAAW,CAAC,GAAG,4BAA4B,CAAC;SACzD;QAED,IAAI,4BAA4B,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE;YAC5D,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;gBACtC,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;aACpD;iBAAM;gBACL,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;aAC/C;SACF;KACF;IAED,IAAI,2BAA2B,EAAE;QAC/B,0FAA0F;QAC1F,oCAAoC;QACpC,YAAY,CAAC,IAAI,CACf,IAAI,iCAAuB,CAAC;YAC1B,mBAAmB,EAAE,2BAA2B;SACjD,CAAC,CACH,CAAC;KACH;IAED,yBAAyB;IACzB,kCAAkC;IAClC,KAAK,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,IAAA,mCAAyB,EAAC,YAAY,CAAC,OAAO,CAAC,EAAE;QAC3F,yEAAyE;QACzE,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7C,YAAY,CAAC,IAAI,CACf,IAAI,8BAAoB,CAAC;YACvB,IAAI,EAAE,UAAU;YAChB,SAAS,EAAE,gBAAgB;YAC3B,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,IAAI,KAAK;YAClD,QAAQ,EAAE,IAAI;SACf,CAAC,CACH,CAAC;KACH;IAED,wBAAwB;IACxB,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE;QAC9B,YAAY,CAAC,IAAI,CACf,IAAI,6BAAiB,CAAC;YACpB,QAAQ,EAAE,IAAA,uBAAa,EAAC,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC;SACnD,CAAC,CACH,CAAC;KACH;IAED,IAAI,YAAY,CAAC,eAAe,EAAE;QAChC,MAAM,oBAAoB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC,oBAAoB,CAAC;QACpF,YAAY,CAAC,IAAI,CACf,IAAI,oBAAoB,CAAC;YACvB,KAAK,EAAE;gBACL,QAAQ,EAAE,KAAK;gBACf,MAAM,EAAE,KAAK;aACd;YACD,cAAc,EAAE,KAAK;YACrB,cAAc,EAAE,sBAAsB;YACtC,kBAAkB,EAAE,IAAI;SACzB,CAAC,CACH,CAAC;KACH;IAED,IAAI,gBAAgB,IAAI,eAAe,EAAE;QACvC,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,IAAI,gBAAgB,EAAE;YACpB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrB;QAED,IAAI,eAAe,EAAE;YACnB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACtB;QAED,YAAY,CAAC,IAAI,CAAC,IAAI,6CAAoB,EAAE,CAAC,CAAC;QAE9C,YAAY,CAAC,IAAI,CACf,IAAI,gCAAsB,CAAC;YACzB,QAAQ,EAAE,YAAY;YACtB,OAAO;YACP,sDAAsD;YACtD,+EAA+E;YAC/E,sFAAsF;YACtF,uCAAuC;YACvC,UAAU,EAAE,aAAa;YACzB,sBAAsB,EAAE,iBAAiB;YACzC,MAAM,EAAE,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;SAC5C,CAAC,CACH,CAAC;KACH;IAED,IAAI,OAAO,EAAE;QACX,YAAY,CAAC,IAAI,CAAC,IAAI,8CAAoB,EAAE,CAAC,CAAC;KAC/C;IAED,IAAI,YAAY,CAAC,SAAS,EAAE;QAC1B,YAAY,CAAC,IAAI,CACf,IAAI,yBAAe,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC,CAC/E,CAAC;KACH;IAED,IAAI,oBAAoB,EAAE;QACxB,YAAY,CAAC,IAAI,CACf,IAAI,0DAA0B,CAAC;YAC7B,aAAa,EAAE,CAAC,QAAQ,CAAC;SAC1B,CAAC,CACH,CAAC;KACH;IAED,IAAI,gBAAgB,IAAI,eAAe,EAAE;QACvC,UAAU,CAAC,IAAI,CAAC;YACd,IAAI,EAAE,cAAc;YACpB,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC;YAC5C,OAAO,EAAE;gBACP,sBAAsB,EAAE,CAAC,OAAe,EAAE,YAAoB,EAAE,EAAE;oBAChE,IAAI,eAAe,EAAE;wBACnB,wDAAwD;wBACxD,OAAO,IAAI,CAAC;qBACb;oBAED,oEAAoE;oBACpE,8CAA8C;oBAC9C,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;gBAChD,CAAC;aACF;SACF,CAAC,CAAC;KACJ;IAED,IAAI,IAAI,IAAI,SAAS,EAAE;QACrB,UAAU,CAAC,IAAI,CAAC;YACd,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,cAAc;YACnE,MAAM,EAAE,kCAAwB;YAChC,0GAA0G;YAC1G,OAAO,EAAE;gBACP,8FAA8F;aAC/F;SACF,CAAC,CAAC;QACH,YAAY,CAAC,IAAI,CAAC,IAAA,4BAAe,EAAC,GAAG,EAAE,GAAG,EAAE,YAAY,CAAC,CAAC,CAAC;KAC5D;IAED,IAAI,iBAAiB,EAAE;QACrB,YAAY,CAAC,IAAI,CAAC,IAAA,4BAAe,EAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;KAC3F;IAED,MAAM,eAAe,GAAG,EAAE,CAAC;IAC3B,IAAI,mBAAmB,EAAE;QACvB,eAAe,CAAC,IAAI,CAClB,IAAI,mCAAyB,CAAC;YAC5B,MAAM,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,sBAAsB;YACnF,SAAS,EAAE,gBAAgB;YAC3B,iBAAiB,EAAE,YAAY,CAAC,iBAAiB;YACjD,mBAAmB,EAAE,CAAC,iCAAW,IAAI,gBAAgB;YACrD,SAAS,EAAE,gBAAgB;YAC3B,cAAc,EAAE,YAAY,CAAC,eAAe;YAC5C,QAAQ,EAAE,YAAY,CAAC,cAAc;SACtC,CAAC,CACH,CAAC;KACH;IAED,IAAI,QAAQ,KAAK,SAAS,IAAI,CAAC,mBAAmB,IAAI,kBAAkB,CAAC,MAAM,CAAC,EAAE;QAChF,eAAe,CAAC,IAAI,CAAC,IAAI,yCAAkB,EAAE,CAAC,CAAC;KAChD;IAED,IAAI,kBAAkB,GAA+D,KAAK,CAAC;IAC3F,IAAI,oBAAoB,IAAI,WAAW,KAAK,MAAM,EAAE;QAClD,kBAAkB,GAAG,WAAW,CAAC;KAClC;SAAM,IAAI,WAAW,KAAK,MAAM,EAAE;QACjC,kBAAkB,GAAG,WAAW,CAAC;KAClC;IAED,OAAO;QACL,IAAI,EAAE,mBAAmB,IAAI,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa;QACrF,OAAO,EAAE,KAAK;QACd,MAAM,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC;QACrD,OAAO,EAAE,YAAY,CAAC,SAAS;QAC/B,OAAO,EAAE;YACP,KAAK,EAAE,CAAC,WAAW,CAAC;YACpB,UAAU,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC;YAC1C,QAAQ,EAAE,CAAC,YAAY,CAAC,gBAAgB;YACxC,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,IAAI,WAAW,EAAE,cAAc,CAAC;YAClE,UAAU,EAAE,gBAAgB;gBAC1B,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC;gBACxC,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC;YACrD,cAAc,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC;SAC5C;QACD,aAAa,EAAE;YACb,QAAQ,EAAE,CAAC,YAAY,CAAC,gBAAgB;SACzC;QACD,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,WAAW;QAClB,SAAS,EAAE,oBAAoB;QAC/B,MAAM,EAAE;YACN,UAAU,EAAE,WAAW;YACvB,YAAY,EAAE,UAAU;YACxB,KAAK,EAAE,YAAY,CAAC,gBAAgB,IAAI,IAAI;YAC5C,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,UAAU,CAAC;YACjD,UAAU,EAAE,YAAY,CAAC,SAAS,IAAI,EAAE;YACxC,QAAQ,EAAE,SAAS,UAAU,CAAC,KAAK,KAAK;YACxC,aAAa,EAAE,SAAS,UAAU,CAAC,KAAK,KAAK;YAC7C,aAAa,EAAE,gBAAgB,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;YACxD,kBAAkB;YAClB,YAAY,EAAE,iBAAiB;YAC/B,UAAU,EAAE,QAAQ;SACrB;QACD,KAAK,EAAE,YAAY,CAAC,KAAK;QACzB,YAAY,EAAE;YACZ,IAAI;YACJ,yFAAyF;YACzF,cAAc,EAAE,YAAY,CAAC,gBAAgB;YAC7C,OAAO,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,oBAAoB;SAC/D;QACD,QAAQ,EAAE;YACR,MAAM,EAAE;gBACN,6FAA6F;gBAC7F,wFAAwF;gBACxF,IAAI,EAAE,YAAY,CAAC,gBAAgB;aACpC;SACF;QACD,WAAW,EAAE;YACX,KAAK,EAAE,KAAK;SACb;QACD,cAAc,EAAE;YACd,sHAAsH;YACtH,iCAAiC;YACjC,yHAAyH;YACzH,mCAAmC;YACnC,iFAAiF;YACjF,kGAAkG;YAClG,+CAA+C;SAChD;QACD,MAAM,EAAE;YACN,0DAA0D;YAC1D,oBAAoB,EAAE,IAAI;YAC1B,MAAM,EAAE;gBACN,UAAU,EAAE;oBACV,cAAc,EAAE,KAAK;oBACrB,yFAAyF;oBACzF,0DAA0D;oBAC1D,GAAG,EAAE,KAAK;oBACV,MAAM,EAAE,CAAC,CAAC,iBAAiB;iBAC5B;aACF;YACD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,gBAAgB;oBACtB,yEAAyE;oBACzE,aAAa,EAAE,cAAc;oBAC7B,IAAI,EAAE,cAAc;iBACrB;gBACD;oBACE,2DAA2D;oBAC3D,sEAAsE;oBACtE,0CAA0C;oBAC1C,IAAI,EAAE,+BAA+B;oBACrC,WAAW,EAAE,IAAI;iBAClB;gBACD;oBACE,IAAI,EAAE,iBAAiB;oBACvB,yGAAyG;oBACzG,OAAO,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE;oBAClC,OAAO,EAAE;wBACP,uGAAuG;qBACxG;oBACD,GAAG,EAAE;wBACH;4BACE,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,4BAA4B,CAAC;4BACrD,OAAO,EAAE;gCACP,WAAW,EAAE;oCACX,kEAAkE;oCAClE,gEAAgE;oCAChE,iGAAiG;oCACjG,sGAAsG;oCACtG,oBAAoB,EAAE,IAAI;iCAC3B;gCACD,cAAc,EAAE,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC,IAAI,KAAK;gCAClF,GAAG,EAAE,YAAY,CAAC,GAAG;gCACrB,QAAQ,EAAE,YAAY,CAAC,cAAc;gCACrC,iBAAiB,EAAE,YAAY,CAAC,iBAAiB;gCACjD,cAAc,EAAE,YAAY;oCAC1B,CAAC,CAAC;wCACE,gBAAgB,EAAE,UAAU,IAAI,WAAW;wCAC3C,aAAa,EAAE,IAAA,yCAA+B,EAAC,IAAI,EAAE,mBAAmB,CAAC;qCAC1E;oCACH,CAAC,CAAC,SAAS;6BACe;yBAC/B;qBACF;iBACF;gBACD,GAAG,UAAU;aACd;SACF;QACD,WAAW,EAAE;YACX,UAAU,EAAE,KAAK;YACjB,eAAe,EAAE,IAAI;YACrB,gBAAgB,EAAE,IAAI;SACvB;QACD,qBAAqB,EAAE;YACrB,KAAK,EAAE,OAAO;YACd,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO;SACrC;QACD,KAAK,EAAE,IAAA,yBAAe,EAAC,OAAO,CAAC;QAC/B,KAAK,EAAE,IAAA,0BAAgB,EAAC,GAAG,EAAE,UAAU,CAAC,IAAI,CAAC;QAC7C,YAAY,EAAE;YACZ,SAAS,EAAE,eAAe;YAC1B,SAAS,EAAE,eAAe;YAC1B,QAAQ,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe;YAC9D,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;YACjD,WAAW,EAAE;gBACX,gBAAgB,EAAE,QAAQ;gBAC1B,WAAW,EAAE;oBACX,OAAO,EAAE,CAAC,CAAC,WAAW,IAAI;wBACxB,MAAM,EAAE,OAAO;wBACf,SAAS,EAAE,CAAC;wBACZ,QAAQ,EAAE,EAAE;qBACb;oBACD,MAAM,EAAE,CAAC,CAAC,WAAW,IAAI;wBACvB,IAAI,EAAE,QAAQ;wBACd,MAAM,EAAE,OAAO;wBACf,SAAS,EAAE,CAAC;wBACZ,OAAO,EAAE,IAAI;wBACb,QAAQ,EAAE,CAAC;qBACZ;oBACD,OAAO,EAAE,KAAK;oBACd,cAAc,EAAE,CAAC,CAAC,WAAW,IAAI;wBAC/B,IAAI,EAAE,QAAQ;wBACd,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM;wBACxC,OAAO,EAAE,IAAI;wBACb,IAAI,EAAE,YAAY;qBACnB;iBACF;aACF;SACF;QACD,OAAO,EAAE;YACP,IAAI,uCAAiB,EAAE;YACvB,IAAI,sCAAiB,CAAC;gBACpB,GAAG;gBACH,mBAAmB;aACpB,CAAC;YACF,IAAI,mCAAyB,CAAC,EAAE,OAAO,EAAE,CAAC;YAC1C,GAAG,YAAY;SAChB;QACD,IAAI,EAAE,KAAK;KACZ,CAAC;AACJ,CAAC;AA5bD,0CA4bC","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 { AngularWebpackLoaderPath } from '@ngtools/webpack';\nimport CopyWebpackPlugin from 'copy-webpack-plugin';\nimport * as path from 'path';\nimport {\n  Compiler,\n  Configuration,\n  ContextReplacementPlugin,\n  RuleSetRule,\n  SourceMapDevToolPlugin,\n} from 'webpack';\nimport { SubresourceIntegrityPlugin } from 'webpack-subresource-integrity';\nimport { AngularBabelLoaderOptions } from '../../babel/webpack-loader';\nimport { WebpackConfigOptions } from '../../utils/build-options';\nimport { allowMangle } from '../../utils/environment-options';\nimport { loadEsmModule } from '../../utils/load-esm';\nimport {\n  CommonJsUsageWarnPlugin,\n  DedupeModuleResolvePlugin,\n  JavaScriptOptimizerPlugin,\n  JsonStatsPlugin,\n  ScriptsWebpackPlugin,\n} from '../plugins';\nimport { DevToolsIgnorePlugin } from '../plugins/devtools-ignore-plugin';\nimport { NamedChunksPlugin } from '../plugins/named-chunks-plugin';\nimport { OccurrencesPlugin } from '../plugins/occurrences-plugin';\nimport { ProgressPlugin } from '../plugins/progress-plugin';\nimport { TransferSizePlugin } from '../plugins/transfer-size-plugin';\nimport { createIvyPlugin } from '../plugins/typescript';\nimport { WatchFilesLogsPlugin } from '../plugins/watch-files-logs-plugin';\nimport {\n  assetPatterns,\n  getCacheSettings,\n  getInstrumentationExcludedPaths,\n  getOutputHashFormat,\n  getStatsOptions,\n  globalScriptsByBundleName,\n  isPlatformServerInstalled,\n} from '../utils/helpers';\n\nconst VENDORS_TEST = /[\\\\/]node_modules[\\\\/]/;\n\n// eslint-disable-next-line max-lines-per-function\nexport async function getCommonConfig(wco: WebpackConfigOptions): Promise<Configuration> {\n  const { root, projectRoot, buildOptions, tsConfig, projectName, sourceRoot, tsConfigPath } = wco;\n  const {\n    cache,\n    codeCoverage,\n    crossOrigin = 'none',\n    platform = 'browser',\n    aot = true,\n    codeCoverageExclude = [],\n    main,\n    sourceMap: {\n      styles: stylesSourceMap,\n      scripts: scriptsSourceMap,\n      vendor: vendorSourceMap,\n      hidden: hiddenSourceMap,\n    },\n    optimization: { styles: stylesOptimization, scripts: scriptsOptimization },\n    commonChunk,\n    vendorChunk,\n    subresourceIntegrity,\n    verbose,\n    poll,\n    webWorkerTsConfig,\n    externalDependencies = [],\n    allowedCommonJsDependencies,\n  } = buildOptions;\n\n  const isPlatformServer = buildOptions.platform === 'server';\n  const extraPlugins: { apply(compiler: Compiler): void }[] = [];\n  const extraRules: RuleSetRule[] = [];\n  const entryPoints: Configuration['entry'] = {};\n\n  // Load ESM `@angular/compiler-cli` using the TypeScript dynamic import workaround.\n  // Once TypeScript provides support for keeping the dynamic import this workaround can be\n  // changed to a direct dynamic import.\n  const {\n    GLOBAL_DEFS_FOR_TERSER,\n    GLOBAL_DEFS_FOR_TERSER_WITH_AOT,\n    VERSION: NG_VERSION,\n  } = await loadEsmModule<typeof import('@angular/compiler-cli')>('@angular/compiler-cli');\n\n  // determine hashing format\n  const hashFormat = getOutputHashFormat(buildOptions.outputHashing);\n\n  if (buildOptions.progress) {\n    extraPlugins.push(new ProgressPlugin(platform));\n  }\n\n  const localizePackageInitEntryPoint = '@angular/localize/init';\n  const hasLocalizeType = tsConfig.options.types?.some(\n    (t) => t === '@angular/localize' || t === localizePackageInitEntryPoint,\n  );\n\n  if (hasLocalizeType) {\n    entryPoints['main'] = [localizePackageInitEntryPoint];\n  }\n\n  if (buildOptions.main) {\n    const mainPath = path.resolve(root, buildOptions.main);\n    if (Array.isArray(entryPoints['main'])) {\n      entryPoints['main'].push(mainPath);\n    } else {\n      entryPoints['main'] = [mainPath];\n    }\n  }\n\n  if (isPlatformServer) {\n    // Fixes Critical dependency: the request of a dependency is an expression\n    extraPlugins.push(new ContextReplacementPlugin(/@?hapi|express[\\\\/]/));\n\n    if (isPlatformServerInstalled(wco.root) && Array.isArray(entryPoints['main'])) {\n      // This import must come before any imports (direct or transitive) that rely on DOM built-ins being\n      // available, such as `@angular/elements`.\n      entryPoints['main'].unshift('@angular/platform-server/init');\n    }\n  }\n\n  const polyfills = [...buildOptions.polyfills];\n  if (!aot) {\n    polyfills.push('@angular/compiler');\n  }\n\n  if (polyfills.length) {\n    // `zone.js/testing` is a **special** polyfill because when not imported in the main it fails with the below errors:\n    // `Error: Expected to be running in 'ProxyZone', but it was not found.`\n    // This was also the reason why previously it was imported in `test.ts` as the first module.\n    // From Jia li:\n    // This is because the jasmine functions such as beforeEach/it will not be patched by zone.js since\n    // jasmine will not be loaded yet, so the ProxyZone will not be there. We have to load zone-testing.js after\n    // jasmine is ready.\n    // We could force loading 'zone.js/testing' prior to jasmine by changing the order of scripts in 'karma-context.html'.\n    // But this has it's own problems as zone.js needs to be loaded prior to jasmine due to patching of timing functions\n    // See: https://github.com/jasmine/jasmine/issues/1944\n    // Thus the correct order is zone.js -> jasmine -> zone.js/testing.\n    const zoneTestingEntryPoint = 'zone.js/testing';\n    const polyfillsExludingZoneTesting = polyfills.filter((p) => p !== zoneTestingEntryPoint);\n\n    if (Array.isArray(entryPoints['polyfills'])) {\n      entryPoints['polyfills'].push(...polyfillsExludingZoneTesting);\n    } else {\n      entryPoints['polyfills'] = polyfillsExludingZoneTesting;\n    }\n\n    if (polyfillsExludingZoneTesting.length !== polyfills.length) {\n      if (Array.isArray(entryPoints['main'])) {\n        entryPoints['main'].unshift(zoneTestingEntryPoint);\n      } else {\n        entryPoints['main'] = [zoneTestingEntryPoint];\n      }\n    }\n  }\n\n  if (allowedCommonJsDependencies) {\n    // When this is not defined it means the builder doesn't support showing common js usages.\n    // When it does it will be an array.\n    extraPlugins.push(\n      new CommonJsUsageWarnPlugin({\n        allowedDependencies: allowedCommonJsDependencies,\n      }),\n    );\n  }\n\n  // process global scripts\n  // Add a new asset for each entry.\n  for (const { bundleName, inject, paths } of globalScriptsByBundleName(buildOptions.scripts)) {\n    // Lazy scripts don't get a hash, otherwise they can't be loaded by name.\n    const hash = inject ? hashFormat.script : '';\n\n    extraPlugins.push(\n      new ScriptsWebpackPlugin({\n        name: bundleName,\n        sourceMap: scriptsSourceMap,\n        scripts: paths,\n        filename: `${path.basename(bundleName)}${hash}.js`,\n        basePath: root,\n      }),\n    );\n  }\n\n  // process asset entries\n  if (buildOptions.assets.length) {\n    extraPlugins.push(\n      new CopyWebpackPlugin({\n        patterns: assetPatterns(root, buildOptions.assets),\n      }),\n    );\n  }\n\n  if (buildOptions.extractLicenses) {\n    const LicenseWebpackPlugin = require('license-webpack-plugin').LicenseWebpackPlugin;\n    extraPlugins.push(\n      new LicenseWebpackPlugin({\n        stats: {\n          warnings: false,\n          errors: false,\n        },\n        perChunkOutput: false,\n        outputFilename: '3rdpartylicenses.txt',\n        skipChildCompilers: true,\n      }),\n    );\n  }\n\n  if (scriptsSourceMap || stylesSourceMap) {\n    const include = [];\n    if (scriptsSourceMap) {\n      include.push(/js$/);\n    }\n\n    if (stylesSourceMap) {\n      include.push(/css$/);\n    }\n\n    extraPlugins.push(new DevToolsIgnorePlugin());\n\n    extraPlugins.push(\n      new SourceMapDevToolPlugin({\n        filename: '[file].map',\n        include,\n        // We want to set sourceRoot to  `webpack:///` for non\n        // inline sourcemaps as otherwise paths to sourcemaps will be broken in browser\n        // `webpack:///` is needed for Visual Studio breakpoints to work properly as currently\n        // there is no way to set the 'webRoot'\n        sourceRoot: 'webpack:///',\n        moduleFilenameTemplate: '[resource-path]',\n        append: hiddenSourceMap ? false : undefined,\n      }),\n    );\n  }\n\n  if (verbose) {\n    extraPlugins.push(new WatchFilesLogsPlugin());\n  }\n\n  if (buildOptions.statsJson) {\n    extraPlugins.push(\n      new JsonStatsPlugin(path.resolve(root, buildOptions.outputPath, 'stats.json')),\n    );\n  }\n\n  if (subresourceIntegrity) {\n    extraPlugins.push(\n      new SubresourceIntegrityPlugin({\n        hashFuncNames: ['sha384'],\n      }),\n    );\n  }\n\n  if (scriptsSourceMap || stylesSourceMap) {\n    extraRules.push({\n      test: /\\.[cm]?jsx?$/,\n      enforce: 'pre',\n      loader: require.resolve('source-map-loader'),\n      options: {\n        filterSourceMappingUrl: (_mapUri: string, resourcePath: string) => {\n          if (vendorSourceMap) {\n            // Consume all sourcemaps when vendor option is enabled.\n            return true;\n          }\n\n          // Don't consume sourcemaps in node_modules when vendor is disabled.\n          // But, do consume local libraries sourcemaps.\n          return !resourcePath.includes('node_modules');\n        },\n      },\n    });\n  }\n\n  if (main || polyfills) {\n    extraRules.push({\n      test: tsConfig.options.allowJs ? /\\.[cm]?[tj]sx?$/ : /\\.[cm]?tsx?$/,\n      loader: AngularWebpackLoaderPath,\n      // The below are known paths that are not part of the TypeScript compilation even when allowJs is enabled.\n      exclude: [\n        /[\\\\/]node_modules[/\\\\](?:css-loader|mini-css-extract-plugin|webpack-dev-server|webpack)[/\\\\]/,\n      ],\n    });\n    extraPlugins.push(createIvyPlugin(wco, aot, tsConfigPath));\n  }\n\n  if (webWorkerTsConfig) {\n    extraPlugins.push(createIvyPlugin(wco, false, path.resolve(wco.root, webWorkerTsConfig)));\n  }\n\n  const extraMinimizers = [];\n  if (scriptsOptimization) {\n    extraMinimizers.push(\n      new JavaScriptOptimizerPlugin({\n        define: buildOptions.aot ? GLOBAL_DEFS_FOR_TERSER_WITH_AOT : GLOBAL_DEFS_FOR_TERSER,\n        sourcemap: scriptsSourceMap,\n        supportedBrowsers: buildOptions.supportedBrowsers,\n        keepIdentifierNames: !allowMangle || isPlatformServer,\n        keepNames: isPlatformServer,\n        removeLicenses: buildOptions.extractLicenses,\n        advanced: buildOptions.buildOptimizer,\n      }),\n    );\n  }\n\n  if (platform === 'browser' && (scriptsOptimization || stylesOptimization.minify)) {\n    extraMinimizers.push(new TransferSizePlugin());\n  }\n\n  let crossOriginLoading: NonNullable<Configuration['output']>['crossOriginLoading'] = false;\n  if (subresourceIntegrity && crossOrigin === 'none') {\n    crossOriginLoading = 'anonymous';\n  } else if (crossOrigin !== 'none') {\n    crossOriginLoading = crossOrigin;\n  }\n\n  return {\n    mode: scriptsOptimization || stylesOptimization.minify ? 'production' : 'development',\n    devtool: false,\n    target: [isPlatformServer ? 'node' : 'web', 'es2015'],\n    profile: buildOptions.statsJson,\n    resolve: {\n      roots: [projectRoot],\n      extensions: ['.ts', '.tsx', '.mjs', '.js'],\n      symlinks: !buildOptions.preserveSymlinks,\n      modules: [tsConfig.options.baseUrl || projectRoot, 'node_modules'],\n      mainFields: isPlatformServer\n        ? ['es2020', 'es2015', 'module', 'main']\n        : ['es2020', 'es2015', 'browser', 'module', 'main'],\n      conditionNames: ['es2020', 'es2015', '...'],\n    },\n    resolveLoader: {\n      symlinks: !buildOptions.preserveSymlinks,\n    },\n    context: root,\n    entry: entryPoints,\n    externals: externalDependencies,\n    output: {\n      uniqueName: projectName,\n      hashFunction: 'xxhash64', // todo: remove in webpack 6. This is part of `futureDefaults`.\n      clean: buildOptions.deleteOutputPath ?? true,\n      path: path.resolve(root, buildOptions.outputPath),\n      publicPath: buildOptions.deployUrl ?? '',\n      filename: `[name]${hashFormat.chunk}.js`,\n      chunkFilename: `[name]${hashFormat.chunk}.js`,\n      libraryTarget: isPlatformServer ? 'commonjs' : undefined,\n      crossOriginLoading,\n      trustedTypes: 'angular#bundler',\n      scriptType: 'module',\n    },\n    watch: buildOptions.watch,\n    watchOptions: {\n      poll,\n      // The below is needed as when preserveSymlinks is enabled we disable `resolve.symlinks`.\n      followSymlinks: buildOptions.preserveSymlinks,\n      ignored: poll === undefined ? undefined : '**/node_modules/**',\n    },\n    snapshot: {\n      module: {\n        // Use hash of content instead of timestamp because the timestamp of the symlink will be used\n        // instead of the referenced files which causes changes in symlinks not to be picked up.\n        hash: buildOptions.preserveSymlinks,\n      },\n    },\n    performance: {\n      hints: false,\n    },\n    ignoreWarnings: [\n      // https://github.com/webpack-contrib/source-map-loader/blob/b2de4249c7431dd8432da607e08f0f65e9d64219/src/index.js#L83\n      /Failed to parse source map from/,\n      // https://github.com/webpack-contrib/postcss-loader/blob/bd261875fdf9c596af4ffb3a1a73fe3c549befda/src/index.js#L153-L158\n      /Add postcss as project dependency/,\n      // esbuild will issue a warning, while still hoists the @charset at the very top.\n      // This is caused by a bug in css-loader https://github.com/webpack-contrib/css-loader/issues/1212\n      /\"@charset\" must be the first rule in the file/,\n    ],\n    module: {\n      // Show an error for missing exports instead of a warning.\n      strictExportPresence: true,\n      parser: {\n        javascript: {\n          requireContext: false,\n          // Disable auto URL asset module creation. This doesn't effect `new Worker(new URL(...))`\n          // https://webpack.js.org/guides/asset-modules/#url-assets\n          url: false,\n          worker: !!webWorkerTsConfig,\n        },\n      },\n      rules: [\n        {\n          test: /\\.?(svg|html)$/,\n          // Only process HTML and SVG which are known Angular component resources.\n          resourceQuery: /\\?ngResource/,\n          type: 'asset/source',\n        },\n        {\n          // Mark files inside `rxjs/add` as containing side effects.\n          // If this is fixed upstream and the fixed version becomes the minimum\n          // supported version, this can be removed.\n          test: /[/\\\\]rxjs[/\\\\]add[/\\\\].+\\.js$/,\n          sideEffects: true,\n        },\n        {\n          test: /\\.[cm]?[tj]sx?$/,\n          // The below is needed due to a bug in `@babel/runtime`. See: https://github.com/babel/babel/issues/12824\n          resolve: { fullySpecified: false },\n          exclude: [\n            /[\\\\/]node_modules[/\\\\](?:core-js|@babel|tslib|web-animations-js|web-streams-polyfill|whatwg-url)[/\\\\]/,\n          ],\n          use: [\n            {\n              loader: require.resolve('../../babel/webpack-loader'),\n              options: {\n                assumptions: {\n                  // Use `setPublicClassFields: true` to avoid decrease bundle sizes\n                  // when targetting ES2022+ with `useDefineForClassFields: true`.\n                  // This is because ervery property of the class will otherwise be wrapped in a `_defineProperty`.\n                  // This is not needed for TypeScript as TS itself will emit the right declaration of class properties.\n                  setPublicClassFields: true,\n                },\n                cacheDirectory: (cache.enabled && path.join(cache.path, 'babel-webpack')) || false,\n                aot: buildOptions.aot,\n                optimize: buildOptions.buildOptimizer,\n                supportedBrowsers: buildOptions.supportedBrowsers,\n                instrumentCode: codeCoverage\n                  ? {\n                      includedBasePath: sourceRoot ?? projectRoot,\n                      excludedPaths: getInstrumentationExcludedPaths(root, codeCoverageExclude),\n                    }\n                  : undefined,\n              } as AngularBabelLoaderOptions,\n            },\n          ],\n        },\n        ...extraRules,\n      ],\n    },\n    experiments: {\n      backCompat: false,\n      syncWebAssembly: true,\n      asyncWebAssembly: true,\n    },\n    infrastructureLogging: {\n      debug: verbose,\n      level: verbose ? 'verbose' : 'error',\n    },\n    stats: getStatsOptions(verbose),\n    cache: getCacheSettings(wco, NG_VERSION.full),\n    optimization: {\n      minimizer: extraMinimizers,\n      moduleIds: 'deterministic',\n      chunkIds: buildOptions.namedChunks ? 'named' : 'deterministic',\n      emitOnErrors: false,\n      runtimeChunk: isPlatformServer ? false : 'single',\n      splitChunks: {\n        maxAsyncRequests: Infinity,\n        cacheGroups: {\n          default: !!commonChunk && {\n            chunks: 'async',\n            minChunks: 2,\n            priority: 10,\n          },\n          common: !!commonChunk && {\n            name: 'common',\n            chunks: 'async',\n            minChunks: 2,\n            enforce: true,\n            priority: 5,\n          },\n          vendors: false,\n          defaultVendors: !!vendorChunk && {\n            name: 'vendor',\n            chunks: (chunk) => chunk.name === 'main',\n            enforce: true,\n            test: VENDORS_TEST,\n          },\n        },\n      },\n    },\n    plugins: [\n      new NamedChunksPlugin(),\n      new OccurrencesPlugin({\n        aot,\n        scriptsOptimization,\n      }),\n      new DedupeModuleResolvePlugin({ verbose }),\n      ...extraPlugins,\n    ],\n    node: false,\n  };\n}\n"]}
420
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/webpack/configs/common.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,8CAA4D;AAC5D,8EAAoD;AACpD,2CAA6B;AAC7B,qCAMiB;AACjB,iFAA2E;AAG3E,yEAA8D;AAC9D,mDAAqD;AACrD,wCAMoB;AACpB,8EAAyE;AACzE,wEAAmE;AACnE,sEAAkE;AAClE,gEAA4D;AAC5D,0EAAqE;AACrE,sDAAwD;AACxD,gFAA0E;AAC1E,8CAQ0B;AAE1B,MAAM,YAAY,GAAG,wBAAwB,CAAC;AAE9C,kDAAkD;AAC3C,KAAK,UAAU,eAAe,CAAC,GAAyB;IAC7D,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,GAAG,CAAC;IACjG,MAAM,EACJ,KAAK,EACL,YAAY,EACZ,WAAW,GAAG,MAAM,EACpB,QAAQ,GAAG,SAAS,EACpB,GAAG,GAAG,IAAI,EACV,mBAAmB,GAAG,EAAE,EACxB,IAAI,EACJ,SAAS,EAAE,EACT,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,gBAAgB,EACzB,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,eAAe,GACxB,EACD,YAAY,EAAE,EAAE,MAAM,EAAE,kBAAkB,EAAE,OAAO,EAAE,mBAAmB,EAAE,EAC1E,WAAW,EACX,WAAW,EACX,oBAAoB,EACpB,OAAO,EACP,IAAI,EACJ,iBAAiB,EACjB,oBAAoB,GAAG,EAAE,EACzB,2BAA2B,GAC5B,GAAG,YAAY,CAAC;IAEjB,MAAM,gBAAgB,GAAG,YAAY,CAAC,QAAQ,KAAK,QAAQ,CAAC;IAC5D,MAAM,YAAY,GAA0C,EAAE,CAAC;IAC/D,MAAM,UAAU,GAAkB,EAAE,CAAC;IACrC,MAAM,WAAW,GAA2B,EAAE,CAAC;IAE/C,mFAAmF;IACnF,yFAAyF;IACzF,sCAAsC;IACtC,MAAM,EACJ,sBAAsB,EACtB,+BAA+B,EAC/B,OAAO,EAAE,UAAU,GACpB,GAAG,MAAM,IAAA,wBAAa,EAAyC,uBAAuB,CAAC,CAAC;IAEzF,2BAA2B;IAC3B,MAAM,UAAU,GAAG,IAAA,6BAAmB,EAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IAEnE,IAAI,YAAY,CAAC,QAAQ,EAAE;QACzB,YAAY,CAAC,IAAI,CAAC,IAAI,gCAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;KACjD;IAED,MAAM,6BAA6B,GAAG,wBAAwB,CAAC;IAC/D,MAAM,eAAe,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAClD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,mBAAmB,IAAI,CAAC,KAAK,6BAA6B,CACxE,CAAC;IAEF,IAAI,eAAe,EAAE;QACnB,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;KACvD;IAED,IAAI,YAAY,CAAC,IAAI,EAAE;QACrB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;QACvD,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;YACtC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACpC;aAAM;YACL,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAClC;KACF;IAED,IAAI,gBAAgB,EAAE;QACpB,0EAA0E;QAC1E,YAAY,CAAC,IAAI,CAAC,IAAI,kCAAwB,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAEvE,IAAI,IAAA,mCAAyB,EAAC,GAAG,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;YAC7E,mGAAmG;YACnG,0CAA0C;YAC1C,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC;SAC9D;KACF;IAED,MAAM,SAAS,GAAG,CAAC,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,GAAG,EAAE;QACR,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;KACrC;IAED,IAAI,SAAS,CAAC,MAAM,EAAE;QACpB,oHAAoH;QACpH,wEAAwE;QACxE,4FAA4F;QAC5F,eAAe;QACf,mGAAmG;QACnG,4GAA4G;QAC5G,oBAAoB;QACpB,sHAAsH;QACtH,oHAAoH;QACpH,sDAAsD;QACtD,mEAAmE;QACnE,MAAM,qBAAqB,GAAG,iBAAiB,CAAC;QAChD,MAAM,4BAA4B,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,qBAAqB,CAAC,CAAC;QAE1F,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,EAAE;YAC3C,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,4BAA4B,CAAC,CAAC;SAChE;aAAM;YACL,WAAW,CAAC,WAAW,CAAC,GAAG,4BAA4B,CAAC;SACzD;QAED,IAAI,4BAA4B,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE;YAC5D,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE;gBACtC,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;aACpD;iBAAM;gBACL,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;aAC/C;SACF;KACF;IAED,IAAI,2BAA2B,EAAE;QAC/B,0FAA0F;QAC1F,oCAAoC;QACpC,YAAY,CAAC,IAAI,CACf,IAAI,iCAAuB,CAAC;YAC1B,mBAAmB,EAAE,2BAA2B;SACjD,CAAC,CACH,CAAC;KACH;IAED,yBAAyB;IACzB,kCAAkC;IAClC,KAAK,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,IAAA,mCAAyB,EAAC,YAAY,CAAC,OAAO,CAAC,EAAE;QAC3F,yEAAyE;QACzE,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7C,YAAY,CAAC,IAAI,CACf,IAAI,8BAAoB,CAAC;YACvB,IAAI,EAAE,UAAU;YAChB,SAAS,EAAE,gBAAgB;YAC3B,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,IAAI,KAAK;YAClD,QAAQ,EAAE,IAAI;SACf,CAAC,CACH,CAAC;KACH;IAED,wBAAwB;IACxB,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE;QAC9B,YAAY,CAAC,IAAI,CACf,IAAI,6BAAiB,CAAC;YACpB,QAAQ,EAAE,IAAA,uBAAa,EAAC,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC;SACnD,CAAC,CACH,CAAC;KACH;IAED,IAAI,YAAY,CAAC,eAAe,EAAE;QAChC,MAAM,oBAAoB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC,oBAAoB,CAAC;QACpF,YAAY,CAAC,IAAI,CACf,IAAI,oBAAoB,CAAC;YACvB,KAAK,EAAE;gBACL,QAAQ,EAAE,KAAK;gBACf,MAAM,EAAE,KAAK;aACd;YACD,cAAc,EAAE,KAAK;YACrB,cAAc,EAAE,sBAAsB;YACtC,kBAAkB,EAAE,IAAI;SACzB,CAAC,CACH,CAAC;KACH;IAED,IAAI,gBAAgB,IAAI,eAAe,EAAE;QACvC,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,IAAI,gBAAgB,EAAE;YACpB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrB;QAED,IAAI,eAAe,EAAE;YACnB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACtB;QAED,YAAY,CAAC,IAAI,CAAC,IAAI,6CAAoB,EAAE,CAAC,CAAC;QAE9C,YAAY,CAAC,IAAI,CACf,IAAI,gCAAsB,CAAC;YACzB,QAAQ,EAAE,YAAY;YACtB,OAAO;YACP,sDAAsD;YACtD,+EAA+E;YAC/E,sFAAsF;YACtF,uCAAuC;YACvC,UAAU,EAAE,aAAa;YACzB,sBAAsB,EAAE,iBAAiB;YACzC,MAAM,EAAE,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;SAC5C,CAAC,CACH,CAAC;KACH;IAED,IAAI,OAAO,EAAE;QACX,YAAY,CAAC,IAAI,CAAC,IAAI,8CAAoB,EAAE,CAAC,CAAC;KAC/C;IAED,IAAI,YAAY,CAAC,SAAS,EAAE;QAC1B,YAAY,CAAC,IAAI,CACf,IAAI,yBAAe,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC,CAC/E,CAAC;KACH;IAED,IAAI,oBAAoB,EAAE;QACxB,YAAY,CAAC,IAAI,CACf,IAAI,0DAA0B,CAAC;YAC7B,aAAa,EAAE,CAAC,QAAQ,CAAC;SAC1B,CAAC,CACH,CAAC;KACH;IAED,IAAI,gBAAgB,IAAI,eAAe,EAAE;QACvC,UAAU,CAAC,IAAI,CAAC;YACd,IAAI,EAAE,cAAc;YACpB,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC;YAC5C,OAAO,EAAE;gBACP,sBAAsB,EAAE,CAAC,OAAe,EAAE,YAAoB,EAAE,EAAE;oBAChE,IAAI,eAAe,EAAE;wBACnB,wDAAwD;wBACxD,OAAO,IAAI,CAAC;qBACb;oBAED,oEAAoE;oBACpE,8CAA8C;oBAC9C,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;gBAChD,CAAC;aACF;SACF,CAAC,CAAC;KACJ;IAED,IAAI,IAAI,IAAI,SAAS,EAAE;QACrB,UAAU,CAAC,IAAI,CAAC;YACd,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,cAAc;YACnE,MAAM,EAAE,kCAAwB;YAChC,0GAA0G;YAC1G,OAAO,EAAE;gBACP,8FAA8F;aAC/F;SACF,CAAC,CAAC;QACH,YAAY,CAAC,IAAI,CAAC,IAAA,4BAAe,EAAC,GAAG,EAAE,GAAG,EAAE,YAAY,CAAC,CAAC,CAAC;KAC5D;IAED,IAAI,iBAAiB,EAAE;QACrB,YAAY,CAAC,IAAI,CAAC,IAAA,4BAAe,EAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;KAC3F;IAED,MAAM,eAAe,GAAG,EAAE,CAAC;IAC3B,IAAI,mBAAmB,EAAE;QACvB,eAAe,CAAC,IAAI,CAClB,IAAI,mCAAyB,CAAC;YAC5B,MAAM,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,sBAAsB;YACnF,SAAS,EAAE,gBAAgB;YAC3B,iBAAiB,EAAE,YAAY,CAAC,iBAAiB;YACjD,mBAAmB,EAAE,CAAC,iCAAW,IAAI,gBAAgB;YACrD,SAAS,EAAE,gBAAgB;YAC3B,cAAc,EAAE,YAAY,CAAC,eAAe;YAC5C,QAAQ,EAAE,YAAY,CAAC,cAAc;SACtC,CAAC,CACH,CAAC;KACH;IAED,IAAI,QAAQ,KAAK,SAAS,IAAI,CAAC,mBAAmB,IAAI,kBAAkB,CAAC,MAAM,CAAC,EAAE;QAChF,eAAe,CAAC,IAAI,CAAC,IAAI,yCAAkB,EAAE,CAAC,CAAC;KAChD;IAED,IAAI,kBAAkB,GAA+D,KAAK,CAAC;IAC3F,IAAI,oBAAoB,IAAI,WAAW,KAAK,MAAM,EAAE;QAClD,kBAAkB,GAAG,WAAW,CAAC;KAClC;SAAM,IAAI,WAAW,KAAK,MAAM,EAAE;QACjC,kBAAkB,GAAG,WAAW,CAAC;KAClC;IAED,OAAO;QACL,IAAI,EAAE,mBAAmB,IAAI,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa;QACrF,OAAO,EAAE,KAAK;QACd,MAAM,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC;QACrD,OAAO,EAAE,YAAY,CAAC,SAAS;QAC/B,OAAO,EAAE;YACP,KAAK,EAAE,CAAC,WAAW,CAAC;YACpB,UAAU,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC;YAC1C,QAAQ,EAAE,CAAC,YAAY,CAAC,gBAAgB;YACxC,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,IAAI,WAAW,EAAE,cAAc,CAAC;YAClE,UAAU,EAAE,gBAAgB;gBAC1B,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC;gBACxC,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC;YACrD,cAAc,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC;SAC5C;QACD,aAAa,EAAE;YACb,QAAQ,EAAE,CAAC,YAAY,CAAC,gBAAgB;SACzC;QACD,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,WAAW;QAClB,SAAS,EAAE,oBAAoB;QAC/B,MAAM,EAAE;YACN,UAAU,EAAE,WAAW;YACvB,YAAY,EAAE,UAAU;YACxB,KAAK,EAAE,YAAY,CAAC,gBAAgB,IAAI,IAAI;YAC5C,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,UAAU,CAAC;YACjD,UAAU,EAAE,YAAY,CAAC,SAAS,IAAI,EAAE;YACxC,QAAQ,EAAE,SAAS,UAAU,CAAC,KAAK,KAAK;YACxC,aAAa,EAAE,SAAS,UAAU,CAAC,KAAK,KAAK;YAC7C,aAAa,EAAE,gBAAgB,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;YACxD,kBAAkB;YAClB,YAAY,EAAE,iBAAiB;YAC/B,UAAU,EAAE,QAAQ;SACrB;QACD,KAAK,EAAE,YAAY,CAAC,KAAK;QACzB,YAAY,EAAE;YACZ,IAAI;YACJ,yFAAyF;YACzF,cAAc,EAAE,YAAY,CAAC,gBAAgB;YAC7C,OAAO,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,oBAAoB;SAC/D;QACD,QAAQ,EAAE;YACR,MAAM,EAAE;gBACN,6FAA6F;gBAC7F,wFAAwF;gBACxF,IAAI,EAAE,YAAY,CAAC,gBAAgB;aACpC;SACF;QACD,WAAW,EAAE;YACX,KAAK,EAAE,KAAK;SACb;QACD,cAAc,EAAE;YACd,sHAAsH;YACtH,iCAAiC;YACjC,yHAAyH;YACzH,mCAAmC;YACnC,iFAAiF;YACjF,kGAAkG;YAClG,+CAA+C;SAChD;QACD,MAAM,EAAE;YACN,0DAA0D;YAC1D,oBAAoB,EAAE,IAAI;YAC1B,MAAM,EAAE;gBACN,UAAU,EAAE;oBACV,cAAc,EAAE,KAAK;oBACrB,yFAAyF;oBACzF,0DAA0D;oBAC1D,GAAG,EAAE,KAAK;oBACV,MAAM,EAAE,CAAC,CAAC,iBAAiB;iBAC5B;aACF;YACD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,gBAAgB;oBACtB,yEAAyE;oBACzE,aAAa,EAAE,cAAc;oBAC7B,IAAI,EAAE,cAAc;iBACrB;gBACD;oBACE,2DAA2D;oBAC3D,sEAAsE;oBACtE,0CAA0C;oBAC1C,IAAI,EAAE,+BAA+B;oBACrC,WAAW,EAAE,IAAI;iBAClB;gBACD;oBACE,IAAI,EAAE,iBAAiB;oBACvB,yGAAyG;oBACzG,OAAO,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE;oBAClC,OAAO,EAAE;wBACP,uGAAuG;qBACxG;oBACD,GAAG,EAAE;wBACH;4BACE,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,4BAA4B,CAAC;4BACrD,OAAO,EAAE;gCACP,cAAc,EAAE,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC,IAAI,KAAK;gCAClF,GAAG,EAAE,YAAY,CAAC,GAAG;gCACrB,QAAQ,EAAE,YAAY,CAAC,cAAc;gCACrC,iBAAiB,EAAE,YAAY,CAAC,iBAAiB;gCACjD,cAAc,EAAE,YAAY;oCAC1B,CAAC,CAAC;wCACE,gBAAgB,EAAE,UAAU,IAAI,WAAW;wCAC3C,aAAa,EAAE,IAAA,yCAA+B,EAAC,IAAI,EAAE,mBAAmB,CAAC;qCAC1E;oCACH,CAAC,CAAC,SAAS;6BACe;yBAC/B;qBACF;iBACF;gBACD,GAAG,UAAU;aACd;SACF;QACD,WAAW,EAAE;YACX,UAAU,EAAE,KAAK;YACjB,eAAe,EAAE,IAAI;YACrB,gBAAgB,EAAE,IAAI;SACvB;QACD,qBAAqB,EAAE;YACrB,KAAK,EAAE,OAAO;YACd,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO;SACrC;QACD,KAAK,EAAE,IAAA,yBAAe,EAAC,OAAO,CAAC;QAC/B,KAAK,EAAE,IAAA,0BAAgB,EAAC,GAAG,EAAE,UAAU,CAAC,IAAI,CAAC;QAC7C,YAAY,EAAE;YACZ,SAAS,EAAE,eAAe;YAC1B,SAAS,EAAE,eAAe;YAC1B,QAAQ,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe;YAC9D,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;YACjD,WAAW,EAAE;gBACX,gBAAgB,EAAE,QAAQ;gBAC1B,WAAW,EAAE;oBACX,OAAO,EAAE,CAAC,CAAC,WAAW,IAAI;wBACxB,MAAM,EAAE,OAAO;wBACf,SAAS,EAAE,CAAC;wBACZ,QAAQ,EAAE,EAAE;qBACb;oBACD,MAAM,EAAE,CAAC,CAAC,WAAW,IAAI;wBACvB,IAAI,EAAE,QAAQ;wBACd,MAAM,EAAE,OAAO;wBACf,SAAS,EAAE,CAAC;wBACZ,OAAO,EAAE,IAAI;wBACb,QAAQ,EAAE,CAAC;qBACZ;oBACD,OAAO,EAAE,KAAK;oBACd,cAAc,EAAE,CAAC,CAAC,WAAW,IAAI;wBAC/B,IAAI,EAAE,QAAQ;wBACd,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM;wBACxC,OAAO,EAAE,IAAI;wBACb,IAAI,EAAE,YAAY;qBACnB;iBACF;aACF;SACF;QACD,OAAO,EAAE;YACP,IAAI,uCAAiB,EAAE;YACvB,IAAI,sCAAiB,CAAC;gBACpB,GAAG;gBACH,mBAAmB;aACpB,CAAC;YACF,IAAI,mCAAyB,CAAC,EAAE,OAAO,EAAE,CAAC;YAC1C,GAAG,YAAY;SAChB;QACD,IAAI,EAAE,KAAK;KACZ,CAAC;AACJ,CAAC;AArbD,0CAqbC","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 { AngularWebpackLoaderPath } from '@ngtools/webpack';\nimport CopyWebpackPlugin from 'copy-webpack-plugin';\nimport * as path from 'path';\nimport {\n  Compiler,\n  Configuration,\n  ContextReplacementPlugin,\n  RuleSetRule,\n  SourceMapDevToolPlugin,\n} from 'webpack';\nimport { SubresourceIntegrityPlugin } from 'webpack-subresource-integrity';\nimport { AngularBabelLoaderOptions } from '../../babel/webpack-loader';\nimport { WebpackConfigOptions } from '../../utils/build-options';\nimport { allowMangle } from '../../utils/environment-options';\nimport { loadEsmModule } from '../../utils/load-esm';\nimport {\n  CommonJsUsageWarnPlugin,\n  DedupeModuleResolvePlugin,\n  JavaScriptOptimizerPlugin,\n  JsonStatsPlugin,\n  ScriptsWebpackPlugin,\n} from '../plugins';\nimport { DevToolsIgnorePlugin } from '../plugins/devtools-ignore-plugin';\nimport { NamedChunksPlugin } from '../plugins/named-chunks-plugin';\nimport { OccurrencesPlugin } from '../plugins/occurrences-plugin';\nimport { ProgressPlugin } from '../plugins/progress-plugin';\nimport { TransferSizePlugin } from '../plugins/transfer-size-plugin';\nimport { createIvyPlugin } from '../plugins/typescript';\nimport { WatchFilesLogsPlugin } from '../plugins/watch-files-logs-plugin';\nimport {\n  assetPatterns,\n  getCacheSettings,\n  getInstrumentationExcludedPaths,\n  getOutputHashFormat,\n  getStatsOptions,\n  globalScriptsByBundleName,\n  isPlatformServerInstalled,\n} from '../utils/helpers';\n\nconst VENDORS_TEST = /[\\\\/]node_modules[\\\\/]/;\n\n// eslint-disable-next-line max-lines-per-function\nexport async function getCommonConfig(wco: WebpackConfigOptions): Promise<Configuration> {\n  const { root, projectRoot, buildOptions, tsConfig, projectName, sourceRoot, tsConfigPath } = wco;\n  const {\n    cache,\n    codeCoverage,\n    crossOrigin = 'none',\n    platform = 'browser',\n    aot = true,\n    codeCoverageExclude = [],\n    main,\n    sourceMap: {\n      styles: stylesSourceMap,\n      scripts: scriptsSourceMap,\n      vendor: vendorSourceMap,\n      hidden: hiddenSourceMap,\n    },\n    optimization: { styles: stylesOptimization, scripts: scriptsOptimization },\n    commonChunk,\n    vendorChunk,\n    subresourceIntegrity,\n    verbose,\n    poll,\n    webWorkerTsConfig,\n    externalDependencies = [],\n    allowedCommonJsDependencies,\n  } = buildOptions;\n\n  const isPlatformServer = buildOptions.platform === 'server';\n  const extraPlugins: { apply(compiler: Compiler): void }[] = [];\n  const extraRules: RuleSetRule[] = [];\n  const entryPoints: Configuration['entry'] = {};\n\n  // Load ESM `@angular/compiler-cli` using the TypeScript dynamic import workaround.\n  // Once TypeScript provides support for keeping the dynamic import this workaround can be\n  // changed to a direct dynamic import.\n  const {\n    GLOBAL_DEFS_FOR_TERSER,\n    GLOBAL_DEFS_FOR_TERSER_WITH_AOT,\n    VERSION: NG_VERSION,\n  } = await loadEsmModule<typeof import('@angular/compiler-cli')>('@angular/compiler-cli');\n\n  // determine hashing format\n  const hashFormat = getOutputHashFormat(buildOptions.outputHashing);\n\n  if (buildOptions.progress) {\n    extraPlugins.push(new ProgressPlugin(platform));\n  }\n\n  const localizePackageInitEntryPoint = '@angular/localize/init';\n  const hasLocalizeType = tsConfig.options.types?.some(\n    (t) => t === '@angular/localize' || t === localizePackageInitEntryPoint,\n  );\n\n  if (hasLocalizeType) {\n    entryPoints['main'] = [localizePackageInitEntryPoint];\n  }\n\n  if (buildOptions.main) {\n    const mainPath = path.resolve(root, buildOptions.main);\n    if (Array.isArray(entryPoints['main'])) {\n      entryPoints['main'].push(mainPath);\n    } else {\n      entryPoints['main'] = [mainPath];\n    }\n  }\n\n  if (isPlatformServer) {\n    // Fixes Critical dependency: the request of a dependency is an expression\n    extraPlugins.push(new ContextReplacementPlugin(/@?hapi|express[\\\\/]/));\n\n    if (isPlatformServerInstalled(wco.root) && Array.isArray(entryPoints['main'])) {\n      // This import must come before any imports (direct or transitive) that rely on DOM built-ins being\n      // available, such as `@angular/elements`.\n      entryPoints['main'].unshift('@angular/platform-server/init');\n    }\n  }\n\n  const polyfills = [...buildOptions.polyfills];\n  if (!aot) {\n    polyfills.push('@angular/compiler');\n  }\n\n  if (polyfills.length) {\n    // `zone.js/testing` is a **special** polyfill because when not imported in the main it fails with the below errors:\n    // `Error: Expected to be running in 'ProxyZone', but it was not found.`\n    // This was also the reason why previously it was imported in `test.ts` as the first module.\n    // From Jia li:\n    // This is because the jasmine functions such as beforeEach/it will not be patched by zone.js since\n    // jasmine will not be loaded yet, so the ProxyZone will not be there. We have to load zone-testing.js after\n    // jasmine is ready.\n    // We could force loading 'zone.js/testing' prior to jasmine by changing the order of scripts in 'karma-context.html'.\n    // But this has it's own problems as zone.js needs to be loaded prior to jasmine due to patching of timing functions\n    // See: https://github.com/jasmine/jasmine/issues/1944\n    // Thus the correct order is zone.js -> jasmine -> zone.js/testing.\n    const zoneTestingEntryPoint = 'zone.js/testing';\n    const polyfillsExludingZoneTesting = polyfills.filter((p) => p !== zoneTestingEntryPoint);\n\n    if (Array.isArray(entryPoints['polyfills'])) {\n      entryPoints['polyfills'].push(...polyfillsExludingZoneTesting);\n    } else {\n      entryPoints['polyfills'] = polyfillsExludingZoneTesting;\n    }\n\n    if (polyfillsExludingZoneTesting.length !== polyfills.length) {\n      if (Array.isArray(entryPoints['main'])) {\n        entryPoints['main'].unshift(zoneTestingEntryPoint);\n      } else {\n        entryPoints['main'] = [zoneTestingEntryPoint];\n      }\n    }\n  }\n\n  if (allowedCommonJsDependencies) {\n    // When this is not defined it means the builder doesn't support showing common js usages.\n    // When it does it will be an array.\n    extraPlugins.push(\n      new CommonJsUsageWarnPlugin({\n        allowedDependencies: allowedCommonJsDependencies,\n      }),\n    );\n  }\n\n  // process global scripts\n  // Add a new asset for each entry.\n  for (const { bundleName, inject, paths } of globalScriptsByBundleName(buildOptions.scripts)) {\n    // Lazy scripts don't get a hash, otherwise they can't be loaded by name.\n    const hash = inject ? hashFormat.script : '';\n\n    extraPlugins.push(\n      new ScriptsWebpackPlugin({\n        name: bundleName,\n        sourceMap: scriptsSourceMap,\n        scripts: paths,\n        filename: `${path.basename(bundleName)}${hash}.js`,\n        basePath: root,\n      }),\n    );\n  }\n\n  // process asset entries\n  if (buildOptions.assets.length) {\n    extraPlugins.push(\n      new CopyWebpackPlugin({\n        patterns: assetPatterns(root, buildOptions.assets),\n      }),\n    );\n  }\n\n  if (buildOptions.extractLicenses) {\n    const LicenseWebpackPlugin = require('license-webpack-plugin').LicenseWebpackPlugin;\n    extraPlugins.push(\n      new LicenseWebpackPlugin({\n        stats: {\n          warnings: false,\n          errors: false,\n        },\n        perChunkOutput: false,\n        outputFilename: '3rdpartylicenses.txt',\n        skipChildCompilers: true,\n      }),\n    );\n  }\n\n  if (scriptsSourceMap || stylesSourceMap) {\n    const include = [];\n    if (scriptsSourceMap) {\n      include.push(/js$/);\n    }\n\n    if (stylesSourceMap) {\n      include.push(/css$/);\n    }\n\n    extraPlugins.push(new DevToolsIgnorePlugin());\n\n    extraPlugins.push(\n      new SourceMapDevToolPlugin({\n        filename: '[file].map',\n        include,\n        // We want to set sourceRoot to  `webpack:///` for non\n        // inline sourcemaps as otherwise paths to sourcemaps will be broken in browser\n        // `webpack:///` is needed for Visual Studio breakpoints to work properly as currently\n        // there is no way to set the 'webRoot'\n        sourceRoot: 'webpack:///',\n        moduleFilenameTemplate: '[resource-path]',\n        append: hiddenSourceMap ? false : undefined,\n      }),\n    );\n  }\n\n  if (verbose) {\n    extraPlugins.push(new WatchFilesLogsPlugin());\n  }\n\n  if (buildOptions.statsJson) {\n    extraPlugins.push(\n      new JsonStatsPlugin(path.resolve(root, buildOptions.outputPath, 'stats.json')),\n    );\n  }\n\n  if (subresourceIntegrity) {\n    extraPlugins.push(\n      new SubresourceIntegrityPlugin({\n        hashFuncNames: ['sha384'],\n      }),\n    );\n  }\n\n  if (scriptsSourceMap || stylesSourceMap) {\n    extraRules.push({\n      test: /\\.[cm]?jsx?$/,\n      enforce: 'pre',\n      loader: require.resolve('source-map-loader'),\n      options: {\n        filterSourceMappingUrl: (_mapUri: string, resourcePath: string) => {\n          if (vendorSourceMap) {\n            // Consume all sourcemaps when vendor option is enabled.\n            return true;\n          }\n\n          // Don't consume sourcemaps in node_modules when vendor is disabled.\n          // But, do consume local libraries sourcemaps.\n          return !resourcePath.includes('node_modules');\n        },\n      },\n    });\n  }\n\n  if (main || polyfills) {\n    extraRules.push({\n      test: tsConfig.options.allowJs ? /\\.[cm]?[tj]sx?$/ : /\\.[cm]?tsx?$/,\n      loader: AngularWebpackLoaderPath,\n      // The below are known paths that are not part of the TypeScript compilation even when allowJs is enabled.\n      exclude: [\n        /[\\\\/]node_modules[/\\\\](?:css-loader|mini-css-extract-plugin|webpack-dev-server|webpack)[/\\\\]/,\n      ],\n    });\n    extraPlugins.push(createIvyPlugin(wco, aot, tsConfigPath));\n  }\n\n  if (webWorkerTsConfig) {\n    extraPlugins.push(createIvyPlugin(wco, false, path.resolve(wco.root, webWorkerTsConfig)));\n  }\n\n  const extraMinimizers = [];\n  if (scriptsOptimization) {\n    extraMinimizers.push(\n      new JavaScriptOptimizerPlugin({\n        define: buildOptions.aot ? GLOBAL_DEFS_FOR_TERSER_WITH_AOT : GLOBAL_DEFS_FOR_TERSER,\n        sourcemap: scriptsSourceMap,\n        supportedBrowsers: buildOptions.supportedBrowsers,\n        keepIdentifierNames: !allowMangle || isPlatformServer,\n        keepNames: isPlatformServer,\n        removeLicenses: buildOptions.extractLicenses,\n        advanced: buildOptions.buildOptimizer,\n      }),\n    );\n  }\n\n  if (platform === 'browser' && (scriptsOptimization || stylesOptimization.minify)) {\n    extraMinimizers.push(new TransferSizePlugin());\n  }\n\n  let crossOriginLoading: NonNullable<Configuration['output']>['crossOriginLoading'] = false;\n  if (subresourceIntegrity && crossOrigin === 'none') {\n    crossOriginLoading = 'anonymous';\n  } else if (crossOrigin !== 'none') {\n    crossOriginLoading = crossOrigin;\n  }\n\n  return {\n    mode: scriptsOptimization || stylesOptimization.minify ? 'production' : 'development',\n    devtool: false,\n    target: [isPlatformServer ? 'node' : 'web', 'es2015'],\n    profile: buildOptions.statsJson,\n    resolve: {\n      roots: [projectRoot],\n      extensions: ['.ts', '.tsx', '.mjs', '.js'],\n      symlinks: !buildOptions.preserveSymlinks,\n      modules: [tsConfig.options.baseUrl || projectRoot, 'node_modules'],\n      mainFields: isPlatformServer\n        ? ['es2020', 'es2015', 'module', 'main']\n        : ['es2020', 'es2015', 'browser', 'module', 'main'],\n      conditionNames: ['es2020', 'es2015', '...'],\n    },\n    resolveLoader: {\n      symlinks: !buildOptions.preserveSymlinks,\n    },\n    context: root,\n    entry: entryPoints,\n    externals: externalDependencies,\n    output: {\n      uniqueName: projectName,\n      hashFunction: 'xxhash64', // todo: remove in webpack 6. This is part of `futureDefaults`.\n      clean: buildOptions.deleteOutputPath ?? true,\n      path: path.resolve(root, buildOptions.outputPath),\n      publicPath: buildOptions.deployUrl ?? '',\n      filename: `[name]${hashFormat.chunk}.js`,\n      chunkFilename: `[name]${hashFormat.chunk}.js`,\n      libraryTarget: isPlatformServer ? 'commonjs' : undefined,\n      crossOriginLoading,\n      trustedTypes: 'angular#bundler',\n      scriptType: 'module',\n    },\n    watch: buildOptions.watch,\n    watchOptions: {\n      poll,\n      // The below is needed as when preserveSymlinks is enabled we disable `resolve.symlinks`.\n      followSymlinks: buildOptions.preserveSymlinks,\n      ignored: poll === undefined ? undefined : '**/node_modules/**',\n    },\n    snapshot: {\n      module: {\n        // Use hash of content instead of timestamp because the timestamp of the symlink will be used\n        // instead of the referenced files which causes changes in symlinks not to be picked up.\n        hash: buildOptions.preserveSymlinks,\n      },\n    },\n    performance: {\n      hints: false,\n    },\n    ignoreWarnings: [\n      // https://github.com/webpack-contrib/source-map-loader/blob/b2de4249c7431dd8432da607e08f0f65e9d64219/src/index.js#L83\n      /Failed to parse source map from/,\n      // https://github.com/webpack-contrib/postcss-loader/blob/bd261875fdf9c596af4ffb3a1a73fe3c549befda/src/index.js#L153-L158\n      /Add postcss as project dependency/,\n      // esbuild will issue a warning, while still hoists the @charset at the very top.\n      // This is caused by a bug in css-loader https://github.com/webpack-contrib/css-loader/issues/1212\n      /\"@charset\" must be the first rule in the file/,\n    ],\n    module: {\n      // Show an error for missing exports instead of a warning.\n      strictExportPresence: true,\n      parser: {\n        javascript: {\n          requireContext: false,\n          // Disable auto URL asset module creation. This doesn't effect `new Worker(new URL(...))`\n          // https://webpack.js.org/guides/asset-modules/#url-assets\n          url: false,\n          worker: !!webWorkerTsConfig,\n        },\n      },\n      rules: [\n        {\n          test: /\\.?(svg|html)$/,\n          // Only process HTML and SVG which are known Angular component resources.\n          resourceQuery: /\\?ngResource/,\n          type: 'asset/source',\n        },\n        {\n          // Mark files inside `rxjs/add` as containing side effects.\n          // If this is fixed upstream and the fixed version becomes the minimum\n          // supported version, this can be removed.\n          test: /[/\\\\]rxjs[/\\\\]add[/\\\\].+\\.js$/,\n          sideEffects: true,\n        },\n        {\n          test: /\\.[cm]?[tj]sx?$/,\n          // The below is needed due to a bug in `@babel/runtime`. See: https://github.com/babel/babel/issues/12824\n          resolve: { fullySpecified: false },\n          exclude: [\n            /[\\\\/]node_modules[/\\\\](?:core-js|@babel|tslib|web-animations-js|web-streams-polyfill|whatwg-url)[/\\\\]/,\n          ],\n          use: [\n            {\n              loader: require.resolve('../../babel/webpack-loader'),\n              options: {\n                cacheDirectory: (cache.enabled && path.join(cache.path, 'babel-webpack')) || false,\n                aot: buildOptions.aot,\n                optimize: buildOptions.buildOptimizer,\n                supportedBrowsers: buildOptions.supportedBrowsers,\n                instrumentCode: codeCoverage\n                  ? {\n                      includedBasePath: sourceRoot ?? projectRoot,\n                      excludedPaths: getInstrumentationExcludedPaths(root, codeCoverageExclude),\n                    }\n                  : undefined,\n              } as AngularBabelLoaderOptions,\n            },\n          ],\n        },\n        ...extraRules,\n      ],\n    },\n    experiments: {\n      backCompat: false,\n      syncWebAssembly: true,\n      asyncWebAssembly: true,\n    },\n    infrastructureLogging: {\n      debug: verbose,\n      level: verbose ? 'verbose' : 'error',\n    },\n    stats: getStatsOptions(verbose),\n    cache: getCacheSettings(wco, NG_VERSION.full),\n    optimization: {\n      minimizer: extraMinimizers,\n      moduleIds: 'deterministic',\n      chunkIds: buildOptions.namedChunks ? 'named' : 'deterministic',\n      emitOnErrors: false,\n      runtimeChunk: isPlatformServer ? false : 'single',\n      splitChunks: {\n        maxAsyncRequests: Infinity,\n        cacheGroups: {\n          default: !!commonChunk && {\n            chunks: 'async',\n            minChunks: 2,\n            priority: 10,\n          },\n          common: !!commonChunk && {\n            name: 'common',\n            chunks: 'async',\n            minChunks: 2,\n            enforce: true,\n            priority: 5,\n          },\n          vendors: false,\n          defaultVendors: !!vendorChunk && {\n            name: 'vendor',\n            chunks: (chunk) => chunk.name === 'main',\n            enforce: true,\n            test: VENDORS_TEST,\n          },\n        },\n      },\n    },\n    plugins: [\n      new NamedChunksPlugin(),\n      new OccurrencesPlugin({\n        aot,\n        scriptsOptimization,\n      }),\n      new DedupeModuleResolvePlugin({ verbose }),\n      ...extraPlugins,\n    ],\n    node: false,\n  };\n}\n"]}