-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.cjs
116 lines (116 loc) · 2.76 KB
/
.eslintrc.cjs
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
module.exports = {
root: true,
env: { browser: true, es2021: true, node: true },
extends: [
"plugin:@typescript-eslint/recommended",
"airbnb",
"airbnb-typescript",
"prettier",
],
ignorePatterns: ["dist", ".eslintrc.cjs"],
parser: "@typescript-eslint/parser",
parserOptions: {
ecmaVersion: "latest",
sourceType: "module",
ecmaFeatures: {
jsx: true,
},
project: "./tsconfig.json",
},
plugins: ["import", "@typescript-eslint", "react", "react-refresh"],
rules: {
"no-nested-ternary": "off",
"no-alert": "off",
"react-refresh/only-export-components": [
"warn",
{ allowConstantExport: true },
],
"import/extensions": [
"error",
"ignorePackages",
{
// Since airbnb javascript rules does not allow to import typescript files without extensions, we need to disable it
ts: "never",
tsx: "never",
},
],
"import/named": "error",
"import/no-extraneous-dependencies": [
"error",
{
packageDir: [__dirname],
},
],
"import/prefer-default-export": "off",
"no-param-reassign": [
"error",
{
props: true,
// function parameters cannot be reassigned for readability, except for the ones in the array
ignorePropertyModificationsFor: ["state"],
},
],
"no-restricted-imports": [
"error",
{
patterns: [
{
group: ["../*"],
message:
"Usage of relative parent imports is not allowed. Use path alias instead.",
},
],
},
],
"radix": ["error", "as-needed"],
"react/function-component-definition": [
"error",
{
namedComponents: "arrow-function",
unnamedComponents: "arrow-function",
},
],
"react/jsx-uses-react": "off",
"react/jsx-no-useless-fragment": [
"error",
{
// this allows <>{value}</> syntax, where value is a string or a number
allowExpressions: true,
},
],
"react/jsx-props-no-spreading": "off",
"react/no-unknown-property": [
"error",
{
ignore: ["css"],
},
],
"react/react-in-jsx-scope": "off",
"react/require-default-props": [
"error",
{
// default values of the optional props must be provided as function arguments
functions: "defaultArguments",
},
],
"@typescript-eslint/consistent-type-imports": [
"error",
{
prefer: "type-imports",
},
],
},
settings: {
"import/parsers": {
"@typescript-eslint/parser": [".ts", ".tsx"],
},
"import/resolver": {
typescript: {
project: ["./tsconfig.json"],
},
},
"react": {
version: "detect",
},
},
};