mirror of
https://github.com/joelwmale/webhook-action.git
synced 2024-11-26 09:25:24 +01:00
686 lines
No EOL
77 KiB
JavaScript
686 lines
No EOL
77 KiB
JavaScript
'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 _minimatch = require('minimatch');var _minimatch2 = _interopRequireDefault(_minimatch);
|
|
var _importType = require('../core/importType');var _importType2 = _interopRequireDefault(_importType);
|
|
var _staticRequire = require('../core/staticRequire');var _staticRequire2 = _interopRequireDefault(_staticRequire);
|
|
var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { default: obj };}
|
|
|
|
const defaultGroups = ['builtin', 'external', 'parent', 'sibling', 'index'];
|
|
|
|
// REPORTING AND FIXING
|
|
|
|
function reverse(array) {
|
|
return array.map(function (v) {
|
|
return Object.assign({}, v, { rank: -v.rank });
|
|
}).reverse();
|
|
}
|
|
|
|
function getTokensOrCommentsAfter(sourceCode, node, count) {
|
|
let currentNodeOrToken = node;
|
|
const result = [];
|
|
for (let i = 0; i < count; i++) {
|
|
currentNodeOrToken = sourceCode.getTokenOrCommentAfter(currentNodeOrToken);
|
|
if (currentNodeOrToken == null) {
|
|
break;
|
|
}
|
|
result.push(currentNodeOrToken);
|
|
}
|
|
return result;
|
|
}
|
|
|
|
function getTokensOrCommentsBefore(sourceCode, node, count) {
|
|
let currentNodeOrToken = node;
|
|
const result = [];
|
|
for (let i = 0; i < count; i++) {
|
|
currentNodeOrToken = sourceCode.getTokenOrCommentBefore(currentNodeOrToken);
|
|
if (currentNodeOrToken == null) {
|
|
break;
|
|
}
|
|
result.push(currentNodeOrToken);
|
|
}
|
|
return result.reverse();
|
|
}
|
|
|
|
function takeTokensAfterWhile(sourceCode, node, condition) {
|
|
const tokens = getTokensOrCommentsAfter(sourceCode, node, 100);
|
|
const result = [];
|
|
for (let i = 0; i < tokens.length; i++) {
|
|
if (condition(tokens[i])) {
|
|
result.push(tokens[i]);
|
|
} else
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
|
|
function takeTokensBeforeWhile(sourceCode, node, condition) {
|
|
const tokens = getTokensOrCommentsBefore(sourceCode, node, 100);
|
|
const result = [];
|
|
for (let i = tokens.length - 1; i >= 0; i--) {
|
|
if (condition(tokens[i])) {
|
|
result.push(tokens[i]);
|
|
} else
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
return result.reverse();
|
|
}
|
|
|
|
function findOutOfOrder(imported) {
|
|
if (imported.length === 0) {
|
|
return [];
|
|
}
|
|
let maxSeenRankNode = imported[0];
|
|
return imported.filter(function (importedModule) {
|
|
const res = importedModule.rank < maxSeenRankNode.rank;
|
|
if (maxSeenRankNode.rank < importedModule.rank) {
|
|
maxSeenRankNode = importedModule;
|
|
}
|
|
return res;
|
|
});
|
|
}
|
|
|
|
function findRootNode(node) {
|
|
let parent = node;
|
|
while (parent.parent != null && parent.parent.body == null) {
|
|
parent = parent.parent;
|
|
}
|
|
return parent;
|
|
}
|
|
|
|
function findEndOfLineWithComments(sourceCode, node) {
|
|
const tokensToEndOfLine = takeTokensAfterWhile(sourceCode, node, commentOnSameLineAs(node));
|
|
let endOfTokens = tokensToEndOfLine.length > 0 ?
|
|
tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1] :
|
|
node.range[1];
|
|
let result = endOfTokens;
|
|
for (let i = endOfTokens; i < sourceCode.text.length; i++) {
|
|
if (sourceCode.text[i] === '\n') {
|
|
result = i + 1;
|
|
break;
|
|
}
|
|
if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\t' && sourceCode.text[i] !== '\r') {
|
|
break;
|
|
}
|
|
result = i + 1;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
function commentOnSameLineAs(node) {
|
|
return token => (token.type === 'Block' || token.type === 'Line') &&
|
|
token.loc.start.line === token.loc.end.line &&
|
|
token.loc.end.line === node.loc.end.line;
|
|
}
|
|
|
|
function findStartOfLineWithComments(sourceCode, node) {
|
|
const tokensToEndOfLine = takeTokensBeforeWhile(sourceCode, node, commentOnSameLineAs(node));
|
|
let startOfTokens = tokensToEndOfLine.length > 0 ? tokensToEndOfLine[0].range[0] : node.range[0];
|
|
let result = startOfTokens;
|
|
for (let i = startOfTokens - 1; i > 0; i--) {
|
|
if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\t') {
|
|
break;
|
|
}
|
|
result = i;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
function isPlainRequireModule(node) {
|
|
if (node.type !== 'VariableDeclaration') {
|
|
return false;
|
|
}
|
|
if (node.declarations.length !== 1) {
|
|
return false;
|
|
}
|
|
const decl = node.declarations[0];
|
|
const result = decl.id && (
|
|
decl.id.type === 'Identifier' || decl.id.type === 'ObjectPattern') &&
|
|
decl.init != null &&
|
|
decl.init.type === 'CallExpression' &&
|
|
decl.init.callee != null &&
|
|
decl.init.callee.name === 'require' &&
|
|
decl.init.arguments != null &&
|
|
decl.init.arguments.length === 1 &&
|
|
decl.init.arguments[0].type === 'Literal';
|
|
return result;
|
|
}
|
|
|
|
function isPlainImportModule(node) {
|
|
return node.type === 'ImportDeclaration' && node.specifiers != null && node.specifiers.length > 0;
|
|
}
|
|
|
|
function isPlainImportEquals(node) {
|
|
return node.type === 'TSImportEqualsDeclaration' && node.moduleReference.expression;
|
|
}
|
|
|
|
function canCrossNodeWhileReorder(node) {
|
|
return isPlainRequireModule(node) || isPlainImportModule(node) || isPlainImportEquals(node);
|
|
}
|
|
|
|
function canReorderItems(firstNode, secondNode) {
|
|
const parent = firstNode.parent;var _sort =
|
|
[
|
|
parent.body.indexOf(firstNode),
|
|
parent.body.indexOf(secondNode)].
|
|
sort(),_sort2 = _slicedToArray(_sort, 2);const firstIndex = _sort2[0],secondIndex = _sort2[1];
|
|
const nodesBetween = parent.body.slice(firstIndex, secondIndex + 1);
|
|
for (var nodeBetween of nodesBetween) {
|
|
if (!canCrossNodeWhileReorder(nodeBetween)) {
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
function fixOutOfOrder(context, firstNode, secondNode, order) {
|
|
const sourceCode = context.getSourceCode();
|
|
|
|
const firstRoot = findRootNode(firstNode.node);
|
|
const firstRootStart = findStartOfLineWithComments(sourceCode, firstRoot);
|
|
const firstRootEnd = findEndOfLineWithComments(sourceCode, firstRoot);
|
|
|
|
const secondRoot = findRootNode(secondNode.node);
|
|
const secondRootStart = findStartOfLineWithComments(sourceCode, secondRoot);
|
|
const secondRootEnd = findEndOfLineWithComments(sourceCode, secondRoot);
|
|
const canFix = canReorderItems(firstRoot, secondRoot);
|
|
|
|
let newCode = sourceCode.text.substring(secondRootStart, secondRootEnd);
|
|
if (newCode[newCode.length - 1] !== '\n') {
|
|
newCode = newCode + '\n';
|
|
}
|
|
|
|
const message = `\`${secondNode.displayName}\` import should occur ${order} import of \`${firstNode.displayName}\``;
|
|
|
|
if (order === 'before') {
|
|
context.report({
|
|
node: secondNode.node,
|
|
message: message,
|
|
fix: canFix && (fixer =>
|
|
fixer.replaceTextRange(
|
|
[firstRootStart, secondRootEnd],
|
|
newCode + sourceCode.text.substring(firstRootStart, secondRootStart))) });
|
|
|
|
|
|
} else if (order === 'after') {
|
|
context.report({
|
|
node: secondNode.node,
|
|
message: message,
|
|
fix: canFix && (fixer =>
|
|
fixer.replaceTextRange(
|
|
[secondRootStart, firstRootEnd],
|
|
sourceCode.text.substring(secondRootEnd, firstRootEnd) + newCode)) });
|
|
|
|
|
|
}
|
|
}
|
|
|
|
function reportOutOfOrder(context, imported, outOfOrder, order) {
|
|
outOfOrder.forEach(function (imp) {
|
|
const found = imported.find(function hasHigherRank(importedItem) {
|
|
return importedItem.rank > imp.rank;
|
|
});
|
|
fixOutOfOrder(context, found, imp, order);
|
|
});
|
|
}
|
|
|
|
function makeOutOfOrderReport(context, imported) {
|
|
const outOfOrder = findOutOfOrder(imported);
|
|
if (!outOfOrder.length) {
|
|
return;
|
|
}
|
|
// There are things to report. Try to minimize the number of reported errors.
|
|
const reversedImported = reverse(imported);
|
|
const reversedOrder = findOutOfOrder(reversedImported);
|
|
if (reversedOrder.length < outOfOrder.length) {
|
|
reportOutOfOrder(context, reversedImported, reversedOrder, 'after');
|
|
return;
|
|
}
|
|
reportOutOfOrder(context, imported, outOfOrder, 'before');
|
|
}
|
|
|
|
function getSorter(ascending) {
|
|
const multiplier = ascending ? 1 : -1;
|
|
|
|
return function importsSorter(importA, importB) {
|
|
let result;
|
|
|
|
if (importA < importB) {
|
|
result = -1;
|
|
} else if (importA > importB) {
|
|
result = 1;
|
|
} else {
|
|
result = 0;
|
|
}
|
|
|
|
return result * multiplier;
|
|
};
|
|
}
|
|
|
|
function mutateRanksToAlphabetize(imported, alphabetizeOptions) {
|
|
const groupedByRanks = imported.reduce(function (acc, importedItem) {
|
|
if (!Array.isArray(acc[importedItem.rank])) {
|
|
acc[importedItem.rank] = [];
|
|
}
|
|
acc[importedItem.rank].push(importedItem.value);
|
|
return acc;
|
|
}, {});
|
|
|
|
const groupRanks = Object.keys(groupedByRanks);
|
|
|
|
const sorterFn = getSorter(alphabetizeOptions.order === 'asc');
|
|
const comparator = alphabetizeOptions.caseInsensitive ? (a, b) => sorterFn(String(a).toLowerCase(), String(b).toLowerCase()) : (a, b) => sorterFn(a, b);
|
|
// sort imports locally within their group
|
|
groupRanks.forEach(function (groupRank) {
|
|
groupedByRanks[groupRank].sort(comparator);
|
|
});
|
|
|
|
// assign globally unique rank to each import
|
|
let newRank = 0;
|
|
const alphabetizedRanks = groupRanks.sort().reduce(function (acc, groupRank) {
|
|
groupedByRanks[groupRank].forEach(function (importedItemName) {
|
|
acc[importedItemName] = parseInt(groupRank, 10) + newRank;
|
|
newRank += 1;
|
|
});
|
|
return acc;
|
|
}, {});
|
|
|
|
// mutate the original group-rank with alphabetized-rank
|
|
imported.forEach(function (importedItem) {
|
|
importedItem.rank = alphabetizedRanks[importedItem.value];
|
|
});
|
|
}
|
|
|
|
// DETECTING
|
|
|
|
function computePathRank(ranks, pathGroups, path, maxPosition) {
|
|
for (let i = 0, l = pathGroups.length; i < l; i++) {var _pathGroups$i =
|
|
pathGroups[i];const pattern = _pathGroups$i.pattern,patternOptions = _pathGroups$i.patternOptions,group = _pathGroups$i.group;var _pathGroups$i$positio = _pathGroups$i.position;const position = _pathGroups$i$positio === undefined ? 1 : _pathGroups$i$positio;
|
|
if ((0, _minimatch2.default)(path, pattern, patternOptions || { nocomment: true })) {
|
|
return ranks[group] + position / maxPosition;
|
|
}
|
|
}
|
|
}
|
|
|
|
function computeRank(context, ranks, importEntry, excludedImportTypes) {
|
|
let impType;
|
|
let rank;
|
|
if (importEntry.type === 'import:object') {
|
|
impType = 'object';
|
|
} else {
|
|
impType = (0, _importType2.default)(importEntry.value, context);
|
|
}
|
|
if (!excludedImportTypes.has(impType)) {
|
|
rank = computePathRank(ranks.groups, ranks.pathGroups, importEntry.value, ranks.maxPosition);
|
|
}
|
|
if (typeof rank === 'undefined') {
|
|
rank = ranks.groups[impType];
|
|
}
|
|
if (importEntry.type !== 'import' && !importEntry.type.startsWith('import:')) {
|
|
rank += 100;
|
|
}
|
|
|
|
return rank;
|
|
}
|
|
|
|
function registerNode(context, importEntry, ranks, imported, excludedImportTypes) {
|
|
const rank = computeRank(context, ranks, importEntry, excludedImportTypes);
|
|
if (rank !== -1) {
|
|
imported.push(Object.assign({}, importEntry, { rank }));
|
|
}
|
|
}
|
|
|
|
function isInVariableDeclarator(node) {
|
|
return node && (
|
|
node.type === 'VariableDeclarator' || isInVariableDeclarator(node.parent));
|
|
}
|
|
|
|
const types = ['builtin', 'external', 'internal', 'unknown', 'parent', 'sibling', 'index', 'object'];
|
|
|
|
// Creates an object with type-rank pairs.
|
|
// Example: { index: 0, sibling: 1, parent: 1, external: 1, builtin: 2, internal: 2 }
|
|
// Will throw an error if it contains a type that does not exist, or has a duplicate
|
|
function convertGroupsToRanks(groups) {
|
|
const rankObject = groups.reduce(function (res, group, index) {
|
|
if (typeof group === 'string') {
|
|
group = [group];
|
|
}
|
|
group.forEach(function (groupItem) {
|
|
if (types.indexOf(groupItem) === -1) {
|
|
throw new Error('Incorrect configuration of the rule: Unknown type `' +
|
|
JSON.stringify(groupItem) + '`');
|
|
}
|
|
if (res[groupItem] !== undefined) {
|
|
throw new Error('Incorrect configuration of the rule: `' + groupItem + '` is duplicated');
|
|
}
|
|
res[groupItem] = index;
|
|
});
|
|
return res;
|
|
}, {});
|
|
|
|
const omittedTypes = types.filter(function (type) {
|
|
return rankObject[type] === undefined;
|
|
});
|
|
|
|
return omittedTypes.reduce(function (res, type) {
|
|
res[type] = groups.length;
|
|
return res;
|
|
}, rankObject);
|
|
}
|
|
|
|
function convertPathGroupsForRanks(pathGroups) {
|
|
const after = {};
|
|
const before = {};
|
|
|
|
const transformed = pathGroups.map((pathGroup, index) => {const
|
|
group = pathGroup.group,positionString = pathGroup.position;
|
|
let position = 0;
|
|
if (positionString === 'after') {
|
|
if (!after[group]) {
|
|
after[group] = 1;
|
|
}
|
|
position = after[group]++;
|
|
} else if (positionString === 'before') {
|
|
if (!before[group]) {
|
|
before[group] = [];
|
|
}
|
|
before[group].push(index);
|
|
}
|
|
|
|
return Object.assign({}, pathGroup, { position });
|
|
});
|
|
|
|
let maxPosition = 1;
|
|
|
|
Object.keys(before).forEach(group => {
|
|
const groupLength = before[group].length;
|
|
before[group].forEach((groupIndex, index) => {
|
|
transformed[groupIndex].position = -1 * (groupLength - index);
|
|
});
|
|
maxPosition = Math.max(maxPosition, groupLength);
|
|
});
|
|
|
|
Object.keys(after).forEach(key => {
|
|
const groupNextPosition = after[key];
|
|
maxPosition = Math.max(maxPosition, groupNextPosition - 1);
|
|
});
|
|
|
|
return {
|
|
pathGroups: transformed,
|
|
maxPosition: maxPosition > 10 ? Math.pow(10, Math.ceil(Math.log10(maxPosition))) : 10 };
|
|
|
|
}
|
|
|
|
function fixNewLineAfterImport(context, previousImport) {
|
|
const prevRoot = findRootNode(previousImport.node);
|
|
const tokensToEndOfLine = takeTokensAfterWhile(
|
|
context.getSourceCode(), prevRoot, commentOnSameLineAs(prevRoot));
|
|
|
|
let endOfLine = prevRoot.range[1];
|
|
if (tokensToEndOfLine.length > 0) {
|
|
endOfLine = tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1];
|
|
}
|
|
return fixer => fixer.insertTextAfterRange([prevRoot.range[0], endOfLine], '\n');
|
|
}
|
|
|
|
function removeNewLineAfterImport(context, currentImport, previousImport) {
|
|
const sourceCode = context.getSourceCode();
|
|
const prevRoot = findRootNode(previousImport.node);
|
|
const currRoot = findRootNode(currentImport.node);
|
|
const rangeToRemove = [
|
|
findEndOfLineWithComments(sourceCode, prevRoot),
|
|
findStartOfLineWithComments(sourceCode, currRoot)];
|
|
|
|
if (/^\s*$/.test(sourceCode.text.substring(rangeToRemove[0], rangeToRemove[1]))) {
|
|
return fixer => fixer.removeRange(rangeToRemove);
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
function makeNewlinesBetweenReport(context, imported, newlinesBetweenImports) {
|
|
const getNumberOfEmptyLinesBetween = (currentImport, previousImport) => {
|
|
const linesBetweenImports = context.getSourceCode().lines.slice(
|
|
previousImport.node.loc.end.line,
|
|
currentImport.node.loc.start.line - 1);
|
|
|
|
|
|
return linesBetweenImports.filter(line => !line.trim().length).length;
|
|
};
|
|
let previousImport = imported[0];
|
|
|
|
imported.slice(1).forEach(function (currentImport) {
|
|
const emptyLinesBetween = getNumberOfEmptyLinesBetween(currentImport, previousImport);
|
|
|
|
if (newlinesBetweenImports === 'always' ||
|
|
newlinesBetweenImports === 'always-and-inside-groups') {
|
|
if (currentImport.rank !== previousImport.rank && emptyLinesBetween === 0) {
|
|
context.report({
|
|
node: previousImport.node,
|
|
message: 'There should be at least one empty line between import groups',
|
|
fix: fixNewLineAfterImport(context, previousImport) });
|
|
|
|
} else if (currentImport.rank === previousImport.rank &&
|
|
emptyLinesBetween > 0 &&
|
|
newlinesBetweenImports !== 'always-and-inside-groups') {
|
|
context.report({
|
|
node: previousImport.node,
|
|
message: 'There should be no empty line within import group',
|
|
fix: removeNewLineAfterImport(context, currentImport, previousImport) });
|
|
|
|
}
|
|
} else if (emptyLinesBetween > 0) {
|
|
context.report({
|
|
node: previousImport.node,
|
|
message: 'There should be no empty line between import groups',
|
|
fix: removeNewLineAfterImport(context, currentImport, previousImport) });
|
|
|
|
}
|
|
|
|
previousImport = currentImport;
|
|
});
|
|
}
|
|
|
|
function getAlphabetizeConfig(options) {
|
|
const alphabetize = options.alphabetize || {};
|
|
const order = alphabetize.order || 'ignore';
|
|
const caseInsensitive = alphabetize.caseInsensitive || false;
|
|
|
|
return { order, caseInsensitive };
|
|
}
|
|
|
|
module.exports = {
|
|
meta: {
|
|
type: 'suggestion',
|
|
docs: {
|
|
url: (0, _docsUrl2.default)('order') },
|
|
|
|
|
|
fixable: 'code',
|
|
schema: [
|
|
{
|
|
type: 'object',
|
|
properties: {
|
|
groups: {
|
|
type: 'array' },
|
|
|
|
pathGroupsExcludedImportTypes: {
|
|
type: 'array' },
|
|
|
|
pathGroups: {
|
|
type: 'array',
|
|
items: {
|
|
type: 'object',
|
|
properties: {
|
|
pattern: {
|
|
type: 'string' },
|
|
|
|
patternOptions: {
|
|
type: 'object' },
|
|
|
|
group: {
|
|
type: 'string',
|
|
enum: types },
|
|
|
|
position: {
|
|
type: 'string',
|
|
enum: ['after', 'before'] } },
|
|
|
|
|
|
required: ['pattern', 'group'] } },
|
|
|
|
|
|
'newlines-between': {
|
|
enum: [
|
|
'ignore',
|
|
'always',
|
|
'always-and-inside-groups',
|
|
'never'] },
|
|
|
|
|
|
alphabetize: {
|
|
type: 'object',
|
|
properties: {
|
|
caseInsensitive: {
|
|
type: 'boolean',
|
|
default: false },
|
|
|
|
order: {
|
|
enum: ['ignore', 'asc', 'desc'],
|
|
default: 'ignore' } },
|
|
|
|
|
|
additionalProperties: false } },
|
|
|
|
|
|
additionalProperties: false }] },
|
|
|
|
|
|
|
|
|
|
create: function importOrderRule(context) {
|
|
const options = context.options[0] || {};
|
|
const newlinesBetweenImports = options['newlines-between'] || 'ignore';
|
|
const pathGroupsExcludedImportTypes = new Set(options['pathGroupsExcludedImportTypes'] || ['builtin', 'external', 'object']);
|
|
const alphabetize = getAlphabetizeConfig(options);
|
|
let ranks;
|
|
|
|
try {var _convertPathGroupsFor =
|
|
convertPathGroupsForRanks(options.pathGroups || []);const pathGroups = _convertPathGroupsFor.pathGroups,maxPosition = _convertPathGroupsFor.maxPosition;
|
|
ranks = {
|
|
groups: convertGroupsToRanks(options.groups || defaultGroups),
|
|
pathGroups,
|
|
maxPosition };
|
|
|
|
} catch (error) {
|
|
// Malformed configuration
|
|
return {
|
|
Program: function (node) {
|
|
context.report(node, error.message);
|
|
} };
|
|
|
|
}
|
|
let imported = [];
|
|
let level = 0;
|
|
|
|
function incrementLevel() {
|
|
level++;
|
|
}
|
|
function decrementLevel() {
|
|
level--;
|
|
}
|
|
|
|
return {
|
|
ImportDeclaration: function handleImports(node) {
|
|
if (node.specifiers.length) {// Ignoring unassigned imports
|
|
const name = node.source.value;
|
|
registerNode(
|
|
context,
|
|
{
|
|
node,
|
|
value: name,
|
|
displayName: name,
|
|
type: 'import' },
|
|
|
|
ranks,
|
|
imported,
|
|
pathGroupsExcludedImportTypes);
|
|
|
|
}
|
|
},
|
|
TSImportEqualsDeclaration: function handleImports(node) {
|
|
let displayName;
|
|
let value;
|
|
let type;
|
|
// skip "export import"s
|
|
if (node.isExport) {
|
|
return;
|
|
}
|
|
if (node.moduleReference.type === 'TSExternalModuleReference') {
|
|
value = node.moduleReference.expression.value;
|
|
displayName = value;
|
|
type = 'import';
|
|
} else {
|
|
value = '';
|
|
displayName = context.getSourceCode().getText(node.moduleReference);
|
|
type = 'import:object';
|
|
}
|
|
registerNode(
|
|
context,
|
|
{
|
|
node,
|
|
value,
|
|
displayName,
|
|
type },
|
|
|
|
ranks,
|
|
imported,
|
|
pathGroupsExcludedImportTypes);
|
|
|
|
},
|
|
CallExpression: function handleRequires(node) {
|
|
if (level !== 0 || !(0, _staticRequire2.default)(node) || !isInVariableDeclarator(node.parent)) {
|
|
return;
|
|
}
|
|
const name = node.arguments[0].value;
|
|
registerNode(
|
|
context,
|
|
{
|
|
node,
|
|
value: name,
|
|
displayName: name,
|
|
type: 'require' },
|
|
|
|
ranks,
|
|
imported,
|
|
pathGroupsExcludedImportTypes);
|
|
|
|
},
|
|
'Program:exit': function reportAndReset() {
|
|
if (newlinesBetweenImports !== 'ignore') {
|
|
makeNewlinesBetweenReport(context, imported, newlinesBetweenImports);
|
|
}
|
|
|
|
if (alphabetize.order !== 'ignore') {
|
|
mutateRanksToAlphabetize(imported, alphabetize);
|
|
}
|
|
|
|
makeOutOfOrderReport(context, imported);
|
|
|
|
imported = [];
|
|
},
|
|
FunctionDeclaration: incrementLevel,
|
|
FunctionExpression: incrementLevel,
|
|
ArrowFunctionExpression: incrementLevel,
|
|
BlockStatement: incrementLevel,
|
|
ObjectExpression: incrementLevel,
|
|
'FunctionDeclaration:exit': decrementLevel,
|
|
'FunctionExpression:exit': decrementLevel,
|
|
'ArrowFunctionExpression:exit': decrementLevel,
|
|
'BlockStatement:exit': decrementLevel,
|
|
'ObjectExpression:exit': decrementLevel };
|
|
|
|
} };
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/order.js"],"names":["defaultGroups","reverse","array","map","v","Object","assign","rank","getTokensOrCommentsAfter","sourceCode","node","count","currentNodeOrToken","result","i","getTokenOrCommentAfter","push","getTokensOrCommentsBefore","getTokenOrCommentBefore","takeTokensAfterWhile","condition","tokens","length","takeTokensBeforeWhile","findOutOfOrder","imported","maxSeenRankNode","filter","importedModule","res","findRootNode","parent","body","findEndOfLineWithComments","tokensToEndOfLine","commentOnSameLineAs","endOfTokens","range","text","token","type","loc","start","line","end","findStartOfLineWithComments","startOfTokens","isPlainRequireModule","declarations","decl","id","init","callee","name","arguments","isPlainImportModule","specifiers","isPlainImportEquals","moduleReference","expression","canCrossNodeWhileReorder","canReorderItems","firstNode","secondNode","indexOf","sort","firstIndex","secondIndex","nodesBetween","slice","nodeBetween","fixOutOfOrder","context","order","getSourceCode","firstRoot","firstRootStart","firstRootEnd","secondRoot","secondRootStart","secondRootEnd","canFix","newCode","substring","message","displayName","report","fix","fixer","replaceTextRange","reportOutOfOrder","outOfOrder","forEach","imp","found","find","hasHigherRank","importedItem","makeOutOfOrderReport","reversedImported","reversedOrder","getSorter","ascending","multiplier","importsSorter","importA","importB","mutateRanksToAlphabetize","alphabetizeOptions","groupedByRanks","reduce","acc","Array","isArray","value","groupRanks","keys","sorterFn","comparator","caseInsensitive","a","b","String","toLowerCase","groupRank","newRank","alphabetizedRanks","importedItemName","parseInt","computePathRank","ranks","pathGroups","path","maxPosition","l","pattern","patternOptions","group","position","nocomment","computeRank","importEntry","excludedImportTypes","impType","has","groups","startsWith","registerNode","isInVariableDeclarator","types","convertGroupsToRanks","rankObject","index","groupItem","Error","JSON","stringify","undefined","omittedTypes","convertPathGroupsForRanks","after","before","transformed","pathGroup","positionString","groupLength","groupIndex","Math","max","key","groupNextPosition","pow","ceil","log10","fixNewLineAfterImport","previousImport","prevRoot","endOfLine","insertTextAfterRange","removeNewLineAfterImport","currentImport","currRoot","rangeToRemove","test","removeRange","makeNewlinesBetweenReport","newlinesBetweenImports","getNumberOfEmptyLinesBetween","linesBetweenImports","lines","trim","emptyLinesBetween","getAlphabetizeConfig","options","alphabetize","module","exports","meta","docs","url","fixable","schema","properties","pathGroupsExcludedImportTypes","items","enum","required","default","additionalProperties","create","importOrderRule","Set","error","Program","level","incrementLevel","decrementLevel","ImportDeclaration","handleImports","source","TSImportEqualsDeclaration","isExport","getText","CallExpression","handleRequires","reportAndReset","FunctionDeclaration","FunctionExpression","ArrowFunctionExpression","BlockStatement","ObjectExpression"],"mappings":"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","file":"order.js","sourcesContent":["'use strict'\n\nimport minimatch from 'minimatch'\nimport importType from '../core/importType'\nimport isStaticRequire from '../core/staticRequire'\nimport docsUrl from '../docsUrl'\n\nconst defaultGroups = ['builtin', 'external', 'parent', 'sibling', 'index']\n\n// REPORTING AND FIXING\n\nfunction reverse(array) {\n  return array.map(function (v) {\n    return Object.assign({}, v, { rank: -v.rank })\n  }).reverse()\n}\n\nfunction getTokensOrCommentsAfter(sourceCode, node, count) {\n  let currentNodeOrToken = node\n  const result = []\n  for (let i = 0; i < count; i++) {\n    currentNodeOrToken = sourceCode.getTokenOrCommentAfter(currentNodeOrToken)\n    if (currentNodeOrToken == null) {\n      break\n    }\n    result.push(currentNodeOrToken)\n  }\n  return result\n}\n\nfunction getTokensOrCommentsBefore(sourceCode, node, count) {\n  let currentNodeOrToken = node\n  const result = []\n  for (let i = 0; i < count; i++) {\n    currentNodeOrToken = sourceCode.getTokenOrCommentBefore(currentNodeOrToken)\n    if (currentNodeOrToken == null) {\n      break\n    }\n    result.push(currentNodeOrToken)\n  }\n  return result.reverse()\n}\n\nfunction takeTokensAfterWhile(sourceCode, node, condition) {\n  const tokens = getTokensOrCommentsAfter(sourceCode, node, 100)\n  const result = []\n  for (let i = 0; i < tokens.length; i++) {\n    if (condition(tokens[i])) {\n      result.push(tokens[i])\n    }\n    else {\n      break\n    }\n  }\n  return result\n}\n\nfunction takeTokensBeforeWhile(sourceCode, node, condition) {\n  const tokens = getTokensOrCommentsBefore(sourceCode, node, 100)\n  const result = []\n  for (let i = tokens.length - 1; i >= 0; i--) {\n    if (condition(tokens[i])) {\n      result.push(tokens[i])\n    }\n    else {\n      break\n    }\n  }\n  return result.reverse()\n}\n\nfunction findOutOfOrder(imported) {\n  if (imported.length === 0) {\n    return []\n  }\n  let maxSeenRankNode = imported[0]\n  return imported.filter(function (importedModule) {\n    const res = importedModule.rank < maxSeenRankNode.rank\n    if (maxSeenRankNode.rank < importedModule.rank) {\n      maxSeenRankNode = importedModule\n    }\n    return res\n  })\n}\n\nfunction findRootNode(node) {\n  let parent = node\n  while (parent.parent != null && parent.parent.body == null) {\n    parent = parent.parent\n  }\n  return parent\n}\n\nfunction findEndOfLineWithComments(sourceCode, node) {\n  const tokensToEndOfLine = takeTokensAfterWhile(sourceCode, node, commentOnSameLineAs(node))\n  let endOfTokens = tokensToEndOfLine.length > 0\n    ? tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1]\n    : node.range[1]\n  let result = endOfTokens\n  for (let i = endOfTokens; i < sourceCode.text.length; i++) {\n    if (sourceCode.text[i] === '\\n') {\n      result = i + 1\n      break\n    }\n    if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\\t' && sourceCode.text[i] !== '\\r') {\n      break\n    }\n    result = i + 1\n  }\n  return result\n}\n\nfunction commentOnSameLineAs(node) {\n  return token => (token.type === 'Block' ||  token.type === 'Line') &&\n      token.loc.start.line === token.loc.end.line &&\n      token.loc.end.line === node.loc.end.line\n}\n\nfunction findStartOfLineWithComments(sourceCode, node) {\n  const tokensToEndOfLine = takeTokensBeforeWhile(sourceCode, node, commentOnSameLineAs(node))\n  let startOfTokens = tokensToEndOfLine.length > 0 ? tokensToEndOfLine[0].range[0] : node.range[0]\n  let result = startOfTokens\n  for (let i = startOfTokens - 1; i > 0; i--) {\n    if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\\t') {\n      break\n    }\n    result = i\n  }\n  return result\n}\n\nfunction isPlainRequireModule(node) {\n  if (node.type !== 'VariableDeclaration') {\n    return false\n  }\n  if (node.declarations.length !== 1) {\n    return false\n  }\n  const decl = node.declarations[0]\n  const result = decl.id &&\n    (decl.id.type === 'Identifier' || decl.id.type === 'ObjectPattern') &&\n    decl.init != null &&\n    decl.init.type === 'CallExpression' &&\n    decl.init.callee != null &&\n    decl.init.callee.name === 'require' &&\n    decl.init.arguments != null &&\n    decl.init.arguments.length === 1 &&\n    decl.init.arguments[0].type === 'Literal'\n  return result\n}\n\nfunction isPlainImportModule(node) {\n  return node.type === 'ImportDeclaration' && node.specifiers != null && node.specifiers.length > 0\n}\n\nfunction isPlainImportEquals(node) {\n  return node.type === 'TSImportEqualsDeclaration' && node.moduleReference.expression\n}\n\nfunction canCrossNodeWhileReorder(node) {\n  return isPlainRequireModule(node) || isPlainImportModule(node) || isPlainImportEquals(node)\n}\n\nfunction canReorderItems(firstNode, secondNode) {\n  const parent = firstNode.parent\n  const [firstIndex, secondIndex] = [\n    parent.body.indexOf(firstNode),\n    parent.body.indexOf(secondNode),\n  ].sort()\n  const nodesBetween = parent.body.slice(firstIndex, secondIndex + 1)\n  for (var nodeBetween of nodesBetween) {\n    if (!canCrossNodeWhileReorder(nodeBetween)) {\n      return false\n    }\n  }\n  return true\n}\n\nfunction fixOutOfOrder(context, firstNode, secondNode, order) {\n  const sourceCode = context.getSourceCode()\n\n  const firstRoot = findRootNode(firstNode.node)\n  const firstRootStart = findStartOfLineWithComments(sourceCode, firstRoot)\n  const firstRootEnd = findEndOfLineWithComments(sourceCode, firstRoot)\n\n  const secondRoot = findRootNode(secondNode.node)\n  const secondRootStart = findStartOfLineWithComments(sourceCode, secondRoot)\n  const secondRootEnd = findEndOfLineWithComments(sourceCode, secondRoot)\n  const canFix = canReorderItems(firstRoot, secondRoot)\n\n  let newCode = sourceCode.text.substring(secondRootStart, secondRootEnd)\n  if (newCode[newCode.length - 1] !== '\\n') {\n    newCode = newCode + '\\n'\n  }\n\n  const message = `\\`${secondNode.displayName}\\` import should occur ${order} import of \\`${firstNode.displayName}\\``\n\n  if (order === 'before') {\n    context.report({\n      node: secondNode.node,\n      message: message,\n      fix: canFix && (fixer =>\n        fixer.replaceTextRange(\n          [firstRootStart, secondRootEnd],\n          newCode + sourceCode.text.substring(firstRootStart, secondRootStart)\n        )),\n    })\n  } else if (order === 'after') {\n    context.report({\n      node: secondNode.node,\n      message: message,\n      fix: canFix && (fixer =>\n        fixer.replaceTextRange(\n          [secondRootStart, firstRootEnd],\n          sourceCode.text.substring(secondRootEnd, firstRootEnd) + newCode\n        )),\n    })\n  }\n}\n\nfunction reportOutOfOrder(context, imported, outOfOrder, order) {\n  outOfOrder.forEach(function (imp) {\n    const found = imported.find(function hasHigherRank(importedItem) {\n      return importedItem.rank > imp.rank\n    })\n    fixOutOfOrder(context, found, imp, order)\n  })\n}\n\nfunction makeOutOfOrderReport(context, imported) {\n  const outOfOrder = findOutOfOrder(imported)\n  if (!outOfOrder.length) {\n    return\n  }\n  // There are things to report. Try to minimize the number of reported errors.\n  const reversedImported = reverse(imported)\n  const reversedOrder = findOutOfOrder(reversedImported)\n  if (reversedOrder.length < outOfOrder.length) {\n    reportOutOfOrder(context, reversedImported, reversedOrder, 'after')\n    return\n  }\n  reportOutOfOrder(context, imported, outOfOrder, 'before')\n}\n\nfunction getSorter(ascending) {\n  const multiplier = ascending ? 1 : -1\n\n  return function importsSorter(importA, importB) {\n    let result\n\n    if (importA < importB) {\n      result = -1\n    } else if (importA > importB) {\n      result = 1\n    } else {\n      result = 0\n    }\n\n    return result * multiplier\n  }\n}\n\nfunction mutateRanksToAlphabetize(imported, alphabetizeOptions) {\n  const groupedByRanks = imported.reduce(function(acc, importedItem) {\n    if (!Array.isArray(acc[importedItem.rank])) {\n      acc[importedItem.rank] = []\n    }\n    acc[importedItem.rank].push(importedItem.value)\n    return acc\n  }, {})\n\n  const groupRanks = Object.keys(groupedByRanks)\n\n  const sorterFn = getSorter(alphabetizeOptions.order === 'asc')\n  const comparator = alphabetizeOptions.caseInsensitive ? (a, b) => sorterFn(String(a).toLowerCase(), String(b).toLowerCase()) : (a, b) => sorterFn(a, b)\n  // sort imports locally within their group\n  groupRanks.forEach(function(groupRank) {\n    groupedByRanks[groupRank].sort(comparator)\n  })\n\n  // assign globally unique rank to each import\n  let newRank = 0\n  const alphabetizedRanks = groupRanks.sort().reduce(function(acc, groupRank) {\n    groupedByRanks[groupRank].forEach(function(importedItemName) {\n      acc[importedItemName] = parseInt(groupRank, 10) + newRank\n      newRank += 1\n    })\n    return acc\n  }, {})\n\n  // mutate the original group-rank with alphabetized-rank\n  imported.forEach(function(importedItem) {\n    importedItem.rank = alphabetizedRanks[importedItem.value]\n  })\n}\n\n// DETECTING\n\nfunction computePathRank(ranks, pathGroups, path, maxPosition) {\n  for (let i = 0, l = pathGroups.length; i < l; i++) {\n    const { pattern, patternOptions, group, position = 1 } = pathGroups[i]\n    if (minimatch(path, pattern, patternOptions || { nocomment: true })) {\n      return ranks[group] + (position / maxPosition)\n    }\n  }\n}\n\nfunction computeRank(context, ranks, importEntry, excludedImportTypes) {\n  let impType\n  let rank\n  if (importEntry.type === 'import:object') {\n    impType = 'object'\n  } else {\n    impType = importType(importEntry.value, context)\n  }\n  if (!excludedImportTypes.has(impType)) {\n    rank = computePathRank(ranks.groups, ranks.pathGroups, importEntry.value, ranks.maxPosition)\n  }\n  if (typeof rank === 'undefined') {\n    rank = ranks.groups[impType]\n  }\n  if (importEntry.type !== 'import' && !importEntry.type.startsWith('import:')) {\n    rank += 100\n  }\n\n  return rank\n}\n\nfunction registerNode(context, importEntry, ranks, imported, excludedImportTypes) {\n  const rank = computeRank(context, ranks, importEntry, excludedImportTypes)\n  if (rank !== -1) {\n    imported.push(Object.assign({}, importEntry, { rank }))\n  }\n}\n\nfunction isInVariableDeclarator(node) {\n  return node &&\n    (node.type === 'VariableDeclarator' || isInVariableDeclarator(node.parent))\n}\n\nconst types = ['builtin', 'external', 'internal', 'unknown', 'parent', 'sibling', 'index', 'object']\n\n// Creates an object with type-rank pairs.\n// Example: { index: 0, sibling: 1, parent: 1, external: 1, builtin: 2, internal: 2 }\n// Will throw an error if it contains a type that does not exist, or has a duplicate\nfunction convertGroupsToRanks(groups) {\n  const rankObject = groups.reduce(function(res, group, index) {\n    if (typeof group === 'string') {\n      group = [group]\n    }\n    group.forEach(function(groupItem) {\n      if (types.indexOf(groupItem) === -1) {\n        throw new Error('Incorrect configuration of the rule: Unknown type `' +\n          JSON.stringify(groupItem) + '`')\n      }\n      if (res[groupItem] !== undefined) {\n        throw new Error('Incorrect configuration of the rule: `' + groupItem + '` is duplicated')\n      }\n      res[groupItem] = index\n    })\n    return res\n  }, {})\n\n  const omittedTypes = types.filter(function(type) {\n    return rankObject[type] === undefined\n  })\n\n  return omittedTypes.reduce(function(res, type) {\n    res[type] = groups.length\n    return res\n  }, rankObject)\n}\n\nfunction convertPathGroupsForRanks(pathGroups) {\n  const after = {}\n  const before = {}\n\n  const transformed = pathGroups.map((pathGroup, index) => {\n    const { group, position: positionString } = pathGroup\n    let position = 0\n    if (positionString === 'after') {\n      if (!after[group]) {\n        after[group] = 1\n      }\n      position = after[group]++\n    } else if (positionString === 'before') {\n      if (!before[group]) {\n        before[group] = []\n      }\n      before[group].push(index)\n    }\n\n    return Object.assign({}, pathGroup, { position })\n  })\n\n  let maxPosition = 1\n\n  Object.keys(before).forEach((group) => {\n    const groupLength = before[group].length\n    before[group].forEach((groupIndex, index) => {\n      transformed[groupIndex].position = -1 * (groupLength - index)\n    })\n    maxPosition = Math.max(maxPosition, groupLength)\n  })\n\n  Object.keys(after).forEach((key) => {\n    const groupNextPosition = after[key]\n    maxPosition = Math.max(maxPosition, groupNextPosition - 1)\n  })\n\n  return {\n    pathGroups: transformed,\n    maxPosition: maxPosition > 10 ? Math.pow(10, Math.ceil(Math.log10(maxPosition))) : 10,\n  }\n}\n\nfunction fixNewLineAfterImport(context, previousImport) {\n  const prevRoot = findRootNode(previousImport.node)\n  const tokensToEndOfLine = takeTokensAfterWhile(\n    context.getSourceCode(), prevRoot, commentOnSameLineAs(prevRoot))\n\n  let endOfLine = prevRoot.range[1]\n  if (tokensToEndOfLine.length > 0) {\n    endOfLine = tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1]\n  }\n  return (fixer) => fixer.insertTextAfterRange([prevRoot.range[0], endOfLine], '\\n')\n}\n\nfunction removeNewLineAfterImport(context, currentImport, previousImport) {\n  const sourceCode = context.getSourceCode()\n  const prevRoot = findRootNode(previousImport.node)\n  const currRoot = findRootNode(currentImport.node)\n  const rangeToRemove = [\n    findEndOfLineWithComments(sourceCode, prevRoot),\n    findStartOfLineWithComments(sourceCode, currRoot),\n  ]\n  if (/^\\s*$/.test(sourceCode.text.substring(rangeToRemove[0], rangeToRemove[1]))) {\n    return (fixer) => fixer.removeRange(rangeToRemove)\n  }\n  return undefined\n}\n\nfunction makeNewlinesBetweenReport (context, imported, newlinesBetweenImports) {\n  const getNumberOfEmptyLinesBetween = (currentImport, previousImport) => {\n    const linesBetweenImports = context.getSourceCode().lines.slice(\n      previousImport.node.loc.end.line,\n      currentImport.node.loc.start.line - 1\n    )\n\n    return linesBetweenImports.filter((line) => !line.trim().length).length\n  }\n  let previousImport = imported[0]\n\n  imported.slice(1).forEach(function(currentImport) {\n    const emptyLinesBetween = getNumberOfEmptyLinesBetween(currentImport, previousImport)\n\n    if (newlinesBetweenImports === 'always'\n        || newlinesBetweenImports === 'always-and-inside-groups') {\n      if (currentImport.rank !== previousImport.rank && emptyLinesBetween === 0) {\n        context.report({\n          node: previousImport.node,\n          message: 'There should be at least one empty line between import groups',\n          fix: fixNewLineAfterImport(context, previousImport),\n        })\n      } else if (currentImport.rank === previousImport.rank\n        && emptyLinesBetween > 0\n        && newlinesBetweenImports !== 'always-and-inside-groups') {\n        context.report({\n          node: previousImport.node,\n          message: 'There should be no empty line within import group',\n          fix: removeNewLineAfterImport(context, currentImport, previousImport),\n        })\n      }\n    } else if (emptyLinesBetween > 0) {\n      context.report({\n        node: previousImport.node,\n        message: 'There should be no empty line between import groups',\n        fix: removeNewLineAfterImport(context, currentImport, previousImport),\n      })\n    }\n\n    previousImport = currentImport\n  })\n}\n\nfunction getAlphabetizeConfig(options) {\n  const alphabetize = options.alphabetize || {}\n  const order = alphabetize.order || 'ignore'\n  const caseInsensitive = alphabetize.caseInsensitive || false\n\n  return {order, caseInsensitive}\n}\n\nmodule.exports = {\n  meta: {\n    type: 'suggestion',\n    docs: {\n      url: docsUrl('order'),\n    },\n\n    fixable: 'code',\n    schema: [\n      {\n        type: 'object',\n        properties: {\n          groups: {\n            type: 'array',\n          },\n          pathGroupsExcludedImportTypes: {\n            type: 'array',\n          },\n          pathGroups: {\n            type: 'array',\n            items: {\n              type: 'object',\n              properties: {\n                pattern: {\n                  type: 'string',\n                },\n                patternOptions: {\n                  type: 'object',\n                },\n                group: {\n                  type: 'string',\n                  enum: types,\n                },\n                position: {\n                  type: 'string',\n                  enum: ['after', 'before'],\n                },\n              },\n              required: ['pattern', 'group'],\n            },\n          },\n          'newlines-between': {\n            enum: [\n              'ignore',\n              'always',\n              'always-and-inside-groups',\n              'never',\n            ],\n          },\n          alphabetize: {\n            type: 'object',\n            properties: {\n              caseInsensitive: {\n                type: 'boolean',\n                default: false,\n              },\n              order: {\n                enum: ['ignore', 'asc', 'desc'],\n                default: 'ignore',\n              },\n            },\n            additionalProperties: false,\n          },\n        },\n        additionalProperties: false,\n      },\n    ],\n  },\n\n  create: function importOrderRule (context) {\n    const options = context.options[0] || {}\n    const newlinesBetweenImports = options['newlines-between'] || 'ignore'\n    const pathGroupsExcludedImportTypes = new Set(options['pathGroupsExcludedImportTypes'] || ['builtin', 'external', 'object'])\n    const alphabetize = getAlphabetizeConfig(options)\n    let ranks\n\n    try {\n      const { pathGroups, maxPosition } = convertPathGroupsForRanks(options.pathGroups || [])\n      ranks = {\n        groups: convertGroupsToRanks(options.groups || defaultGroups),\n        pathGroups,\n        maxPosition,\n      }\n    } catch (error) {\n      // Malformed configuration\n      return {\n        Program: function(node) {\n          context.report(node, error.message)\n        },\n      }\n    }\n    let imported = []\n    let level = 0\n\n    function incrementLevel() {\n      level++\n    }\n    function decrementLevel() {\n      level--\n    }\n\n    return {\n      ImportDeclaration: function handleImports(node) {\n        if (node.specifiers.length) { // Ignoring unassigned imports\n          const name = node.source.value\n          registerNode(\n            context,\n            {\n              node,\n              value: name,\n              displayName: name,\n              type: 'import',\n            },\n            ranks,\n            imported,\n            pathGroupsExcludedImportTypes\n          )\n        }\n      },\n      TSImportEqualsDeclaration: function handleImports(node) {\n        let displayName\n        let value\n        let type\n        // skip \"export import\"s\n        if (node.isExport) {\n          return\n        }\n        if (node.moduleReference.type === 'TSExternalModuleReference') {\n          value = node.moduleReference.expression.value\n          displayName = value\n          type = 'import'\n        } else {\n          value = ''\n          displayName = context.getSourceCode().getText(node.moduleReference)\n          type = 'import:object'\n        }\n        registerNode(\n          context,\n          {\n            node,\n            value,\n            displayName,\n            type,\n          },\n          ranks,\n          imported,\n          pathGroupsExcludedImportTypes\n        )\n      },\n      CallExpression: function handleRequires(node) {\n        if (level !== 0 || !isStaticRequire(node) || !isInVariableDeclarator(node.parent)) {\n          return\n        }\n        const name = node.arguments[0].value\n        registerNode(\n          context,\n          {\n            node,\n            value: name,\n            displayName: name,\n            type: 'require',\n          },\n          ranks,\n          imported,\n          pathGroupsExcludedImportTypes\n        )\n      },\n      'Program:exit': function reportAndReset() {\n        if (newlinesBetweenImports !== 'ignore') {\n          makeNewlinesBetweenReport(context, imported, newlinesBetweenImports)\n        }\n\n        if (alphabetize.order !== 'ignore') {\n          mutateRanksToAlphabetize(imported, alphabetize)\n        }\n\n        makeOutOfOrderReport(context, imported)\n\n        imported = []\n      },\n      FunctionDeclaration: incrementLevel,\n      FunctionExpression: incrementLevel,\n      ArrowFunctionExpression: incrementLevel,\n      BlockStatement: incrementLevel,\n      ObjectExpression: incrementLevel,\n      'FunctionDeclaration:exit': decrementLevel,\n      'FunctionExpression:exit': decrementLevel,\n      'ArrowFunctionExpression:exit': decrementLevel,\n      'BlockStatement:exit': decrementLevel,\n      'ObjectExpression:exit': decrementLevel,\n    }\n  },\n}\n"]}
|