-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.eslintrc.cjs
56 lines (56 loc) · 1.96 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
56
/** @type { import("eslint").Linter.Config } */
module.exports = {
env: {
browser: true,
es2021: true,
},
extends: [
'airbnb',
'airbnb-typescript',
'airbnb/hooks',
'plugin:react/recommended',
'plugin:@typescript-eslint/recommended',
'plugin:prettier/recommended',
],
overrides: [],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
project: ['./tsconfig.json', './tsconfig.node.json', './tsconfig.app.json'],
},
plugins: ['react', '@typescript-eslint', 'prettier', 'simple-import-sort'],
rules: {
'simple-import-sort/imports': [
'error',
{
groups: [
// 1. Side effect imports at the start. For me this is important because I want to import reset.css and global styles at the top of my main file.
['^\\u0000'],
// 2. `react` and packages: Things that start with a letter (or digit or underscore), or `@` followed by a letter.
['^react$', '^@?\\w'],
// 3. Absolute imports and other imports such as Vue-style `@/foo`.
// Anything not matched in another group. (also relative imports starting with "../")
['^@', '^'],
// 4. relative imports from same folder "./" (I like to have them grouped together)
['^\\./'],
// 5. style module imports always come last, this helps to avoid CSS order issues
['^.+\\.(module.css|module.scss)$'],
// 6. media imports
['^.+\\.(gif|png|svg|jpg)$'],
],
},
],
'react/react-in-jsx-scope': 0,
'import/no-extraneous-dependencies': 'off',
'import/prefer-default-export': 'off',
'import/order': 'warn',
'import/extensions': 'warn',
'@typescript-eslint/no-exp': 'off',
'react/no-array': 'off',
'react/function-component-definition': 'off',
'react-hooks/exhaustive-deps': 'off',
'react/prop-types': 'off',
'react/jsx-props-no-spreading': 'off',
},
};