-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy patheslint.config.js
More file actions
101 lines (97 loc) · 2.66 KB
/
eslint.config.js
File metadata and controls
101 lines (97 loc) · 2.66 KB
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
// For more info, see https://github.com/storybookjs/eslint-plugin-storybook#configuration-flat-config-format
import storybook from "eslint-plugin-storybook";
import js from "@eslint/js";
import react from "eslint-plugin-react";
import reactHooks from "eslint-plugin-react-hooks";
import tseslint from "typescript-eslint";
export default tseslint.config(
js.configs.recommended,
...tseslint.configs.recommended,
{
files: ["src/**/*.{js,jsx,ts,tsx}"],
plugins: {
react,
"react-hooks": reactHooks,
},
languageOptions: {
ecmaVersion: 2025,
sourceType: "module",
parserOptions: {
ecmaFeatures: {
jsx: true,
},
},
},
settings: {
react: {
version: "detect",
},
},
rules: {
// React specific rules
"react/jsx-uses-react": "error",
"react/jsx-uses-vars": "error",
"react/react-in-jsx-scope": "off", // Not needed with React 17+
"react/prop-types": "off", // Using TypeScript for prop validation
"react/jsx-sort-props": [
"error",
{
callbacksLast: true,
multiline: "last",
},
],
// React Hooks rules
"react-hooks/rules-of-hooks": "error",
"react-hooks/exhaustive-deps": "warn",
// TypeScript specific rules
"@typescript-eslint/no-unused-vars": ["error", { argsIgnorePattern: "^_" }],
"@typescript-eslint/explicit-function-return-type": "off",
"@typescript-eslint/explicit-module-boundary-types": "off",
"@typescript-eslint/no-explicit-any": "warn",
"@typescript-eslint/member-ordering": [
"error",
{
default: {
order: "alphabetically",
optionalityOrder: "required-first",
},
interfaces: {
memberTypes: ["field", "method"],
},
classes: {
order: "alphabetically-case-insensitive",
memberTypes: [
"#private-field",
"public-field",
"constructor",
"private-accessor",
"#private-method",
"protected-method",
"abstract-method",
["public-get", "public-set"],
"method",
],
},
},
],
// General rules
"no-console": "warn",
"no-debugger": "error",
"prefer-const": "error",
"no-var": "error",
},
},
{
// Ignore patterns
ignores: [
"node_modules/**",
"dist/**",
"build/**",
"*.config.js",
"*.config.ts",
"src/**/*.test.{js,jsx,ts,tsx}",
"vite-env.d.ts",
],
},
storybook.configs["flat/recommended"],
);