/
.eslintrc.js
134 lines (134 loc) · 3.7 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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
module.exports = {
parserOptions: {
ecmaVersion: 2020,
project: require.resolve("./tsconfig.json"),
},
extends: [
"plugin:@ota-meshi/recommended",
"plugin:@ota-meshi/+node",
"plugin:@ota-meshi/+typescript",
"plugin:@ota-meshi/+eslint-plugin",
"plugin:@ota-meshi/+vue3",
"plugin:@ota-meshi/+json",
"plugin:@ota-meshi/+package-json",
"plugin:@ota-meshi/+yaml",
"plugin:@ota-meshi/+md",
"plugin:@ota-meshi/+prettier",
],
rules: {
"require-jsdoc": "error",
"no-warning-comments": "warn",
"no-lonely-if": "off",
"@typescript-eslint/no-non-null-assertion": "off",
"@typescript-eslint/no-explicit-any": "off",
"no-shadow": "off",
"one-var": "off",
"no-invalid-this": "off",
// Repo rule
"no-restricted-imports": [
"error",
{
patterns: [
{
group: ["/regexpp", "/regexpp/*"],
message: "Please use `@eslint-community/regexpp` instead.",
},
{
group: ["/eslint-utils", "/eslint-utils/*"],
message: "Please use `@eslint-community/eslint-utils` instead.",
},
],
},
],
"no-restricted-properties": [
"error",
{
object: "context",
property: "getSourceCode",
message:
"Please use `eslint-compat-utils` module's `getSourceCode(context)` instead.",
},
{
object: "context",
property: "sourceCode",
message:
"Please use `eslint-compat-utils` module's `getSourceCode(context)` instead.",
},
{
object: "context",
property: "getFilename",
message:
"Please use `eslint-compat-utils` module's `getFilename(context)` instead.",
},
{
object: "context",
property: "filename",
message:
"Please use `eslint-compat-utils` module's `getFilename(context)` instead.",
},
{
object: "context",
property: "getCwd",
message:
"Please use `eslint-compat-utils` module's `getCwd(context)` instead.",
},
{
object: "context",
property: "cwd",
message:
"Please use `eslint-compat-utils` module's `getCwd(context)` instead.",
},
{
object: "context",
property: "getScope",
message:
"Please use `eslint-compat-utils` module's `getSourceCode(context).getScope()` instead.",
},
{
object: "context",
property: "parserServices",
message:
"Please use `eslint-compat-utils` module's `getSourceCode(context).parserServices` instead.",
},
],
},
overrides: [
{
files: ["*.ts", "*.mts"],
rules: {
"@typescript-eslint/naming-convention": "off",
},
parser: "@typescript-eslint/parser",
parserOptions: {
sourceType: "module",
project: "./tsconfig.json",
},
},
{
files: ["*.md/**", "**/*.md/**"],
rules: {
"n/no-missing-import": "off",
},
},
{
files: ["scripts/**/*.ts", "tests/**/*.ts", "tests-integrations/**/*.ts"],
rules: {
"require-jsdoc": "off",
"no-console": "off",
"@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-misused-promises": "off",
},
},
{
files: ["docs/.vitepress/**/*.*"],
rules: {
"eslint-plugin/require-meta-docs-description": "off",
"eslint-plugin/require-meta-docs-url": "off",
"eslint-plugin/require-meta-type": "off",
"eslint-plugin/prefer-message-ids": "off",
"eslint-plugin/prefer-object-rule": "off",
"eslint-plugin/require-meta-schema": "off",
},
},
],
};