|
| 1 | +const noUnusedVarRule = [ |
| 2 | + 'error', |
| 3 | + { |
| 4 | + vars: 'all', |
| 5 | + varsIgnorePattern: '^_', |
| 6 | + args: 'after-used', |
| 7 | + argsIgnorePattern: '^_', |
| 8 | + ignoreRestSiblings: true, |
| 9 | + }, |
| 10 | +] |
| 11 | + |
| 12 | +module.exports = { |
| 13 | + 'env': { |
| 14 | + 'node': true, |
| 15 | + 'es2024': true, |
| 16 | + 'jest/globals': true, |
| 17 | + }, |
| 18 | + 'extends': ['plugin:github/recommended', 'prettier', 'plugin:prettier/recommended'], |
| 19 | + 'parser': '@typescript-eslint/parser', |
| 20 | + 'parserOptions': { |
| 21 | + 'ecmaVersion': 'latest', |
| 22 | + 'sourceType': 'module', |
| 23 | + 'project': ['tsconfig(.*)?.json'], |
| 24 | + }, |
| 25 | + 'plugins': ['jest', '@typescript-eslint', 'eslint-plugin-prettier', 'prettier'], |
| 26 | + 'rules': { |
| 27 | + '@typescript-eslint/array-type': 'error', |
| 28 | + '@typescript-eslint/await-thenable': 'error', |
| 29 | + '@typescript-eslint/ban-ts-comment': 'error', |
| 30 | + '@typescript-eslint/consistent-type-assertions': 'error', |
| 31 | + '@typescript-eslint/explicit-function-return-type': [ |
| 32 | + 'error', |
| 33 | + { 'allowExpressions': true }, |
| 34 | + ], |
| 35 | + '@typescript-eslint/explicit-member-accessibility': [ |
| 36 | + 'error', |
| 37 | + { 'accessibility': 'no-public' }, |
| 38 | + ], |
| 39 | + '@typescript-eslint/func-call-spacing': ['error', 'never'], |
| 40 | + '@typescript-eslint/no-array-constructor': 'error', |
| 41 | + '@typescript-eslint/no-empty-interface': 'error', |
| 42 | + '@typescript-eslint/no-explicit-any': 'error', |
| 43 | + '@typescript-eslint/no-extraneous-class': 'error', |
| 44 | + '@typescript-eslint/no-for-in-array': 'error', |
| 45 | + '@typescript-eslint/no-inferrable-types': 'error', |
| 46 | + '@typescript-eslint/no-misused-new': 'error', |
| 47 | + '@typescript-eslint/no-namespace': 'error', |
| 48 | + '@typescript-eslint/no-non-null-assertion': 'warn', |
| 49 | + '@typescript-eslint/no-require-imports': 'warn', |
| 50 | + '@typescript-eslint/no-unnecessary-qualifier': 'warn', |
| 51 | + '@typescript-eslint/no-unnecessary-type-assertion': 'error', |
| 52 | + '@typescript-eslint/no-unused-vars': noUnusedVarRule, |
| 53 | + '@typescript-eslint/no-useless-constructor': 'error', |
| 54 | + '@typescript-eslint/no-var-requires': 'error', |
| 55 | + '@typescript-eslint/prefer-for-of': 'warn', |
| 56 | + '@typescript-eslint/prefer-function-type': 'warn', |
| 57 | + '@typescript-eslint/prefer-includes': 'error', |
| 58 | + '@typescript-eslint/prefer-string-starts-ends-with': 'error', |
| 59 | + '@typescript-eslint/promise-function-async': 'error', |
| 60 | + '@typescript-eslint/require-array-sort-compare': 'error', |
| 61 | + '@typescript-eslint/restrict-plus-operands': 'error', |
| 62 | + '@typescript-eslint/semi': ['error', 'never'], |
| 63 | + '@typescript-eslint/type-annotation-spacing': 'error', |
| 64 | + '@typescript-eslint/unbound-method': 'error', |
| 65 | + 'camelcase': 'off', |
| 66 | + 'eslint-comments/no-use': 'off', |
| 67 | + 'filenames/match-regex': 'off', |
| 68 | + 'i18n-text/no-en': 'off', |
| 69 | + 'import/no-namespace': 'off', |
| 70 | + 'prettier/prettier': ['error', { 'usePrettierrc': true }], |
| 71 | + 'semi': 'off', |
| 72 | + }, |
| 73 | + overrides: [ |
| 74 | + { |
| 75 | + files: ['*.cjs'], |
| 76 | + rules: { |
| 77 | + 'import/no-commonjs': 'off', |
| 78 | + }, |
| 79 | + }, |
| 80 | + ], |
| 81 | +} |
0 commit comments