UNPKG

eslint-plugin-perfectionist

Version:

ESLint plugin for sorting various data such as objects, imports, types, enums, JSX props, etc.

157 lines (156 loc) 5.04 kB
import { defaultComparatorByOptionsComputer } from '../../utils/compare/default-comparator-by-options-computer.js' import { buildOptionsByGroupIndexComputer } from '../../utils/build-options-by-group-index-computer.js' import { validateCustomSortConfiguration } from '../../utils/validate-custom-sort-configuration.js' import { validateGroupsConfiguration } from '../../utils/validate-groups-configuration.js' import { getEslintDisabledLines } from '../../utils/get-eslint-disabled-lines.js' import { doesCustomGroupMatch } from '../../utils/does-custom-group-match.js' import { isNodeEslintDisabled } from '../../utils/is-node-eslint-disabled.js' import { sortNodesByGroups } from '../../utils/sort-nodes-by-groups.js' import { reportAllErrors } from '../../utils/report-all-errors.js' import { shouldPartition } from '../../utils/should-partition.js' import { computeGroup } from '../../utils/compute-group.js' import { rangeToDiff } from '../../utils/range-to-diff.js' import { getSettings } from '../../utils/get-settings.js' import { isSortable } from '../../utils/is-sortable.js' import { complete } from '../../utils/complete.js' import { EXTRA_SPACING_ERROR_ID, GROUP_ORDER_ERROR_ID, MISSED_SPACING_ERROR_ID, ORDER_ERROR_ID, } from './types.js' import { computeNodeName } from './compute-node-name.js' import { computeMatchedContextOptions } from './compute-matched-context-options.js' import { AST_NODE_TYPES } from '@typescript-eslint/utils' var defaultOptions = { fallbackSort: { type: 'unsorted' }, newlinesInside: 'newlinesBetween', specialCharacters: 'keep', partitionByComment: false, partitionByNewLine: false, newlinesBetween: 'ignore', useConfigurationIf: {}, type: 'alphabetical', ignoreCase: true, customGroups: [], locales: 'en-US', alphabet: '', order: 'asc', groups: [], } function sortPotentialMap({ matchedAstSelectors, context, node }) { if ( node.callee.type !== AST_NODE_TYPES.Identifier || node.callee.name !== 'Map' || node.arguments.length === 0 || node.arguments[0]?.type !== AST_NODE_TYPES.ArrayExpression ) { return } let [{ elements }] = node.arguments if (!isSortable(elements)) { return } let { sourceCode, id } = context let settings = getSettings(context.settings) let options = complete( computeMatchedContextOptions({ matchedAstSelectors, elements, context, }), settings, defaultOptions, ) validateCustomSortConfiguration(options) validateGroupsConfiguration({ selectors: [], modifiers: [], options, }) let eslintDisabledLines = getEslintDisabledLines({ ruleName: id, sourceCode, }) let optionsByGroupIndexComputer = buildOptionsByGroupIndexComputer(options) let parts = elements.reduce( (accumulator, element) => { if (element === null || element.type === AST_NODE_TYPES.SpreadElement) { accumulator.push([]) } else { accumulator.at(-1).push(element) } return accumulator }, [[]], ) for (let part of parts) { let formattedMembers = [[]] for (let element of part) { let name = computeNodeName({ node: element, sourceCode, }) let lastSortingNode = formattedMembers.at(-1)?.at(-1) let group = computeGroup({ customGroupMatcher: customGroup => doesCustomGroupMatch({ elementName: name, selectors: [], modifiers: [], customGroup, }), predefinedGroups: [], options, }) let sortingNode = { isEslintDisabled: isNodeEslintDisabled(element, eslintDisabledLines), size: rangeToDiff(element, sourceCode), node: element, group, name, } if ( shouldPartition({ lastSortingNode, sortingNode, sourceCode, options, }) ) { formattedMembers.push([]) } formattedMembers.at(-1).push({ ...sortingNode, partitionId: formattedMembers.length, }) } for (let nodes of formattedMembers) { function createSortNodesExcludingEslintDisabled(sortingNodes) { return function (ignoreEslintDisabledNodes) { return sortNodesByGroups({ comparatorByOptionsComputer: defaultComparatorByOptionsComputer, optionsByGroupIndexComputer, ignoreEslintDisabledNodes, groups: options.groups, nodes: sortingNodes, }) } } reportAllErrors({ availableMessageIds: { missedSpacingBetweenMembers: MISSED_SPACING_ERROR_ID, extraSpacingBetweenMembers: EXTRA_SPACING_ERROR_ID, unexpectedGroupOrder: GROUP_ORDER_ERROR_ID, unexpectedOrder: ORDER_ERROR_ID, }, sortNodesExcludingEslintDisabled: createSortNodesExcludingEslintDisabled(nodes), options, context, nodes, }) } } } export { defaultOptions, sortPotentialMap }