forked from alexa/ask-toolkit-for-vscode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
143 lines (137 loc) · 6.55 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
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
131
132
133
134
135
136
137
138
139
140
141
142
143
module.exports = {
"root": true,
"parser": "@typescript-eslint/parser",
"plugins": ["@typescript-eslint", "prettier"],
"env": {
"node": true,
"es6": true,
},
"extends": [
// Ideally want to use airbnb config, but that is leading to module not found error for vscode
// "airbnb",
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:eslint-comments/recommended",
// Disable below extends and parser options if having performance issues
// https://github.com/typescript-eslint/typescript-eslint/blob/master/docs/getting-started/linting/TYPED_LINTING.md
'plugin:@typescript-eslint/recommended-requiring-type-checking',
],
"rules": {
// ---------------------------------------------------------
// --- Rules from eslint:recommended that we override
// ---------------------------------------------------------
"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 }],
"indent": "off",
"new-parens": "error",
"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",
// TODO: reEnable no-unsafe-assignment
"@typescript-eslint/no-unsafe-assignment": "off",
// TODO: reEnable no-unsafe-member-access
"@typescript-eslint/no-unsafe-member-access": "off",
// TODO: reEnable restrict-template-expressions
"@typescript-eslint/restrict-template-expressions": "off",
// TODO: reEnable no-unused-vars
"@typescript-eslint/no-unused-vars": "off",
// TODO: reEnable explicit-module-boundary-types
"@typescript-eslint/explicit-module-boundary-types": "off"
// -- Rules form tsdoc
// "tsdoc/syntax": "warn", // TODO: enable once we have better tsdoc coverage
},
// parserOptions: {
// project: "./tsconfig.json",
// },
"parserOptions": {
"ecmaVersion": 6,
"sourceType": "module",
// Disable below extends and parser options if having performance issues
// https://github.com/typescript-eslint/typescript-eslint/blob/master/docs/getting-started/linting/TYPED_LINTING.md
"tsconfigRootDir": __dirname,
"project": "./tsconfig.json",
},
"settings": {
"import/extensions": [".js",".jsx",".ts",".tsx"],
"import/parsers": {
"@typescript-eslint/parser": [".ts",".tsx"]
},
"import/resolver": {
"node": {
"extensions": [".js",".jsx",".ts",".tsx"]
},
// use <root>/tsconfig.json
"typescript": {
// "alwaysTryTypes": true, // always try to resolve types under `<root>@types` directory even it doesn't contain any source code, like `@types/unist`,
// "directory": "./"
},
}
}
};