@angular/core 15.0.0-next.4 → 15.0.0-next.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/esm2020/src/application_ref.mjs +1 -1
  2. package/esm2020/src/core_private_export.mjs +2 -1
  3. package/esm2020/src/di/index.mjs +2 -2
  4. package/esm2020/src/di/injectable.mjs +1 -1
  5. package/esm2020/src/di/injection_token.mjs +6 -3
  6. package/esm2020/src/di/interface/defs.mjs +1 -1
  7. package/esm2020/src/di/interface/provider.mjs +4 -2
  8. package/esm2020/src/di/provider_collection.mjs +30 -4
  9. package/esm2020/src/di/r3_injector.mjs +4 -6
  10. package/esm2020/src/errors.mjs +1 -1
  11. package/esm2020/src/metadata/directives.mjs +1 -1
  12. package/esm2020/src/metadata/ng_module.mjs +1 -1
  13. package/esm2020/src/render3/component_ref.mjs +20 -10
  14. package/esm2020/src/render3/errors_di.mjs +9 -3
  15. package/esm2020/src/render3/features/host_directives_feature.mjs +101 -9
  16. package/esm2020/src/render3/features/ng_onchanges_feature.mjs +4 -2
  17. package/esm2020/src/render3/instructions/shared.mjs +70 -34
  18. package/esm2020/src/render3/interfaces/definition.mjs +1 -1
  19. package/esm2020/src/render3/jit/directive.mjs +2 -6
  20. package/esm2020/src/render3/jit/module.mjs +2 -2
  21. package/esm2020/src/render3/ng_module_ref.mjs +1 -1
  22. package/esm2020/src/version.mjs +1 -1
  23. package/esm2020/testing/src/logger.mjs +3 -3
  24. package/esm2020/testing/src/ng_zone_mock.mjs +3 -3
  25. package/esm2020/testing/src/test_bed_compiler.mjs +29 -11
  26. package/fesm2015/core.mjs +243 -69
  27. package/fesm2015/core.mjs.map +1 -1
  28. package/fesm2015/testing.mjs +269 -73
  29. package/fesm2015/testing.mjs.map +1 -1
  30. package/fesm2020/core.mjs +243 -69
  31. package/fesm2020/core.mjs.map +1 -1
  32. package/fesm2020/testing.mjs +269 -73
  33. package/fesm2020/testing.mjs.map +1 -1
  34. package/index.d.ts +103 -32
  35. package/package.json +2 -2
  36. package/schematics/migrations/relative-link-resolution/index.d.ts +10 -0
  37. package/schematics/migrations/relative-link-resolution/index.js +68 -0
  38. package/schematics/migrations/relative-link-resolution/util.d.ts +20 -0
  39. package/schematics/migrations/relative-link-resolution/util.js +82 -0
  40. package/schematics/migrations/router-link-with-href/index.d.ts +10 -0
  41. package/schematics/migrations/router-link-with-href/index.js +70 -0
  42. package/schematics/migrations/router-link-with-href/util.d.ts +19 -0
  43. package/schematics/migrations/router-link-with-href/util.js +111 -0
  44. package/schematics/migrations.json +10 -0
  45. package/schematics/utils/typescript/imports.d.ts +10 -0
  46. package/schematics/utils/typescript/imports.js +17 -2
  47. package/testing/index.d.ts +1 -1
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ /// <amd-module name="@angular/core/schematics/migrations/router-link-with-href/util" />
9
+ import ts from 'typescript';
10
+ export declare const routerLink = "RouterLink";
11
+ export declare const routerLinkWithHref = "RouterLinkWithHref";
12
+ export declare const routerModule = "@angular/router";
13
+ export interface RewriteEntity {
14
+ startPos: number;
15
+ width: number;
16
+ replacement: string;
17
+ }
18
+ export declare type RewriteFn = (startPos: number, width: number, text: string) => void;
19
+ export declare function migrateFile(sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: RewriteFn): void;
@@ -0,0 +1,111 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ var __importDefault = (this && this.__importDefault) || function (mod) {
9
+ return (mod && mod.__esModule) ? mod : { "default": mod };
10
+ };
11
+ (function (factory) {
12
+ if (typeof module === "object" && typeof module.exports === "object") {
13
+ var v = factory(require, exports);
14
+ if (v !== undefined) module.exports = v;
15
+ }
16
+ else if (typeof define === "function" && define.amd) {
17
+ define("@angular/core/schematics/migrations/router-link-with-href/util", ["require", "exports", "typescript", "@angular/core/schematics/utils/typescript/imports", "@angular/core/schematics/utils/typescript/nodes"], factory);
18
+ }
19
+ })(function (require, exports) {
20
+ "use strict";
21
+ Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.migrateFile = exports.routerModule = exports.routerLinkWithHref = exports.routerLink = void 0;
23
+ const typescript_1 = __importDefault(require("typescript"));
24
+ const imports_1 = require("@angular/core/schematics/utils/typescript/imports");
25
+ const nodes_1 = require("@angular/core/schematics/utils/typescript/nodes");
26
+ exports.routerLink = 'RouterLink';
27
+ exports.routerLinkWithHref = 'RouterLinkWithHref';
28
+ exports.routerModule = '@angular/router';
29
+ function migrateFile(sourceFile, typeChecker, rewrite) {
30
+ const routerLinkWithHrefSpec = (0, imports_1.getImportSpecifier)(sourceFile, exports.routerModule, exports.routerLinkWithHref);
31
+ // No `RouterLinkWithHref` found, nothing to migrate, exit early.
32
+ if (routerLinkWithHrefSpec === null)
33
+ return;
34
+ let rewrites = findUsages(sourceFile, typeChecker);
35
+ // There are some usages of the `RouterLinkWithHref` symbol, which need to
36
+ // be rewritten to `RouterLink` instead. Let's check if the `RouterLink` is
37
+ // already imported.
38
+ const routerLinkSpec = (0, imports_1.getImportSpecifier)(sourceFile, exports.routerModule, exports.routerLink);
39
+ if (routerLinkSpec) {
40
+ // The `RouterLink` symbol is already imported, just drop the `RouterLinkWithHref` one.
41
+ const routerLinkNamedImports = routerLinkWithHrefSpec ?
42
+ (0, nodes_1.closestNode)(routerLinkWithHrefSpec, typescript_1.default.SyntaxKind.NamedImports) :
43
+ null;
44
+ if (routerLinkNamedImports !== null) {
45
+ // Given an original import like this one:
46
+ // ```
47
+ // import {RouterModule, RouterLinkWithHref, RouterLink} from '@angular/router';
48
+ // ```
49
+ // The code below removes the `RouterLinkWithHref` from the named imports section
50
+ // (i.e. `{RouterModule, RouterLinkWithHref, RouterLink}`) and prints an updated
51
+ // version (`{RouterModule, RouterLink}`) to a string, which is used as a
52
+ // replacement.
53
+ const rewrittenNamedImports = (0, imports_1.removeSymbolFromNamedImports)(routerLinkNamedImports, routerLinkWithHrefSpec);
54
+ const printer = typescript_1.default.createPrinter();
55
+ const replacement = printer.printNode(typescript_1.default.EmitHint.Unspecified, rewrittenNamedImports, sourceFile);
56
+ rewrites.push({
57
+ startPos: routerLinkNamedImports.getStart(),
58
+ width: routerLinkNamedImports.getWidth(),
59
+ replacement: replacement,
60
+ });
61
+ }
62
+ }
63
+ else {
64
+ // The `RouterLink` symbol is not imported, but the `RouterLinkWithHref` is imported,
65
+ // so rewrite `RouterLinkWithHref` -> `RouterLink`.
66
+ rewrites.push({
67
+ startPos: routerLinkWithHrefSpec.getStart(),
68
+ width: routerLinkWithHrefSpec.getWidth(),
69
+ replacement: exports.routerLink,
70
+ });
71
+ }
72
+ // Process rewrites last-to-first (based on start pos) to avoid offset shifts during rewrites.
73
+ rewrites = sortByStartPosDescending(rewrites);
74
+ for (const usage of rewrites) {
75
+ rewrite(usage.startPos, usage.width, usage.replacement);
76
+ }
77
+ }
78
+ exports.migrateFile = migrateFile;
79
+ function findUsages(sourceFile, typeChecker) {
80
+ const usages = [];
81
+ const visitNode = (node) => {
82
+ if (typescript_1.default.isImportSpecifier(node)) {
83
+ // Skip this node and all of its children; imports are a special case.
84
+ return;
85
+ }
86
+ if (typescript_1.default.isIdentifier(node)) {
87
+ const importIdentifier = (0, imports_1.getImportOfIdentifier)(typeChecker, node);
88
+ if ((importIdentifier === null || importIdentifier === void 0 ? void 0 : importIdentifier.importModule) === exports.routerModule &&
89
+ importIdentifier.name === exports.routerLinkWithHref) {
90
+ usages.push({
91
+ startPos: node.getStart(),
92
+ width: node.getWidth(),
93
+ replacement: exports.routerLink,
94
+ });
95
+ }
96
+ }
97
+ typescript_1.default.forEachChild(node, visitNode);
98
+ };
99
+ typescript_1.default.forEachChild(sourceFile, visitNode);
100
+ return usages;
101
+ }
102
+ /**
103
+ * Sort all found usages based on their start positions in the source file in descending order (i.e.
104
+ * last usage goes first on the list, etc). This is needed to avoid shifting offsets in the source
105
+ * file (in case there are multiple usages) as we rewrite symbols.
106
+ */
107
+ function sortByStartPosDescending(rewrites) {
108
+ return rewrites.sort((entityA, entityB) => entityB.startPos - entityA.startPos);
109
+ }
110
+ });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/router-link-with-href/util.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 ts from 'typescript';\n\nimport {getImportOfIdentifier, getImportSpecifier, removeSymbolFromNamedImports} from '../../utils/typescript/imports';\nimport {closestNode} from '../../utils/typescript/nodes';\n\nexport const routerLink = 'RouterLink';\nexport const routerLinkWithHref = 'RouterLinkWithHref';\nexport const routerModule = '@angular/router';\n\nexport interface RewriteEntity {\n  startPos: number;\n  width: number;\n  replacement: string;\n}\n\nexport type RewriteFn = (startPos: number, width: number, text: string) => void;\n\nexport function migrateFile(\n    sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker, rewrite: RewriteFn) {\n  const routerLinkWithHrefSpec = getImportSpecifier(sourceFile, routerModule, routerLinkWithHref);\n\n  // No `RouterLinkWithHref` found, nothing to migrate, exit early.\n  if (routerLinkWithHrefSpec === null) return;\n\n  let rewrites = findUsages(sourceFile, typeChecker);\n\n  // There are some usages of the `RouterLinkWithHref` symbol, which need to\n  // be rewritten to `RouterLink` instead. Let's check if the `RouterLink` is\n  // already imported.\n  const routerLinkSpec = getImportSpecifier(sourceFile, routerModule, routerLink);\n\n  if (routerLinkSpec) {\n    // The `RouterLink` symbol is already imported, just drop the `RouterLinkWithHref` one.\n    const routerLinkNamedImports = routerLinkWithHrefSpec ?\n        closestNode<ts.NamedImports>(routerLinkWithHrefSpec, ts.SyntaxKind.NamedImports) :\n        null;\n    if (routerLinkNamedImports !== null) {\n      // Given an original import like this one:\n      // ```\n      // import {RouterModule, RouterLinkWithHref, RouterLink} from '@angular/router';\n      // ```\n      // The code below removes the `RouterLinkWithHref` from the named imports section\n      // (i.e. `{RouterModule, RouterLinkWithHref, RouterLink}`) and prints an updated\n      // version (`{RouterModule, RouterLink}`) to a string, which is used as a\n      // replacement.\n      const rewrittenNamedImports =\n          removeSymbolFromNamedImports(routerLinkNamedImports, routerLinkWithHrefSpec);\n      const printer = ts.createPrinter();\n      const replacement =\n          printer.printNode(ts.EmitHint.Unspecified, rewrittenNamedImports, sourceFile);\n      rewrites.push({\n        startPos: routerLinkNamedImports.getStart(),\n        width: routerLinkNamedImports.getWidth(),\n        replacement: replacement,\n      });\n    }\n  } else {\n    // The `RouterLink` symbol is not imported, but the `RouterLinkWithHref` is imported,\n    // so rewrite `RouterLinkWithHref` -> `RouterLink`.\n    rewrites.push({\n      startPos: routerLinkWithHrefSpec.getStart(),\n      width: routerLinkWithHrefSpec.getWidth(),\n      replacement: routerLink,\n    });\n  }\n\n  // Process rewrites last-to-first (based on start pos) to avoid offset shifts during rewrites.\n  rewrites = sortByStartPosDescending(rewrites);\n  for (const usage of rewrites) {\n    rewrite(usage.startPos, usage.width, usage.replacement);\n  }\n}\n\nfunction findUsages(sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker): RewriteEntity[] {\n  const usages: RewriteEntity[] = [];\n  const visitNode = (node: ts.Node) => {\n    if (ts.isImportSpecifier(node)) {\n      // Skip this node and all of its children; imports are a special case.\n      return;\n    }\n    if (ts.isIdentifier(node)) {\n      const importIdentifier = getImportOfIdentifier(typeChecker, node);\n      if (importIdentifier?.importModule === routerModule &&\n          importIdentifier.name === routerLinkWithHref) {\n        usages.push({\n          startPos: node.getStart(),\n          width: node.getWidth(),\n          replacement: routerLink,\n        });\n      }\n    }\n    ts.forEachChild(node, visitNode);\n  };\n  ts.forEachChild(sourceFile, visitNode);\n  return usages;\n}\n\n/**\n * Sort all found usages based on their start positions in the source file in descending order (i.e.\n * last usage goes first on the list, etc). This is needed to avoid shifting offsets in the source\n * file (in case there are multiple usages) as we rewrite symbols.\n */\nfunction sortByStartPosDescending(rewrites: RewriteEntity[]): RewriteEntity[] {\n  return rewrites.sort((entityA, entityB) => entityB.startPos - entityA.startPos);\n}\n"]}
@@ -14,6 +14,16 @@
14
14
  "version": "14.0.0-beta",
15
15
  "description": "In Angular version 14, the `pathMatch` property of `Routes` was updated to be a strict union of the two valid options: `'full'|'prefix'`. `Routes` and `Route` variables need an explicit type so TypeScript does not infer the property as the looser `string`.",
16
16
  "factory": "./migrations/path-match-type/index"
17
+ },
18
+ "migration-v15-router-link-with-href": {
19
+ "version": "15.0.0-beta",
20
+ "description": "Since Angular v15, the `RouterLink` contains the logic of the `RouterLinkWithHref` directive. This migration replaces all `RouterLinkWithHref` references with `RouterLink`.",
21
+ "factory": "./migrations/router-link-with-href/index"
22
+ },
23
+ "migration-v15-relative-link-resolution": {
24
+ "version": "15.0.0-beta",
25
+ "description": "In Angular version 15, the deprecated `relativeLinkResolution` config parameter of the Router is removed. This migration removes all `relativeLinkResolution` fields from the Router config objects.",
26
+ "factory": "./migrations/relative-link-resolution/index"
17
27
  }
