-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy path.eslintrc.js
64 lines (60 loc) · 1.96 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
module.exports = {
root: true,
extends: [
require.resolve('@codecademy/eslint-config'),
'plugin:react/jsx-runtime',
],
plugins: ['eslint-plugin-gamut'],
rules: {
'gamut/prefer-themed': 'error',
'gamut/no-css-standalone': 'error',
'gamut/import-paths': 'error',
'import/no-extraneous-dependencies': 'off',
},
overrides: [
{
files: ['**/typings/*', '*.d.ts'],
rules: {
'@typescript-eslint/no-namespace': 'off',
},
},
{
files: ['*.mdx'],
rules: {
'gamut/import-paths': 'off',
},
},
{
// We need to override them here, because as a result of the `extends` command pulling
// in additional plugins, the base rules settings of turning this rules off were NOT
// being respected. By moving them into this override definition, they are properly
// being applied to subsequent plugin imports/extensions. Wild.
files: ['*.tsx', '*.ts'],
rules: {
// These rules could be useful, but we haven't gotten around to enabling them here
// See WEB-2 for general tracking.
'@typescript-eslint/no-explicit-any': 'off',
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/no-non-null-assertion': 'off',
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
'@typescript-eslint/no-unsafe-return': 'off',
'@typescript-eslint/restrict-plus-operands': 'off',
'@typescript-eslint/restrict-template-expressions': 'off',
'import/no-cycle': 'off',
'react/no-unknown-property': [
'error',
{ ignore: ['mask-type', 'xmlns-x', 'xmlns-i', 'xmlns-graph'] },
],
},
},
{
files: ['*.ts', '*.tsx', '*.js', '*.jsx'],
plugins: ['lodash'],
rules: {
'lodash/import-scope': ['error', 'method'],
},
},
],
};