source: trip-planner-front/node_modules/@angular/core/schematics/migrations/navigation-extras-omissions/util.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 18.6 KB
Line 
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(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/core/schematics/migrations/navigation-extras-omissions/util", ["require", "exports", "typescript", "@angular/core/schematics/utils/typescript/imports", "@angular/core/schematics/utils/typescript/symbol"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.findLiteralsToMigrate = exports.migrateLiteral = void 0;
20 const ts = require("typescript");
21 const imports_1 = require("@angular/core/schematics/utils/typescript/imports");
22 const symbol_1 = require("@angular/core/schematics/utils/typescript/symbol");
23 /**
24 * Configures the methods that the migration should be looking for
25 * and the properties from `NavigationExtras` that should be preserved.
26 */
27 const methodConfig = new Map([
28 ['navigateByUrl', new Set(['skipLocationChange', 'replaceUrl', 'state'])],
29 [
30 'createUrlTree', new Set([
31 'relativeTo', 'queryParams', 'fragment', 'preserveQueryParams', 'queryParamsHandling',
32 'preserveFragment'
33 ])
34 ]
35 ]);
36 function migrateLiteral(methodName, node) {
37 const allowedProperties = methodConfig.get(methodName);
38 if (!allowedProperties) {
39 throw Error(`Attempting to migrate unconfigured method called ${methodName}.`);
40 }
41 const propertiesToKeep = [];
42 const removedPropertyNames = [];
43 node.properties.forEach(property => {
44 // Only look for regular and shorthand property assignments since resolving things
45 // like spread operators becomes too complicated for this migration.
46 if ((ts.isPropertyAssignment(property) || ts.isShorthandPropertyAssignment(property)) &&
47 (ts.isStringLiteralLike(property.name) || ts.isNumericLiteral(property.name) ||
48 ts.isIdentifier(property.name))) {
49 if (allowedProperties.has(property.name.text)) {
50 propertiesToKeep.push(property);
51 }
52 else {
53 removedPropertyNames.push(property.name.text);
54 }
55 }
56 else {
57 propertiesToKeep.push(property);
58 }
59 });
60 // Don't modify the node if there's nothing to remove.
61 if (removedPropertyNames.length === 0) {
62 return node;
63 }
64 // Note that the trailing/leading spaces are necessary so the comment looks good.
65 const removalComment = ` Removed unsupported properties by Angular migration: ${removedPropertyNames.join(', ')}. `;
66 if (propertiesToKeep.length > 0) {
67 propertiesToKeep[0] = addUniqueLeadingComment(propertiesToKeep[0], removalComment);
68 return ts.createObjectLiteral(propertiesToKeep);
69 }
70 else {
71 return addUniqueLeadingComment(ts.createObjectLiteral(propertiesToKeep), removalComment);
72 }
73 }
74 exports.migrateLiteral = migrateLiteral;
75 function findLiteralsToMigrate(sourceFile, typeChecker) {
76 const results = new Map(Array.from(methodConfig.keys(), key => [key, new Set()]));
77 const routerImport = imports_1.getImportSpecifier(sourceFile, '@angular/router', 'Router');
78 const seenLiterals = new Map();
79 if (routerImport) {
80 sourceFile.forEachChild(function visitNode(node) {
81 var _a;
82 // Look for calls that look like `foo.<method to migrate>` with more than one parameter.
83 if (ts.isCallExpression(node) && node.arguments.length > 1 &&
84 ts.isPropertyAccessExpression(node.expression) && ts.isIdentifier(node.expression.name) &&
85 methodConfig.has(node.expression.name.text)) {
86 // Check whether the type of the object on which the
87 // function is called refers to the Router import.
88 if (symbol_1.isReferenceToImport(typeChecker, node.expression.expression, routerImport)) {
89 const methodName = node.expression.name.text;
90 const parameterDeclaration = (_a = typeChecker.getTypeAtLocation(node.arguments[1]).getSymbol()) === null || _a === void 0 ? void 0 : _a.valueDeclaration;
91 // Find the source of the object literal.
92 if (parameterDeclaration && ts.isObjectLiteralExpression(parameterDeclaration)) {
93 if (!seenLiterals.has(parameterDeclaration)) {
94 results.get(methodName).add(parameterDeclaration);
95 seenLiterals.set(parameterDeclaration, methodName);
96 // If the same literal has been passed into multiple different methods, we can't
97 // migrate it, because the supported properties are different. When we detect such
98 // a case, we drop it from the results so that it gets ignored. If it's used multiple
99 // times for the same method, it can still be migrated.
100 }
101 else if (seenLiterals.get(parameterDeclaration) !== methodName) {
102 results.forEach(literals => literals.delete(parameterDeclaration));
103 }
104 }
105 }
106 }
107 else {
108 node.forEachChild(visitNode);
109 }
110 });
111 }
112 return results;
113 }
114 exports.findLiteralsToMigrate = findLiteralsToMigrate;
115 /** Adds a leading comment to a node, if the node doesn't have such a comment already. */
116 function addUniqueLeadingComment(node, comment) {
117 const existingComments = ts.getSyntheticLeadingComments(node);
118 // This logic is primarily to ensure that we don't add the same comment multiple
119 // times when tslint runs over the same file again with outdated information.
120 if (!existingComments || existingComments.every(c => c.text !== comment)) {
121 return ts.addSyntheticLeadingComment(node, ts.SyntaxKind.MultiLineCommentTrivia, comment);
122 }
123 return node;
124 }
125});
126//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/navigation-extras-omissions/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 * as ts from 'typescript';\n\nimport {getImportSpecifier} from '../../utils/typescript/imports';\nimport {isReferenceToImport} from '../../utils/typescript/symbol';\n\n/**\n * Configures the methods that the migration should be looking for\n * and the properties from `NavigationExtras` that should be preserved.\n */\nconst methodConfig = new Map<string, Set<string>>([\n  ['navigateByUrl', new Set<string>(['skipLocationChange', 'replaceUrl', 'state'])],\n  [\n    'createUrlTree', new Set<string>([\n      'relativeTo', 'queryParams', 'fragment', 'preserveQueryParams', 'queryParamsHandling',\n      'preserveFragment'\n    ])\n  ]\n]);\n\nexport function migrateLiteral(\n    methodName: string, node: ts.ObjectLiteralExpression): ts.ObjectLiteralExpression {\n  const allowedProperties = methodConfig.get(methodName);\n\n  if (!allowedProperties) {\n    throw Error(`Attempting to migrate unconfigured method called ${methodName}.`);\n  }\n\n  const propertiesToKeep: ts.ObjectLiteralElementLike[] = [];\n  const removedPropertyNames: string[] = [];\n\n  node.properties.forEach(property => {\n    // Only look for regular and shorthand property assignments since resolving things\n    // like spread operators becomes too complicated for this migration.\n    if ((ts.isPropertyAssignment(property) || ts.isShorthandPropertyAssignment(property)) &&\n        (ts.isStringLiteralLike(property.name) || ts.isNumericLiteral(property.name) ||\n         ts.isIdentifier(property.name))) {\n      if (allowedProperties.has(property.name.text)) {\n        propertiesToKeep.push(property);\n      } else {\n        removedPropertyNames.push(property.name.text);\n      }\n    } else {\n      propertiesToKeep.push(property);\n    }\n  });\n\n  // Don't modify the node if there's nothing to remove.\n  if (removedPropertyNames.length === 0) {\n    return node;\n  }\n\n  // Note that the trailing/leading spaces are necessary so the comment looks good.\n  const removalComment =\n      ` Removed unsupported properties by Angular migration: ${removedPropertyNames.join(', ')}. `;\n\n  if (propertiesToKeep.length > 0) {\n    propertiesToKeep[0] = addUniqueLeadingComment(propertiesToKeep[0], removalComment);\n    return ts.createObjectLiteral(propertiesToKeep);\n  } else {\n    return addUniqueLeadingComment(ts.createObjectLiteral(propertiesToKeep), removalComment);\n  }\n}\n\nexport function findLiteralsToMigrate(sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker) {\n  const results = new Map<string, Set<ts.ObjectLiteralExpression>>(\n      Array.from(methodConfig.keys(), key => [key, new Set()]));\n  const routerImport = getImportSpecifier(sourceFile, '@angular/router', 'Router');\n  const seenLiterals = new Map<ts.ObjectLiteralExpression, string>();\n\n  if (routerImport) {\n    sourceFile.forEachChild(function visitNode(node: ts.Node) {\n      // Look for calls that look like `foo.<method to migrate>` with more than one parameter.\n      if (ts.isCallExpression(node) && node.arguments.length > 1 &&\n          ts.isPropertyAccessExpression(node.expression) && ts.isIdentifier(node.expression.name) &&\n          methodConfig.has(node.expression.name.text)) {\n        // Check whether the type of the object on which the\n        // function is called refers to the Router import.\n        if (isReferenceToImport(typeChecker, node.expression.expression, routerImport)) {\n          const methodName = node.expression.name.text;\n          const parameterDeclaration =\n              typeChecker.getTypeAtLocation(node.arguments[1]).getSymbol()?.valueDeclaration;\n\n          // Find the source of the object literal.\n          if (parameterDeclaration && ts.isObjectLiteralExpression(parameterDeclaration)) {\n            if (!seenLiterals.has(parameterDeclaration)) {\n              results.get(methodName)!.add(parameterDeclaration);\n              seenLiterals.set(parameterDeclaration, methodName);\n              // If the same literal has been passed into multiple different methods, we can't\n              // migrate it, because the supported properties are different. When we detect such\n              // a case, we drop it from the results so that it gets ignored. If it's used multiple\n              // times for the same method, it can still be migrated.\n            } else if (seenLiterals.get(parameterDeclaration) !== methodName) {\n              results.forEach(literals => literals.delete(parameterDeclaration));\n            }\n          }\n        }\n      } else {\n        node.forEachChild(visitNode);\n      }\n    });\n  }\n\n  return results;\n}\n\n/** Adds a leading comment to a node, if the node doesn't have such a comment already. */\nfunction addUniqueLeadingComment<T extends ts.Node>(node: T, comment: string): T {\n  const existingComments = ts.getSyntheticLeadingComments(node);\n\n  // This logic is primarily to ensure that we don't add the same comment multiple\n  // times when tslint runs over the same file again with outdated information.\n  if (!existingComments || existingComments.every(c => c.text !== comment)) {\n    return ts.addSyntheticLeadingComment(node, ts.SyntaxKind.MultiLineCommentTrivia, comment);\n  }\n\n  return node;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.