-
Notifications
You must be signed in to change notification settings - Fork 2
/
.eslintrc.js
56 lines (49 loc) · 1.46 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
48
49
50
51
52
53
54
55
56
module.exports = {
env: {
es2021: true,
node: true,
},
parserOptions: {
ecmaVersion: 12,
sourceType: "module",
},
parser: "@typescript-eslint/parser",
plugins: ["@typescript-eslint"],
extends: ["eslint:recommended", "plugin:@typescript-eslint/recommended"],
rules: {
"prefer-const": ["error", { destructuring: "all" }],
// Will be part of eslint:recommended in ESlint 9, so we can remove then.
"no-new-native-nonconstructor": ["error"],
// TypeScript-focused rules -----------------------------------------------
// There is a TypeScript-enhanced version of no-unused-vars; use it instead
// of the built-in. (It will still check .js files, too.)
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": [
"error",
{
argsIgnorePattern: "^_",
varsIgnorePattern: "^_",
},
],
"@typescript-eslint/explicit-module-boundary-types": [
"warn",
{
allowArgumentsExplicitlyTypedAsAny: true,
},
],
"@typescript-eslint/no-empty-function": "off",
"@typescript-eslint/no-explicit-any": "off",
// We have some plain JS in the codebase that we don't want a build step
// for; they need `require()` support.
"@typescript-eslint/no-var-requires": "off",
},
ignorePatterns: ["node_modules", "dist", "coverage", "scratch.*"],
overrides: [
{
files: ["**/__mocks__/*.{js,ts}"],
env: {
jest: true,
},
},
],
};