-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patheslint.config.mjs
119 lines (99 loc) · 3.09 KB
/
eslint.config.mjs
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
import react from "eslint-plugin-react";
import reactHooks from "eslint-plugin-react-hooks";
import typescriptEslint from "@typescript-eslint/eslint-plugin";
import { fixupPluginRules } from "@eslint/compat";
import globals from "globals";
import tsParser from "@typescript-eslint/parser";
import path from "node:path";
import { fileURLToPath } from "node:url";
import js from "@eslint/js";
import { FlatCompat } from "@eslint/eslintrc";
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const compat = new FlatCompat({
baseDirectory: __dirname,
recommendedConfig: js.configs.recommended,
allConfig: js.configs.all
});
export default [...compat.extends(
"eslint:recommended",
"plugin:react/recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"plugin:@typescript-eslint/recommended-requiring-type-checking",
), {
plugins: {
react,
"react-hooks": fixupPluginRules(reactHooks),
"@typescript-eslint": typescriptEslint,
},
languageOptions: {
globals: {
...globals.jest,
...globals.node,
Atomics: "readonly",
SharedArrayBuffer: "readonly",
},
parser: tsParser,
ecmaVersion: 5,
sourceType: "module",
parserOptions: {
project: "./tsconfig.json",
},
},
settings: {
react: {
version: "detect",
},
},
rules: {
"@typescript-eslint/member-ordering": ["error"],
"@typescript-eslint/no-empty-function": "off",
"@typescript-eslint/no-explicit-any": "off",
"array-bracket-spacing": ["error", "always", {
arraysInArrays: true,
objectsInArrays: true,
}],
"comma-dangle": ["error", "always-multiline"],
"comma-spacing": ["error", {
after: true,
before: false,
}],
"comma-style": ["error", "last"],
indent: ["error", 2, {
SwitchCase: 1,
}],
"key-spacing": ["error", {
beforeColon: false,
}],
"linebreak-style": ["error", "unix"],
"no-empty-function": "error",
"no-multi-spaces": "error",
"object-curly-spacing": ["error", "always", {
objectsInObjects: false,
}],
quotes: ["error", "single", {
avoidEscape: true,
}],
"react/display-name": "off",
"react/prop-types": "off",
"react/react-in-jsx-scope": "off",
semi: ["error", "always"],
"semi-spacing": ["error", {
after: true,
before: true,
}],
"sort-imports": ["error", {
allowSeparatedGroups: true,
ignoreCase: false,
ignoreDeclarationSort: false,
ignoreMemberSort: false,
memberSyntaxSortOrder: ["none", "all", "multiple", "single"],
}],
"sort-keys": ["error", "asc", {
caseSensitive: true,
minKeys: 2,
natural: false,
}],
},
}];