-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path.eslintrc.js
68 lines (67 loc) · 1.99 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
module.exports = {
extends: 'erb',
env: { es2021: true },
rules: {
// A temporary hack related to IDE not resolving correct package.json
'import/no-extraneous-dependencies': 'off',
// 'import/no-extraneous-dependencies': ['error', { devDependencies: true }],
// Since React 17 and typescript 4.1 you can safely disable the rule
'react/react-in-jsx-scope': 'off',
'jsx-a11y/label-has-associated-control': [
'warn',
{
labelComponents: ['label'],
labelAttributes: ['label'],
controlComponents: ['FullCheckbox'],
depth: 3,
},
],
'dot-notation': 'off',
'@typescript-eslint/dot-notation': 'off',
// TODO: needs to be turned on again
'@typescript-eslint/no-explicit-any': 'off',
'react/static-property-placement': 'off',
'import/no-cycle': 'warn',
'no-console': 'off',
// added after package upgrades in 0.3.12
'import/extensions': [
'error',
{
json: 'always',
},
],
'react/jsx-filename-extension': [1, { extensions: ['.tsx', '.jsx'] }],
// no dumb, useless rules
'react/jsx-no-useless-fragment': 'off',
// turn off b/c typescript does this for us(?)
'no-undef': 'off',
'no-unused-vars': ['error', { args: 'none', caughtErrors: 'none' }],
'class-methods-use-this': 'off',
'import/no-import-module-exports': [
'error',
{
exceptions: ['**/*/webpack.config.*.ts'],
},
],
},
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
project: './tsconfig.json',
tsconfigRootDir: __dirname,
createDefaultProgram: true,
},
settings: {
'import/resolver': {
// See https://github.com/benmosher/eslint-plugin-import/issues/1396#issuecomment-575727774 for line below
node: {},
webpack: {
config: require.resolve('./.erb/configs/webpack.config.eslint.ts'),
},
typescript: {},
},
'import/parsers': {
'@typescript-eslint/parser': ['.ts', '.tsx'],
},
},
};