-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathreact.mjs
104 lines (101 loc) · 2.44 KB
/
react.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
import path from 'node:path'
import {fileURLToPath} from 'node:url'
import tseslint from 'typescript-eslint'
import {FlatCompat} from '@eslint/eslintrc'
import js from '@eslint/js'
import reactPlugin from 'eslint-plugin-react'
import jsxA11y from 'eslint-plugin-jsx-a11y'
import preferFC from 'eslint-plugin-react-prefer-function-component/config'
import storybook from 'eslint-plugin-storybook'
import eslintConfigPrettier from 'eslint-config-prettier'
import ssrFriendly from 'eslint-plugin-ssr-friendly'
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
})
const reactConfig = [
reactPlugin.configs.flat.recommended,
...storybook.configs['flat/recommended'],
preferFC.configs.recommended,
eslintConfigPrettier,
...compat.extends(
'plugin:jsx-a11y/recommended',
'plugin:react-hooks/recommended'
),
{
languageOptions: {
parser: tseslint.parser
},
settings: {
react: {
version: 'detect'
}
},
plugins: {
'jsx-a11y': jsxA11y,
'ssr-friendly': ssrFriendly
},
rules: {
'react/prop-types': 'off',
'react/jsx-pascal-case': 'error',
'react/jsx-fragments': 'error',
'react/jsx-no-target-blank': 'off',
'react/jsx-no-useless-fragment': 'error',
'react/no-multi-comp': 'error',
'react/hook-use-state': 'error',
'react-hooks/exhaustive-deps': [
'warn',
{
additionalHooks: '(useDeferCallback)'
}
],
'react/no-unstable-nested-components': [
'error',
{
allowAsProps: true
}
],
'jsx-a11y/no-autofocus': [
'error',
{
ignoreNonDOM: true
}
]
}
},
{
files: ['*.jsx', '*.tsx'],
rules: {
'import/no-default-export': 'off'
}
},
{
files: [
'**/test/**',
'**/tests/**',
'**/spec/**',
'**/__tests__/**',
'**/__stories__/**',
'*.test.*',
'*.spec.*',
'*.story.*',
'*.e2e.*',
'*.e2e-spec.*'
],
rules: {
'react/no-multi-comp': 'off'
}
},
{
files: ['**/__stories__/**', '*.story.*'],
rules: {
'import/no-unused-modules': 'off',
'import/no-anonymous-default-export': 'off',
'storybook/default-exports': 'off'
}
}
]
export {reactConfig}