-
Notifications
You must be signed in to change notification settings - Fork 192
/
Copy patheslint.config.js
92 lines (90 loc) · 2.88 KB
/
eslint.config.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
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
// @ts-check
import gitignore from 'eslint-config-flat-gitignore';
import {
code,
compat,
jsons,
override,
tslint,
node,
config,
} from '@glimmer-workspace/eslint-plugin';
/** @internal */
export default config(
gitignore(),
{
name: '@glimmer-workspace/ignores',
ignores: ['ts-dist/**/*'],
},
override('no-console packages', {
filter: 'env!=console',
rules: { 'no-console': 'error' },
}),
override('console packages', {
filter: 'env=console',
rules: { 'no-console': 'off' },
}),
code('strict packages', {
filter: 'strictness=strict',
extends: [tslint.configs.strictTypeChecked],
rules: {
'@typescript-eslint/consistent-return': 'off',
'@typescript-eslint/no-invalid-void-type': 'off',
'@typescript-eslint/no-unnecessary-type-parameters': 'off',
'@typescript-eslint/no-confusing-void-expression': [
'error',
{ ignoreVoidOperator: true, ignoreVoidReturningFunctions: true },
],
'@typescript-eslint/no-unnecessary-condition': [
'error',
{ allowConstantLoopConditions: true, checkTypePredicates: false },
],
},
}),
code('loose packages', {
filter: 'strictness=loose',
extends: [tslint.configs.recommendedTypeChecked],
rules: {
'@typescript-eslint/no-explicit-any': 'off',
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-return': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
'@typescript-eslint/no-unsafe-function-type': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/restrict-template-expressions': 'off',
'@typescript-eslint/no-deprecated': 'error',
'@typescript-eslint/no-floating-promises': 'error',
},
}),
code('test packages', {
filter: 'scope=@glimmer-test',
extends: [tslint.configs.recommendedTypeChecked, compat.extends('plugin:qunit/recommended')],
rules: {
'qunit/require-expect': ['error', 'never-except-zero'],
// we're using assert.step instead of this sort of thing
'qunit/no-conditional-assertions': 'off',
'@typescript-eslint/no-explicit-any': 'warn',
'@typescript-eslint/no-non-null-assertion': 'warn',
'@typescript-eslint/no-unsafe-member-access': 'warn',
'@typescript-eslint/no-unsafe-call': 'warn',
'@typescript-eslint/no-unsafe-return': 'warn',
'@typescript-eslint/restrict-template-expressions': 'warn',
'@typescript-eslint/no-unsafe-assignment': 'warn',
'@typescript-eslint/no-unsafe-argument': 'warn',
},
}),
code('type packages', {
filter: 'scope=@types',
extensions: ['d.ts'],
extends: [tslint.configs.recommendedTypeChecked],
}),
code('node packages', {
filter: 'env=node',
plugins: {
n: node,
},
rules: { 'n/no-process-exit': 'error' },
}),
jsons
);