-
Notifications
You must be signed in to change notification settings - Fork 4
/
eslint.config.js
75 lines (70 loc) · 2.15 KB
/
eslint.config.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
69
70
71
72
73
74
75
// @ts-check
import js from "@eslint/js";
import gitignore from "eslint-config-flat-gitignore";
import prettierRecommended from "eslint-plugin-prettier/recommended";
import vitest from "@vitest/eslint-plugin";
import globals from "globals";
import path from "node:path";
import { fileURLToPath } from "node:url";
import ts from "typescript-eslint";
import tailwind from "eslint-plugin-tailwindcss";
export default ts.config(
gitignore(),
js.configs.recommended,
...ts.configs.strictTypeChecked,
...ts.configs.stylisticTypeChecked,
...tailwind.configs["flat/recommended"],
{
languageOptions: {
globals: globals.node,
parserOptions: {
project: "tsconfig.*.json",
tsconfigRootDir: path.dirname(fileURLToPath(import.meta.url)),
projectService: true,
},
},
linterOptions: {
reportUnusedDisableDirectives: true,
},
},
{
files: ["**/*.?(c|m)[j]s?(x)"],
...ts.configs.disableTypeChecked,
},
// Global overrides
{
files: ["**/*.?(c|m)[t]s?(x)"],
rules: {
// Both interface and type are useful in different ways
"@typescript-eslint/consistent-type-definitions": "off",
// Empty functions are often useful and shouldn't require adding a comment
"@typescript-eslint/no-empty-function": "off",
// Default settings interfere with react-hook-form's form `onSubmit` handler
// https://github.com/orgs/react-hook-form/discussions/8622
"@typescript-eslint/no-misused-promises": [
"error",
{ checksVoidReturn: { attributes: false } },
],
// Allow TypeScript/tsc-style underscore-prefixed unused variables
"@typescript-eslint/no-unused-vars": [
"error",
{
args: "all",
argsIgnorePattern: "^_",
caughtErrorsIgnorePattern: "^_",
destructuredArrayIgnorePattern: "^_",
ignoreRestSiblings: true,
},
],
"@typescript-eslint/switch-exhaustiveness-check": "error",
},
},
// Tests
{
files: [`src/**/*.test.?(c|m)[jt]s?(x)`],
plugins: { vitest },
rules: vitest.configs.recommended.rules,
},
// Must be last
prettierRecommended,
);