-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
eslint.config.js
113 lines (104 loc) · 2.8 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
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
/**
* @fileoverview ESLint configuration file.
* @author Nicholas C. Zakas
*/
//-----------------------------------------------------------------------------
// Imports
//-----------------------------------------------------------------------------
import eslintConfigESLint from "eslint-config-eslint";
import eslintPlugin from "eslint-plugin-eslint-plugin";
import json from "@eslint/json";
//-----------------------------------------------------------------------------
// Helpers
//-----------------------------------------------------------------------------
const eslintPluginJSDoc = eslintConfigESLint.find(
config => config.plugins?.jsdoc,
).plugins.jsdoc;
const eslintPluginRulesRecommendedConfig =
eslintPlugin.configs["flat/rules-recommended"];
const eslintPluginTestsRecommendedConfig =
eslintPlugin.configs["flat/tests-recommended"];
//-----------------------------------------------------------------------------
// 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",
},
},
},
{
files: ["src/rules/*.js"],
...eslintPluginRulesRecommendedConfig,
rules: {
...eslintPluginRulesRecommendedConfig.rules,
"eslint-plugin/require-meta-schema": "off", // `schema` defaults to []
"eslint-plugin/prefer-placeholders": "error",
"eslint-plugin/prefer-replace-text": "error",
"eslint-plugin/report-message-format": ["error", "[^a-z].*\\.$"],
"eslint-plugin/require-meta-docs-description": [
"error",
{ pattern: "^(Enforce|Require|Disallow) .+[^. ]$" },
],
},
},
{
files: ["tests/rules/*.test.js"],
...eslintPluginTestsRecommendedConfig,
rules: {
...eslintPluginTestsRecommendedConfig.rules,
"eslint-plugin/test-case-property-ordering": [
"error",
[
"name",
"filename",
"code",
"output",
"language",
"options",
"languageOptions",
"errors",
],
],
"eslint-plugin/test-case-shorthand-strings": "error",
},
},
];