-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
eslint.config.js
71 lines (63 loc) · 1.66 KB
/
eslint.config.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
/**
* @fileoverview ESLint configuration file.
* @author Nicholas C. Zakas
*/
//-----------------------------------------------------------------------------
// Imports
//-----------------------------------------------------------------------------
import eslintConfigESLint from "eslint-config-eslint";
import json from "@eslint/json";
//-----------------------------------------------------------------------------
// Helpers
//-----------------------------------------------------------------------------
const eslintPluginJSDoc = eslintConfigESLint.find(
config => config.plugins?.jsdoc,
).plugins.jsdoc;
//-----------------------------------------------------------------------------
// Configuration
//-----------------------------------------------------------------------------
export default [
{
ignores: ["**/tests/fixtures/", "**/dist/"],
},
...eslintConfigESLint.map(config => ({
files: ["**/*.js"],
...config,
})),
{
files: ["**/*.json"],
ignores: ["**/package-lock.json"],
language: "json/json",
...json.configs.recommended,
},
{
files: ["**/*.js"],
rules: {
// disable rules we don't want to use from eslint-config-eslint
"no-undefined": "off",
"class-methods-use-this": "off",
// TODO: re-enable eslint-plugin-jsdoc rules
...Object.fromEntries(
Object.keys(eslintPluginJSDoc.rules).map(name => [
`jsdoc/${name}`,
"off",
]),
),
},
},
{
files: ["**/tests/**"],
languageOptions: {
globals: {
describe: "readonly",
xdescribe: "readonly",
it: "readonly",
xit: "readonly",
beforeEach: "readonly",
afterEach: "readonly",
before: "readonly",
after: "readonly",
},
},
},
];