-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
40 lines (39 loc) · 2.27 KB
/
.eslintrc.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
module.exports = /** @type {import("eslint").Linter.BaseConfig & import("@typescript-eslint/experimental-utils").TSESLint.Linter.Config} */ ({
root: true,
parser: "@typescript-eslint/parser",
parserOptions: {
tsconfigRootDir: __dirname,
project: ["./tsconfig.json"],
},
ignorePatterns: [".eslintrc.js"],
plugins: [
"@typescript-eslint",
"only-warn",
],
extends: [
// use all recommended rules as base
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:@typescript-eslint/recommended-requiring-type-checking",
],
rules: {
// eslint
"comma-dangle": ["warn", "always-multiline"],
"quotes": ["warn", "double", { avoidEscape: true }],
"no-constant-condition": ["warn", { checkLoops: false }], // allows `while (true)`
// typescript-eslint
"@typescript-eslint/no-unused-vars": ["off"], // literally just what typescript already has, no thanks
"@typescript-eslint/no-explicit-any": ["off"], // `any` is a useful type mostly for type arguments. It should be avoided by writing good, strongly-typed code, not warned in all uses
"@typescript-eslint/await-thenable": ["off"], // this has a warning built in to TS (the ... under the `await`)
"@typescript-eslint/no-non-null-assertion": ["off"], // listen, type guards are waaaay not good enough to go without language features like this
"@typescript-eslint/no-namespace": ["off"], // this is super useful to add stuff to classes and interfaces and enums and stuff
"@typescript-eslint/explicit-module-boundary-types": ["off"], // it would be so annoying to explicitly type all the methods that return `this`
// "@typescript-eslint/no-unsafe-member-access": ["off"],
"@typescript-eslint/ban-types": ["off"], // there's actually a lot of useful types in here, add more restrictions back later if need be
// "@typescript-eslint/no-misused-promises": ["warn", { "checksVoidReturn": false }], // this prevents hanging promises
// "@typescript-eslint/unbound-method": ["warn", { "ignoreStatic": true }],
"@typescript-eslint/unbound-method": ["off"], // we have @Bound for this purpose,
"@typescript-eslint/no-empty-function": ["warn", { allow: ["private-constructors", "protected-constructors", "decoratedFunctions"] }],
"@typescript-eslint/no-empty-interface": ["warn", { allowSingleExtends: true }],
},
});