-
-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy patheslint.config.mjs
65 lines (60 loc) · 1.52 KB
/
eslint.config.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
// @ts-check
import eslint from '@eslint/js';
import eslintPluginPrettierRecommended from 'eslint-plugin-prettier/recommended';
import globals from 'globals';
import xo from 'eslint-config-xo';
import tseslint from 'typescript-eslint';
export default tseslint.config([
{
ignores: ['dist', 'node_modules', 'coverage'],
},
eslint.configs.recommended,
...xo,
{
languageOptions: {
globals: {
...globals.node,
},
},
rules: {
'default-param-last': 'off',
'padding-line-between-statements': 'off',
'max-params': 'off',
'no-eq-null': 'off',
eqeqeq: [
'error',
'always',
{
null: 'ignore',
},
],
'prettier/prettier': 'error',
},
},
{
files: ['**/*.mts', '**/*.ts'],
extends: [...tseslint.configs.strictTypeChecked],
languageOptions: {
parserOptions: {
projectService: true,
},
},
rules: {
'@typescript-eslint/no-explicit-any': 'off',
// TODO: Need to fix the code to allow those rules
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
'@typescript-eslint/no-unsafe-return': 'off',
'@typescript-eslint/no-non-null-assertion': 'off',
},
},
{
files: ['__tests__/**'],
rules: {
'@typescript-eslint/unbound-method': 'off',
},
},
eslintPluginPrettierRecommended,
]);