-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
133 lines (132 loc) · 4.1 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
126
127
128
129
130
131
132
133
const pkg = require('./package.json');
module.exports = {
extends: [
'airbnb',
'airbnb/hooks',
// 'plugin:postcss-modules/recommended',
'plugin:@typescript-eslint/recommended',
'plugin:storybook/recommended',
],
env: {
browser: true,
jest: true,
},
plugins: [
// 'react',
// 'react-hooks',
// 'import',
// 'postcss-modules',
'@typescript-eslint',
],
settings: {
// 'postcss-modules': {
// 'camelCase': 'camelCaseOnly',
// },
'import/resolver': {
'babel-module': {
root: ['.'],
extensions: ['.js', '.jsx', '.ts', '.tsx'],
alias: {
'#components': './src/components',
'#hooks': './src/hooks',
'#utils': './src/utils',
},
},
},
react: {
version: 'detect',
},
},
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 2018,
ecmaFeatures: {
jsx: true,
},
sourceType: 'module',
allowImportExportEverywhere: true,
},
rules: {
// 'postcss-modules/no-unused-class': 'warn',
// 'postcss-modules/no-undef-class': 'warn',
strict: 1,
indent: ['error', 4, {
SwitchCase: 1,
}],
'no-unused-vars': 0,
'@typescript-eslint/no-unused-vars': 1,
'no-console': 0,
'no-use-before-define': 0,
'@typescript-eslint/no-use-before-define': 1,
// note you must disable the base rule as it can report incorrect errors
'no-shadow': 'off',
'@typescript-eslint/no-shadow': ['error'],
'prefer-destructuring': 'warn',
'function-paren-newline': ['warn', 'consistent'],
'object-curly-newline': [2, {
ObjectExpression: {
consistent: true,
},
ObjectPattern: {
consistent: true,
},
ImportDeclaration: {
consistent: true,
},
ExportDeclaration: {
consistent: true,
},
}],
'import/no-unresolved': ['error', {
ignore: Object.keys(pkg.peerDependencies),
}],
'import/extensions': ['off', 'never'],
'import/no-extraneous-dependencies': ['error', {
devDependencies: true,
}],
'@typescript-eslint/no-empty-interface': 0,
'@typescript-eslint/explicit-function-return-type': 0,
'@typescript-eslint/explicit-module-boundary-types': 0,
'jsx-a11y/anchor-is-valid': ['error', {
components: ['Link'],
specialLink: ['to'],
}],
'jsx-a11y/label-has-associated-control': [2, {
controlComponents: ['RawInput'],
}],
'react/prop-types': 0,
'react/jsx-props-no-spreading': 0,
'react/jsx-key': ['warn', {
checkFragmentShorthand: true,
checkKeyMustBeforeSpread: true,
}],
// 'react/prop-types': [1, { ignore: [], customValidators: [], skipUndeclared: false }],
'react/no-unused-state': 'warn',
'react/require-default-props': ['warn', {
ignoreFunctionalComponents: true,
}],
'react/default-props-match-prop-types': ['warn', {
allowRequiredDefaults: true,
}],
'react/jsx-indent': [2, 4],
'react/jsx-indent-props': [2, 4],
'react/jsx-filename-extension': ['error', {
extensions: ['.js', '.jsx', '.ts', '.tsx'],
}],
'react/forbid-prop-types': [1],
'react/destructuring-assignment': [1, 'always', {
ignoreClassFields: true,
}],
'react/sort-comp': [1, {
order: [
'static-methods',
'constructor',
'lifecycle',
'everything-else',
'render',
],
}],
'react-hooks/rules-of-hooks': 'error',
'react-hooks/exhaustive-deps': 'warn',
},
};