-
Notifications
You must be signed in to change notification settings - Fork 408
/
Copy pathclassnames-import-rule.js
48 lines (43 loc) · 1.48 KB
/
classnames-import-rule.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
const { ESLintUtils } = require('@typescript-eslint/utils');
const { replaceImportDefault } = require('../../ast-grep/replace-import-default');
const pkgName = 'classnames';
const expectLocalName = 'cls';
const rule = ESLintUtils.RuleCreator.withoutDocs({
defaultOptions: [{}],
meta: {
type: 'suggestion',
docs: {
description: `Enforce a consistent import name for the "${pkgName}" library`,
category: 'Best Practices',
recommended: true,
},
messages: {
unexpectedImportName: `Expected "${pkgName}" to be imported as "${expectLocalName}".`,
},
fixable: 'code',
schema: [], // No options
},
create: (context) => ({
ImportDeclaration(node) {
const { source, specifiers } = node;
if (source.value === pkgName) {
specifiers.forEach((specifier) => {
if (specifier.type === 'ImportDefaultSpecifier' && specifier.local.name !== expectLocalName) {
// 报告问题并提供修复方案
context.report({
node: specifier.local,
messageId: 'unexpectedImportName',
fix: (fixer) => {
const sourceCode = context.getSourceCode();
const source = sourceCode.text;
const result = replaceImportDefault(source, pkgName, expectLocalName);
return fixer.replaceTextRange(sourceCode.ast.range, result);
},
});
}
});
}
},
}),
});
module.exports = rule;