Files
payloadcms/packages/eslint-config-payload/eslint-config/index.js
2024-03-13 12:10:54 -04:00

149 lines
4.0 KiB
JavaScript

const sharedRules = {
'@typescript-eslint/ban-ts-comment': 'off',
'@typescript-eslint/consistent-type-imports': 'warn',
'@typescript-eslint/no-explicit-any': 'warn',
// Type-aware any rules:
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-return': 'off',
// This rule doesn't work well in .tsx files
'@typescript-eslint/no-misused-promises': 'off',
// Type-aware any rules end
// ts-expect should always be preferred over ts-ignore
'@typescript-eslint/prefer-ts-expect-error': 'warn',
// This rule makes no sense when overriding class methods. This is used a lot in richtext-lexical.
'class-methods-use-this': 'off',
// By default, it errors for unused variables. This is annoying, warnings are enough.
'@typescript-eslint/no-unused-vars': [
'warn',
{
vars: 'all',
args: 'after-used',
ignoreRestSiblings: false,
argsIgnorePattern: '^_',
varsIgnorePattern: '^_',
destructuredArrayIgnorePattern: '^_',
caughtErrorsIgnorePattern: '^ignore',
},
],
'@typescript-eslint/no-use-before-define': 'off',
'arrow-body-style': 0,
'import/prefer-default-export': 'off',
'no-restricted-exports': ['warn', { restrictDefaultExports: { direct: true } }],
'no-console': 'warn',
'no-sparse-arrays': 'off',
'no-underscore-dangle': 'off',
'no-use-before-define': 'off',
'object-shorthand': 'warn',
'react/no-unused-prop-types': 'off',
'react/prop-types': 'off',
'react/require-default-props': 'off',
'perfectionist/sort-objects': [
'error',
{
type: 'natural',
order: 'asc',
'partition-by-comment': true,
groups: ['top', 'unknown'],
'custom-groups': {
top: ['_id', 'id', 'name', 'slug', 'type'],
},
},
],
}
/** @type {import('eslint').Linter.Config} */
module.exports = {
env: {
es6: true,
browser: true,
node: true,
},
extends: [
'eslint:recommended',
'plugin:perfectionist/recommended-natural',
'plugin:regexp/recommended',
'prettier',
],
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 'latest',
sourceType: 'module',
},
plugins: [],
overrides: [
{
files: ['**/*.ts'],
plugins: ['@typescript-eslint'],
extends: [
'eslint:recommended',
'plugin:perfectionist/recommended-natural',
'plugin:@typescript-eslint/recommended-type-checked',
'plugin:regexp/recommended',
'prettier',
],
parser: '@typescript-eslint/parser',
rules: sharedRules,
},
{
files: ['**/*.tsx'],
plugins: ['@typescript-eslint'],
extends: [
'eslint:recommended',
'plugin:perfectionist/recommended-natural',
'plugin:@typescript-eslint/recommended-type-checked',
'plugin:regexp/recommended',
'plugin:react/recommended',
'plugin:react-hooks/recommended',
'./configs/react/index.js',
'prettier',
],
parser: '@typescript-eslint/parser',
rules: sharedRules,
},
{
files: ['**/*.spec.ts'],
plugins: ['@typescript-eslint'],
extends: [
'eslint:recommended',
'plugin:perfectionist/recommended-natural',
'plugin:@typescript-eslint/recommended-type-checked',
'plugin:regexp/recommended',
'./configs/jest/index.js',
'prettier',
],
parser: '@typescript-eslint/parser',
rules: {
...sharedRules,
'@typescript-eslint/unbound-method': 'off',
},
},
{
files: ['*.config.ts'],
rules: {
...sharedRules,
'no-restricted-exports': 'off',
},
},
{
files: ['config.ts'],
rules: {
...sharedRules,
'no-restricted-exports': 'off',
},
},
],
rules: sharedRules,
settings: {
'import/parsers': {
'@typescript-eslint/parser': ['.ts', '.tsx'],
},
},
}