-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.cjs
85 lines (85 loc) · 2.02 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
81
82
83
84
85
module.exports = {
extends: [
"eslint:recommended",
"plugin:n/recommended",
"plugin:import/recommended",
"plugin:import/typescript",
"plugin:promise/recommended",
"prettier",
],
parserOptions: {
sourceType: "module",
ecmaFeatures: {
jsx: true,
},
},
env: {
es2022: true,
node: true,
},
rules: {
"no-unused-vars": [
"error",
{
// allow unused args if they start with _
argsIgnorePattern: "^_",
},
],
// handled by import/no-unresolved
"n/no-missing-import": "off",
// don't check for unsupported features - too much config to make this work
"n/no-unsupported-features/es-builtins": "off",
"n/no-unsupported-features/es-syntax": "off",
"n/no-unsupported-features/node-builtins": "off",
},
overrides: [
{
files: ["*.ts", "*.tsx"],
extends: [
"plugin:@typescript-eslint/recommended",
"plugin:@typescript-eslint/recommended-requiring-type-checking",
],
parserOptions: {
project: "./tsconfig.json",
},
settings: {
"import/parsers": {
"@typescript-eslint/parser": [".ts", ".tsx"],
},
"import/resolver": "typescript",
},
rules: {
"@typescript-eslint/no-unused-vars": [
"error",
{
// allow unused args if they start with _
argsIgnorePattern: "^_",
},
],
// this rule gets in the way of designing APIs
"@typescript-eslint/require-await": "off",
"@typescript-eslint/consistent-type-imports": [
"error",
{
fixStyle: "separate-type-imports",
prefer: "type-imports",
},
],
},
},
{
files: [
"*.spec.js",
"*.spec.jsx",
"*.spec.ts",
"*.spec.tsx",
"*.test.js",
"*.test.jsx",
"*.test.ts",
"*.test.tsx",
],
extends: ["plugin:vitest/recommended"],
plugins: ["vitest"],
},
],
};