-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.cjs
80 lines (78 loc) · 2.29 KB
/
.eslintrc.cjs
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/**
* @type { import("eslint").Linter.Config }
*/
const config = {
root: true,
reportUnusedDisableDirectives: true,
env: {
es2020: true,
node: true,
},
extends: [
'eslint:recommended',
'plugin:node/recommended',
'plugin:import/errors',
'plugin:import/warnings',
'plugin:promise/recommended',
'plugin:prettier/recommended',
],
ignorePatterns: [
'**/[Ss]amples/**', // cspell:disable-line
'**/[Tt]emp/**',
'**/*.d.ts',
'**/*.map',
'**/coverage/**',
'**/dist/**',
'**/node_modules/**',
'**/.docusaurus/**',
],
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
},
plugins: ['import'],
overrides: [
{
files: '**/*.ts',
extends: ['plugin:@typescript-eslint/recommended', 'plugin:import/typescript'],
parser: '@typescript-eslint/parser',
plugins: ['@typescript-eslint'],
rules: {
'@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_', varsIgnorePattern: '^_' }],
// This is caught by 'import/no-unresolved'
'node/no-missing-import': [
'off',
{
tryExtensions: ['.js', '.d.ts', '.ts'],
},
],
'node/no-unsupported-features/es-syntax': [
'error',
{
ignores: ['modules'],
},
],
},
},
{
files: ['**/*.test.ts', '**/*.spec.ts'],
},
],
settings: {
'import/parsers': {
'@typescript-eslint/parser': ['.ts', '.tsx'],
},
'import/resolver': {
typescript: {
alwaysTryTypes: true, // always try to resolve types under `<root>@types` directory even it doesn't contain any source code
// use an array of glob patterns
project: ['packages/*/tsconfig.json', 'integration-tests/tsconfig.json'],
},
},
},
rules: {
// turn on errors for missing imports
'import/no-unresolved': 'error',
},
};
module.exports = config;