-
Notifications
You must be signed in to change notification settings - Fork 4
/
.eslintrc.json
127 lines (127 loc) · 3.52 KB
/
.eslintrc.json
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
{
"root": true,
"ignorePatterns": ["**/*"],
"plugins": ["@nx"],
"extends": ["eslint:recommended"],
"parserOptions": {
"tsconfigRootDir": ".",
"project": ["tsconfig.base.json"]
},
"overrides": [
// Nx
{
"files": ["*.ts", "*.tsx", "*.js", "*.jsx"],
"rules": {
"@nx/enforce-module-boundaries": [
"error",
{
"enforceBuildableLibDependency": true,
"allow": [],
"depConstraints": [
{
"sourceTag": "*",
"onlyDependOnLibsWithTags": ["*"]
}
]
}
]
}
},
// Typescript
{
"files": ["*.ts", "*.tsx"],
"extends": ["plugin:@nx/typescript"],
"rules": {
"@typescript-eslint/explicit-module-boundary-types": "error",
"@typescript-eslint/no-floating-promises": [
"error",
{
"ignoreVoid": false
}
],
"@typescript-eslint/no-misused-promises": "error",
"@typescript-eslint/naming-convention": [
"error",
{
"selector": ["classMethod", "classProperty"],
"format": null,
"filter": {
"regex": "^__", // ignore if starts with "__"
"match": true
}
},
{
"selector": ["classMethod", "classProperty"],
"modifiers": ["public"],
"format": ["camelCase"],
"leadingUnderscore": "forbid"
},
{
"selector": ["classMethod", "classProperty"],
"format": ["camelCase"],
"leadingUnderscore": "require"
}
],
"@typescript-eslint/no-unsafe-argument": "warn",
"@typescript-eslint/no-unsafe-assignment": "warn",
"@typescript-eslint/no-unsafe-call": "warn",
"@typescript-eslint/no-unsafe-member-access": "warn",
"@typescript-eslint/no-unsafe-return": "warn",
"@typescript-eslint/no-unused-vars": [
"error",
{
"argsIgnorePattern": "^_",
"vars": "all",
"args": "all"
}
],
"no-await-in-loop": "warn",
"no-console": "error",
"no-warning-comments": [
"error",
{
"terms": ["@nocommit", "no-commit", "@no-commit", "nocommit"],
"location": "anywhere"
}
],
"eqeqeq": ["warn", "smart"],
"no-restricted-syntax": [
"error",
{
"selector": "TSEnumDeclaration",
// This avoids issues where enums are stripped out due to tree-shaking
"message": "Use object literals with 'as const' instead of enums"
}
]
// "require-await": "error"
}
},
// Javascript
{
"files": ["*.js", "*.jsx"],
"extends": ["plugin:@nx/javascript"],
"rules": {}
},
// Tests
{
"files": ["*.test.ts", "*.test.tsx", "*.test.js", "*.test.jsx"],
"env": {
"jest": true
},
"rules": {
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-floating-promises": [
"error",
{
"ignoreVoid": true
}
],
"@typescript-eslint/no-unsafe-argument": "off",
"@typescript-eslint/no-unsafe-member-access": "off",
"@typescript-eslint/no-unsafe-assignment": "off",
"@typescript-eslint/no-unsafe-call": "off",
"@typescript-eslint/no-unsafe-return": "off"
}
}
]
}