-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patheslint.config.js
55 lines (52 loc) · 1.39 KB
/
eslint.config.js
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
47
48
49
50
51
52
53
54
55
import eslint from '@eslint/js'
import vitest from '@vitest/eslint-plugin'
import tseslint from 'typescript-eslint'
export default tseslint.config(
{
ignores: [
'coverage*',
'lib',
'node_modules',
'pnpm-lock.yaml',
'**/*.snap',
],
},
{
linterOptions: {
reportUnusedDisableDirectives: 'error',
},
},
eslint.configs.recommended,
...tseslint.config({
extends: tseslint.configs.strictTypeChecked,
files: ['**/*.js', '**/*.ts'],
languageOptions: {
parserOptions: {
projectService: {
allowDefaultProject: ['*.*s', 'eslint.config.js'],
defaultProject: './tsconfig.json',
},
tsconfigRootDir: import.meta.dirname,
},
},
rules: {
// These on-by-default rules don't work well for this repo and we like them off.
'no-constant-condition': 'off',
// These on-by-default rules work well for this repo if configured
'@typescript-eslint/no-unused-vars': ['error', { caughtErrors: 'all' }],
},
}),
{
files: ['**/*.test.*'],
languageOptions: {
globals: vitest.environments.env.globals,
},
plugins: { vitest },
rules: {
...vitest.configs.recommended.rules,
// These on-by-default rules aren't useful in test files.
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
},
},
)