-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path.eslintrc.js
47 lines (38 loc) · 1.73 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
41
42
43
44
45
46
47
module.exports = {
root: true,
parser: "@typescript-eslint/parser",
parserOptions: {
tsconfigRootDir: __dirname,
project: ["./packages/*/tsconfig.json"],
},
plugins: ["@typescript-eslint", "node", "jest"],
extends: [
// Core eslint recommended rules.
"eslint:recommended",
// Override those with TypeScript versions, where necessary.
"plugin:@typescript-eslint/eslint-recommended",
// Core TypeScript recommended rules - syntax only.
"plugin:@typescript-eslint/recommended",
// Core TypeScript recommended rules - full type checking.
"plugin:@typescript-eslint/recommended-requiring-type-checking",
// Disable formatting rules that prettier will handle.
"prettier/@typescript-eslint",
],
rules: {
// Importing any package in the project will likely work in dev because
// of the symlinks that yarn workspaces creates in the root node_modules.
// We can't prevent that, but we can tell eslint to fail.
// (This rule is poorly named. It should be "no-implicit-import".)
"node/no-extraneous-import": "error",
// Be explicit when you must, but return type is usually inferred correctly.
"@typescript-eslint/explicit-function-return-type": "off",
// Function return types can be inferred, so this is too onerous.
"@typescript-eslint/explicit-module-boundary-types": "off",
// Avoid using "any" or "as any" wherever possible, but this is too onerous.
"@typescript-eslint/no-explicit-any": "off",
// Avoid foo!.bar wherever possible, but this is too onerous.
"@typescript-eslint/no-non-null-assertion": "off",
// Clean up unused vars before committing, but this is too onerous during dev.
"@typescript-eslint/no-unused-vars": "warn",
},
};