-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.js
118 lines (117 loc) · 2.81 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
/* eslint-disable import/unambiguous */
/* eslint-disable import/no-commonjs */
module.exports = {
env: {
browser: true,
es2021: true
},
extends: [
"airbnb-base",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"plugin:prettier/recommended"
],
overrides: [
{
files: ["*.spec.ts"],
globals: {
/**
* These globals are all used by Jest and as such are restricted to test files
*/
afterEach: "readonly",
describe: "readonly",
beforeEach: "readonly",
expect: "readonly",
it: "readonly",
jest: "readonly"
}
},
{
files: ["*.types.ts"],
rules: {
"no-use-before-define": "off",
"no-unused-vars": "off"
}
}
],
parser: "@typescript-eslint/parser",
parserOptions: {
ecmaVersion: "latest",
sourceType: "module"
},
plugins: ["@typescript-eslint", "prettier"],
rules: {
/**
* JavaScript allows the omission of curly braces when a block contains
* only one statement. However, it is considered by many to be best
* practice to never omit curly braces around blocks, even when they
* are optional, because it can lead to bugs and reduces code clarity.
*/
curly: ["error", "all"],
/**
* Since we have node-resolve installed we do not need extensions listed.
*/
"import/extensions": [
"error",
"ignorePackages",
{
js: "never",
ts: "never"
}
],
/**
* This slightly alters the allowed order of imports to allow us to put types clearly at the bottom.
*/
"import/order": [
"error",
{
groups: [
"index",
"sibling",
"parent",
"internal",
"external",
"builtin",
"object",
"type"
]
}
],
/**
* We allow console errors to be used for the sake of information
*/
"no-console": [
"error",
{
allow: ["error"]
}
],
/**
* This rule is disabled in functions since there is no problem using a
* variable in a function before it is defined at the root. In that case
* it is still defined before use and allows us to keep everything in
* alphabetical order. In the case that the variable truly does not exist,
* Typescript should let us know…
*
* example:
* const getCoordinates = (x) => retrieveCoorsJson()[x];
* const retrieveCoorsJson = () => fetch();
*/
"no-use-before-define": [
"error",
{
functions: false
}
]
},
settings: {
"import/parsers": {
"@typescript-eslint/parser": [".ts"]
},
"import/resolver": {
typescript: {
alwaysTryTypes: true
}
}
}
};