-
Notifications
You must be signed in to change notification settings - Fork 23
/
.eslintrc.json
130 lines (124 loc) · 5.31 KB
/
.eslintrc.json
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
{
"extends": [
"eslint:recommended",
"prettier/@typescript-eslint"
//"plugin:@typescript-eslint/recommended"
//"plugin:@typescript-eslint/recommended-requiring-type-checking" // TODO: fix errors and turn on.
],
"parser": "@typescript-eslint/parser",
"plugins": ["@typescript-eslint", "@typescript-eslint/eslint-plugin", "eslint-plugin-tsdoc"],
"env": {
"commonjs": true,
"node": true,
"mocha": true
},
"globals": {
"Atomics": "readonly",
"SharedArrayBuffer": "readonly"
},
"parserOptions": {
"ecmaVersion": 2019,
"sourceType": "module",
"ecmaFeatures": {
"modules": true,
"impliedStrict": true
},
// NOTE: change this to an absolute path if viewing the code via a skill
// codebase with files in /lambda. This fixes 'Can't open tsconfig.json'
// errors
"project": "tsconfig.json"
},
"rules": {
// ---------------------------------------------------------
// --- Rules from eslint:recommended that we override
// ---------------------------------------------------------
"no-empty": "warn",
"no-unused-vars": "off", // because it flags types that are imported for type declarations (but otherwise unused).
"no-undef": "off", // because if flags lack of import for Set. // TODO: fix the issues and remove this override.
// ---------------------------------------------------------
// --- Rules that we add and/or customize
// ---------------------------------------------------------
"eqeqeq": ["error", "smart"],
"guard-for-in": "error",
"id-blacklist": [
"error",
"any",
"Number",
"number",
"String",
"string",
"Boolean",
"boolean",
"Undefined",
"undefined"
],
"id-match": "error",
"import/no-extraneous-dependencies": ["off", { "devDependencies": false }],
"no-caller": "error",
"no-duplicate-imports": "error",
"no-eval": "error",
"no-extra-bind": "error",
"no-new-func": "error",
"no-new-wrappers": "error",
"no-return-await": "error",
"no-sequences": "error",
"no-shadow": ["off", { "hoist": "all" }],
"no-undef-init": "error",
"no-var": "error",
"object-shorthand": "error",
"one-var": ["error", "never"],
"prefer-const": "error",
"prefer-object-spread": "error",
"radix": "error",
// -- Rules from @typescript-eslint
"@typescript-eslint/strict-boolean-expressions": ["error"], // avoids frequent sources of errors: 0, "", Promise<T>, null vs undefined
"@typescript-eslint/adjacent-overload-signatures": "error",
"@typescript-eslint/array-type": ["error", { "default": "array-simple" }],
"@typescript-eslint/ban-types": [
"error",
{
"types": {
"Object": { "message": "Avoid using the `Object` type. Did you mean `object`?" },
"Function": {
"message": "Avoid using the `Function` type. Prefer a specific function type, like `() => void`."
},
"Boolean": { "message": "Avoid using the `Boolean` type. Did you mean `boolean`?" },
"Number": { "message": "Avoid using the `Number` type. Did you mean `number`?" },
"String": { "message": "Avoid using the `String` type. Did you mean `string`?" },
"Symbol": { "message": "Avoid using the `Symbol` type. Did you mean `symbol`?" }
}
}
],
"@typescript-eslint/consistent-type-assertions": "error",
"@typescript-eslint/consistent-type-definitions": "off",
"@typescript-eslint/explicit-member-accessibility": ["off", { "accessibility": "explicit" }],
"@typescript-eslint/interface-name-prefix": "off",
"@typescript-eslint/member-ordering": "off",
"@typescript-eslint/no-empty-function": "off",
"@typescript-eslint/no-empty-interface": "off",
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-misused-new": "error",
"@typescript-eslint/no-floating-promises": ["error"], // prevent those nasty forgotten promises !
"@typescript-eslint/no-namespace": "off",
"@typescript-eslint/no-parameter-properties": "off",
"@typescript-eslint/no-this-alias": "error",
"@typescript-eslint/no-unused-expressions": "off",
"@typescript-eslint/no-use-before-define": "off",
"@typescript-eslint/no-var-requires": "error",
"@typescript-eslint/prefer-for-of": "error",
"@typescript-eslint/prefer-function-type": "error",
"@typescript-eslint/prefer-namespace-keyword": "error",
"@typescript-eslint/triple-slash-reference": [
"error",
{
"path": "always",
"types": "prefer-import",
"lib": "always"
}
],
"@typescript-eslint/type-annotation-spacing": "error",
"@typescript-eslint/unified-signatures": "error",
// -- Rules form tsdoc
"tsdoc/syntax": "error"
}
}