124 lines
3.7 KiB
JavaScript
124 lines
3.7 KiB
JavaScript
import js from "@eslint/js";
|
||
import importPlugin from "eslint-plugin-import";
|
||
import perfectionist from "eslint-plugin-perfectionist";
|
||
import eslintPluginPrettierRecommended from "eslint-plugin-prettier/recommended";
|
||
import reactHooks from "eslint-plugin-react-hooks";
|
||
import reactRefresh from "eslint-plugin-react-refresh";
|
||
import tseslint from "typescript-eslint";
|
||
|
||
const noDirectConsoleMessage =
|
||
"后端运行时代码禁止直接使用 console.*;请通过注入的 Logger 实例输出日志,配置加载失败前使用 createConsoleFallback()。";
|
||
|
||
const noDirectConsoleFrontendMessage =
|
||
"前端代码禁止直接使用 console.*;请使用 useLogger() hook(组件内)或 createConsoleLogger()(非组件纯函数)。";
|
||
|
||
export default tseslint.config(
|
||
{
|
||
ignores: [
|
||
"node_modules/**",
|
||
"dist/**",
|
||
".build/**",
|
||
"*.bun-build",
|
||
"openspec/**",
|
||
".opencode/**",
|
||
".claude/**",
|
||
".codex/**",
|
||
".agents/**",
|
||
".worktrees/**",
|
||
"bin/**",
|
||
"bun.lock",
|
||
"data/**",
|
||
],
|
||
},
|
||
js.configs.recommended,
|
||
...tseslint.configs.recommendedTypeChecked,
|
||
...tseslint.configs.stylisticTypeChecked,
|
||
importPlugin.flatConfigs.recommended,
|
||
importPlugin.flatConfigs.typescript,
|
||
perfectionist.configs["recommended-natural"],
|
||
{
|
||
languageOptions: {
|
||
parserOptions: {
|
||
projectService: true,
|
||
tsconfigRootDir: import.meta.dirname,
|
||
},
|
||
},
|
||
settings: {
|
||
"import/resolver": { node: true, typescript: true },
|
||
},
|
||
},
|
||
{
|
||
rules: {
|
||
"@typescript-eslint/array-type": ["error", { default: "array-simple" }],
|
||
"@typescript-eslint/consistent-type-assertions": ["error", { assertionStyle: "as" }],
|
||
"@typescript-eslint/consistent-type-imports": ["error", { prefer: "type-imports" }],
|
||
"@typescript-eslint/no-unused-vars": ["error", { argsIgnorePattern: "^_" }],
|
||
"@typescript-eslint/only-throw-error": "error",
|
||
"@typescript-eslint/prefer-nullish-coalescing": "error",
|
||
"@typescript-eslint/prefer-optional-chain": "error",
|
||
"import/no-unresolved": ["error", { ignore: ["^bun:"] }],
|
||
"no-undef": "off",
|
||
},
|
||
},
|
||
{
|
||
files: ["eslint.config.js"],
|
||
rules: {
|
||
"import/no-named-as-default": "off",
|
||
"import/no-named-as-default-member": "off",
|
||
},
|
||
},
|
||
{
|
||
files: ["src/server/**/*.ts"],
|
||
ignores: ["src/server/logger.ts"],
|
||
rules: {
|
||
"no-restricted-syntax": [
|
||
"error",
|
||
{
|
||
message: noDirectConsoleMessage,
|
||
selector: "MemberExpression[object.name='console']",
|
||
},
|
||
],
|
||
},
|
||
},
|
||
{
|
||
files: ["src/web/**/*.{ts,tsx}"],
|
||
ignores: ["src/web/**/logger.ts"],
|
||
plugins: {
|
||
"react-hooks": reactHooks,
|
||
"react-refresh": reactRefresh,
|
||
},
|
||
rules: {
|
||
...reactHooks.configs.recommended.rules,
|
||
"no-restricted-imports": [
|
||
"error",
|
||
{
|
||
patterns: [
|
||
{
|
||
group: [
|
||
"../server/*",
|
||
"../server/**",
|
||
"../**/server/*",
|
||
"../**/server/**",
|
||
"../../server/*",
|
||
"../../server/**",
|
||
"src/server/*",
|
||
"src/server/**",
|
||
],
|
||
message: "前端不得导入 src/server 后端运行时实现;请改用 src/shared 类型或 HTTP API。",
|
||
},
|
||
],
|
||
},
|
||
],
|
||
"no-restricted-syntax": [
|
||
"error",
|
||
{
|
||
message: noDirectConsoleFrontendMessage,
|
||
selector: "MemberExpression[object.name='console']",
|
||
},
|
||
],
|
||
"react-refresh/only-export-components": ["warn", { allowConstantExport: true }],
|
||
},
|
||
},
|
||
eslintPluginPrettierRecommended,
|
||
);
|