@angular-devkit/build-angular 15.1.3 → 15.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,15 +1,15 @@
1
1
  {
2
2
  "name": "@angular-devkit/build-angular",
3
- "version": "15.1.3",
3
+ "version": "15.1.5",
4
4
  "description": "Angular Webpack Build Facade",
5
5
  "main": "src/index.js",
6
6
  "typings": "src/index.d.ts",
7
7
  "builders": "builders.json",
8
8
  "dependencies": {
9
9
  "@ampproject/remapping": "2.2.0",
10
- "@angular-devkit/architect": "0.1501.3",
11
- "@angular-devkit/build-webpack": "0.1501.3",
12
- "@angular-devkit/core": "15.1.3",
10
+ "@angular-devkit/architect": "0.1501.5",
11
+ "@angular-devkit/build-webpack": "0.1501.5",
12
+ "@angular-devkit/core": "15.1.5",
13
13
  "@babel/core": "7.20.12",
14
14
  "@babel/generator": "7.20.7",
15
15
  "@babel/helper-annotate-as-pure": "7.18.6",
@@ -20,7 +20,7 @@
20
20
  "@babel/runtime": "7.20.7",
21
21
  "@babel/template": "7.20.7",
22
22
  "@discoveryjs/json-ext": "0.5.7",
23
- "@ngtools/webpack": "15.1.3",
23
+ "@ngtools/webpack": "15.1.5",
24
24
  "ansi-colors": "4.1.3",
25
25
  "autoprefixer": "10.4.13",
26
26
  "babel-loader": "9.1.2",
@@ -193,9 +193,44 @@ function default_1() {
193
193
  const origin = hasExport ? parentPath : path;
194
194
  const { wrapStatementPaths, hasPotentialSideEffects } = analyzeClassSiblings(origin, classNode.id, wrapDecorators);
195
195
  visitedClasses.add(classNode);
196
- if (hasPotentialSideEffects || wrapStatementPaths.length === 0) {
196
+ if (hasPotentialSideEffects) {
197
197
  return;
198
198
  }
199
+ // If no statements to wrap, check for static class properties.
200
+ // Static class properties may be downleveled at later stages in the build pipeline
201
+ // which results in additional function calls outside the class body. These calls
202
+ // then cause the class to be referenced and not eligible for removal. Since it is
203
+ // not known at this stage whether the class needs to be downleveled, the transform
204
+ // wraps classes preemptively to allow for potential removal within the optimization
205
+ // stages.
206
+ if (wrapStatementPaths.length === 0) {
207
+ let shouldWrap = false;
208
+ for (const element of path.get('body').get('body')) {
209
+ if (element.isClassProperty()) {
210
+ // Only need to analyze static properties
211
+ if (!element.node.static) {
212
+ continue;
213
+ }
214
+ // Check for potential side effects.
215
+ // These checks are conservative and could potentially be expanded in the future.
216
+ const elementKey = element.get('key');
217
+ const elementValue = element.get('value');
218
+ if (elementKey.isIdentifier() &&
219
+ (!elementValue.isExpression() ||
220
+ canWrapProperty(elementKey.get('name'), elementValue))) {
221
+ shouldWrap = true;
222
+ }
223
+ else {
224
+ // Not safe to wrap
225
+ shouldWrap = false;
226
+ break;
227
+ }
228
+ }
229
+ }
230
+ if (!shouldWrap) {
231
+ return;
232
+ }
233
+ }
199
234
  const wrapStatementNodes = [];
200
235
  for (const statementPath of wrapStatementPaths) {
201
236
  wrapStatementNodes.push(statementPath.node);
@@ -272,4 +307,4 @@ function default_1() {
272
307
  };
273
308
  }
274
309
  exports.default = default_1;
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adjust-static-class-members.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/babel/plugins/adjust-static-class-members.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 { NodePath, PluginObj, PluginPass, types } from '@babel/core';\nimport annotateAsPure from '@babel/helper-annotate-as-pure';\n\n/**\n * The name of the Typescript decorator helper function created by the TypeScript compiler.\n */\nconst TSLIB_DECORATE_HELPER_NAME = '__decorate';\n\n/**\n * The set of Angular static fields that should always be wrapped.\n * These fields may appear to have side effects but are safe to remove if the associated class\n * is otherwise unused within the output.\n */\nconst angularStaticsToWrap = new Set([\n  'ɵcmp',\n  'ɵdir',\n  'ɵfac',\n  'ɵinj',\n  'ɵmod',\n  'ɵpipe',\n  'ɵprov',\n  'INJECTOR_KEY',\n]);\n\n/**\n * An object map of static fields and related value checks for discovery of Angular generated\n * JIT related static fields.\n */\nconst angularStaticsToElide: Record<string, (path: NodePath<types.Expression>) => boolean> = {\n  'ctorParameters'(path) {\n    return path.isFunctionExpression() || path.isArrowFunctionExpression();\n  },\n  'decorators'(path) {\n    return path.isArrayExpression();\n  },\n  'propDecorators'(path) {\n    return path.isObjectExpression();\n  },\n};\n\n/**\n * Provides one or more keywords that if found within the content of a source file indicate\n * that this plugin should be used with a source file.\n *\n * @returns An a string iterable containing one or more keywords.\n */\nexport function getKeywords(): Iterable<string> {\n  return ['class'];\n}\n\n/**\n * Determines whether a property and its initializer value can be safely wrapped in a pure\n * annotated IIFE. Values that may cause side effects are not considered safe to wrap.\n * Wrapping such values may cause runtime errors and/or incorrect runtime behavior.\n *\n * @param propertyName The name of the property to analyze.\n * @param assignmentValue The initializer value that will be assigned to the property.\n * @returns If the property can be safely wrapped, then true; otherwise, false.\n */\nfunction canWrapProperty(propertyName: string, assignmentValue: NodePath): boolean {\n  if (angularStaticsToWrap.has(propertyName)) {\n    return true;\n  }\n\n  const { leadingComments } = assignmentValue.node as { leadingComments?: { value: string }[] };\n  if (\n    leadingComments?.some(\n      // `@pureOrBreakMyCode` is used by closure and is present in Angular code\n      ({ value }) =>\n        value.includes('@__PURE__') ||\n        value.includes('#__PURE__') ||\n        value.includes('@pureOrBreakMyCode'),\n    )\n  ) {\n    return true;\n  }\n\n  return assignmentValue.isPure();\n}\n\n/**\n * Analyze the sibling nodes of a class to determine if any downlevel elements should be\n * wrapped in a pure annotated IIFE. Also determines if any elements have potential side\n * effects.\n *\n * @param origin The starting NodePath location for analyzing siblings.\n * @param classIdentifier The identifier node that represents the name of the class.\n * @param allowWrappingDecorators Whether to allow decorators to be wrapped.\n * @returns An object containing the results of the analysis.\n */\nfunction analyzeClassSiblings(\n  origin: NodePath,\n  classIdentifier: types.Identifier,\n  allowWrappingDecorators: boolean,\n): { hasPotentialSideEffects: boolean; wrapStatementPaths: NodePath<types.Statement>[] } {\n  const wrapStatementPaths: NodePath<types.Statement>[] = [];\n  let hasPotentialSideEffects = false;\n  for (let i = 1; ; ++i) {\n    const nextStatement = origin.getSibling(+origin.key + i);\n    if (!nextStatement.isExpressionStatement()) {\n      break;\n    }\n\n    // Valid sibling statements for class declarations are only assignment expressions\n    // and TypeScript decorator helper call expressions\n    const nextExpression = nextStatement.get('expression');\n    if (nextExpression.isCallExpression()) {\n      if (\n        !types.isIdentifier(nextExpression.node.callee) ||\n        nextExpression.node.callee.name !== TSLIB_DECORATE_HELPER_NAME\n      ) {\n        break;\n      }\n\n      if (allowWrappingDecorators) {\n        wrapStatementPaths.push(nextStatement);\n      } else {\n        // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n        // The statement will prevent even a wrapped class from being optimized away.\n        hasPotentialSideEffects = true;\n      }\n\n      continue;\n    } else if (!nextExpression.isAssignmentExpression()) {\n      break;\n    }\n\n    // Valid assignment expressions should be member access expressions using the class\n    // name as the object and an identifier as the property for static fields or only\n    // the class name for decorators.\n    const left = nextExpression.get('left');\n    if (left.isIdentifier()) {\n      if (\n        !left.scope.bindingIdentifierEquals(left.node.name, classIdentifier) ||\n        !types.isCallExpression(nextExpression.node.right) ||\n        !types.isIdentifier(nextExpression.node.right.callee) ||\n        nextExpression.node.right.callee.name !== TSLIB_DECORATE_HELPER_NAME\n      ) {\n        break;\n      }\n\n      if (allowWrappingDecorators) {\n        wrapStatementPaths.push(nextStatement);\n      } else {\n        // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n        // The statement will prevent even a wrapped class from being optimized away.\n        hasPotentialSideEffects = true;\n      }\n\n      continue;\n    } else if (\n      !left.isMemberExpression() ||\n      !types.isIdentifier(left.node.object) ||\n      !left.scope.bindingIdentifierEquals(left.node.object.name, classIdentifier) ||\n      !types.isIdentifier(left.node.property)\n    ) {\n      break;\n    }\n\n    const propertyName = left.node.property.name;\n    const assignmentValue = nextExpression.get('right');\n    if (angularStaticsToElide[propertyName]?.(assignmentValue)) {\n      nextStatement.remove();\n      --i;\n    } else if (canWrapProperty(propertyName, assignmentValue)) {\n      wrapStatementPaths.push(nextStatement);\n    } else {\n      // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n      // The statement will prevent even a wrapped class from being optimized away.\n      hasPotentialSideEffects = true;\n    }\n  }\n\n  return { hasPotentialSideEffects, wrapStatementPaths };\n}\n\n/**\n * The set of classed already visited and analyzed during the plugin's execution.\n * This is used to prevent adjusted classes from being repeatedly analyzed which can lead\n * to an infinite loop.\n */\nconst visitedClasses = new WeakSet<types.Class>();\n\n/**\n * A babel plugin factory function for adjusting classes; primarily with Angular metadata.\n * The adjustments include wrapping classes with known safe or no side effects with pure\n * annotations to support dead code removal of unused classes. Angular compiler generated\n * metadata static fields not required in AOT mode are also elided to better support bundler-\n * level treeshaking.\n *\n * @returns A babel plugin object instance.\n */\nexport default function (): PluginObj {\n  return {\n    visitor: {\n      ClassDeclaration(path: NodePath<types.ClassDeclaration>, state: PluginPass) {\n        const { node: classNode, parentPath } = path;\n        const { wrapDecorators } = state.opts as { wrapDecorators: boolean };\n\n        if (visitedClasses.has(classNode)) {\n          return;\n        }\n\n        // Analyze sibling statements for elements of the class that were downleveled\n        const hasExport =\n          parentPath.isExportNamedDeclaration() || parentPath.isExportDefaultDeclaration();\n        const origin = hasExport ? parentPath : path;\n        const { wrapStatementPaths, hasPotentialSideEffects } = analyzeClassSiblings(\n          origin,\n          classNode.id,\n          wrapDecorators,\n        );\n\n        visitedClasses.add(classNode);\n\n        if (hasPotentialSideEffects || wrapStatementPaths.length === 0) {\n          return;\n        }\n\n        const wrapStatementNodes: types.Statement[] = [];\n        for (const statementPath of wrapStatementPaths) {\n          wrapStatementNodes.push(statementPath.node);\n          statementPath.remove();\n        }\n\n        // Wrap class and safe static assignments in a pure annotated IIFE\n        const container = types.arrowFunctionExpression(\n          [],\n          types.blockStatement([\n            classNode,\n            ...wrapStatementNodes,\n            types.returnStatement(types.cloneNode(classNode.id)),\n          ]),\n        );\n        const replacementInitializer = types.callExpression(\n          types.parenthesizedExpression(container),\n          [],\n        );\n        annotateAsPure(replacementInitializer);\n\n        // Replace class with IIFE wrapped class\n        const declaration = types.variableDeclaration('let', [\n          types.variableDeclarator(types.cloneNode(classNode.id), replacementInitializer),\n        ]);\n        if (parentPath.isExportDefaultDeclaration()) {\n          // When converted to a variable declaration, the default export must be moved\n          // to a subsequent statement to prevent a JavaScript syntax error.\n          parentPath.replaceWithMultiple([\n            declaration,\n            types.exportNamedDeclaration(undefined, [\n              types.exportSpecifier(types.cloneNode(classNode.id), types.identifier('default')),\n            ]),\n          ]);\n        } else {\n          path.replaceWith(declaration);\n        }\n      },\n      ClassExpression(path: NodePath<types.ClassExpression>, state: PluginPass) {\n        const { node: classNode, parentPath } = path;\n        const { wrapDecorators } = state.opts as { wrapDecorators: boolean };\n\n        // Class expressions are used by TypeScript to represent downlevel class/constructor decorators.\n        // If not wrapping decorators, they do not need to be processed.\n        if (!wrapDecorators || visitedClasses.has(classNode)) {\n          return;\n        }\n\n        if (\n          !classNode.id ||\n          !parentPath.isVariableDeclarator() ||\n          !types.isIdentifier(parentPath.node.id) ||\n          parentPath.node.id.name !== classNode.id.name\n        ) {\n          return;\n        }\n\n        const origin = parentPath.parentPath;\n        if (!origin.isVariableDeclaration() || origin.node.declarations.length !== 1) {\n          return;\n        }\n\n        const { wrapStatementPaths, hasPotentialSideEffects } = analyzeClassSiblings(\n          origin,\n          parentPath.node.id,\n          wrapDecorators,\n        );\n\n        visitedClasses.add(classNode);\n\n        if (hasPotentialSideEffects || wrapStatementPaths.length === 0) {\n          return;\n        }\n\n        const wrapStatementNodes: types.Statement[] = [];\n        for (const statementPath of wrapStatementPaths) {\n          wrapStatementNodes.push(statementPath.node);\n          statementPath.remove();\n        }\n\n        // Wrap class and safe static assignments in a pure annotated IIFE\n        const container = types.arrowFunctionExpression(\n          [],\n          types.blockStatement([\n            types.variableDeclaration('let', [\n              types.variableDeclarator(types.cloneNode(classNode.id), classNode),\n            ]),\n            ...wrapStatementNodes,\n            types.returnStatement(types.cloneNode(classNode.id)),\n          ]),\n        );\n        const replacementInitializer = types.callExpression(\n          types.parenthesizedExpression(container),\n          [],\n        );\n        annotateAsPure(replacementInitializer);\n\n        // Add the wrapped class directly to the variable declaration\n        parentPath.get('init').replaceWith(replacementInitializer);\n      },\n    },\n  };\n}\n"]}
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adjust-static-class-members.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/babel/plugins/adjust-static-class-members.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 { NodePath, PluginObj, PluginPass, types } from '@babel/core';\nimport annotateAsPure from '@babel/helper-annotate-as-pure';\n\n/**\n * The name of the Typescript decorator helper function created by the TypeScript compiler.\n */\nconst TSLIB_DECORATE_HELPER_NAME = '__decorate';\n\n/**\n * The set of Angular static fields that should always be wrapped.\n * These fields may appear to have side effects but are safe to remove if the associated class\n * is otherwise unused within the output.\n */\nconst angularStaticsToWrap = new Set([\n  'ɵcmp',\n  'ɵdir',\n  'ɵfac',\n  'ɵinj',\n  'ɵmod',\n  'ɵpipe',\n  'ɵprov',\n  'INJECTOR_KEY',\n]);\n\n/**\n * An object map of static fields and related value checks for discovery of Angular generated\n * JIT related static fields.\n */\nconst angularStaticsToElide: Record<string, (path: NodePath<types.Expression>) => boolean> = {\n  'ctorParameters'(path) {\n    return path.isFunctionExpression() || path.isArrowFunctionExpression();\n  },\n  'decorators'(path) {\n    return path.isArrayExpression();\n  },\n  'propDecorators'(path) {\n    return path.isObjectExpression();\n  },\n};\n\n/**\n * Provides one or more keywords that if found within the content of a source file indicate\n * that this plugin should be used with a source file.\n *\n * @returns An a string iterable containing one or more keywords.\n */\nexport function getKeywords(): Iterable<string> {\n  return ['class'];\n}\n\n/**\n * Determines whether a property and its initializer value can be safely wrapped in a pure\n * annotated IIFE. Values that may cause side effects are not considered safe to wrap.\n * Wrapping such values may cause runtime errors and/or incorrect runtime behavior.\n *\n * @param propertyName The name of the property to analyze.\n * @param assignmentValue The initializer value that will be assigned to the property.\n * @returns If the property can be safely wrapped, then true; otherwise, false.\n */\nfunction canWrapProperty(propertyName: string, assignmentValue: NodePath): boolean {\n  if (angularStaticsToWrap.has(propertyName)) {\n    return true;\n  }\n\n  const { leadingComments } = assignmentValue.node as { leadingComments?: { value: string }[] };\n  if (\n    leadingComments?.some(\n      // `@pureOrBreakMyCode` is used by closure and is present in Angular code\n      ({ value }) =>\n        value.includes('@__PURE__') ||\n        value.includes('#__PURE__') ||\n        value.includes('@pureOrBreakMyCode'),\n    )\n  ) {\n    return true;\n  }\n\n  return assignmentValue.isPure();\n}\n\n/**\n * Analyze the sibling nodes of a class to determine if any downlevel elements should be\n * wrapped in a pure annotated IIFE. Also determines if any elements have potential side\n * effects.\n *\n * @param origin The starting NodePath location for analyzing siblings.\n * @param classIdentifier The identifier node that represents the name of the class.\n * @param allowWrappingDecorators Whether to allow decorators to be wrapped.\n * @returns An object containing the results of the analysis.\n */\nfunction analyzeClassSiblings(\n  origin: NodePath,\n  classIdentifier: types.Identifier,\n  allowWrappingDecorators: boolean,\n): { hasPotentialSideEffects: boolean; wrapStatementPaths: NodePath<types.Statement>[] } {\n  const wrapStatementPaths: NodePath<types.Statement>[] = [];\n  let hasPotentialSideEffects = false;\n  for (let i = 1; ; ++i) {\n    const nextStatement = origin.getSibling(+origin.key + i);\n    if (!nextStatement.isExpressionStatement()) {\n      break;\n    }\n\n    // Valid sibling statements for class declarations are only assignment expressions\n    // and TypeScript decorator helper call expressions\n    const nextExpression = nextStatement.get('expression');\n    if (nextExpression.isCallExpression()) {\n      if (\n        !types.isIdentifier(nextExpression.node.callee) ||\n        nextExpression.node.callee.name !== TSLIB_DECORATE_HELPER_NAME\n      ) {\n        break;\n      }\n\n      if (allowWrappingDecorators) {\n        wrapStatementPaths.push(nextStatement);\n      } else {\n        // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n        // The statement will prevent even a wrapped class from being optimized away.\n        hasPotentialSideEffects = true;\n      }\n\n      continue;\n    } else if (!nextExpression.isAssignmentExpression()) {\n      break;\n    }\n\n    // Valid assignment expressions should be member access expressions using the class\n    // name as the object and an identifier as the property for static fields or only\n    // the class name for decorators.\n    const left = nextExpression.get('left');\n    if (left.isIdentifier()) {\n      if (\n        !left.scope.bindingIdentifierEquals(left.node.name, classIdentifier) ||\n        !types.isCallExpression(nextExpression.node.right) ||\n        !types.isIdentifier(nextExpression.node.right.callee) ||\n        nextExpression.node.right.callee.name !== TSLIB_DECORATE_HELPER_NAME\n      ) {\n        break;\n      }\n\n      if (allowWrappingDecorators) {\n        wrapStatementPaths.push(nextStatement);\n      } else {\n        // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n        // The statement will prevent even a wrapped class from being optimized away.\n        hasPotentialSideEffects = true;\n      }\n\n      continue;\n    } else if (\n      !left.isMemberExpression() ||\n      !types.isIdentifier(left.node.object) ||\n      !left.scope.bindingIdentifierEquals(left.node.object.name, classIdentifier) ||\n      !types.isIdentifier(left.node.property)\n    ) {\n      break;\n    }\n\n    const propertyName = left.node.property.name;\n    const assignmentValue = nextExpression.get('right');\n    if (angularStaticsToElide[propertyName]?.(assignmentValue)) {\n      nextStatement.remove();\n      --i;\n    } else if (canWrapProperty(propertyName, assignmentValue)) {\n      wrapStatementPaths.push(nextStatement);\n    } else {\n      // Statement cannot be safely wrapped which makes wrapping the class unneeded.\n      // The statement will prevent even a wrapped class from being optimized away.\n      hasPotentialSideEffects = true;\n    }\n  }\n\n  return { hasPotentialSideEffects, wrapStatementPaths };\n}\n\n/**\n * The set of classed already visited and analyzed during the plugin's execution.\n * This is used to prevent adjusted classes from being repeatedly analyzed which can lead\n * to an infinite loop.\n */\nconst visitedClasses = new WeakSet<types.Class>();\n\n/**\n * A babel plugin factory function for adjusting classes; primarily with Angular metadata.\n * The adjustments include wrapping classes with known safe or no side effects with pure\n * annotations to support dead code removal of unused classes. Angular compiler generated\n * metadata static fields not required in AOT mode are also elided to better support bundler-\n * level treeshaking.\n *\n * @returns A babel plugin object instance.\n */\nexport default function (): PluginObj {\n  return {\n    visitor: {\n      ClassDeclaration(path: NodePath<types.ClassDeclaration>, state: PluginPass) {\n        const { node: classNode, parentPath } = path;\n        const { wrapDecorators } = state.opts as { wrapDecorators: boolean };\n\n        if (visitedClasses.has(classNode)) {\n          return;\n        }\n\n        // Analyze sibling statements for elements of the class that were downleveled\n        const hasExport =\n          parentPath.isExportNamedDeclaration() || parentPath.isExportDefaultDeclaration();\n        const origin = hasExport ? parentPath : path;\n        const { wrapStatementPaths, hasPotentialSideEffects } = analyzeClassSiblings(\n          origin,\n          classNode.id,\n          wrapDecorators,\n        );\n\n        visitedClasses.add(classNode);\n\n        if (hasPotentialSideEffects) {\n          return;\n        }\n\n        // If no statements to wrap, check for static class properties.\n        // Static class properties may be downleveled at later stages in the build pipeline\n        // which results in additional function calls outside the class body. These calls\n        // then cause the class to be referenced and not eligible for removal. Since it is\n        // not known at this stage whether the class needs to be downleveled, the transform\n        // wraps classes preemptively to allow for potential removal within the optimization\n        // stages.\n        if (wrapStatementPaths.length === 0) {\n          let shouldWrap = false;\n          for (const element of path.get('body').get('body')) {\n            if (element.isClassProperty()) {\n              // Only need to analyze static properties\n              if (!element.node.static) {\n                continue;\n              }\n\n              // Check for potential side effects.\n              // These checks are conservative and could potentially be expanded in the future.\n              const elementKey = element.get('key');\n              const elementValue = element.get('value');\n              if (\n                elementKey.isIdentifier() &&\n                (!elementValue.isExpression() ||\n                  canWrapProperty(elementKey.get('name'), elementValue))\n              ) {\n                shouldWrap = true;\n              } else {\n                // Not safe to wrap\n                shouldWrap = false;\n                break;\n              }\n            }\n          }\n          if (!shouldWrap) {\n            return;\n          }\n        }\n\n        const wrapStatementNodes: types.Statement[] = [];\n        for (const statementPath of wrapStatementPaths) {\n          wrapStatementNodes.push(statementPath.node);\n          statementPath.remove();\n        }\n\n        // Wrap class and safe static assignments in a pure annotated IIFE\n        const container = types.arrowFunctionExpression(\n          [],\n          types.blockStatement([\n            classNode,\n            ...wrapStatementNodes,\n            types.returnStatement(types.cloneNode(classNode.id)),\n          ]),\n        );\n        const replacementInitializer = types.callExpression(\n          types.parenthesizedExpression(container),\n          [],\n        );\n        annotateAsPure(replacementInitializer);\n\n        // Replace class with IIFE wrapped class\n        const declaration = types.variableDeclaration('let', [\n          types.variableDeclarator(types.cloneNode(classNode.id), replacementInitializer),\n        ]);\n        if (parentPath.isExportDefaultDeclaration()) {\n          // When converted to a variable declaration, the default export must be moved\n          // to a subsequent statement to prevent a JavaScript syntax error.\n          parentPath.replaceWithMultiple([\n            declaration,\n            types.exportNamedDeclaration(undefined, [\n              types.exportSpecifier(types.cloneNode(classNode.id), types.identifier('default')),\n            ]),\n          ]);\n        } else {\n          path.replaceWith(declaration);\n        }\n      },\n      ClassExpression(path: NodePath<types.ClassExpression>, state: PluginPass) {\n        const { node: classNode, parentPath } = path;\n        const { wrapDecorators } = state.opts as { wrapDecorators: boolean };\n\n        // Class expressions are used by TypeScript to represent downlevel class/constructor decorators.\n        // If not wrapping decorators, they do not need to be processed.\n        if (!wrapDecorators || visitedClasses.has(classNode)) {\n          return;\n        }\n\n        if (\n          !classNode.id ||\n          !parentPath.isVariableDeclarator() ||\n          !types.isIdentifier(parentPath.node.id) ||\n          parentPath.node.id.name !== classNode.id.name\n        ) {\n          return;\n        }\n\n        const origin = parentPath.parentPath;\n        if (!origin.isVariableDeclaration() || origin.node.declarations.length !== 1) {\n          return;\n        }\n\n        const { wrapStatementPaths, hasPotentialSideEffects } = analyzeClassSiblings(\n          origin,\n          parentPath.node.id,\n          wrapDecorators,\n        );\n\n        visitedClasses.add(classNode);\n\n        if (hasPotentialSideEffects || wrapStatementPaths.length === 0) {\n          return;\n        }\n\n        const wrapStatementNodes: types.Statement[] = [];\n        for (const statementPath of wrapStatementPaths) {\n          wrapStatementNodes.push(statementPath.node);\n          statementPath.remove();\n        }\n\n        // Wrap class and safe static assignments in a pure annotated IIFE\n        const container = types.arrowFunctionExpression(\n          [],\n          types.blockStatement([\n            types.variableDeclaration('let', [\n              types.variableDeclarator(types.cloneNode(classNode.id), classNode),\n            ]),\n            ...wrapStatementNodes,\n            types.returnStatement(types.cloneNode(classNode.id)),\n          ]),\n        );\n        const replacementInitializer = types.callExpression(\n          types.parenthesizedExpression(container),\n          [],\n        );\n        annotateAsPure(replacementInitializer);\n\n        // Add the wrapped class directly to the variable declaration\n        parentPath.get('init').replaceWith(replacementInitializer);\n      },\n    },\n  };\n}\n"]}
@@ -37,9 +37,9 @@ exports.FindTestsPlugin = void 0;
37
37
  const assert_1 = __importDefault(require("assert"));
38
38
  const fs_1 = require("fs");
39
39
  const glob_1 = __importStar(require("glob"));
40
+ const mini_css_extract_plugin_1 = require("mini-css-extract-plugin");
40
41
  const path_1 = require("path");
41
42
  const util_1 = require("util");
42
- const webpack_diagnostics_1 = require("../../utils/webpack-diagnostics");
43
43
  const globPromise = (0, util_1.promisify)(glob_1.default);
44
44
  /**
45
45
  * The name of the plugin provided to Webpack when tapping Webpack compiler hooks.
@@ -57,17 +57,21 @@ class FindTestsPlugin {
57
57
  // Add tests files are part of the entry-point.
58
58
  webpackOptions.entry = async () => {
59
59
  const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);
60
- if (!specFiles.length) {
61
- (0, assert_1.default)(this.compilation, 'Compilation cannot be undefined.');
62
- (0, webpack_diagnostics_1.addError)(this.compilation, `Specified patterns: "${include.join(', ')}" did not match any spec files.`);
63
- }
64
60
  const entrypoints = await entry;
65
61
  const entrypoint = entrypoints['main'];
66
62
  if (!entrypoint.import) {
67
63
  throw new Error(`Cannot find 'main' entrypoint.`);
68
64
  }
69
- originalImport !== null && originalImport !== void 0 ? originalImport : (originalImport = entrypoint.import);
70
- entrypoint.import = [...originalImport, ...specFiles];
65
+ if (specFiles.length) {
66
+ originalImport !== null && originalImport !== void 0 ? originalImport : (originalImport = entrypoint.import);
67
+ entrypoint.import = [...originalImport, ...specFiles];
68
+ }
69
+ else {
70
+ (0, assert_1.default)(this.compilation, 'Compilation cannot be undefined.');
71
+ this.compilation
72
+ .getLogger(mini_css_extract_plugin_1.pluginName)
73
+ .error(`Specified patterns: "${include.join(', ')}" did not match any spec files.`);
74
+ }
71
75
  return entrypoints;
72
76
  };
73
77
  compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {
@@ -138,4 +142,4 @@ async function exists(path) {
138
142
  return false;
139
143
  }
140
144
  }
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-tests-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/find-tests-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport assert from 'assert';\nimport { PathLike, constants, promises as fs } from 'fs';\nimport glob, { hasMagic } from 'glob';\nimport { basename, dirname, extname, join, relative } from 'path';\nimport { promisify } from 'util';\nimport type { Compilation, Compiler } from 'webpack';\nimport { addError } from '../../utils/webpack-diagnostics';\n\nconst globPromise = promisify(glob);\n\n/**\n * The name of the plugin provided to Webpack when tapping Webpack compiler hooks.\n */\nconst PLUGIN_NAME = 'angular-find-tests-plugin';\n\nexport interface FindTestsPluginOptions {\n  include?: string[];\n  exclude?: string[];\n  workspaceRoot: string;\n  projectSourceRoot: string;\n}\n\nexport class FindTestsPlugin {\n  private compilation: Compilation | undefined;\n\n  constructor(private options: FindTestsPluginOptions) {}\n\n  apply(compiler: Compiler): void {\n    const {\n      include = ['**/*.spec.ts'],\n      exclude = [],\n      projectSourceRoot,\n      workspaceRoot,\n    } = this.options;\n    const webpackOptions = compiler.options;\n    const entry =\n      typeof webpackOptions.entry === 'function' ? webpackOptions.entry() : webpackOptions.entry;\n\n    let originalImport: string[] | undefined;\n\n    // Add tests files are part of the entry-point.\n    webpackOptions.entry = async () => {\n      const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);\n\n      if (!specFiles.length) {\n        assert(this.compilation, 'Compilation cannot be undefined.');\n        addError(\n          this.compilation,\n          `Specified patterns: \"${include.join(', ')}\" did not match any spec files.`,\n        );\n      }\n\n      const entrypoints = await entry;\n      const entrypoint = entrypoints['main'];\n      if (!entrypoint.import) {\n        throw new Error(`Cannot find 'main' entrypoint.`);\n      }\n\n      originalImport ??= entrypoint.import;\n      entrypoint.import = [...originalImport, ...specFiles];\n\n      return entrypoints;\n    };\n\n    compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {\n      this.compilation = compilation;\n      compilation.contextDependencies.add(projectSourceRoot);\n    });\n  }\n}\n\n// go through all patterns and find unique list of files\nasync function findTests(\n  include: string[],\n  exclude: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  const matchingTestsPromises = include.map((pattern) =>\n    findMatchingTests(pattern, exclude, workspaceRoot, projectSourceRoot),\n  );\n  const files = await Promise.all(matchingTestsPromises);\n\n  // Unique file names\n  return [...new Set(files.flat())];\n}\n\nconst normalizePath = (path: string): string => path.replace(/\\\\/g, '/');\n\nasync function findMatchingTests(\n  pattern: string,\n  ignore: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  // normalize pattern, glob lib only accepts forward slashes\n  let normalizedPattern = normalizePath(pattern);\n  if (normalizedPattern.charAt(0) === '/') {\n    normalizedPattern = normalizedPattern.substring(1);\n  }\n\n  const relativeProjectRoot = normalizePath(relative(workspaceRoot, projectSourceRoot) + '/');\n\n  // remove relativeProjectRoot to support relative paths from root\n  // such paths are easy to get when running scripts via IDEs\n  if (normalizedPattern.startsWith(relativeProjectRoot)) {\n    normalizedPattern = normalizedPattern.substring(relativeProjectRoot.length);\n  }\n\n  // special logic when pattern does not look like a glob\n  if (!hasMagic(normalizedPattern)) {\n    if (await isDirectory(join(projectSourceRoot, normalizedPattern))) {\n      normalizedPattern = `${normalizedPattern}/**/*.spec.@(ts|tsx)`;\n    } else {\n      // see if matching spec file exists\n      const fileExt = extname(normalizedPattern);\n      // Replace extension to `.spec.ext`. Example: `src/app/app.component.ts`-> `src/app/app.component.spec.ts`\n      const potentialSpec = join(\n        projectSourceRoot,\n        dirname(normalizedPattern),\n        `${basename(normalizedPattern, fileExt)}.spec${fileExt}`,\n      );\n\n      if (await exists(potentialSpec)) {\n        return [potentialSpec];\n      }\n    }\n  }\n\n  return globPromise(normalizedPattern, {\n    cwd: projectSourceRoot,\n    root: projectSourceRoot,\n    nomount: true,\n    absolute: true,\n    ignore: ['**/node_modules/**', ...ignore],\n  });\n}\n\nasync function isDirectory(path: PathLike): Promise<boolean> {\n  try {\n    const stats = await fs.stat(path);\n\n    return stats.isDirectory();\n  } catch {\n    return false;\n  }\n}\n\nasync function exists(path: PathLike): Promise<boolean> {\n  try {\n    await fs.access(path, constants.F_OK);\n\n    return true;\n  } catch {\n    return false;\n  }\n}\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-tests-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/find-tests-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport assert from 'assert';\nimport { PathLike, constants, promises as fs } from 'fs';\nimport glob, { hasMagic } from 'glob';\nimport { pluginName } from 'mini-css-extract-plugin';\nimport { basename, dirname, extname, join, relative } from 'path';\nimport { promisify } from 'util';\nimport type { Compilation, Compiler } from 'webpack';\n\nconst globPromise = promisify(glob);\n\n/**\n * The name of the plugin provided to Webpack when tapping Webpack compiler hooks.\n */\nconst PLUGIN_NAME = 'angular-find-tests-plugin';\n\nexport interface FindTestsPluginOptions {\n  include?: string[];\n  exclude?: string[];\n  workspaceRoot: string;\n  projectSourceRoot: string;\n}\n\nexport class FindTestsPlugin {\n  private compilation: Compilation | undefined;\n\n  constructor(private options: FindTestsPluginOptions) {}\n\n  apply(compiler: Compiler): void {\n    const {\n      include = ['**/*.spec.ts'],\n      exclude = [],\n      projectSourceRoot,\n      workspaceRoot,\n    } = this.options;\n    const webpackOptions = compiler.options;\n    const entry =\n      typeof webpackOptions.entry === 'function' ? webpackOptions.entry() : webpackOptions.entry;\n\n    let originalImport: string[] | undefined;\n\n    // Add tests files are part of the entry-point.\n    webpackOptions.entry = async () => {\n      const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);\n      const entrypoints = await entry;\n      const entrypoint = entrypoints['main'];\n      if (!entrypoint.import) {\n        throw new Error(`Cannot find 'main' entrypoint.`);\n      }\n\n      if (specFiles.length) {\n        originalImport ??= entrypoint.import;\n        entrypoint.import = [...originalImport, ...specFiles];\n      } else {\n        assert(this.compilation, 'Compilation cannot be undefined.');\n        this.compilation\n          .getLogger(pluginName)\n          .error(`Specified patterns: \"${include.join(', ')}\" did not match any spec files.`);\n      }\n\n      return entrypoints;\n    };\n\n    compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {\n      this.compilation = compilation;\n      compilation.contextDependencies.add(projectSourceRoot);\n    });\n  }\n}\n\n// go through all patterns and find unique list of files\nasync function findTests(\n  include: string[],\n  exclude: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  const matchingTestsPromises = include.map((pattern) =>\n    findMatchingTests(pattern, exclude, workspaceRoot, projectSourceRoot),\n  );\n  const files = await Promise.all(matchingTestsPromises);\n\n  // Unique file names\n  return [...new Set(files.flat())];\n}\n\nconst normalizePath = (path: string): string => path.replace(/\\\\/g, '/');\n\nasync function findMatchingTests(\n  pattern: string,\n  ignore: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  // normalize pattern, glob lib only accepts forward slashes\n  let normalizedPattern = normalizePath(pattern);\n  if (normalizedPattern.charAt(0) === '/') {\n    normalizedPattern = normalizedPattern.substring(1);\n  }\n\n  const relativeProjectRoot = normalizePath(relative(workspaceRoot, projectSourceRoot) + '/');\n\n  // remove relativeProjectRoot to support relative paths from root\n  // such paths are easy to get when running scripts via IDEs\n  if (normalizedPattern.startsWith(relativeProjectRoot)) {\n    normalizedPattern = normalizedPattern.substring(relativeProjectRoot.length);\n  }\n\n  // special logic when pattern does not look like a glob\n  if (!hasMagic(normalizedPattern)) {\n    if (await isDirectory(join(projectSourceRoot, normalizedPattern))) {\n      normalizedPattern = `${normalizedPattern}/**/*.spec.@(ts|tsx)`;\n    } else {\n      // see if matching spec file exists\n      const fileExt = extname(normalizedPattern);\n      // Replace extension to `.spec.ext`. Example: `src/app/app.component.ts`-> `src/app/app.component.spec.ts`\n      const potentialSpec = join(\n        projectSourceRoot,\n        dirname(normalizedPattern),\n        `${basename(normalizedPattern, fileExt)}.spec${fileExt}`,\n      );\n\n      if (await exists(potentialSpec)) {\n        return [potentialSpec];\n      }\n    }\n  }\n\n  return globPromise(normalizedPattern, {\n    cwd: projectSourceRoot,\n    root: projectSourceRoot,\n    nomount: true,\n    absolute: true,\n    ignore: ['**/node_modules/**', ...ignore],\n  });\n}\n\nasync function isDirectory(path: PathLike): Promise<boolean> {\n  try {\n    const stats = await fs.stat(path);\n\n    return stats.isDirectory();\n  } catch {\n    return false;\n  }\n}\n\nasync function exists(path: PathLike): Promise<boolean> {\n  try {\n    await fs.access(path, constants.F_OK);\n\n    return true;\n  } catch {\n    return false;\n  }\n}\n"]}
@@ -68,11 +68,17 @@ function execute(options, context, transforms = {}) {
68
68
  },
69
69
  }).pipe((0, operators_1.concatMap)(async (output) => {
70
70
  var _a;
71
- const { emittedFiles = [], outputPath, webpackStats } = output;
71
+ const { emittedFiles = [], outputPath, webpackStats, success } = output;
72
72
  if (!webpackStats) {
73
73
  throw new Error('Webpack stats build result is required.');
74
74
  }
75
- if (!output.success) {
75
+ if (!success) {
76
+ if ((0, stats_1.statsHasWarnings)(webpackStats)) {
77
+ context.logger.warn((0, stats_1.statsWarningsToString)(webpackStats, { colors: true }));
78
+ }
79
+ if ((0, stats_1.statsHasErrors)(webpackStats)) {
80
+ context.logger.error((0, stats_1.statsErrorsToString)(webpackStats, { colors: true }));
81
+ }
76
82
  return output;
77
83
  }
78
84
  const spinner = new spinner_1.Spinner();
@@ -178,4 +184,4 @@ function getPlatformServerExportsConfig(wco) {
178
184
  }
179
185
  : {};
180
186
  }
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/server/index.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,yDAAyF;AACzF,iEAA2D;AAC3D,2CAA6B;AAC7B,+BAAwC;AACxC,8CAA2C;AAG3C,uCAIqB;AACrB,6CAA2C;AAC3C,yDAAqD;AACrD,6CAAkD;AAClD,6DAAmE;AAEnE,2DAA6D;AAC7D,yDAA+D;AAC/D,iDAA8C;AAC9C,iDAAqE;AACrE,+EAG4C;AAC5C,mDAAyE;AACzE,yDAAwE;AACxE,qDAA+D;AAyB/D;;GAEG;AACH,SAAgB,OAAO,CACrB,OAA6B,EAC7B,OAAuB,EACvB,aAEI,EAAE;IAEN,MAAM,IAAI,GAAG,OAAO,CAAC,aAAa,CAAC;IAEnC,yBAAyB;IACzB,IAAA,wCAA8B,EAAC,IAAI,CAAC,CAAC;IAErC,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;IAC9D,IAAI,WAA4C,CAAC;IAEjD,OAAO,IAAA,WAAI,EAAC,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAC7E,IAAA,qBAAS,EAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,iBAAiB,EAAE,EAAE,EAAE;QAC7D,OAAO,IAAA,0BAAU,EAAC,MAAM,EAAE,OAAO,EAAE;YACjC,cAAc,EAAE,OAAO,CAAC,SAAS,CAAmB;YACpD,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;gBACzB,IAAI,OAAO,CAAC,OAAO,EAAE;oBACnB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;iBACnD;YACH,CAAC;SACF,CAAC,CAAC,IAAI,CACL,IAAA,qBAAS,EAAC,KAAK,EAAE,MAAM,EAAE,EAAE;;YACzB,MAAM,EAAE,YAAY,GAAG,EAAE,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC;YAC/D,IAAI,CAAC,YAAY,EAAE;gBACjB,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;aAC5D;YAED,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBACnB,OAAO,MAAM,CAAC;aACf;YAED,MAAM,OAAO,GAAG,IAAI,iBAAO,EAAE,CAAC;YAC9B,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC,QAAQ,KAAK,KAAK,CAAC;YAC7C,WAAW,GAAG,IAAA,gCAAiB,EAAC,cAAc,EAAE,IAAI,CAAC,CAAC;YAEtD,cAAc;YACd,IAAI,CAAC,OAAO,CAAC,KAAK,KAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,MAAM,CAAA,EAAE;gBAC5C,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;gBACnC,IAAI;oBACF,MAAM,IAAA,wBAAU,EACd,IAAA,8BAAsB,EACpB,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,aAAa,EACrB,WAAW,EACX,iBAAiB,CAClB,EACD,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAChC,OAAO,CAAC,aAAa,CACtB,CAAC;oBACF,OAAO,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;iBAC7C;gBAAC,OAAO,GAAG,EAAE;oBACZ,OAAO,CAAC,IAAI,CAAC,cAAM,CAAC,SAAS,CAAC,2BAA2B,CAAC,CAAC,CAAC;oBAC5D,IAAA,qBAAa,EAAC,GAAG,CAAC,CAAC;oBAEnB,OAAO;wBACL,GAAG,MAAM;wBACT,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,yBAAyB,GAAG,GAAG,CAAC,OAAO;qBAC/C,CAAC;iBACH;aACF;YAED,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,MAAM,OAAO,GAAG,MAAM,IAAA,sCAAsB,EAC1C,OAAO,EACP,YAAY,EACZ,IAAI,EACJ,cAAc,EACd,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAChC,EAAE,EACF,UAAU,EACV,OAAO,CAAC,sBAAsB,CAC/B,CAAC;gBACF,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO;wBACL,GAAG,MAAM;wBACT,OAAO,EAAE,KAAK;qBACf,CAAC;iBACH;aACF;YAED,IAAA,0BAAkB,EAAC,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;YAEzD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,EACF,IAAA,qBAAS,EAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QACzB,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YACnB,OAAO,MAA6B,CAAC;SACtC;QAED,OAAO;YACL,GAAG,MAAM;YACT,cAAc;YACd,UAAU,EAAE,cAAc;YAC1B,WAAW,EAAE,WAAW,IAAI,CAAC,cAAc,CAAC;YAC5C,OAAO,EAAE,CAAC,WAAW;gBACnB,CAAC,GAAG,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;oBAClD,MAAM;oBACN,IAAI;iBACL,CAAC,CAAC,CAAC,IAAI;gBACR,IAAI,EAAE,cAAc;aACrB;SACqB,CAAC;IAC3B,CAAC,CAAC,CACH,CAAC;AACJ,CAAC;AA/GD,0BA+GC;AAED,kBAAe,IAAA,yBAAa,EAA4C,OAAO,CAAC,CAAC;AAEjF,KAAK,UAAU,UAAU,CACvB,OAA6B,EAC7B,OAAuB,EACvB,6BAA2E;;IAO3E,8BAA8B;IAC9B,MAAM,IAAA,kCAAoB,EAAC,OAAO,CAAC,CAAC;IAEpC,MAAM,YAAY,GAAG,CAAC,wDAAa,cAAc,GAAC,CAAC,CAAC,OAAO,CAAC;IAC5D,MAAM,kBAAkB,GAAG,OAAO,CAAC,UAAU,CAAC;IAC9C,oEAAoE;IACpE,MAAM,eAAe,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IAE7E,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,iBAAiB,EAAE,IAAI,EAAE,GACpD,MAAM,IAAA,oEAA2C,EAC/C;QACE,GAAG,eAAe;QAClB,cAAc,EAAE,KAAK;QACrB,GAAG,EAAE,IAAI;QACT,QAAQ,EAAE,QAAQ;KACe,EACnC,OAAO,EACP,CAAC,GAAG,EAAE,EAAE;;;QACN,iEAAiE;QACjE,YAAA,GAAG,CAAC,YAAY,EAAC,iBAAiB,uCAAjB,iBAAiB,GAAK,EAAE,EAAC;QAC1C,GAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,0BAA0B,CAAC,CAAC,CAAC;QAErF,OAAO,CAAC,8BAA8B,CAAC,GAAG,CAAC,EAAE,IAAA,yBAAe,EAAC,GAAG,CAAC,EAAE,IAAA,yBAAe,EAAC,GAAG,CAAC,CAAC,CAAC;IAC3F,CAAC,CACF,CAAC;IAEJ,IAAI,OAAO,CAAC,gBAAgB,EAAE;QAC5B,IAAA,uBAAe,EAAC,OAAO,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAC;KAC5D;IAED,MAAM,iBAAiB,GAAG,MAAA,CAAC,MAAM,CAAA,6BAA6B,aAA7B,6BAA6B,uBAA7B,6BAA6B,CAAG,MAAM,CAAC,CAAA,CAAC,mCAAI,MAAM,CAAC;IAEpF,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,IAAI,EAAE,WAAW,EAAE,iBAAiB,EAAE,CAAC;AAC7E,CAAC;AAED;;;GAGG;AACH,SAAS,8BAA8B,CAAC,GAAgC;IACtE,0CAA0C;IAC1C,+FAA+F;IAE/F,oEAAoE;IACpE,uFAAuF;IACvF,mGAAmG;IAEnG,OAAO,IAAA,mCAAyB,EAAC,GAAG,CAAC,IAAI,CAAC;QACxC,CAAC,CAAC;YACE,MAAM,EAAE;gBACN,KAAK,EAAE;oBACL;wBACE,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,kCAAkC,CAAC;wBAC3D,OAAO,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;qBACzD;iBACF;aACF;SACF;QACH,CAAC,CAAC,EAAE,CAAC;AACT,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { runWebpack } from '@angular-devkit/build-webpack';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport webpack, { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport {\n  NormalizedBrowserBuilderSchema,\n  deleteOutputDir,\n  normalizeAssetPatterns,\n} from '../../utils';\nimport { colors } from '../../utils/color';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { i18nInlineEmittedFiles } from '../../utils/i18n-inlining';\nimport { I18nOptions } from '../../utils/i18n-options';\nimport { ensureOutputPaths } from '../../utils/output-paths';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { Spinner } from '../../utils/spinner';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport {\n  BrowserWebpackConfigOptions,\n  generateI18nBrowserWebpackConfigFromContext,\n} from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { isPlatformServerInstalled } from '../../webpack/utils/helpers';\nimport { webpackStatsLogger } from '../../webpack/utils/stats';\nimport { Schema as ServerBuilderOptions } from './schema';\n\n/**\n * @experimental Direct usage of this type is considered experimental.\n */\nexport type ServerBuilderOutput = BuilderOutput & {\n  baseOutputPath: string;\n  /**\n   * @deprecated in version 14. Use 'outputs' instead.\n   */\n  outputPaths: string[];\n  /**\n   * @deprecated in version 9. Use 'outputs' instead.\n   */\n  outputPath: string;\n\n  outputs: {\n    locale?: string;\n    path: string;\n  }[];\n};\n\nexport { ServerBuilderOptions };\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  } = {},\n): Observable<ServerBuilderOutput> {\n  const root = context.workspaceRoot;\n\n  // Check Angular version.\n  assertCompatibleAngularVersion(root);\n\n  const baseOutputPath = path.resolve(root, options.outputPath);\n  let outputPaths: undefined | Map<string, string>;\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    concatMap(({ config, i18n, projectRoot, projectSourceRoot }) => {\n      return runWebpack(config, context, {\n        webpackFactory: require('webpack') as typeof webpack,\n        logging: (stats, config) => {\n          if (options.verbose) {\n            context.logger.info(stats.toString(config.stats));\n          }\n        },\n      }).pipe(\n        concatMap(async (output) => {\n          const { emittedFiles = [], outputPath, webpackStats } = output;\n          if (!webpackStats) {\n            throw new Error('Webpack stats build result is required.');\n          }\n\n          if (!output.success) {\n            return output;\n          }\n\n          const spinner = new Spinner();\n          spinner.enabled = options.progress !== false;\n          outputPaths = ensureOutputPaths(baseOutputPath, i18n);\n\n          // Copy assets\n          if (!options.watch && options.assets?.length) {\n            spinner.start('Copying assets...');\n            try {\n              await copyAssets(\n                normalizeAssetPatterns(\n                  options.assets,\n                  context.workspaceRoot,\n                  projectRoot,\n                  projectSourceRoot,\n                ),\n                Array.from(outputPaths.values()),\n                context.workspaceRoot,\n              );\n              spinner.succeed('Copying assets complete.');\n            } catch (err) {\n              spinner.fail(colors.redBright('Copying of assets failed.'));\n              assertIsError(err);\n\n              return {\n                ...output,\n                success: false,\n                error: 'Unable to copy assets: ' + err.message,\n              };\n            }\n          }\n\n          if (i18n.shouldInline) {\n            const success = await i18nInlineEmittedFiles(\n              context,\n              emittedFiles,\n              i18n,\n              baseOutputPath,\n              Array.from(outputPaths.values()),\n              [],\n              outputPath,\n              options.i18nMissingTranslation,\n            );\n            if (!success) {\n              return {\n                ...output,\n                success: false,\n              };\n            }\n          }\n\n          webpackStatsLogger(context.logger, webpackStats, config);\n\n          return output;\n        }),\n      );\n    }),\n    concatMap(async (output) => {\n      if (!output.success) {\n        return output as ServerBuilderOutput;\n      }\n\n      return {\n        ...output,\n        baseOutputPath,\n        outputPath: baseOutputPath,\n        outputPaths: outputPaths || [baseOutputPath],\n        outputs: (outputPaths &&\n          [...outputPaths.entries()].map(([locale, path]) => ({\n            locale,\n            path,\n          }))) || {\n          path: baseOutputPath,\n        },\n      } as ServerBuilderOutput;\n    }),\n  );\n}\n\nexport default createBuilder<ServerBuilderOptions, ServerBuilderOutput>(execute);\n\nasync function initialize(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransform?: ExecutionTransformer<webpack.Configuration>,\n): Promise<{\n  config: webpack.Configuration;\n  i18n: I18nOptions;\n  projectRoot: string;\n  projectSourceRoot?: string;\n}> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const browserslist = (await import('browserslist')).default;\n  const originalOutputPath = options.outputPath;\n  // Assets are processed directly by the builder except when watching\n  const adjustedOptions = options.watch ? options : { ...options, assets: [] };\n\n  const { config, projectRoot, projectSourceRoot, i18n } =\n    await generateI18nBrowserWebpackConfigFromContext(\n      {\n        ...adjustedOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n      } as NormalizedBrowserBuilderSchema,\n      context,\n      (wco) => {\n        // We use the platform to determine the JavaScript syntax output.\n        wco.buildOptions.supportedBrowsers ??= [];\n        wco.buildOptions.supportedBrowsers.push(...browserslist('maintained node versions'));\n\n        return [getPlatformServerExportsConfig(wco), getCommonConfig(wco), getStylesConfig(wco)];\n      },\n    );\n\n  if (options.deleteOutputPath) {\n    deleteOutputDir(context.workspaceRoot, originalOutputPath);\n  }\n\n  const transformedConfig = (await webpackConfigurationTransform?.(config)) ?? config;\n\n  return { config: transformedConfig, i18n, projectRoot, projectSourceRoot };\n}\n\n/**\n * Add `@angular/platform-server` exports.\n * This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n */\nfunction getPlatformServerExportsConfig(wco: BrowserWebpackConfigOptions): Partial<Configuration> {\n  // Add `@angular/platform-server` exports.\n  // This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n\n  // Only add `@angular/platform-server` exports when it is installed.\n  // In some cases this builder is used when `@angular/platform-server` is not installed.\n  // Example: when using `@nguniversal/common/clover` which does not need `@angular/platform-server`.\n\n  return isPlatformServerInstalled(wco.root)\n    ? {\n        module: {\n          rules: [\n            {\n              loader: require.resolve('./platform-server-exports-loader'),\n              include: [path.resolve(wco.root, wco.buildOptions.main)],\n            },\n          ],\n        },\n      }\n    : {};\n}\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/server/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { runWebpack } from '@angular-devkit/build-webpack';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport webpack, { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport {\n  NormalizedBrowserBuilderSchema,\n  deleteOutputDir,\n  normalizeAssetPatterns,\n} from '../../utils';\nimport { colors } from '../../utils/color';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { i18nInlineEmittedFiles } from '../../utils/i18n-inlining';\nimport { I18nOptions } from '../../utils/i18n-options';\nimport { ensureOutputPaths } from '../../utils/output-paths';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { Spinner } from '../../utils/spinner';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport {\n  BrowserWebpackConfigOptions,\n  generateI18nBrowserWebpackConfigFromContext,\n} from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { isPlatformServerInstalled } from '../../webpack/utils/helpers';\nimport {\n  statsErrorsToString,\n  statsHasErrors,\n  statsHasWarnings,\n  statsWarningsToString,\n  webpackStatsLogger,\n} from '../../webpack/utils/stats';\nimport { Schema as ServerBuilderOptions } from './schema';\n\n/**\n * @experimental Direct usage of this type is considered experimental.\n */\nexport type ServerBuilderOutput = BuilderOutput & {\n  baseOutputPath: string;\n  /**\n   * @deprecated in version 14. Use 'outputs' instead.\n   */\n  outputPaths: string[];\n  /**\n   * @deprecated in version 9. Use 'outputs' instead.\n   */\n  outputPath: string;\n\n  outputs: {\n    locale?: string;\n    path: string;\n  }[];\n};\n\nexport { ServerBuilderOptions };\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  } = {},\n): Observable<ServerBuilderOutput> {\n  const root = context.workspaceRoot;\n\n  // Check Angular version.\n  assertCompatibleAngularVersion(root);\n\n  const baseOutputPath = path.resolve(root, options.outputPath);\n  let outputPaths: undefined | Map<string, string>;\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    concatMap(({ config, i18n, projectRoot, projectSourceRoot }) => {\n      return runWebpack(config, context, {\n        webpackFactory: require('webpack') as typeof webpack,\n        logging: (stats, config) => {\n          if (options.verbose) {\n            context.logger.info(stats.toString(config.stats));\n          }\n        },\n      }).pipe(\n        concatMap(async (output) => {\n          const { emittedFiles = [], outputPath, webpackStats, success } = output;\n          if (!webpackStats) {\n            throw new Error('Webpack stats build result is required.');\n          }\n\n          if (!success) {\n            if (statsHasWarnings(webpackStats)) {\n              context.logger.warn(statsWarningsToString(webpackStats, { colors: true }));\n            }\n            if (statsHasErrors(webpackStats)) {\n              context.logger.error(statsErrorsToString(webpackStats, { colors: true }));\n            }\n\n            return output;\n          }\n\n          const spinner = new Spinner();\n          spinner.enabled = options.progress !== false;\n          outputPaths = ensureOutputPaths(baseOutputPath, i18n);\n\n          // Copy assets\n          if (!options.watch && options.assets?.length) {\n            spinner.start('Copying assets...');\n            try {\n              await copyAssets(\n                normalizeAssetPatterns(\n                  options.assets,\n                  context.workspaceRoot,\n                  projectRoot,\n                  projectSourceRoot,\n                ),\n                Array.from(outputPaths.values()),\n                context.workspaceRoot,\n              );\n              spinner.succeed('Copying assets complete.');\n            } catch (err) {\n              spinner.fail(colors.redBright('Copying of assets failed.'));\n              assertIsError(err);\n\n              return {\n                ...output,\n                success: false,\n                error: 'Unable to copy assets: ' + err.message,\n              };\n            }\n          }\n\n          if (i18n.shouldInline) {\n            const success = await i18nInlineEmittedFiles(\n              context,\n              emittedFiles,\n              i18n,\n              baseOutputPath,\n              Array.from(outputPaths.values()),\n              [],\n              outputPath,\n              options.i18nMissingTranslation,\n            );\n            if (!success) {\n              return {\n                ...output,\n                success: false,\n              };\n            }\n          }\n\n          webpackStatsLogger(context.logger, webpackStats, config);\n\n          return output;\n        }),\n      );\n    }),\n    concatMap(async (output) => {\n      if (!output.success) {\n        return output as ServerBuilderOutput;\n      }\n\n      return {\n        ...output,\n        baseOutputPath,\n        outputPath: baseOutputPath,\n        outputPaths: outputPaths || [baseOutputPath],\n        outputs: (outputPaths &&\n          [...outputPaths.entries()].map(([locale, path]) => ({\n            locale,\n            path,\n          }))) || {\n          path: baseOutputPath,\n        },\n      } as ServerBuilderOutput;\n    }),\n  );\n}\n\nexport default createBuilder<ServerBuilderOptions, ServerBuilderOutput>(execute);\n\nasync function initialize(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransform?: ExecutionTransformer<webpack.Configuration>,\n): Promise<{\n  config: webpack.Configuration;\n  i18n: I18nOptions;\n  projectRoot: string;\n  projectSourceRoot?: string;\n}> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const browserslist = (await import('browserslist')).default;\n  const originalOutputPath = options.outputPath;\n  // Assets are processed directly by the builder except when watching\n  const adjustedOptions = options.watch ? options : { ...options, assets: [] };\n\n  const { config, projectRoot, projectSourceRoot, i18n } =\n    await generateI18nBrowserWebpackConfigFromContext(\n      {\n        ...adjustedOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n      } as NormalizedBrowserBuilderSchema,\n      context,\n      (wco) => {\n        // We use the platform to determine the JavaScript syntax output.\n        wco.buildOptions.supportedBrowsers ??= [];\n        wco.buildOptions.supportedBrowsers.push(...browserslist('maintained node versions'));\n\n        return [getPlatformServerExportsConfig(wco), getCommonConfig(wco), getStylesConfig(wco)];\n      },\n    );\n\n  if (options.deleteOutputPath) {\n    deleteOutputDir(context.workspaceRoot, originalOutputPath);\n  }\n\n  const transformedConfig = (await webpackConfigurationTransform?.(config)) ?? config;\n\n  return { config: transformedConfig, i18n, projectRoot, projectSourceRoot };\n}\n\n/**\n * Add `@angular/platform-server` exports.\n * This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n */\nfunction getPlatformServerExportsConfig(wco: BrowserWebpackConfigOptions): Partial<Configuration> {\n  // Add `@angular/platform-server` exports.\n  // This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n\n  // Only add `@angular/platform-server` exports when it is installed.\n  // In some cases this builder is used when `@angular/platform-server` is not installed.\n  // Example: when using `@nguniversal/common/clover` which does not need `@angular/platform-server`.\n\n  return isPlatformServerInstalled(wco.root)\n    ? {\n        module: {\n          rules: [\n            {\n              loader: require.resolve('./platform-server-exports-loader'),\n              include: [path.resolve(wco.root, wco.buildOptions.main)],\n            },\n          ],\n        },\n      }\n    : {};\n}\n"]}
@@ -35,7 +35,7 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
35
35
  // to perform minimum supported feature checks. esbuild also expects a single version.
36
36
  [version] = version.split('-');
37
37
  if (esBuildSupportedBrowsers.has(browserName)) {
38
- if (browserName === 'safari' && version === 'TP') {
38
+ if (browserName === 'safari' && version === 'tp') {
39
39
  // esbuild only supports numeric versions so `TP` is converted to a high number (999) since
40
40
  // a Technology Preview (TP) of Safari is assumed to support all currently known features.
41
41
  version = '999';
@@ -52,4 +52,4 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
52
52
  return transformed;
53
53
  }
54
54
  exports.transformSupportedBrowsersToTargets = transformSupportedBrowsersToTargets;
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNidWlsZC10YXJnZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdXRpbHMvZXNidWlsZC10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUVIOzs7R0FHRztBQUNILFNBQWdCLG1DQUFtQyxDQUFDLGlCQUEyQjtJQUM3RSxNQUFNLFdBQVcsR0FBYSxFQUFFLENBQUM7SUFFakMsd0NBQXdDO0lBQ3hDLE1BQU0sd0JBQXdCLEdBQUcsSUFBSSxHQUFHLENBQUM7UUFDdkMsUUFBUTtRQUNSLE1BQU07UUFDTixTQUFTO1FBQ1QsSUFBSTtRQUNKLEtBQUs7UUFDTCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVE7S0FDVCxDQUFDLENBQUM7SUFFSCxLQUFLLE1BQU0sT0FBTyxJQUFJLGlCQUFpQixFQUFFO1FBQ3ZDLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUU5RCxpRkFBaUY7UUFDakYsSUFBSSxXQUFXLEtBQUssU0FBUyxFQUFFO1lBQzdCLFdBQVcsR0FBRyxLQUFLLENBQUM7U0FDckI7UUFFRCxnRkFBZ0Y7UUFDaEYsc0ZBQXNGO1FBQ3RGLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUUvQixJQUFJLHdCQUF3QixDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUM3QyxJQUFJLFdBQVcsS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLElBQUksRUFBRTtnQkFDaEQsMkZBQTJGO2dCQUMzRiwwRkFBMEY7Z0JBQzFGLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDakI7aUJBQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pDLHdGQUF3RjtnQkFDeEYsMEZBQTBGO2dCQUMxRiwyRUFBMkU7Z0JBQzNFLE9BQU8sSUFBSSxJQUFJLENBQUM7YUFDakI7WUFFRCxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxPQUFPLENBQUMsQ0FBQztTQUN6QztLQUNGO0lBRUQsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQTVDRCxrRkE0Q0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBUcmFuc2Zvcm0gYnJvd3Nlcmxpc3RzIHJlc3VsdCB0byBlc2J1aWxkIHRhcmdldC5cbiAqIEBzZWUgaHR0cHM6Ly9lc2J1aWxkLmdpdGh1Yi5pby9hcGkvI3RhcmdldFxuICovXG5leHBvcnQgZnVuY3Rpb24gdHJhbnNmb3JtU3VwcG9ydGVkQnJvd3NlcnNUb1RhcmdldHMoc3VwcG9ydGVkQnJvd3NlcnM6IHN0cmluZ1tdKTogc3RyaW5nW10ge1xuICBjb25zdCB0cmFuc2Zvcm1lZDogc3RyaW5nW10gPSBbXTtcblxuICAvLyBodHRwczovL2VzYnVpbGQuZ2l0aHViLmlvL2FwaS8jdGFyZ2V0XG4gIGNvbnN0IGVzQnVpbGRTdXBwb3J0ZWRCcm93c2VycyA9IG5ldyBTZXQoW1xuICAgICdjaHJvbWUnLFxuICAgICdlZGdlJyxcbiAgICAnZmlyZWZveCcsXG4gICAgJ2llJyxcbiAgICAnaW9zJyxcbiAgICAnbm9kZScsXG4gICAgJ29wZXJhJyxcbiAgICAnc2FmYXJpJyxcbiAgXSk7XG5cbiAgZm9yIChjb25zdCBicm93c2VyIG9mIHN1cHBvcnRlZEJyb3dzZXJzKSB7XG4gICAgbGV0IFticm93c2VyTmFtZSwgdmVyc2lvbl0gPSBicm93c2VyLnRvTG93ZXJDYXNlKCkuc3BsaXQoJyAnKTtcblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHRoZSBuYW1lIGBpb3Nfc2FmYCBmb3IgaU9TIFNhZmFyaSB3aGVyZWFzIGVzYnVpbGQgdXNlcyBgaW9zYFxuICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ2lvc19zYWYnKSB7XG4gICAgICBicm93c2VyTmFtZSA9ICdpb3MnO1xuICAgIH1cblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHJhbmdlcyBgMTUuMi0xNS4zYCB2ZXJzaW9ucyBidXQgb25seSB0aGUgbG93ZXN0IGlzIHJlcXVpcmVkXG4gICAgLy8gdG8gcGVyZm9ybSBtaW5pbXVtIHN1cHBvcnRlZCBmZWF0dXJlIGNoZWNrcy4gZXNidWlsZCBhbHNvIGV4cGVjdHMgYSBzaW5nbGUgdmVyc2lvbi5cbiAgICBbdmVyc2lvbl0gPSB2ZXJzaW9uLnNwbGl0KCctJyk7XG5cbiAgICBpZiAoZXNCdWlsZFN1cHBvcnRlZEJyb3dzZXJzLmhhcyhicm93c2VyTmFtZSkpIHtcbiAgICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ3NhZmFyaScgJiYgdmVyc2lvbiA9PT0gJ1RQJykge1xuICAgICAgICAvLyBlc2J1aWxkIG9ubHkgc3VwcG9ydHMgbnVtZXJpYyB2ZXJzaW9ucyBzbyBgVFBgIGlzIGNvbnZlcnRlZCB0byBhIGhpZ2ggbnVtYmVyICg5OTkpIHNpbmNlXG4gICAgICAgIC8vIGEgVGVjaG5vbG9neSBQcmV2aWV3IChUUCkgb2YgU2FmYXJpIGlzIGFzc3VtZWQgdG8gc3VwcG9ydCBhbGwgY3VycmVudGx5IGtub3duIGZlYXR1cmVzLlxuICAgICAgICB2ZXJzaW9uID0gJzk5OSc7XG4gICAgICB9IGVsc2UgaWYgKCF2ZXJzaW9uLmluY2x1ZGVzKCcuJykpIHtcbiAgICAgICAgLy8gQSBsb25lIG1ham9yIHZlcnNpb24gaXMgY29uc2lkZXJlZCBieSBlc2J1aWxkIHRvIGluY2x1ZGUgYWxsIG1pbm9yIHZlcnNpb25zLiBIb3dldmVyLFxuICAgICAgICAvLyBicm93c2Vyc2xpc3QgZG9lcyBub3QgYW5kIGlzIGFsc28gaW5jb25zaXN0ZW50IGluIGl0cyBgLjBgIHZlcnNpb24gbmFtaW5nLiBGb3IgZXhhbXBsZSxcbiAgICAgICAgLy8gU2FmYXJpIDE1LjAgaXMgbmFtZWQgYHNhZmFyaSAxNWAgYnV0IFNhZmFyaSAxNi4wIGlzIG5hbWVkIGBzYWZhcmkgMTYuMGAuXG4gICAgICAgIHZlcnNpb24gKz0gJy4wJztcbiAgICAgIH1cblxuICAgICAgdHJhbnNmb3JtZWQucHVzaChicm93c2VyTmFtZSArIHZlcnNpb24pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cmFuc2Zvcm1lZDtcbn1cbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNidWlsZC10YXJnZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdXRpbHMvZXNidWlsZC10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUVIOzs7R0FHRztBQUNILFNBQWdCLG1DQUFtQyxDQUFDLGlCQUEyQjtJQUM3RSxNQUFNLFdBQVcsR0FBYSxFQUFFLENBQUM7SUFFakMsd0NBQXdDO0lBQ3hDLE1BQU0sd0JBQXdCLEdBQUcsSUFBSSxHQUFHLENBQUM7UUFDdkMsUUFBUTtRQUNSLE1BQU07UUFDTixTQUFTO1FBQ1QsSUFBSTtRQUNKLEtBQUs7UUFDTCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVE7S0FDVCxDQUFDLENBQUM7SUFFSCxLQUFLLE1BQU0sT0FBTyxJQUFJLGlCQUFpQixFQUFFO1FBQ3ZDLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUU5RCxpRkFBaUY7UUFDakYsSUFBSSxXQUFXLEtBQUssU0FBUyxFQUFFO1lBQzdCLFdBQVcsR0FBRyxLQUFLLENBQUM7U0FDckI7UUFFRCxnRkFBZ0Y7UUFDaEYsc0ZBQXNGO1FBQ3RGLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUUvQixJQUFJLHdCQUF3QixDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUM3QyxJQUFJLFdBQVcsS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLElBQUksRUFBRTtnQkFDaEQsMkZBQTJGO2dCQUMzRiwwRkFBMEY7Z0JBQzFGLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDakI7aUJBQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pDLHdGQUF3RjtnQkFDeEYsMEZBQTBGO2dCQUMxRiwyRUFBMkU7Z0JBQzNFLE9BQU8sSUFBSSxJQUFJLENBQUM7YUFDakI7WUFFRCxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxPQUFPLENBQUMsQ0FBQztTQUN6QztLQUNGO0lBRUQsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQTVDRCxrRkE0Q0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBUcmFuc2Zvcm0gYnJvd3Nlcmxpc3RzIHJlc3VsdCB0byBlc2J1aWxkIHRhcmdldC5cbiAqIEBzZWUgaHR0cHM6Ly9lc2J1aWxkLmdpdGh1Yi5pby9hcGkvI3RhcmdldFxuICovXG5leHBvcnQgZnVuY3Rpb24gdHJhbnNmb3JtU3VwcG9ydGVkQnJvd3NlcnNUb1RhcmdldHMoc3VwcG9ydGVkQnJvd3NlcnM6IHN0cmluZ1tdKTogc3RyaW5nW10ge1xuICBjb25zdCB0cmFuc2Zvcm1lZDogc3RyaW5nW10gPSBbXTtcblxuICAvLyBodHRwczovL2VzYnVpbGQuZ2l0aHViLmlvL2FwaS8jdGFyZ2V0XG4gIGNvbnN0IGVzQnVpbGRTdXBwb3J0ZWRCcm93c2VycyA9IG5ldyBTZXQoW1xuICAgICdjaHJvbWUnLFxuICAgICdlZGdlJyxcbiAgICAnZmlyZWZveCcsXG4gICAgJ2llJyxcbiAgICAnaW9zJyxcbiAgICAnbm9kZScsXG4gICAgJ29wZXJhJyxcbiAgICAnc2FmYXJpJyxcbiAgXSk7XG5cbiAgZm9yIChjb25zdCBicm93c2VyIG9mIHN1cHBvcnRlZEJyb3dzZXJzKSB7XG4gICAgbGV0IFticm93c2VyTmFtZSwgdmVyc2lvbl0gPSBicm93c2VyLnRvTG93ZXJDYXNlKCkuc3BsaXQoJyAnKTtcblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHRoZSBuYW1lIGBpb3Nfc2FmYCBmb3IgaU9TIFNhZmFyaSB3aGVyZWFzIGVzYnVpbGQgdXNlcyBgaW9zYFxuICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ2lvc19zYWYnKSB7XG4gICAgICBicm93c2VyTmFtZSA9ICdpb3MnO1xuICAgIH1cblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHJhbmdlcyBgMTUuMi0xNS4zYCB2ZXJzaW9ucyBidXQgb25seSB0aGUgbG93ZXN0IGlzIHJlcXVpcmVkXG4gICAgLy8gdG8gcGVyZm9ybSBtaW5pbXVtIHN1cHBvcnRlZCBmZWF0dXJlIGNoZWNrcy4gZXNidWlsZCBhbHNvIGV4cGVjdHMgYSBzaW5nbGUgdmVyc2lvbi5cbiAgICBbdmVyc2lvbl0gPSB2ZXJzaW9uLnNwbGl0KCctJyk7XG5cbiAgICBpZiAoZXNCdWlsZFN1cHBvcnRlZEJyb3dzZXJzLmhhcyhicm93c2VyTmFtZSkpIHtcbiAgICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ3NhZmFyaScgJiYgdmVyc2lvbiA9PT0gJ3RwJykge1xuICAgICAgICAvLyBlc2J1aWxkIG9ubHkgc3VwcG9ydHMgbnVtZXJpYyB2ZXJzaW9ucyBzbyBgVFBgIGlzIGNvbnZlcnRlZCB0byBhIGhpZ2ggbnVtYmVyICg5OTkpIHNpbmNlXG4gICAgICAgIC8vIGEgVGVjaG5vbG9neSBQcmV2aWV3IChUUCkgb2YgU2FmYXJpIGlzIGFzc3VtZWQgdG8gc3VwcG9ydCBhbGwgY3VycmVudGx5IGtub3duIGZlYXR1cmVzLlxuICAgICAgICB2ZXJzaW9uID0gJzk5OSc7XG4gICAgICB9IGVsc2UgaWYgKCF2ZXJzaW9uLmluY2x1ZGVzKCcuJykpIHtcbiAgICAgICAgLy8gQSBsb25lIG1ham9yIHZlcnNpb24gaXMgY29uc2lkZXJlZCBieSBlc2J1aWxkIHRvIGluY2x1ZGUgYWxsIG1pbm9yIHZlcnNpb25zLiBIb3dldmVyLFxuICAgICAgICAvLyBicm93c2Vyc2xpc3QgZG9lcyBub3QgYW5kIGlzIGFsc28gaW5jb25zaXN0ZW50IGluIGl0cyBgLjBgIHZlcnNpb24gbmFtaW5nLiBGb3IgZXhhbXBsZSxcbiAgICAgICAgLy8gU2FmYXJpIDE1LjAgaXMgbmFtZWQgYHNhZmFyaSAxNWAgYnV0IFNhZmFyaSAxNi4wIGlzIG5hbWVkIGBzYWZhcmkgMTYuMGAuXG4gICAgICAgIHZlcnNpb24gKz0gJy4wJztcbiAgICAgIH1cblxuICAgICAgdHJhbnNmb3JtZWQucHVzaChicm93c2VyTmFtZSArIHZlcnNpb24pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cmFuc2Zvcm1lZDtcbn1cbiJdfQ==
@@ -34,10 +34,10 @@ Reloaded before every execution run.
34
34
  <script src="_karma_webpack_/polyfills.js" crossorigin="anonymous"></script>
35
35
  <!-- Dynamically replaced with <script> tags -->
36
36
  %SCRIPTS%
37
- <script src="_karma_webpack_/scripts.js" crossorigin="anonymous"></script>
38
- <script src="_karma_webpack_/vendor.js" crossorigin="anonymous"></script>
39
- <script src="_karma_webpack_/main.js" crossorigin="anonymous"></script>
40
- <script type="text/javascript">
37
+ <script src="_karma_webpack_/scripts.js" crossorigin="anonymous" defer></script>
38
+ <script src="_karma_webpack_/vendor.js" crossorigin="anonymous" type="module"></script>
39
+ <script src="_karma_webpack_/main.js" crossorigin="anonymous" type="module"></script>
40
+ <script type="module">
41
41
  window.__karma__.loaded();
42
42
  </script>
43
43
  </body>
@@ -36,10 +36,10 @@ just for immediate execution, without reporting to Karma server.
36
36
  <script src="_karma_webpack_/polyfills.js" crossorigin="anonymous"></script>
37
37
  <!-- Dynamically replaced with <script> tags -->
38
38
  %SCRIPTS%
39
- <script src="_karma_webpack_/scripts.js" crossorigin="anonymous"></script>
40
- <script src="_karma_webpack_/vendor.js" crossorigin="anonymous"></script>
41
- <script src="_karma_webpack_/main.js" crossorigin="anonymous"></script>
42
- <script type="text/javascript">
39
+ <script src="_karma_webpack_/scripts.js" crossorigin="anonymous" defer></script>
40
+ <script src="_karma_webpack_/vendor.js" crossorigin="anonymous" type="module"></script>
41
+ <script src="_karma_webpack_/main.js" crossorigin="anonymous" type="module"></script>
42
+ <script type="module">
43
43
  window.__karma__.loaded();
44
44
  </script>
45
45
  </body>