forked from opencollective/opencollective-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.json
82 lines (82 loc) · 3.5 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
{
"extends": ["plugin:@typescript-eslint/recommended", "plugin:import/typescript", "opencollective"],
"parser": "@typescript-eslint/parser",
"env": { "mocha": true },
"plugins": ["@typescript-eslint", "graphql", "mocha", "simple-import-sort"],
"rules": {
// console logs are OK in Node
"no-console": "off",
"mocha/no-exclusive-tests": "error",
// use es6 module imports and exports
"import/no-commonjs": "error",
// common warnings in the codebase
"no-process-exit": "off",
"node/shebang": "off",
"no-useless-escape": "off",
"prefer-rest-params": "off",
// relaxing because we have many errors
"require-atomic-updates": "off",
// typescript
"node/no-missing-import": ["error", { "tryExtensions": [".js", ".ts"] }],
// enforce strictly camelcase
"camelcase": "error",
// simple-import-sort
"simple-import-sort/imports": [
"error",
{
"groups": [
// Side effect imports.
["^\\u0000"],
// Node.js builtins. You could also generate this regex if you use a `.js` config.
// For example: `^(${require("module").builtinModules.join("|")})(/|$)`
[
"^(_http_agent|_http_client|_http_common|_http_incoming|_http_outgoing|_http_server|_stream_duplex|_stream_passthrough|_stream_readable|_stream_transform|_stream_wrap|_stream_writable|_tls_common|_tls_wrap|assert|async_hooks|buffer|child_process|cluster|console|constants|crypto|dgram|dns|domain|events|fs|http|http2|https|inspector|module|net|os|path|perf_hooks|process|punycode|querystring|readline|repl|stream|string_decoder|sys|timers|tls|trace_events|tty|url|util|v8|vm|worker_threads|zlib)(/|$)"
],
// Packages.
// Things that start with a letter (or digit or underscore), or `@` followed by a letter.
["^@?\\w"],
// Absolute imports and other imports such as Vue-style `@/foo`.
// Anything that does not start with a dot.
["^[^.]"],
// Parent imports. Put `..` last.
["^\\.\\.(?!/?$)", "^\\.\\./?$"],
// Other relative imports. Put same-folder imports and `.` last.
["^\\./(?=.*/)(?!/?$)", "^\\.(?!/?$)", "^\\./?$"]
]
}
],
// tweak typescript defaults
"@typescript-eslint/ban-types": "warn",
// GraphQL
// To lint multiple schemas each one needs a different tagName.
// https://github.com/apollographql/eslint-plugin-graphql#additional-schemas-or-tags
"graphql/template-strings": [
"error",
{ "env": "apollo", "projectName": "opencollective_v1" },
{ "env": "apollo", "tagName": "gqlV2", "projectName": "opencollective_v2" }
],
"graphql/named-operations": ["error"],
"graphql/capitalized-type-name": ["error"],
// This rule is useful in frontend(s), but it's totally fine to keep tests for deprecated fields in API
"graphql/no-deprecated-fields": "off",
// Already being validated by @typescript-eslint/no-unused-vars
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": ["error"]
},
// Disable typescript checks in JS
"overrides": [
{
"files": ["*.js"],
"rules": {
"@typescript-eslint/no-use-before-define": "off",
"@typescript-eslint/indent": "off",
"@typescript-eslint/explicit-function-return-type": "off",
"@typescript-eslint/explicit-module-boundary-types": "off"
}
}
],
"settings": {
// Ignore .d.ts files for import (they just define the types)
"import/ignore": [".d.ts$"]
}
}