order.js 80 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692
  1. '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");}};}();
  2. var _minimatch = require('minimatch');var _minimatch2 = _interopRequireDefault(_minimatch);
  3. var _importType = require('../core/importType');var _importType2 = _interopRequireDefault(_importType);
  4. var _staticRequire = require('../core/staticRequire');var _staticRequire2 = _interopRequireDefault(_staticRequire);
  5. var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { 'default': obj };}
  6. var defaultGroups = ['builtin', 'external', 'parent', 'sibling', 'index'];
  7. // REPORTING AND FIXING
  8. function reverse(array) {
  9. return array.map(function (v) {
  10. return Object.assign({}, v, { rank: -v.rank });
  11. }).reverse();
  12. }
  13. function getTokensOrCommentsAfter(sourceCode, node, count) {
  14. var currentNodeOrToken = node;
  15. var result = [];
  16. for (var i = 0; i < count; i++) {
  17. currentNodeOrToken = sourceCode.getTokenOrCommentAfter(currentNodeOrToken);
  18. if (currentNodeOrToken == null) {
  19. break;
  20. }
  21. result.push(currentNodeOrToken);
  22. }
  23. return result;
  24. }
  25. function getTokensOrCommentsBefore(sourceCode, node, count) {
  26. var currentNodeOrToken = node;
  27. var result = [];
  28. for (var i = 0; i < count; i++) {
  29. currentNodeOrToken = sourceCode.getTokenOrCommentBefore(currentNodeOrToken);
  30. if (currentNodeOrToken == null) {
  31. break;
  32. }
  33. result.push(currentNodeOrToken);
  34. }
  35. return result.reverse();
  36. }
  37. function takeTokensAfterWhile(sourceCode, node, condition) {
  38. var tokens = getTokensOrCommentsAfter(sourceCode, node, 100);
  39. var result = [];
  40. for (var i = 0; i < tokens.length; i++) {
  41. if (condition(tokens[i])) {
  42. result.push(tokens[i]);
  43. } else {
  44. break;
  45. }
  46. }
  47. return result;
  48. }
  49. function takeTokensBeforeWhile(sourceCode, node, condition) {
  50. var tokens = getTokensOrCommentsBefore(sourceCode, node, 100);
  51. var result = [];
  52. for (var i = tokens.length - 1; i >= 0; i--) {
  53. if (condition(tokens[i])) {
  54. result.push(tokens[i]);
  55. } else {
  56. break;
  57. }
  58. }
  59. return result.reverse();
  60. }
  61. function findOutOfOrder(imported) {
  62. if (imported.length === 0) {
  63. return [];
  64. }
  65. var maxSeenRankNode = imported[0];
  66. return imported.filter(function (importedModule) {
  67. var res = importedModule.rank < maxSeenRankNode.rank;
  68. if (maxSeenRankNode.rank < importedModule.rank) {
  69. maxSeenRankNode = importedModule;
  70. }
  71. return res;
  72. });
  73. }
  74. function findRootNode(node) {
  75. var parent = node;
  76. while (parent.parent != null && parent.parent.body == null) {
  77. parent = parent.parent;
  78. }
  79. return parent;
  80. }
  81. function findEndOfLineWithComments(sourceCode, node) {
  82. var tokensToEndOfLine = takeTokensAfterWhile(sourceCode, node, commentOnSameLineAs(node));
  83. var endOfTokens = tokensToEndOfLine.length > 0 ?
  84. tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1] :
  85. node.range[1];
  86. var result = endOfTokens;
  87. for (var i = endOfTokens; i < sourceCode.text.length; i++) {
  88. if (sourceCode.text[i] === '\n') {
  89. result = i + 1;
  90. break;
  91. }
  92. if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\t' && sourceCode.text[i] !== '\r') {
  93. break;
  94. }
  95. result = i + 1;
  96. }
  97. return result;
  98. }
  99. function commentOnSameLineAs(node) {
  100. return function (token) {return (token.type === 'Block' || token.type === 'Line') &&
  101. token.loc.start.line === token.loc.end.line &&
  102. token.loc.end.line === node.loc.end.line;};
  103. }
  104. function findStartOfLineWithComments(sourceCode, node) {
  105. var tokensToEndOfLine = takeTokensBeforeWhile(sourceCode, node, commentOnSameLineAs(node));
  106. var startOfTokens = tokensToEndOfLine.length > 0 ? tokensToEndOfLine[0].range[0] : node.range[0];
  107. var result = startOfTokens;
  108. for (var i = startOfTokens - 1; i > 0; i--) {
  109. if (sourceCode.text[i] !== ' ' && sourceCode.text[i] !== '\t') {
  110. break;
  111. }
  112. result = i;
  113. }
  114. return result;
  115. }
  116. function isPlainRequireModule(node) {
  117. if (node.type !== 'VariableDeclaration') {
  118. return false;
  119. }
  120. if (node.declarations.length !== 1) {
  121. return false;
  122. }
  123. var decl = node.declarations[0];
  124. var result = decl.id && (
  125. decl.id.type === 'Identifier' || decl.id.type === 'ObjectPattern') &&
  126. decl.init != null &&
  127. decl.init.type === 'CallExpression' &&
  128. decl.init.callee != null &&
  129. decl.init.callee.name === 'require' &&
  130. decl.init.arguments != null &&
  131. decl.init.arguments.length === 1 &&
  132. decl.init.arguments[0].type === 'Literal';
  133. return result;
  134. }
  135. function isPlainImportModule(node) {
  136. return node.type === 'ImportDeclaration' && node.specifiers != null && node.specifiers.length > 0;
  137. }
  138. function isPlainImportEquals(node) {
  139. return node.type === 'TSImportEqualsDeclaration' && node.moduleReference.expression;
  140. }
  141. function canCrossNodeWhileReorder(node) {
  142. return isPlainRequireModule(node) || isPlainImportModule(node) || isPlainImportEquals(node);
  143. }
  144. function canReorderItems(firstNode, secondNode) {
  145. var parent = firstNode.parent;var _sort =
  146. [
  147. parent.body.indexOf(firstNode),
  148. parent.body.indexOf(secondNode)].
  149. sort(),_sort2 = _slicedToArray(_sort, 2),firstIndex = _sort2[0],secondIndex = _sort2[1];
  150. var nodesBetween = parent.body.slice(firstIndex, secondIndex + 1);var _iteratorNormalCompletion = true;var _didIteratorError = false;var _iteratorError = undefined;try {
  151. for (var _iterator = nodesBetween[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {var nodeBetween = _step.value;
  152. if (!canCrossNodeWhileReorder(nodeBetween)) {
  153. return false;
  154. }
  155. }} catch (err) {_didIteratorError = true;_iteratorError = err;} finally {try {if (!_iteratorNormalCompletion && _iterator['return']) {_iterator['return']();}} finally {if (_didIteratorError) {throw _iteratorError;}}}
  156. return true;
  157. }
  158. function fixOutOfOrder(context, firstNode, secondNode, order) {
  159. var sourceCode = context.getSourceCode();
  160. var firstRoot = findRootNode(firstNode.node);
  161. var firstRootStart = findStartOfLineWithComments(sourceCode, firstRoot);
  162. var firstRootEnd = findEndOfLineWithComments(sourceCode, firstRoot);
  163. var secondRoot = findRootNode(secondNode.node);
  164. var secondRootStart = findStartOfLineWithComments(sourceCode, secondRoot);
  165. var secondRootEnd = findEndOfLineWithComments(sourceCode, secondRoot);
  166. var canFix = canReorderItems(firstRoot, secondRoot);
  167. var newCode = sourceCode.text.substring(secondRootStart, secondRootEnd);
  168. if (newCode[newCode.length - 1] !== '\n') {
  169. newCode = newCode + '\n';
  170. }
  171. var message = '`' + String(secondNode.displayName) + '` import should occur ' + String(order) + ' import of `' + String(firstNode.displayName) + '`';
  172. if (order === 'before') {
  173. context.report({
  174. node: secondNode.node,
  175. message: message,
  176. fix: canFix && function (fixer) {return (
  177. fixer.replaceTextRange(
  178. [firstRootStart, secondRootEnd],
  179. newCode + sourceCode.text.substring(firstRootStart, secondRootStart)));} });
  180. } else if (order === 'after') {
  181. context.report({
  182. node: secondNode.node,
  183. message: message,
  184. fix: canFix && function (fixer) {return (
  185. fixer.replaceTextRange(
  186. [secondRootStart, firstRootEnd],
  187. sourceCode.text.substring(secondRootEnd, firstRootEnd) + newCode));} });
  188. }
  189. }
  190. function reportOutOfOrder(context, imported, outOfOrder, order) {
  191. outOfOrder.forEach(function (imp) {
  192. var found = imported.find(function () {function hasHigherRank(importedItem) {
  193. return importedItem.rank > imp.rank;
  194. }return hasHigherRank;}());
  195. fixOutOfOrder(context, found, imp, order);
  196. });
  197. }
  198. function makeOutOfOrderReport(context, imported) {
  199. var outOfOrder = findOutOfOrder(imported);
  200. if (!outOfOrder.length) {
  201. return;
  202. }
  203. // There are things to report. Try to minimize the number of reported errors.
  204. var reversedImported = reverse(imported);
  205. var reversedOrder = findOutOfOrder(reversedImported);
  206. if (reversedOrder.length < outOfOrder.length) {
  207. reportOutOfOrder(context, reversedImported, reversedOrder, 'after');
  208. return;
  209. }
  210. reportOutOfOrder(context, imported, outOfOrder, 'before');
  211. }
  212. function getSorter(ascending) {
  213. var multiplier = ascending ? 1 : -1;
  214. return function () {function importsSorter(importA, importB) {
  215. var result = void 0;
  216. if (importA < importB) {
  217. result = -1;
  218. } else if (importA > importB) {
  219. result = 1;
  220. } else {
  221. result = 0;
  222. }
  223. return result * multiplier;
  224. }return importsSorter;}();
  225. }
  226. function mutateRanksToAlphabetize(imported, alphabetizeOptions) {
  227. var groupedByRanks = imported.reduce(function (acc, importedItem) {
  228. if (!Array.isArray(acc[importedItem.rank])) {
  229. acc[importedItem.rank] = [];
  230. }
  231. acc[importedItem.rank].push(importedItem);
  232. return acc;
  233. }, {});
  234. var groupRanks = Object.keys(groupedByRanks);
  235. var sorterFn = getSorter(alphabetizeOptions.order === 'asc');
  236. var comparator = alphabetizeOptions.caseInsensitive ?
  237. function (a, b) {return sorterFn(String(a.value).toLowerCase(), String(b.value).toLowerCase());} :
  238. function (a, b) {return sorterFn(a.value, b.value);};
  239. // sort imports locally within their group
  240. groupRanks.forEach(function (groupRank) {
  241. groupedByRanks[groupRank].sort(comparator);
  242. });
  243. // assign globally unique rank to each import
  244. var newRank = 0;
  245. var alphabetizedRanks = groupRanks.sort().reduce(function (acc, groupRank) {
  246. groupedByRanks[groupRank].forEach(function (importedItem) {
  247. acc[String(importedItem.value) + '|' + String(importedItem.node.importKind)] = parseInt(groupRank, 10) + newRank;
  248. newRank += 1;
  249. });
  250. return acc;
  251. }, {});
  252. // mutate the original group-rank with alphabetized-rank
  253. imported.forEach(function (importedItem) {
  254. importedItem.rank = alphabetizedRanks[String(importedItem.value) + '|' + String(importedItem.node.importKind)];
  255. });
  256. }
  257. // DETECTING
  258. function computePathRank(ranks, pathGroups, path, maxPosition) {
  259. for (var i = 0, l = pathGroups.length; i < l; i++) {var _pathGroups$i =
  260. pathGroups[i],pattern = _pathGroups$i.pattern,patternOptions = _pathGroups$i.patternOptions,group = _pathGroups$i.group,_pathGroups$i$positio = _pathGroups$i.position,position = _pathGroups$i$positio === undefined ? 1 : _pathGroups$i$positio;
  261. if ((0, _minimatch2['default'])(path, pattern, patternOptions || { nocomment: true })) {
  262. return ranks[group] + position / maxPosition;
  263. }
  264. }
  265. }
  266. function computeRank(context, ranks, importEntry, excludedImportTypes) {
  267. var impType = void 0;
  268. var rank = void 0;
  269. if (importEntry.type === 'import:object') {
  270. impType = 'object';
  271. } else if (importEntry.node.importKind === 'type' && ranks.omittedTypes.indexOf('type') === -1) {
  272. impType = 'type';
  273. } else {
  274. impType = (0, _importType2['default'])(importEntry.value, context);
  275. }
  276. if (!excludedImportTypes.has(impType)) {
  277. rank = computePathRank(ranks.groups, ranks.pathGroups, importEntry.value, ranks.maxPosition);
  278. }
  279. if (typeof rank === 'undefined') {
  280. rank = ranks.groups[impType];
  281. }
  282. if (importEntry.type !== 'import' && !importEntry.type.startsWith('import:')) {
  283. rank += 100;
  284. }
  285. return rank;
  286. }
  287. function registerNode(context, importEntry, ranks, imported, excludedImportTypes) {
  288. var rank = computeRank(context, ranks, importEntry, excludedImportTypes);
  289. if (rank !== -1) {
  290. imported.push(Object.assign({}, importEntry, { rank: rank }));
  291. }
  292. }
  293. function isModuleLevelRequire(node) {
  294. var n = node;
  295. // Handle cases like `const baz = require('foo').bar.baz`
  296. // and `const foo = require('foo')()`
  297. while (
  298. n.parent.type === 'MemberExpression' && n.parent.object === n ||
  299. n.parent.type === 'CallExpression' && n.parent.callee === n)
  300. {
  301. n = n.parent;
  302. }
  303. return (
  304. n.parent.type === 'VariableDeclarator' &&
  305. n.parent.parent.type === 'VariableDeclaration' &&
  306. n.parent.parent.parent.type === 'Program');
  307. }
  308. var types = ['builtin', 'external', 'internal', 'unknown', 'parent', 'sibling', 'index', 'object', 'type'];
  309. // Creates an object with type-rank pairs.
  310. // Example: { index: 0, sibling: 1, parent: 1, external: 1, builtin: 2, internal: 2 }
  311. // Will throw an error if it contains a type that does not exist, or has a duplicate
  312. function convertGroupsToRanks(groups) {
  313. var rankObject = groups.reduce(function (res, group, index) {
  314. if (typeof group === 'string') {
  315. group = [group];
  316. }
  317. group.forEach(function (groupItem) {
  318. if (types.indexOf(groupItem) === -1) {
  319. throw new Error('Incorrect configuration of the rule: Unknown type `' +
  320. JSON.stringify(groupItem) + '`');
  321. }
  322. if (res[groupItem] !== undefined) {
  323. throw new Error('Incorrect configuration of the rule: `' + groupItem + '` is duplicated');
  324. }
  325. res[groupItem] = index;
  326. });
  327. return res;
  328. }, {});
  329. var omittedTypes = types.filter(function (type) {
  330. return rankObject[type] === undefined;
  331. });
  332. var ranks = omittedTypes.reduce(function (res, type) {
  333. res[type] = groups.length;
  334. return res;
  335. }, rankObject);
  336. return { groups: ranks, omittedTypes: omittedTypes };
  337. }
  338. function convertPathGroupsForRanks(pathGroups) {
  339. var after = {};
  340. var before = {};
  341. var transformed = pathGroups.map(function (pathGroup, index) {var
  342. group = pathGroup.group,positionString = pathGroup.position;
  343. var position = 0;
  344. if (positionString === 'after') {
  345. if (!after[group]) {
  346. after[group] = 1;
  347. }
  348. position = after[group]++;
  349. } else if (positionString === 'before') {
  350. if (!before[group]) {
  351. before[group] = [];
  352. }
  353. before[group].push(index);
  354. }
  355. return Object.assign({}, pathGroup, { position: position });
  356. });
  357. var maxPosition = 1;
  358. Object.keys(before).forEach(function (group) {
  359. var groupLength = before[group].length;
  360. before[group].forEach(function (groupIndex, index) {
  361. transformed[groupIndex].position = -1 * (groupLength - index);
  362. });
  363. maxPosition = Math.max(maxPosition, groupLength);
  364. });
  365. Object.keys(after).forEach(function (key) {
  366. var groupNextPosition = after[key];
  367. maxPosition = Math.max(maxPosition, groupNextPosition - 1);
  368. });
  369. return {
  370. pathGroups: transformed,
  371. maxPosition: maxPosition > 10 ? Math.pow(10, Math.ceil(Math.log10(maxPosition))) : 10 };
  372. }
  373. function fixNewLineAfterImport(context, previousImport) {
  374. var prevRoot = findRootNode(previousImport.node);
  375. var tokensToEndOfLine = takeTokensAfterWhile(
  376. context.getSourceCode(), prevRoot, commentOnSameLineAs(prevRoot));
  377. var endOfLine = prevRoot.range[1];
  378. if (tokensToEndOfLine.length > 0) {
  379. endOfLine = tokensToEndOfLine[tokensToEndOfLine.length - 1].range[1];
  380. }
  381. return function (fixer) {return fixer.insertTextAfterRange([prevRoot.range[0], endOfLine], '\n');};
  382. }
  383. function removeNewLineAfterImport(context, currentImport, previousImport) {
  384. var sourceCode = context.getSourceCode();
  385. var prevRoot = findRootNode(previousImport.node);
  386. var currRoot = findRootNode(currentImport.node);
  387. var rangeToRemove = [
  388. findEndOfLineWithComments(sourceCode, prevRoot),
  389. findStartOfLineWithComments(sourceCode, currRoot)];
  390. if (/^\s*$/.test(sourceCode.text.substring(rangeToRemove[0], rangeToRemove[1]))) {
  391. return function (fixer) {return fixer.removeRange(rangeToRemove);};
  392. }
  393. return undefined;
  394. }
  395. function makeNewlinesBetweenReport(context, imported, newlinesBetweenImports) {
  396. var getNumberOfEmptyLinesBetween = function getNumberOfEmptyLinesBetween(currentImport, previousImport) {
  397. var linesBetweenImports = context.getSourceCode().lines.slice(
  398. previousImport.node.loc.end.line,
  399. currentImport.node.loc.start.line - 1);
  400. return linesBetweenImports.filter(function (line) {return !line.trim().length;}).length;
  401. };
  402. var previousImport = imported[0];
  403. imported.slice(1).forEach(function (currentImport) {
  404. var emptyLinesBetween = getNumberOfEmptyLinesBetween(currentImport, previousImport);
  405. if (newlinesBetweenImports === 'always' ||
  406. newlinesBetweenImports === 'always-and-inside-groups') {
  407. if (currentImport.rank !== previousImport.rank && emptyLinesBetween === 0) {
  408. context.report({
  409. node: previousImport.node,
  410. message: 'There should be at least one empty line between import groups',
  411. fix: fixNewLineAfterImport(context, previousImport) });
  412. } else if (currentImport.rank === previousImport.rank &&
  413. emptyLinesBetween > 0 &&
  414. newlinesBetweenImports !== 'always-and-inside-groups') {
  415. context.report({
  416. node: previousImport.node,
  417. message: 'There should be no empty line within import group',
  418. fix: removeNewLineAfterImport(context, currentImport, previousImport) });
  419. }
  420. } else if (emptyLinesBetween > 0) {
  421. context.report({
  422. node: previousImport.node,
  423. message: 'There should be no empty line between import groups',
  424. fix: removeNewLineAfterImport(context, currentImport, previousImport) });
  425. }
  426. previousImport = currentImport;
  427. });
  428. }
  429. function getAlphabetizeConfig(options) {
  430. var alphabetize = options.alphabetize || {};
  431. var order = alphabetize.order || 'ignore';
  432. var caseInsensitive = alphabetize.caseInsensitive || false;
  433. return { order: order, caseInsensitive: caseInsensitive };
  434. }
  435. module.exports = {
  436. meta: {
  437. type: 'suggestion',
  438. docs: {
  439. url: (0, _docsUrl2['default'])('order') },
  440. fixable: 'code',
  441. schema: [
  442. {
  443. type: 'object',
  444. properties: {
  445. groups: {
  446. type: 'array' },
  447. pathGroupsExcludedImportTypes: {
  448. type: 'array' },
  449. pathGroups: {
  450. type: 'array',
  451. items: {
  452. type: 'object',
  453. properties: {
  454. pattern: {
  455. type: 'string' },
  456. patternOptions: {
  457. type: 'object' },
  458. group: {
  459. type: 'string',
  460. 'enum': types },
  461. position: {
  462. type: 'string',
  463. 'enum': ['after', 'before'] } },
  464. required: ['pattern', 'group'] } },
  465. 'newlines-between': {
  466. 'enum': [
  467. 'ignore',
  468. 'always',
  469. 'always-and-inside-groups',
  470. 'never'] },
  471. alphabetize: {
  472. type: 'object',
  473. properties: {
  474. caseInsensitive: {
  475. type: 'boolean',
  476. 'default': false },
  477. order: {
  478. 'enum': ['ignore', 'asc', 'desc'],
  479. 'default': 'ignore' } },
  480. additionalProperties: false },
  481. warnOnUnassignedImports: {
  482. type: 'boolean',
  483. 'default': false } },
  484. additionalProperties: false }] },
  485. create: function () {function importOrderRule(context) {
  486. var options = context.options[0] || {};
  487. var newlinesBetweenImports = options['newlines-between'] || 'ignore';
  488. var pathGroupsExcludedImportTypes = new Set(options['pathGroupsExcludedImportTypes'] || ['builtin', 'external', 'object']);
  489. var alphabetize = getAlphabetizeConfig(options);
  490. var ranks = void 0;
  491. try {var _convertPathGroupsFor =
  492. convertPathGroupsForRanks(options.pathGroups || []),pathGroups = _convertPathGroupsFor.pathGroups,maxPosition = _convertPathGroupsFor.maxPosition;var _convertGroupsToRanks =
  493. convertGroupsToRanks(options.groups || defaultGroups),groups = _convertGroupsToRanks.groups,omittedTypes = _convertGroupsToRanks.omittedTypes;
  494. ranks = {
  495. groups: groups,
  496. omittedTypes: omittedTypes,
  497. pathGroups: pathGroups,
  498. maxPosition: maxPosition };
  499. } catch (error) {
  500. // Malformed configuration
  501. return {
  502. Program: function () {function Program(node) {
  503. context.report(node, error.message);
  504. }return Program;}() };
  505. }
  506. var imported = [];
  507. return {
  508. ImportDeclaration: function () {function handleImports(node) {
  509. // Ignoring unassigned imports unless warnOnUnassignedImports is set
  510. if (node.specifiers.length || options.warnOnUnassignedImports) {
  511. var name = node.source.value;
  512. registerNode(
  513. context,
  514. {
  515. node: node,
  516. value: name,
  517. displayName: name,
  518. type: 'import' },
  519. ranks,
  520. imported,
  521. pathGroupsExcludedImportTypes);
  522. }
  523. }return handleImports;}(),
  524. TSImportEqualsDeclaration: function () {function handleImports(node) {
  525. var displayName = void 0;
  526. var value = void 0;
  527. var type = void 0;
  528. // skip "export import"s
  529. if (node.isExport) {
  530. return;
  531. }
  532. if (node.moduleReference.type === 'TSExternalModuleReference') {
  533. value = node.moduleReference.expression.value;
  534. displayName = value;
  535. type = 'import';
  536. } else {
  537. value = '';
  538. displayName = context.getSourceCode().getText(node.moduleReference);
  539. type = 'import:object';
  540. }
  541. registerNode(
  542. context,
  543. {
  544. node: node,
  545. value: value,
  546. displayName: displayName,
  547. type: type },
  548. ranks,
  549. imported,
  550. pathGroupsExcludedImportTypes);
  551. }return handleImports;}(),
  552. CallExpression: function () {function handleRequires(node) {
  553. if (!(0, _staticRequire2['default'])(node) || !isModuleLevelRequire(node)) {
  554. return;
  555. }
  556. var name = node.arguments[0].value;
  557. registerNode(
  558. context,
  559. {
  560. node: node,
  561. value: name,
  562. displayName: name,
  563. type: 'require' },
  564. ranks,
  565. imported,
  566. pathGroupsExcludedImportTypes);
  567. }return handleRequires;}(),
  568. 'Program:exit': function () {function reportAndReset() {
  569. if (newlinesBetweenImports !== 'ignore') {
  570. makeNewlinesBetweenReport(context, imported, newlinesBetweenImports);
  571. }
  572. if (alphabetize.order !== 'ignore') {
  573. mutateRanksToAlphabetize(imported, alphabetize);
  574. }
  575. makeOutOfOrderReport(context, imported);
  576. imported = [];
  577. }return reportAndReset;}() };
  578. }return importOrderRule;}() };
  579. //# 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","groupRanks","keys","sorterFn","comparator","caseInsensitive","a","b","String","value","toLowerCase","groupRank","newRank","alphabetizedRanks","importKind","parseInt","computePathRank","ranks","pathGroups","path","maxPosition","l","pattern","patternOptions","group","position","nocomment","computeRank","importEntry","excludedImportTypes","impType","omittedTypes","has","groups","startsWith","registerNode","isModuleLevelRequire","n","object","types","convertGroupsToRanks","rankObject","index","groupItem","Error","JSON","stringify","undefined","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","required","additionalProperties","warnOnUnassignedImports","create","importOrderRule","Set","error","Program","ImportDeclaration","handleImports","source","TSImportEqualsDeclaration","isExport","getText","CallExpression","handleRequires","reportAndReset"],"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    } 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    } 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  const 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  const 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 (const 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);\n    return acc;\n  }, {});\n\n  const groupRanks = Object.keys(groupedByRanks);\n\n  const sorterFn = getSorter(alphabetizeOptions.order === 'asc');\n  const comparator = alphabetizeOptions.caseInsensitive\n    ? (a, b) => sorterFn(String(a.value).toLowerCase(), String(b.value).toLowerCase())\n    : (a, b) => sorterFn(a.value, b.value);\n\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(importedItem) {\n      acc[`${importedItem.value}|${importedItem.node.importKind}`] = 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}|${importedItem.node.importKind}`];\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 if (importEntry.node.importKind === 'type' && ranks.omittedTypes.indexOf('type') === -1) {\n    impType = 'type';\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 isModuleLevelRequire(node) {\n  let n = node;\n  // Handle cases like `const baz = require('foo').bar.baz`\n  // and `const foo = require('foo')()`\n  while (\n    (n.parent.type === 'MemberExpression' && n.parent.object === n) ||\n    (n.parent.type === 'CallExpression' && n.parent.callee === n)\n  ) {\n    n = n.parent;\n  }\n  return (\n    n.parent.type === 'VariableDeclarator' &&\n    n.parent.parent.type === 'VariableDeclaration' &&\n    n.parent.parent.parent.type === 'Program'\n  );\n}\n\nconst types = ['builtin', 'external', 'internal', 'unknown', 'parent', 'sibling', 'index', 'object', 'type'];\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  const ranks = omittedTypes.reduce(function(res, type) {\n    res[type] = groups.length;\n    return res;\n  }, rankObject);\n\n  return { groups: ranks, omittedTypes };\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          warnOnUnassignedImports: {\n            type: 'boolean',\n            default: 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      const { groups, omittedTypes } = convertGroupsToRanks(options.groups || defaultGroups);\n      ranks = {\n        groups,\n        omittedTypes,\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\n    return {\n      ImportDeclaration: function handleImports(node) {\n        // Ignoring unassigned imports unless warnOnUnassignedImports is set\n        if (node.specifiers.length || options.warnOnUnassignedImports) {\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 (!isStaticRequire(node) || !isModuleLevelRequire(node)) {\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    };\n  },\n};\n"]}