-
Notifications
You must be signed in to change notification settings - Fork 24
/
.eslintrc
121 lines (121 loc) · 3.49 KB
/
.eslintrc
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
{
"extends": ["next", "airbnb-typescript-prettier"],
"settings": {
"import/parsers": {
"@typescript-eslint/parser": [".ts", ".tsx"]
},
"import/resolver": {
"typescript": {
"alwaysTryTypes": true
}
}
},
"rules": {
"curly": ["error", "all"],
"no-console": [
"warn",
{
"allow": ["error", "warn", "debug", "info"]
}
],
"no-duplicate-imports": "warn",
"no-restricted-imports": [
"warn",
{
"patterns": [
{
"group": ["../*"],
"message": "\nPlease use absolute paths for imports.\nExample:\n\n import { Button } from 'components/button' // Good\n import { Button } from '../components/button' // Bad"
}
]
}
],
// Using next/link component that passes href attribute down to wrapped <a /> tag so we dont need this warning
"jsx-a11y/anchor-is-valid": [
"error",
{
"components": ["Link"],
"specialLink": ["hrefLeft", "hrefRight"],
"aspects": ["invalidHref", "preferButton"]
}
],
// Named exports are preferable
// https://blog.piotrnalepa.pl/2020/06/26/default-exports-vs-named-exports/
"import/prefer-default-export": "off",
"react/prefer-stateless-function": ["warn"],
// Disable checking for missing 'import React'
// https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html#whats-different-in-the-new-transform
"react/react-in-jsx-scope": "off",
"react/require-default-props": "off",
"react/jsx-props-no-spreading": "off",
"import/no-extraneous-dependencies": [
"error",
{
"devDependencies": true
}
],
"padding-line-between-statements": [
"error",
// Always require blank lines after directive (like 'use-strict'), except between directives
{
"blankLine": "always",
"prev": "directive",
"next": "*"
},
{
"blankLine": "any",
"prev": "directive",
"next": "directive"
},
// Always require blank lines after import, except between imports
{
"blankLine": "always",
"prev": "import",
"next": "*"
},
{
"blankLine": "any",
"prev": "import",
"next": "import"
},
// Always require blank lines before and after every sequence of variable declarations and export
{
"blankLine": "always",
"prev": "*",
"next": ["const", "let", "var", "export"]
},
{
"blankLine": "always",
"prev": ["const", "let", "var", "export"],
"next": "*"
},
{
"blankLine": "any",
"prev": ["const", "let", "var", "export"],
"next": ["const", "let", "var", "export"]
},
// Always require blank lines before and after class declaration, if, do/while, switch, try
{
"blankLine": "always",
"prev": "*",
"next": ["if", "class", "for", "do", "while", "switch", "try"]
},
{
"blankLine": "always",
"prev": ["if", "class", "for", "do", "while", "switch", "try"],
"next": "*"
},
// Always require blank lines before return statements
{
"blankLine": "always",
"prev": "*",
"next": "return"
}
],
"react/function-component-definition": "off",
"no-restricted-exports": "off",
"react/jsx-no-useless-fragment": "off",
"react/jsx-no-bind": "off",
"react/no-unstable-nested-components": "off"
}
}