-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.eslintrc.js
50 lines (50 loc) Β· 1.75 KB
/
.eslintrc.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
module.exports = {
parser: '@typescript-eslint/parser',
parserOptions: {
project: 'tsconfig.json',
tsconfigRootDir: __dirname,
sourceType: 'module',
},
plugins: ['@typescript-eslint/eslint-plugin', 'simple-import-sort'],
extends: ['plugin:@typescript-eslint/recommended', 'plugin:prettier/recommended'],
root: true,
env: {
node: true,
jest: true,
},
ignorePatterns: ['.eslintrc.js'],
rules: {
'@typescript-eslint/interface-name-prefix': 'off',
'@typescript-eslint/explicit-function-return-type': 'off',
'no-console': 'warn',
'no-absolute-path': 'error',
'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)$'],
],
},
],
// 'prettier/prettier': 'error',
},
// settings: {
// 'import/resolver': {
// typescript: {
// project: 'tsconfig.json', // Resolve paths using tsconfig.json
// },
// },
// },
};