-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.eslintrc.js
307 lines (279 loc) · 10.7 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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
module.exports = {
extends: [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"plugin:react/recommended",
// Uncomment to enable cycle-detection. Note that caching doesn't seem to
// work quite right with this plugin; after fixing some issues, you will
// have to delete .eslintcache to make it stop reporting the error.
// Commented out because there are immport cycles that haven't been resolved
// yet.
"plugin:import/typescript",
"plugin:prettier/recommended",
],
parser: "@typescript-eslint/parser",
parserOptions: {
allowImportExportEverywhere: true,
ecmaVersion: 6,
sourceType: "module",
project: "./tsconfig.json",
},
rules: {
"babel/generator-star-spacing": 0,
// A function with a name starting with an uppercase letter should only be
// used as a constructor
"babel/new-cap": [
1,
{
capIsNewExceptions: [
"Optional",
"OneOf",
"Maybe",
"MailChimpAPI",
"Juice",
"Run",
"AppComposer",
"Query",
"Map",
"List",
],
},
],
"babel/array-bracket-spacing": 0,
"babel/object-curly-spacing": 0,
"babel/object-shorthand": 0,
"babel/arrow-parens": 0,
"eol-last": 1,
"no-await-in-loop": 0,
"comma-dangle": 0,
eqeqeq: [1, "always", { null: "ignore" }],
"key-spacing": 0,
"no-extra-boolean-cast": 0,
"no-undef": 1,
"no-unused-vars": [
1,
{
vars: "all",
args: "none",
varsIgnorePattern: "React|PropTypes|Component",
},
],
"no-console": ["warn", { allow: ["info", "warn", "error"] }],
"no-template-curly-in-string": 1,
"no-tabs": 1,
"no-extend-native": 1,
"react/prop-types": 0,
"react/jsx-equals-spacing": 1,
"react/jsx-pascal-case": 1,
"react/jsx-child-element-spacing": 1,
"no-case-declarations": 0,
"react/no-unescaped-entities": 0,
"react/display-name": 0,
"react/jsx-no-comment-textnodes": 1,
// Differs from no-mixed-operators default only in that "??" is added to the first group
"react-hooks/rules-of-hooks": "error",
"react-hooks/exhaustive-deps": "warn",
"import/no-unresolved": "off",
"import/named": 1,
"import/default": 1,
"import/namespace": 1,
"import/no-dynamic-require": 1,
"import/no-self-import": 1,
"import/export": 1,
"import/no-named-as-default-member": 1,
"import/no-deprecated": 1,
"import/no-extraneous-dependencies": 0,
"import/no-duplicates": 1,
"import/extensions": 0,
"import/no-cycle": 1,
"import/no-mutable-exports": 1,
"import/no-restricted-paths": [
"error",
{
zones: [
{
target: "packages/lesswrong/components",
from: "packages/lesswrong/server",
message: "server cannot be imported into components - move the shared code into lib",
},
{
target: "packages/lesswrong/lib",
from: "packages/lesswrong/server",
message: "server cannot be imported into lib - move the shared code into lib",
},
{
target: "packages/lesswrong/client",
from: "packages/lesswrong/server",
message: "server cannot be imported into client - move the shared code into lib",
},
{
target: "packages/lesswrong/themes",
from: "packages/lesswrong/server",
message: "server cannot be imported into themes - move the shared code into lib",
},
],
},
],
"no-restricted-imports": [
"error",
{
paths: [
{ name: "lodash", message: "Don't import all of lodash, import a specific lodash function, eg lodash/sumBy" },
{
name: "lodash/fp",
message: "Don't import all of lodash/fp, import a specific lodash function, eg lodash/fp/capitalize",
},
{ name: "@material-ui", message: "Don't import all of material-ui/icons" },
{ name: "@material-ui/core", message: "Don't import all of material-ui/core" },
{ name: "@material-ui/core/colors", message: "Don't use material-ui/core/colors, use the theme palette" },
{ name: "@material-ui/icons", message: "Don't import all of material-ui/icons" },
{
name: "@material-ui/core/Hidden",
message:
"Don't use material-UI's Hidden component, it's subtly broken; use breapoints and JSS styles instead",
},
{
name: "@material-ui/core/Typography",
message: "Don't use material-UI's Typography component; use Components.LWTypography or JSS styles",
},
{
name: "@material-ui/core/Dialog",
message: "Don't use material-UI's Dialog component directly, use LWDialog instead",
},
{
name: "@material-ui/core/Popper",
importNames: ["Popper"],
message: "Don't use material-UI's Popper component directly, use LWPopper instead",
},
{
name: "@material-ui/core/MenuItem",
message: "Don't use material-UI's MenuItem component directly; use Components.MenuItem or JSS styles",
},
{
name: "@material-ui/core/NoSsr",
importNames: ["Popper"],
message: "Don't use @material-ui/core/NoSsr/NoSsr; use react-no-ssr instead",
},
{ name: "react-router", message: "Don't import react-router, use lib/reactRouterWrapper" },
{ name: "react-router-dom", message: "Don't import react-router-dom, use lib/reactRouterWrapper" },
],
patterns: ["@material-ui/core/colors/*"],
},
],
// Warn on missing await
// The ignoreVoid option makes it so that
// void someAwaitableFunction()
// can be used as a way of marking a function as deliberately not-awaited.
"@typescript-eslint/no-floating-promises": [
1,
{
ignoreVoid: true,
},
],
// Like no-implicit-any, but specifically for things that are exported. Turn
// on some day, but not yet.
"@typescript-eslint/explicit-module-boundary-types": 0,
// Allow @ts-ignore
"@typescript-eslint/ban-ts-comment": 0,
// explicit-function-return-type: Disabled. Would forbid functions with
// undeclared return type.
"@typescript-eslint/explicit-function-return-type": 0,
// no-use-before-define: Disabled. This would require all function calls to
// be below their definition in files, which there's no good reason for.
"@typescript-eslint/no-use-before-define": 0,
// prefer-const: Disabled. Would forbit declaring a variable as mutable
// (with let) when it could have been immutable (with const).
"prefer-const": 0,
// no-var: Disabled. Would forbid declaring a variable with "var" (as
// opposed to let or const).
"no-var": 0,
// ban-ts-ignore: Disabled. Would forbid use of @ts-ignore, which suppresses
// type-checking errors.
"@typescript-eslint/ban-ts-ignore": 0,
// no-non-null-assertion: Currently disabled, may enable later. Forbids use
// of "somevar!" to coerce somevar from Type|null to Type.
"@typescript-eslint/no-non-null-assertion": 0,
// no-empty-interface: Disabled. Would forbid interfaces with no members
// (ie, interfaces defined solely by other interfaces that they extend).
"@typescript-eslint/no-empty-interface": 0,
// member-delimiter-style: Disabled. Would make semicolons between
// interface members non-optional.
"@typescript-eslint/member-delimiter-style": 0,
// type-annotation-spacing: Disabled. Would enforce spaces around => and
// after : in type annotations.
"@typescript-eslint/type-annotation-spacing": 0,
// no-empty-function: Disabled. Would forbid functions with empty bodies.
"@typescript-eslint/no-empty-function": 0,
// ban-types: Disabled. Would forbid '{}' as a type, which means "any non-
// nullish value".
"@typescript-eslint/ban-types": 0,
// prefer-rest-params: Currently disabled. Would forbid use of the `arguments`
// keyword.
"prefer-rest-params": 0,
// prefer-spread: Disabled. Would forbid use of fn.apply(foo) as opposed to
// fn(...foo).
"prefer-spread": 0,
// no-this-alias. Currently disabled. Would forbid 'const self=this'.
"@typescript-eslint/no-this-alias": 0,
// class-name-casing: Disabled. Forbids types from deviating from upper-
// camelcase, which would forbid the naming convention we are using for
// subfragments.
"@typescript-eslint/class-name-casing": 0,
// camelcase: Disabled. Would force type and variable names to be camel
// case.
"@typescript-eslint/camelcase": 0,
// no-prototype-builtins: Disabled. Would forbid hasOwnProperty.
"no-prototype-builtins": 0,
// no-extra-semi: Disabled. Would forbid semicolons after class declarations
"no-extra-semi": 0,
"@typescript-eslint/no-extra-semi": 0,
// no-var-requires: Disabled. Would forbid use of require() statements of
// libraries from node_modules.
"@typescript-eslint/no-var-requires": 0,
// no-undef: Currently disabled due to excessive false positives which are
// hard to resolve (in particular, the `registerComponent` idiom generates
// a false positive). If something were truly undefined, it would generate
// an error in `npm run checktypes`, which does not have this issue.
"no-undef": 0,
// no-explicit-any: Some day, we may be ready to turn on this rule. That day
// is not today. Activating this would require *everything* be fully typed,
// including interface points with libraries that might not have type
// annotations available.
"@typescript-eslint/no-explicit-any": 0,
// no-unused-vars: Currently disabled due to excessive false positives which
// are hard to resolve (this counts things as unused when they actually are
// used, if the usage is as a type rather than as a value.)
"no-unused-vars": 0,
"@typescript-eslint/no-unused-vars": 0,
},
env: {
browser: true,
commonjs: true,
es6: true,
node: true,
},
plugins: ["@typescript-eslint", "babel", "react", "react-hooks", "import"],
settings: {
"import/core-modules": ["sinon", "sinon-chai", "chai-enzyme"],
react: {
version: "16.4.1",
},
},
root: true,
globals: {
param: true,
returns: true,
describe: true,
it: true,
before: true,
after: true,
beforeEach: true,
afterEach: true,
},
ignorePatterns: [
"build.js",
// You wouldn't have thought this was necessary would you
".eslintrc.js",
],
};