-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path.eslintrc.cjs
81 lines (65 loc) · 2.61 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
module.exports = {
env: {
node: true,
},
extends: [
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"prettier",
],
parser: "@typescript-eslint/parser",
parserOptions: {
ecmaVersion: "latest",
sourceType: "module",
},
plugins: [],
ignorePatterns: ["/dist"],
overrides: [
{
files: [".eslintrc.{js,cjs}"],
env: {
node: true,
},
parserOptions: {
sourceType: "script",
},
},
],
rules: {
// ---------- JavaScript ----------
// Enforce consistent brace style for all control statements
curly: "error",
// Require `===` when `==` can be ambiguous
eqeqeq: ["error", "always"],
// Disallow the use of `console.log`, which helps not forget them after debugging; for permanent logging, use `console.info/warn/error`
"no-console": ["warn", { allow: ["info", "warn", "error"] }],
// Disallow the use of `debugger`
"no-debugger": "warn",
// Disallow the use of `eval()`; if `eval()` is necessary, use `// eslint-disable-next-line no-eval` where it's needed
"no-eval": "error",
// Disallow `new` operators with the `Function` object, as this is similar to `eval()`; if necessary, use `// eslint-disable-next-line no-new-func` where it's needed
"no-new-func": "error",
// The use of `@typescript-eslint/no-shadow` necessitates to disable `no-shadow`, see https://typescript-eslint.io/rules/no-shadow
"no-shadow": "off",
// Disallow ternary operators when simpler alternatives exist; example: prevent `const x = y === 1 ? true : false` in favour of `const x = y === 1`
"no-unneeded-ternary": "warn",
// Disallow renaming import, export, and destructured assignments to the same name; example: prevent `const { a: a } = b;` in favour of `const { a } = b;`
"no-useless-rename": "warn",
// Disallow throwing anything else than the `Error object`
"no-throw-literal": "error",
// Require method and property shorthand syntax for object literals; example: prevent `a = { b: b };` in favour of `a = { b };`
"object-shorthand": "warn",
// ---------- TypeScript ----------
// Enforce consistent usage of type imports
// Maybe later, VS Code automatic support isn't great; "@typescript-eslint/consistent-type-imports": "error",
// Disallow the declaration of empty interfaces, but allow to extend a single interface
"@typescript-eslint/no-empty-interface": [
"error",
{ allowSingleExtends: true },
],
// Disallow non-null assertions using the `!` postfix operator
"@typescript-eslint/no-non-null-assertion": "error",
// Disallow variable declarations from shadowing variables declared in the outer scope
"@typescript-eslint/no-shadow": "warn",
},
};