-
Notifications
You must be signed in to change notification settings - Fork 27
/
.eslintrc.js
116 lines (116 loc) · 3.72 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
module.exports = {
env: {
browser: true,
es6: true,
jest: true,
},
extends: ["airbnb", "plugin:testing-library/react", "prettier"],
globals: {
Atomics: "readonly",
SharedArrayBuffer: "readonly",
Fusion: "readonly",
history: "readonly",
},
ignorePatterns: [
"**/features/ad-taboola/default.jsx",
"**/features/alert-bar/default.jsx",
"**/features/search-results-list/_children/custom-content.jsx",
"**/features/search-results-list/_children/global-content.jsx",
],
overrides: [
{
files: ["**/?(*.)+(test).js(x)*"],
extends: ["plugin:testing-library/react"],
},
],
parser: "@babel/eslint-parser",
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 2020,
sourceType: "module",
},
plugins: ["jest", "jest-dom", "jsx-a11y", "react", "react-hooks", "testing-library"],
rules: {
"default-param-last": "warn",
"global-require": "off",
"import/no-extraneous-dependencies": "off", // This might be fine. It's worth looking into at the very least.
"import/no-named-as-default": "warn",
"import/no-named-as-default-member": "warn",
"import/no-unresolved": [
2,
{
ignore: [
"react",
"^fusion:.+$",
"^@arc-test-org/.+$",
"^@arc-publishing/.+$",
"^@wpmedia/.+$",
"~/blocks.json",
],
},
],
// For list of a11y definitions for this see: https://github.com/evcohen/eslint-plugin-jsx-a11y
"jsx-a11y/accessible-emoji": 2,
"jsx-a11y/alt-text": 2,
"jsx-a11y/anchor-has-content": 2,
"jsx-a11y/anchor-is-valid": 2,
"jsx-a11y/aria-activedescendant-has-tabindex": 2,
"jsx-a11y/aria-props": 2,
"jsx-a11y/aria-proptypes": 2,
"jsx-a11y/aria-role": 2,
"jsx-a11y/aria-unsupported-elements": 2,
"jsx-a11y/click-events-have-key-events": 2,
"jsx-a11y/control-has-associated-label": "warn",
"jsx-a11y/heading-has-content": 2,
"jsx-a11y/html-has-lang": 2,
"jsx-a11y/iframe-has-title": 2,
"jsx-a11y/img-redundant-alt": "off",
"jsx-a11y/interactive-supports-focus": 2,
"jsx-a11y/label-has-associated-control": [
2,
{
required: {
some: ["nesting", "id"],
},
},
],
"jsx-a11y/lang": 2,
"jsx-a11y/media-has-caption": "off",
"jsx-a11y/mouse-events-have-key-events": 2,
"jsx-a11y/no-access-key": 2,
"jsx-a11y/no-autofocus": 2,
"jsx-a11y/no-distracting-elements": 2,
"jsx-a11y/no-interactive-element-to-noninteractive-role": 2,
"jsx-a11y/no-noninteractive-element-interactions": "off",
"jsx-a11y/no-noninteractive-element-to-interactive-role": "off",
"jsx-a11y/no-noninteractive-tabindex": 2,
"jsx-a11y/no-onchange": 2,
"jsx-a11y/no-redundant-roles": 2,
"jsx-a11y/no-static-element-interactions": 2,
"jsx-a11y/role-has-required-aria-props": 2,
"jsx-a11y/role-supports-aria-props": 2,
"jsx-a11y/scope": 2,
"jsx-a11y/tabindex-no-positive": 2,
"no-promise-executor-return": "warn",
"no-underscore-dangle": ["error", { allow: ["_website", "_id"] }],
"react-hooks/exhaustive-deps": "error",
"react-hooks/rules-of-hooks": "error",
"react/forbid-prop-types": "off",
"react/function-component-definition": "off",
"react/jsx-props-no-spreading": "off",
"react/no-danger": "off",
"react/no-unstable-nested-components": "warn",
"react/prop-types": "off", // We will want to be more granular with this I assume.
"react/require-default-props": "off", // We will also want to have some rules around this. Whitelisting certain props for example
"testing-library/await-async-queries": "warn",
"testing-library/await-async-utils": "warn",
"testing-library/no-container": "warn",
"testing-library/no-node-access": "warn",
"testing-library/no-unnecessary-act": "warn",
"testing-library/prefer-find-by": "warn",
"testing-library/prefer-presence-queries": "warn",
"testing-library/prefer-screen-queries": "warn",
},
};