-
Notifications
You must be signed in to change notification settings - Fork 2
/
.eslintrc
138 lines (138 loc) · 4.15 KB
/
.eslintrc
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
{
"env": {
"node": true,
"jest": true
},
"parser": "@babel/eslint-parser",
"plugins": [
"prettier",
"flowtype",
"@babel"
],
"rules": {
"prettier/prettier": "error",
// The default rule wants to enforce // @flow, but we frequently have it
// as part of the file's docstring.
"flowtype/require-valid-file-annotation": [
0,
"always"
],
// ---------------------------------------
// ES6 rules.
"constructor-super": 2,
"no-const-assign": 2,
"no-this-before-super": 2,
"no-console": 0,
"no-var": 2,
"prefer-const": 2,
"prefer-spread": 2,
// We turned this off because it complains when you have a
// multi-line string, which I think is going too far.
"prefer-template": 0,
// We've decided explicitly not to care about this.
"arrow-parens": 0,
// ---------------------------------------
// ES6/jsx stuff that's disabled for now, but maybe shouldn't be.
// TODO(csilvers): enable these if/when community agrees on it.
"prefer-arrow-callback": 0,
// We'd possibly like to remove the 'properties': 'never' one day.
"camelcase": [
2,
{
"properties": "never",
"allow": [
"^UNSAFE_"
]
}
],
"curly": 2,
"eqeqeq": [
2,
"allow-null"
],
"guard-for-in": 2,
"linebreak-style": [
2,
"unix"
],
"max-lines": [
2,
1000
],
"no-alert": 2,
"no-array-constructor": 2,
"no-debugger": 2,
"no-dupe-class-members": 2,
"no-dupe-keys": 2,
"no-extra-bind": 2,
"no-new": 2,
"no-new-func": 2,
"no-new-object": 2,
"no-throw-literal": 2,
"no-undef": 2,
"no-unexpected-multiline": 2,
"no-unreachable": 2,
// NOTE: If you change the options here, be sure to update eslintrc.flow also
"no-unused-expressions": [
2,
{
"allowShortCircuit": true,
"allowTernary": true
}
],
"no-unused-vars": [
2,
{
"args": "none",
"varsIgnorePattern": "^_*$"
}
],
"no-useless-call": 2,
"no-with": 2,
"one-var": [
2,
"never"
],
// TODO(scottgrant): Add additional a11y rules as we support them.
// ---------------------------------------
// Stuff that's disabled for now, but maybe shouldn't be.
// TODO(jeresig): It's an anti-pattern but it appears to be used
// frequently in reducers, the alternative would be super-clunky.
"no-case-declarations": 0,
// TODO(csilvers): enable these if/when community agrees on it.
// Might be nice to turn this on one day, but since we don't
// use jsdoc anywhere it seems silly to require it yet.
"valid-jsdoc": 0,
"require-jsdoc": 0,
"flowtype/boolean-style": [
2,
"boolean"
],
"flowtype/define-flow-type": 1, // suppress no-undef on flow types
"flowtype/no-dupe-keys": 2,
// Use Flow's version of no-unused-expressions
"flowtype/no-unused-expressions": [
2,
{
"allowShortCircuit": true,
"allowTernary": true
}
],
"flowtype/no-weak-types": 0, // allow 'any' for now
// flow may still require parameter types in certain situations
"flowtype/require-parameter-type": 0,
"flowtype/require-return-type": 0,
"flowtype/sort": 0,
"flowtype/type-id-match": 0,
"flowtype/use-flow-type": 1 // suppress no-unused-vars on flow types
},
"extends": [
"prettier"
],
"globals": {
"DEBUG": "readonly",
"Promise": "readonly",
"Set": "readonly",
"__DEV__": "readonly"
}
}