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
JavaScript
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 }