-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path.eslintrc.cjs
More file actions
46 lines (44 loc) · 1.1 KB
/
.eslintrc.cjs
File metadata and controls
46 lines (44 loc) · 1.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
const typescriptEslintPlugin = require('@typescript-eslint/eslint-plugin')
// Disable typescript linting rules for certain kinds of files
const permissiveTypescriptRules = Object.keys(
typescriptEslintPlugin.rules
).reduce((table, rule) => {
table[`@typescript-eslint/${rule}`] = ['off']
return table
}, {})
/** @type {import('@types/eslint').Linter.BaseConfig}*/
module.exports = {
root: true,
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 'latest',
tsconfigRootDir: __dirname,
project: ['./tsconfig.json'],
},
plugins: ['@typescript-eslint', 'jest'],
extends: [
'eslint:recommended',
'prettier',
'plugin:@typescript-eslint/recommended',
'plugin:@typescript-eslint/recommended-requiring-type-checking',
],
rules: {
'no-console': ['warn'],
'@typescript-eslint/no-explicit-any': ['off'],
},
// While we use vitest instead of jest, because of the very similar API, we
// can still make good use of jest's linting plugin
settings: {
jest: {
version: 28,
},
},
overrides: [
{
files: ['*.test.*'],
rules: {
...permissiveTypescriptRules,
},
},
],
}