-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy path.eslintrc.js
125 lines (110 loc) · 3.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
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
122
123
124
125
module.exports = {
root: true,
parser: '@babel/eslint-parser',
extends: [
'standard',
'standard-react',
],
plugins: [
'@babel',
'import',
'react',
'react-hooks',
],
env: {
browser: true,
commonjs: true,
es2020: true,
jest: true,
node: true,
},
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
ecmaFeatures: {
jsx: true,
},
babelOptions: {
configFile: './.babelrc.js',
},
},
settings: {
react: {
version: 'detect',
},
},
globals: {
__DEV__: false,
},
rules: {
'comma-dangle': ['error', {
arrays: 'always-multiline',
objects: 'always-multiline',
imports: 'always-multiline',
exports: 'always-multiline',
functions: 'never',
}],
'generator-star-spacing': ['error', { 'before': false, 'after': true }],
'no-duplicate-imports': 'error',
'object-curly-spacing': ['error', 'always'],
'prefer-object-spread': 'error',
// quotes in properties where quote aren't needed should be ok
'quote-props': 'off',
// be picky about ternary multiline and indents
'multiline-ternary': ['error', 'always-multiline'],
// modified from eslint-config-standard for ternary expressions
indent: [
'error',
2,
{
SwitchCase: 1,
VariableDeclarator: 1,
outerIIFEBody: 1,
MemberExpression: 1,
FunctionDeclaration: { parameters: 1, body: 1 },
FunctionExpression: { parameters: 1, body: 1 },
CallExpression: { arguments: 1 },
ArrayExpression: 1,
ObjectExpression: 1,
ImportDeclaration: 1,
ignoreComments: false,
ignoredNodes: [
'TemplateLiteral *', 'JSXElement', 'JSXElement > *', 'JSXAttribute', 'JSXIdentifier',
'JSXNamespacedName', 'JSXMemberExpression', 'JSXSpreadAttribute', 'JSXExpressionContainer',
'JSXOpeningElement', 'JSXClosingElement', 'JSXFragment', 'JSXOpeningFragment',
'JSXClosingFragment', 'JSXText', 'JSXEmptyExpression', 'JSXSpreadChild',
],
flatTernaryExpressions: true,
offsetTernaryExpressions: false,
},
],
'import/no-duplicates': 'error',
// ref: https://github.com/yannickcr/eslint-plugin-react
// basic react and jsx rules
'react/no-unsafe': 'warn',
'react/jsx-uses-vars': 'warn',
'react/jsx-uses-react': 'warn',
'react/jsx-fragments': ['warn', 'syntax'],
'react/jsx-equals-spacing': ['error', 'never'],
'react/jsx-pascal-case': ['warn', { allowAllCaps: true, ignore: [] }],
// JSX formatting, indents and multiline rules:
'react/jsx-closing-tag-location': 'warn',
'react/jsx-closing-bracket-location': ['warn', 'line-aligned'],
'react/jsx-indent': ['warn', 2, { checkAttributes: true, indentLogicalExpressions: true }],
'react/jsx-indent-props': ['warn', 2],
'react/jsx-wrap-multilines': [
'warn',
{
declaration: 'parens-new-line',
assignment: 'parens-new-line',
return: 'parens-new-line',
arrow: 'parens-new-line',
condition: 'parens-new-line',
logical: 'parens-new-line',
prop: 'parens-new-line',
},
],
'react-hooks/rules-of-hooks': 'error',
'react-hooks/exhaustive-deps': 'warn',
},
}