18
28
  }
19
29
  }
@@ -34,10 +34,20 @@ export declare function getImportOfIdentifier(typeChecker: ts.TypeChecker, node:
34
34
  export declare function getImportSpecifier(sourceFile: ts.SourceFile, moduleName: string, specifierName: string): ts.ImportSpecifier | null;
35
35
  /**
36
36
  * Replaces an import inside a named imports node with a different one.
37
+ *
37
38
  * @param node Node that contains the imports.
38
39
  * @param existingImport Import that should be replaced.
39
40
  * @param newImportName Import that should be inserted.
40
41
  */
41
42
  export declare function replaceImport(node: ts.NamedImports, existingImport: string, newImportName: string): ts.NamedImports;
43
+ /**
44
+ * Removes a symbol from the named imports and updates a node
45
+ * that represents a given named imports.
46
+ *
47
+ * @param node Node that contains the imports.
48
+ * @param symbol Symbol that should be removed.
49
+ * @returns An updated node (ts.NamedImports).
50
+ */
51
+ export declare function removeSymbolFromNamedImports(node: ts.NamedImports, symbol: ts.ImportSpecifier): ts.NamedImports;
42
52
  /** Finds an import specifier with a particular name. */
43
53
  export declare function findImportSpecifier(nodes: ts.NodeArray<ts.ImportSpecifier>, specifierName: string): ts.ImportSpecifier | undefined;
@@ -19,7 +19,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
19
19
  })(function (require, exports) {
20
20
  "use strict";
21
21
  Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.findImportSpecifier = exports.replaceImport = exports.getImportSpecifier = exports.getImportOfIdentifier = void 0;
22
+ exports.findImportSpecifier = exports.removeSymbolFromNamedImports = exports.replaceImport = exports.getImportSpecifier = exports.getImportOfIdentifier = void 0;
23
23
  const typescript_1 = __importDefault(require("typescript"));
24
24
  /** Gets import information about the specified identifier by using the Type checker. */
25
25
  function getImportOfIdentifier(typeChecker, node) {
@@ -78,6 +78,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
78
78
  exports.getImportSpecifier = getImportSpecifier;
79
79
  /**
80
80
  * Replaces an import inside a named imports node with a different one.
81
+ *
81
82
  * @param node Node that contains the imports.
82
83
  * @param existingImport Import that should be replaced.
83
84
  * @param newImportName Import that should be inserted.
@@ -101,6 +102,20 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
101
102
  ]);
102
103
  }
103
104
  exports.replaceImport = replaceImport;
105
+ /**
106
+ * Removes a symbol from the named imports and updates a node
107
+ * that represents a given named imports.
108
+ *
109
+ * @param node Node that contains the imports.
110
+ * @param symbol Symbol that should be removed.
111
+ * @returns An updated node (ts.NamedImports).
112
+ */
113
+ function removeSymbolFromNamedImports(node, symbol) {
114
+ return typescript_1.default.factory.updateNamedImports(node, [
115
+ ...node.elements.filter(current => current !== symbol),
116
+ ]);
117
+ }
118
+ exports.removeSymbolFromNamedImports = removeSymbolFromNamedImports;
104
119
  /** Finds an import specifier with a particular name. */
105
120
  function findImportSpecifier(nodes, specifierName) {
106
121
  return nodes.find(element => {
@@ -110,4 +125,4 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
110
125
  }
111
126
  exports.findImportSpecifier = findImportSpecifier;
112
127
  });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"imports.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/utils/typescript/imports.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 ts from 'typescript';\n\nexport type Import = {\n  name: string,\n  importModule: string,\n  node: ts.ImportDeclaration\n};\n\n/** Gets import information about the specified identifier by using the Type checker. */\nexport function getImportOfIdentifier(typeChecker: ts.TypeChecker, node: ts.Identifier): Import|\n    null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  if (!symbol || symbol.declarations === undefined || !symbol.declarations.length) {\n    return null;\n  }\n\n  const decl = symbol.declarations[0];\n\n  if (!ts.isImportSpecifier(decl)) {\n    return null;\n  }\n\n  const importDecl = decl.parent.parent.parent;\n\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n\n  return {\n    // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n    name: decl.propertyName ? decl.propertyName.text : decl.name.text,\n    importModule: importDecl.moduleSpecifier.text,\n    node: importDecl\n  };\n}\n\n\n/**\n * Gets a top-level import specifier with a specific name that is imported from a particular module.\n * E.g. given a file that looks like:\n *\n * ```\n * import { Component, Directive } from '@angular/core';\n * import { Foo } from './foo';\n * ```\n *\n * Calling `getImportSpecifier(sourceFile, '@angular/core', 'Directive')` will yield the node\n * referring to `Directive` in the top import.\n *\n * @param sourceFile File in which to look for imports.\n * @param moduleName Name of the import's module.\n * @param specifierName Original name of the specifier to look for. Aliases will be resolved to\n *    their original name.\n */\nexport function getImportSpecifier(\n    sourceFile: ts.SourceFile, moduleName: string, specifierName: string): ts.ImportSpecifier|null {\n  for (const node of sourceFile.statements) {\n    if (ts.isImportDeclaration(node) && ts.isStringLiteral(node.moduleSpecifier) &&\n        node.moduleSpecifier.text === moduleName) {\n      const namedBindings = node.importClause && node.importClause.namedBindings;\n      if (namedBindings && ts.isNamedImports(namedBindings)) {\n        const match = findImportSpecifier(namedBindings.elements, specifierName);\n        if (match) {\n          return match;\n        }\n      }\n    }\n  }\n\n  return null;\n}\n\n\n/**\n * Replaces an import inside a named imports node with a different one.\n * @param node Node that contains the imports.\n * @param existingImport Import that should be replaced.\n * @param newImportName Import that should be inserted.\n */\nexport function replaceImport(\n    node: ts.NamedImports, existingImport: string, newImportName: string) {\n  const isAlreadyImported = findImportSpecifier(node.elements, newImportName);\n  if (isAlreadyImported) {\n    return node;\n  }\n\n  const existingImportNode = findImportSpecifier(node.elements, existingImport);\n  if (!existingImportNode) {\n    return node;\n  }\n\n  const importPropertyName =\n      existingImportNode.propertyName ? ts.factory.createIdentifier(newImportName) : undefined;\n  const importName = existingImportNode.propertyName ? existingImportNode.name :\n                                                       ts.factory.createIdentifier(newImportName);\n\n  return ts.factory.updateNamedImports(node, [\n    ...node.elements.filter(current => current !== existingImportNode),\n    // Create a new import while trying to preserve the alias of the old one.\n    ts.factory.createImportSpecifier(false, importPropertyName, importName)\n  ]);\n}\n\n\n/** Finds an import specifier with a particular name. */\nexport function findImportSpecifier(\n    nodes: ts.NodeArray<ts.ImportSpecifier>, specifierName: string): ts.ImportSpecifier|undefined {\n  return nodes.find(element => {\n    const {name, propertyName} = element;\n    return propertyName ? propertyName.text === specifierName : name.text === specifierName;\n  });\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"imports.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/utils/typescript/imports.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 ts from 'typescript';\n\nexport type Import = {\n  name: string,\n  importModule: string,\n  node: ts.ImportDeclaration\n};\n\n/** Gets import information about the specified identifier by using the Type checker. */\nexport function getImportOfIdentifier(typeChecker: ts.TypeChecker, node: ts.Identifier): Import|\n    null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  if (!symbol || symbol.declarations === undefined || !symbol.declarations.length) {\n    return null;\n  }\n\n  const decl = symbol.declarations[0];\n\n  if (!ts.isImportSpecifier(decl)) {\n    return null;\n  }\n\n  const importDecl = decl.parent.parent.parent;\n\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n\n  return {\n    // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n    name: decl.propertyName ? decl.propertyName.text : decl.name.text,\n    importModule: importDecl.moduleSpecifier.text,\n    node: importDecl\n  };\n}\n\n\n/**\n * Gets a top-level import specifier with a specific name that is imported from a particular module.\n * E.g. given a file that looks like:\n *\n * ```\n * import { Component, Directive } from '@angular/core';\n * import { Foo } from './foo';\n * ```\n *\n * Calling `getImportSpecifier(sourceFile, '@angular/core', 'Directive')` will yield the node\n * referring to `Directive` in the top import.\n *\n * @param sourceFile File in which to look for imports.\n * @param moduleName Name of the import's module.\n * @param specifierName Original name of the specifier to look for. Aliases will be resolved to\n *    their original name.\n */\nexport function getImportSpecifier(\n    sourceFile: ts.SourceFile, moduleName: string, specifierName: string): ts.ImportSpecifier|null {\n  for (const node of sourceFile.statements) {\n    if (ts.isImportDeclaration(node) && ts.isStringLiteral(node.moduleSpecifier) &&\n        node.moduleSpecifier.text === moduleName) {\n      const namedBindings = node.importClause && node.importClause.namedBindings;\n      if (namedBindings && ts.isNamedImports(namedBindings)) {\n        const match = findImportSpecifier(namedBindings.elements, specifierName);\n        if (match) {\n          return match;\n        }\n      }\n    }\n  }\n\n  return null;\n}\n\n\n/**\n * Replaces an import inside a named imports node with a different one.\n *\n * @param node Node that contains the imports.\n * @param existingImport Import that should be replaced.\n * @param newImportName Import that should be inserted.\n */\nexport function replaceImport(\n    node: ts.NamedImports, existingImport: string, newImportName: string) {\n  const isAlreadyImported = findImportSpecifier(node.elements, newImportName);\n  if (isAlreadyImported) {\n    return node;\n  }\n\n  const existingImportNode = findImportSpecifier(node.elements, existingImport);\n  if (!existingImportNode) {\n    return node;\n  }\n\n  const importPropertyName =\n      existingImportNode.propertyName ? ts.factory.createIdentifier(newImportName) : undefined;\n  const importName = existingImportNode.propertyName ? existingImportNode.name :\n                                                       ts.factory.createIdentifier(newImportName);\n\n  return ts.factory.updateNamedImports(node, [\n    ...node.elements.filter(current => current !== existingImportNode),\n    // Create a new import while trying to preserve the alias of the old one.\n    ts.factory.createImportSpecifier(false, importPropertyName, importName)\n  ]);\n}\n\n/**\n * Removes a symbol from the named imports and updates a node\n * that represents a given named imports.\n *\n * @param node Node that contains the imports.\n * @param symbol Symbol that should be removed.\n * @returns An updated node (ts.NamedImports).\n */\nexport function removeSymbolFromNamedImports(node: ts.NamedImports, symbol: ts.ImportSpecifier) {\n  return ts.factory.updateNamedImports(node, [\n    ...node.elements.filter(current => current !== symbol),\n  ]);\n}\n\n/** Finds an import specifier with a particular name. */\nexport function findImportSpecifier(\n    nodes: ts.NodeArray<ts.ImportSpecifier>, specifierName: string): ts.ImportSpecifier|undefined {\n  return nodes.find(element => {\n    const {name, propertyName} = element;\n    return propertyName ? propertyName.text === specifierName : name.text === specifierName;\n  });\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v15.0.0-next.4
2
+ * @license Angular v15.0.0-next.6
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */