-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.eslintrc.js
113 lines (113 loc) · 3.46 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
module.exports = {
ignorePatterns: [
"node_modules/*",
".next/*",
".out/*",
"public/explore/storybook/*",
"src/generated/*",
"cypress/integration/examples",
],
env: {
browser: true,
es2021: true,
node: true,
jest: true,
"cypress/globals": true,
},
extends: [
"next",
"airbnb",
"plugin:@typescript-eslint/recommended",
"plugin:react/recommended",
"plugin:react-hooks/recommended",
"plugin:jsx-a11y/recommended",
"plugin:prettier/recommended",
"plugin:jest-dom/recommended",
"plugin:cypress/recommended",
],
parser: "@typescript-eslint/parser",
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 12,
sourceType: "module",
},
plugins: [
"react",
"@typescript-eslint",
"tailwindcss",
"jest-dom",
"cypress",
],
// other configuration are omitted for brevity
settings: {
"import/resolver": {
typescript: {}, // this loads <rootdir>/tsconfig.json to eslint
},
},
rules: {
"prettier/prettier": ["error", {}, { usePrettierrc: true }],
// No need to import React when using Next.js
"react/react-in-jsx-scope": "off",
"react/jsx-filename-extension": [1, { extensions: [".ts", ".tsx"] }],
"import/extensions": "off",
"react/prop-types": "off",
"jsx-a11y/anchor-is-valid": "off",
"react/jsx-props-no-spreading": "off", // ["error", { custom: "ignore" }],
"react/no-unescaped-entities": "off",
"import/no-cycle": [0, { ignoreExternal: true }],
// "prefer-const": "off",
// needed because of https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-use-before-define.md#how-to-use & https://stackoverflow.com/questions/63818415/react-was-used-before-it-was-defined
"no-use-before-define": "off",
"@typescript-eslint/no-use-before-define": [
"error",
{ functions: false, classes: false, variables: false },
],
// needed because of https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unused-vars.md
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": ["error"],
"import/prefer-default-export": "off",
// weird - thinks "react" is "@types/react"
"import/no-extraneous-dependencies": [
"error",
{
devDependencies: true,
optionalDependencies: false,
peerDependencies: false,
},
],
"no-restricted-imports": [
"error",
{
patterns: [
{
group: [
"../generated/graphql",
"../../generated/graphql",
"../../../generated/graphql",
"../../../../generated/graphql",
"../../../../../generated/graphql",
],
message:
"Don't import generated modules directly, import from src/libs/graphql",
},
],
},
],
"tailwindcss/classnames-order": "error",
"tailwindcss/no-custom-classname": [
"warn",
{
whitelist: ["bg-primary", "bg-brand-primary", "bg-brand-secondary"],
},
],
"tailwindcss/no-contradicting-classname": "error",
// https://github.com/testing-library/eslint-plugin-jest-dom#usage
"jest-dom/prefer-checked": "error",
"jest-dom/prefer-enabled-disabled": "error",
"jest-dom/prefer-required": "error",
"jest-dom/prefer-to-have-attribute": "error",
"jsx-a11y/click-events-have-key-events": "off",
},
};