UNPKG

@angular/cdk

Version:

Angular Material Component Development Kit

67 lines 2.91 kB
"use strict"; /** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ Object.defineProperty(exports, "__esModule", { value: true }); const chalk_1 = require("chalk"); const tslint_1 = require("tslint"); const angular_1 = require("../../html-parsing/angular"); const component_walker_1 = require("../../tslint/component-walker"); const upgrade_data_1 = require("../../upgrade-data"); /** * Rule that walks through every inline or external HTML template and switches changed input * bindings to the proper new name. */ class Rule extends tslint_1.Rules.AbstractRule { apply(sourceFile) { return this.applyWithWalker(new Walker(sourceFile, this.getOptions())); } } exports.Rule = Rule; class Walker extends component_walker_1.ComponentWalker { constructor() { super(...arguments); /** Change data that upgrades to the specified target version. */ this.data = upgrade_data_1.getUpgradeDataFromWalker(this, 'inputNames'); } visitInlineTemplate(node) { this._createReplacementsForContent(node, node.getText()).forEach(data => { this.addFailureAtReplacement(data.failureMessage, data.replacement); }); } visitExternalTemplate(node) { this._createReplacementsForContent(node, node.getText()).forEach(data => { this.addExternalFailureAtReplacement(node, data.failureMessage, data.replacement); }); } /** * Searches for outdated input bindings in the specified content and creates * replacements with the according messages that can be added to a rule failure. */ _createReplacementsForContent(node, templateContent) { const replacements = []; this.data.forEach(name => { const whitelist = name.whitelist; const relativeOffsets = []; const failureMessage = `Found deprecated @Input() "${chalk_1.red(name.replace)}"` + ` which has been renamed to "${chalk_1.green(name.replaceWith)}"`; if (whitelist.attributes) { relativeOffsets.push(...angular_1.findInputsOnElementWithAttr(templateContent, name.replace, whitelist.attributes)); } if (whitelist.elements) { relativeOffsets.push(...angular_1.findInputsOnElementWithTag(templateContent, name.replace, whitelist.elements)); } relativeOffsets .map(offset => node.getStart() + offset) .map(start => new tslint_1.Replacement(start, name.replace.length, name.replaceWith)) .forEach(replacement => replacements.push({ replacement, failureMessage })); }); return replacements; } } exports.Walker = Walker; //# sourceMappingURL=inputNamesTemplateRule.js.map