eslint-plugin-import
Advanced tools
Comparing version 2.27.2 to 2.27.3
@@ -32,63 +32,78 @@ 'use strict';var _slicedToArray = function () {function sliceIterator(arr, i) {var _arr = [];var _n = true;var _d = false;var _e = undefined;try {for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {_arr.push(_s.value);if (i && _arr.length === i) break;}} catch (err) {_d = true;_e = err;} finally {try {if (!_n && _i["return"]) _i["return"]();} finally {if (_d) throw _e;}}return _arr;}return function (arr, i) {if (Array.isArray(arr)) {return arr;} else if (Symbol.iterator in Object(arr)) {return sliceIterator(arr, i);} else {throw new TypeError("Invalid attempt to destructure non-iterable instance");}};}();var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { 'default': obj };} | ||
create: function () {function create(context) { | ||
var importsWithoutNameds = []; | ||
return { | ||
Program: function () {function Program(node) { | ||
node.tokens.forEach(function (token, idx) { | ||
var nextToken = node.tokens[idx + 1]; | ||
ImportDeclaration: function () {function ImportDeclaration(node) { | ||
if (!node.specifiers.some(function (x) {return x.type === 'ImportSpecifier';})) { | ||
importsWithoutNameds.push(node); | ||
} | ||
}return ImportDeclaration;}(), | ||
if (nextToken && token.value === '{' && nextToken.value === '}') { | ||
var hasOtherIdentifiers = node.tokens.some(function (token) {return ( | ||
token.type === 'Identifier' && | ||
token.value !== 'from' && | ||
token.value !== 'type' && | ||
token.value !== 'typeof');}); | ||
'Program:exit': function () {function ProgramExit(program) { | ||
var importsTokens = importsWithoutNameds.map(function (node) { | ||
return [node, program.tokens.filter(function (x) {return x.range[0] >= node.range[0] && x.range[1] <= node.range[1];})]; | ||
}); | ||
importsTokens.forEach(function (_ref) {var _ref2 = _slicedToArray(_ref, 2),node = _ref2[0],tokens = _ref2[1]; | ||
tokens.forEach(function (token) { | ||
var idx = program.tokens.indexOf(token); | ||
var nextToken = program.tokens[idx + 1]; | ||
// If it has no other identifiers it's the only thing in the import, so we can either remove the import | ||
// completely or transform it in a side-effects only import | ||
if (!hasOtherIdentifiers) { | ||
context.report({ | ||
node: node, | ||
message: 'Unexpected empty named import block', | ||
suggest: [ | ||
{ | ||
desc: 'Remove unused import', | ||
fix: function () {function fix(fixer) { | ||
// Remove the whole import | ||
return fixer.remove(node); | ||
}return fix;}() }, | ||
if (nextToken && token.value === '{' && nextToken.value === '}') { | ||
var hasOtherIdentifiers = tokens.some(function (token) {return ( | ||
token.type === 'Identifier' && | ||
token.value !== 'from' && | ||
token.value !== 'type' && | ||
token.value !== 'typeof');}); | ||
{ | ||
desc: 'Remove empty import block', | ||
fix: function () {function fix(fixer) { | ||
// Remove the empty block and the 'from' token, leaving the import only for its side | ||
// effects, e.g. `import 'mod'` | ||
var sourceCode = context.getSourceCode(); | ||
var fromToken = node.tokens.find(function (t) {return t.value === 'from';}); | ||
var importToken = node.tokens.find(function (t) {return t.value === 'import';}); | ||
var hasSpaceAfterFrom = sourceCode.isSpaceBetween(fromToken, sourceCode.getTokenAfter(fromToken)); | ||
var hasSpaceAfterImport = sourceCode.isSpaceBetween(importToken, sourceCode.getTokenAfter(fromToken));var _getEmptyBlockRange = | ||
getEmptyBlockRange(node.tokens, idx),_getEmptyBlockRange2 = _slicedToArray(_getEmptyBlockRange, 1),start = _getEmptyBlockRange2[0];var _fromToken$range = _slicedToArray( | ||
fromToken.range, 2),end = _fromToken$range[1]; | ||
var range = [start, hasSpaceAfterFrom ? end + 1 : end]; | ||
// If it has no other identifiers it's the only thing in the import, so we can either remove the import | ||
// completely or transform it in a side-effects only import | ||
if (!hasOtherIdentifiers) { | ||
context.report({ | ||
node: node, | ||
message: 'Unexpected empty named import block', | ||
suggest: [ | ||
{ | ||
desc: 'Remove unused import', | ||
fix: function () {function fix(fixer) { | ||
// Remove the whole import | ||
return fixer.remove(node); | ||
}return fix;}() }, | ||
return fixer.replaceTextRange(range, hasSpaceAfterImport ? '' : ' '); | ||
}return fix;}() }] }); | ||
{ | ||
desc: 'Remove empty import block', | ||
fix: function () {function fix(fixer) { | ||
// Remove the empty block and the 'from' token, leaving the import only for its side | ||
// effects, e.g. `import 'mod'` | ||
var sourceCode = context.getSourceCode(); | ||
var fromToken = program.tokens.find(function (t) {return t.value === 'from';}); | ||
var importToken = program.tokens.find(function (t) {return t.value === 'import';}); | ||
var hasSpaceAfterFrom = sourceCode.isSpaceBetween(fromToken, sourceCode.getTokenAfter(fromToken)); | ||
var hasSpaceAfterImport = sourceCode.isSpaceBetween(importToken, sourceCode.getTokenAfter(fromToken));var _getEmptyBlockRange = | ||
getEmptyBlockRange(program.tokens, idx),_getEmptyBlockRange2 = _slicedToArray(_getEmptyBlockRange, 1),start = _getEmptyBlockRange2[0];var _fromToken$range = _slicedToArray( | ||
fromToken.range, 2),end = _fromToken$range[1]; | ||
var range = [start, hasSpaceAfterFrom ? end + 1 : end]; | ||
return fixer.replaceTextRange(range, hasSpaceAfterImport ? '' : ' '); | ||
}return fix;}() }] }); | ||
} else { | ||
context.report({ | ||
node: node, | ||
message: 'Unexpected empty named import block', | ||
fix: function () {function fix(fixer) { | ||
return fixer.removeRange(getEmptyBlockRange(node.tokens, idx)); | ||
}return fix;}() }); | ||
} else { | ||
context.report({ | ||
node: node, | ||
message: 'Unexpected empty named import block', | ||
fix: function () {function fix(fixer) { | ||
return fixer.removeRange(getEmptyBlockRange(program.tokens, idx)); | ||
}return fix;}() }); | ||
} | ||
} | ||
} | ||
}); | ||
}); | ||
}return Program;}() }; | ||
}return ProgramExit;}() }; | ||
}return create;}() }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/no-empty-named-blocks.js"],"names":["getEmptyBlockRange","tokens","index","token","nextToken","prevToken","start","range","end","value","module","exports","meta","type","docs","category","description","url","fixable","schema","hasSuggestions","create","context","Program","node","forEach","idx","hasOtherIdentifiers","some","report","message","suggest","desc","fix","fixer","remove","sourceCode","getSourceCode","fromToken","find","t","importToken","hasSpaceAfterFrom","isSpaceBetween","getTokenAfter","hasSpaceAfterImport","replaceTextRange","removeRange"],"mappings":"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","file":"no-empty-named-blocks.js","sourcesContent":["import docsUrl from '../docsUrl';\n\nfunction getEmptyBlockRange(tokens, index) {\n  const token = tokens[index];\n  const nextToken = tokens[index + 1];\n  const prevToken = tokens[index - 1];\n  let start = token.range[0];\n  const end = nextToken.range[1];\n\n  // Remove block tokens and the previous comma\n  if (prevToken.value === ','|| prevToken.value === 'type' || prevToken.value === 'typeof') {\n    start = prevToken.range[0];\n  }\n\n  return [start, end];\n}\n\nmodule.exports = {\n  meta: {\n    type: 'suggestion',\n    docs: {\n      category: 'Helpful warnings',\n      description: 'Forbid empty named import blocks.',\n      url: docsUrl('no-empty-named-blocks'),\n    },\n    fixable: 'code',\n    schema: [],\n    hasSuggestions: true,\n  },\n\n  create(context) {\n    return {\n      Program(node) {\n        node.tokens.forEach((token, idx) => {\n          const nextToken = node.tokens[idx + 1];\n\n          if (nextToken && token.value === '{' && nextToken.value === '}') {\n            const hasOtherIdentifiers = node.tokens.some((token) => (\n              token.type === 'Identifier'\n                && token.value !== 'from'\n                && token.value !== 'type'\n                && token.value !== 'typeof'\n            ));\n\n            // If it has no other identifiers it's the only thing in the import, so we can either remove the import\n            // completely or transform it in a side-effects only import\n            if (!hasOtherIdentifiers) {\n              context.report({\n                node,\n                message: 'Unexpected empty named import block',\n                suggest: [\n                  {\n                    desc: 'Remove unused import',\n                    fix(fixer) {\n                      // Remove the whole import\n                      return fixer.remove(node);\n                    },\n                  },\n                  {\n                    desc: 'Remove empty import block',\n                    fix(fixer) {\n                      // Remove the empty block and the 'from' token, leaving the import only for its side\n                      // effects, e.g. `import 'mod'`\n                      const sourceCode = context.getSourceCode();\n                      const fromToken = node.tokens.find(t => t.value === 'from');\n                      const importToken = node.tokens.find(t => t.value === 'import');\n                      const hasSpaceAfterFrom = sourceCode.isSpaceBetween(fromToken, sourceCode.getTokenAfter(fromToken));\n                      const hasSpaceAfterImport = sourceCode.isSpaceBetween(importToken, sourceCode.getTokenAfter(fromToken));\n\n                      const [start] = getEmptyBlockRange(node.tokens, idx);\n                      const [, end] = fromToken.range;\n                      const range = [start, hasSpaceAfterFrom ? end + 1 : end];\n\n                      return fixer.replaceTextRange(range, hasSpaceAfterImport ? '' : ' ');\n                    },\n                  },\n                ],\n              });\n            } else {\n              context.report({\n                node,\n                message: 'Unexpected empty named import block',\n                fix(fixer) {\n                  return fixer.removeRange(getEmptyBlockRange(node.tokens, idx));\n                },\n              });\n            }\n          }\n        });\n      },\n    };\n  },\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/no-empty-named-blocks.js"],"names":["getEmptyBlockRange","tokens","index","token","nextToken","prevToken","start","range","end","value","module","exports","meta","type","docs","category","description","url","fixable","schema","hasSuggestions","create","context","importsWithoutNameds","ImportDeclaration","node","specifiers","some","x","push","program","importsTokens","map","filter","forEach","idx","indexOf","hasOtherIdentifiers","report","message","suggest","desc","fix","fixer","remove","sourceCode","getSourceCode","fromToken","find","t","importToken","hasSpaceAfterFrom","isSpaceBetween","getTokenAfter","hasSpaceAfterImport","replaceTextRange","removeRange"],"mappings":"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","file":"no-empty-named-blocks.js","sourcesContent":["import docsUrl from '../docsUrl';\n\nfunction getEmptyBlockRange(tokens, index) {\n  const token = tokens[index];\n  const nextToken = tokens[index + 1];\n  const prevToken = tokens[index - 1];\n  let start = token.range[0];\n  const end = nextToken.range[1];\n\n  // Remove block tokens and the previous comma\n  if (prevToken.value === ','|| prevToken.value === 'type' || prevToken.value === 'typeof') {\n    start = prevToken.range[0];\n  }\n\n  return [start, end];\n}\n\nmodule.exports = {\n  meta: {\n    type: 'suggestion',\n    docs: {\n      category: 'Helpful warnings',\n      description: 'Forbid empty named import blocks.',\n      url: docsUrl('no-empty-named-blocks'),\n    },\n    fixable: 'code',\n    schema: [],\n    hasSuggestions: true,\n  },\n\n  create(context) {\n    const importsWithoutNameds = [];\n\n    return {\n      ImportDeclaration(node) {\n        if (!node.specifiers.some(x => x.type === 'ImportSpecifier')) {\n          importsWithoutNameds.push(node);\n        }\n      },\n\n      'Program:exit': function (program) {\n        const importsTokens = importsWithoutNameds.map((node) => {\n          return [node, program.tokens.filter(x => x.range[0] >= node.range[0] && x.range[1] <= node.range[1])];\n        });\n\n        importsTokens.forEach(([node, tokens]) => {\n          tokens.forEach((token) => {\n            const idx = program.tokens.indexOf(token);\n            const nextToken = program.tokens[idx + 1];\n\n            if (nextToken && token.value === '{' && nextToken.value === '}') {\n              const hasOtherIdentifiers = tokens.some((token) => (\n                token.type === 'Identifier'\n                  && token.value !== 'from'\n                  && token.value !== 'type'\n                  && token.value !== 'typeof'\n              ));\n\n              // If it has no other identifiers it's the only thing in the import, so we can either remove the import\n              // completely or transform it in a side-effects only import\n              if (!hasOtherIdentifiers) {\n                context.report({\n                  node,\n                  message: 'Unexpected empty named import block',\n                  suggest: [\n                    {\n                      desc: 'Remove unused import',\n                      fix(fixer) {\n                        // Remove the whole import\n                        return fixer.remove(node);\n                      },\n                    },\n                    {\n                      desc: 'Remove empty import block',\n                      fix(fixer) {\n                        // Remove the empty block and the 'from' token, leaving the import only for its side\n                        // effects, e.g. `import 'mod'`\n                        const sourceCode = context.getSourceCode();\n                        const fromToken = program.tokens.find(t => t.value === 'from');\n                        const importToken = program.tokens.find(t => t.value === 'import');\n                        const hasSpaceAfterFrom = sourceCode.isSpaceBetween(fromToken, sourceCode.getTokenAfter(fromToken));\n                        const hasSpaceAfterImport = sourceCode.isSpaceBetween(importToken, sourceCode.getTokenAfter(fromToken));\n\n                        const [start] = getEmptyBlockRange(program.tokens, idx);\n                        const [, end] = fromToken.range;\n                        const range = [start, hasSpaceAfterFrom ? end + 1 : end];\n\n                        return fixer.replaceTextRange(range, hasSpaceAfterImport ? '' : ' ');\n                      },\n                    },\n                  ],\n                });\n              } else {\n                context.report({\n                  node,\n                  message: 'Unexpected empty named import block',\n                  fix(fixer) {\n                    return fixer.removeRange(getEmptyBlockRange(program.tokens, idx));\n                  },\n                });\n              }\n            }\n          });\n        });\n      },\n    };\n  },\n};\n"]} |
{ | ||
"name": "eslint-plugin-import", | ||
"version": "2.27.2", | ||
"version": "2.27.3", | ||
"description": "Import with sanity.", | ||
@@ -5,0 +5,0 @@ "engines": { |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Deprecated
MaintenanceThe maintainer of the package marked it as deprecated. This could indicate that a single version should not be used, or that the package is no longer maintained and any new vulnerabilities will not be fixed.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Deprecated
MaintenanceThe maintainer of the package marked it as deprecated. This could indicate that a single version should not be used, or that the package is no longer maintained and any new vulnerabilities will not be fixed.
Found 1 instance in 1 package
1193491
5741
0
1