-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
54 lines (54 loc) · 1.69 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
module.exports = {
extends: "erb",
plugins: ["@typescript-eslint"],
rules: {
// A temporary hack related to IDE not resolving correct package.json
"import/no-extraneous-dependencies": "off",
"react/react-in-jsx-scope": "off",
"react/jsx-filename-extension": "off",
"import/extensions": "off",
"import/no-unresolved": "off",
"import/no-import-module-exports": "off",
"no-shadow": "off",
"@typescript-eslint/no-shadow": "error",
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": ["error", {destructuredArrayIgnorePattern: "^_"}],
"react-hooks/exhaustive-deps": "warn",
"react/prop-types": "warn",
"react/require-default-props": "off",
"no-alert": "warn",
"no-restricted-syntax": "warn",
"no-restricted-exports": 0,
"jsx-a11y/click-events-have-key-events": "warn",
"jsx-a11y/no-static-element-interactions": "warn",
"jsx-a11y/label-has-associated-control": [2, {labelAttributes: ["htmlFor"]}],
"jsx-a11y/control-has-associated-label": "warn",
"promise/always-return": "off",
camelcase: ["error", {allow: ["^dB_", "_dB$", "amp_range"]}],
},
parserOptions: {
ecmaVersion: 2022,
sourceType: "module",
},
overrides: [
{
files: ["*.ts", "*.tsx"],
rules: {
"no-undef": "off",
},
},
],
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"],
},
},
};