-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.eslintrc.cjs
56 lines (53 loc) · 1.57 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
// eslint-disable-next-line @typescript-eslint/no-var-requires
const path = require("path");
/** @type {import("eslint").Linter.Config} */
const config = {
overrides: [
{
extends: [
"plugin:@typescript-eslint/recommended-requiring-type-checking"
],
files: ["*.ts", "*.tsx"],
parserOptions: {
project: path.join(__dirname, "tsconfig.json")
}
}
],
parser: "@typescript-eslint/parser",
parserOptions: {
project: path.join(__dirname, "tsconfig.json")
},
plugins: ["@typescript-eslint", "simple-import-sort", "react-hooks"],
extends: ["plugin:@typescript-eslint/recommended"],
rules: {
"simple-import-sort/imports": [
"error",
{
groups: [
// Packages. `react` and 'next'
["^react", "^next"],
// Related packages
["^@?\\w"],
// Internal packages
["^(app|common|core|components|ducks|mock|utils|testUtils)(/.*|$)"],
// Side effect imports.
["^\\u0000"],
// Other relative imports. Put same-folder imports and `.` last.
["^\\./(?=.*/)(?!/?$)", "^\\.(?!/?$)", "^\\./?$", "^.+\\.s?css$"]
]
}
],
"@typescript-eslint/consistent-type-imports": [
"error",
{
prefer: "type-imports",
fixStyle: "inline-type-imports"
}
],
"react-hooks/exhaustive-deps": "error",
"@typescript-eslint/no-unused-vars": ["warn", { argsIgnorePattern: "^_" }],
"no-console": "error",
"no-underscore-dangle": ["error", { allow: [""] }]
}
};
module.exports = config;