-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy patheslint.config.mjs
More file actions
74 lines (73 loc) · 1.92 KB
/
eslint.config.mjs
File metadata and controls
74 lines (73 loc) · 1.92 KB
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
import lexicalPlugin from "@lexical/eslint-plugin";
import nx from "@nx/eslint-plugin";
import tseslint from "typescript-eslint";
export default [
...nx.configs["flat/base"],
...nx.configs["flat/typescript"],
...nx.configs["flat/javascript"],
...tseslint.configs.strict,
...tseslint.configs.stylistic,
{
ignores: [
"**/build",
"**/dist",
"**/out-tsc",
"**/temp",
"**/tmp",
"**/coverage",
"**/vite.config.*.timestamp*",
"**/vitest.config.*.timestamp*",
],
},
{
files: ["**/*.ts", "**/*.tsx", "**/*.js", "**/*.jsx"],
plugins: { "@lexical": lexicalPlugin },
rules: {
"@lexical/rules-of-lexical": "error",
"@nx/enforce-module-boundaries": [
"error",
{
enforceBuildableLibDependency: true,
allow: ["^.*/eslint(\\.base)?\\.config\\.[cm]?[jt]s$"],
depConstraints: [
{
sourceTag: "*",
onlyDependOnLibsWithTags: ["*"],
},
],
},
],
// Add a few key rules from other standards:
eqeqeq: ["error", "always", { null: "ignore" }], // We added `null: "ignore"`.
"prefer-const": "error",
"no-var": "error",
"no-console": "warn",
// Our custom overrides:
// Prefer index-signature `{ [projectId: string]: number }` over `Record<string, number>`
// since the additional information of the key name gives a hint to its usage.
"@typescript-eslint/consistent-indexed-object-style": ["error", "index-signature"],
},
},
{
files: [
"**/*.ts",
"**/*.tsx",
"**/*.cts",
"**/*.mts",
"**/*.js",
"**/*.jsx",
"**/*.cjs",
"**/*.mjs",
],
// Override or add rules here
rules: {},
},
{
files: ["**/*.json"],
// Override or add rules here
rules: {},
languageOptions: {
parser: await import("jsonc-eslint-parser"),
},
},
];