-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
81 lines (80 loc) · 2.11 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
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": {
browser: true,
node: true,
es6: true,
jest: true
},
"parser": "@typescript-eslint/parser",
"extends": [
"eslint:recommended",
"plugin:react/recommended",
"plugin:@typescript-eslint/recommended",
],
"parserOptions": {
"ecmaFeatures": {
"jsx": true
},
"ecmaVersion": "latest",
"sourceType": "module"
},
"plugins": [
"react",
"@typescript-eslint",
"prettier"
],
"rules": {
// disabling this bc it is checked by typescript so it is
// redundant and doesn't function properly
"react/prop-types": 0,
"no-unused-vars": "off",
"prettier/prettier": "error",
"@typescript-eslint/no-empty-interface": 0,
"@typescript-eslint/no-use-before-define": [
"error",
{ functions: false, variables: false },
],
"@typescript-eslint/no-unused-vars": [
"error",
{
vars: "all",
args: "after-used",
// ignore underscore _vars or jsx imports or React imports
argsIgnorePattern: "^_.*",
varsIgnorePattern: "^jsx$|^React$|^_.*",
ignoreRestSiblings: true,
},
],
"react/no-unescaped-entities": [
"error",
{
forbid: [">", "}"],
},
],
// disable this rule because it is unnecessarily strict for TS
"@typescript-eslint/explicit-function-return-type": 0,
"@typescript-eslint/explicit-module-boundary-types": 0,
// camelcase: "error",
// "@typescript-eslint/camelcase": 0,
eqeqeq: ["error", "smart"],
"id-blacklist": [
"error",
"any",
"Number",
"number",
"String",
"string",
"Boolean",
"Undefined",
],
"id-match": "error",
"no-eval": "error",
"no-redeclare": "error",
"no-var": "error",
},
settings: {
react: {
version: "detect",
},
},
}