- 启用 TanStack Query flat/recommended(7 条规则) - 新增 no-console(允许 warn/error)、consistent-type-imports(inline 风格)、no-non-null-assertion 规则 - 新增自定义规则 no-hardcoded-color-in-style,检测 JSX style 中硬编码颜色值 - 将 ESLint 检查集成到 build 命令(tsc -b && eslint . && vite build) - 修复现有代码中的 lint 违规(import 顺序、type import 风格、unused vars) - 使用 @typescript-eslint/rule-tester 编写自定义规则集成测试
71 lines
2.0 KiB
JavaScript
71 lines
2.0 KiB
JavaScript
import js from '@eslint/js'
|
|
import globals from 'globals'
|
|
import reactHooks from 'eslint-plugin-react-hooks'
|
|
import reactRefresh from 'eslint-plugin-react-refresh'
|
|
import tseslint from 'typescript-eslint'
|
|
import importPlugin from 'eslint-plugin-import'
|
|
import tanstackQuery from '@tanstack/eslint-plugin-query'
|
|
import localRules from './eslint-rules/index.js'
|
|
|
|
export default tseslint.config(
|
|
{ ignores: ['dist'] },
|
|
...tanstackQuery.configs['flat/recommended'],
|
|
{
|
|
extends: [js.configs.recommended, ...tseslint.configs.recommended],
|
|
files: ['**/*.{ts,tsx}'],
|
|
languageOptions: {
|
|
ecmaVersion: 2023,
|
|
globals: globals.browser,
|
|
},
|
|
plugins: {
|
|
'react-hooks': reactHooks,
|
|
'react-refresh': reactRefresh,
|
|
import: importPlugin,
|
|
'@tanstack/query': tanstackQuery,
|
|
local: localRules,
|
|
},
|
|
rules: {
|
|
...reactHooks.configs.recommended.rules,
|
|
'react-refresh/only-export-components': [
|
|
'warn',
|
|
{ allowConstantExport: true },
|
|
],
|
|
'no-console': ['error', { allow: ['warn', 'error'] }],
|
|
'@typescript-eslint/consistent-type-imports': [
|
|
'error',
|
|
{ prefer: 'type-imports', fixStyle: 'inline-type-imports' },
|
|
],
|
|
'@typescript-eslint/no-non-null-assertion': 'error',
|
|
'local/no-hardcoded-color-in-style': 'warn',
|
|
'import/order': [
|
|
'warn',
|
|
{
|
|
groups: [
|
|
'builtin',
|
|
'external',
|
|
'internal',
|
|
'parent',
|
|
'sibling',
|
|
'index',
|
|
'type',
|
|
],
|
|
'newlines-between': 'never',
|
|
alphabetize: { order: 'asc', caseInsensitive: true },
|
|
pathGroups: [
|
|
{ pattern: '@/**', group: 'internal', position: 'before' },
|
|
],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
{
|
|
files: ['src/__tests__/**', 'e2e/**'],
|
|
rules: {
|
|
'@typescript-eslint/no-non-null-assertion': 'off',
|
|
'react-hooks/exhaustive-deps': 'off',
|
|
'@typescript-eslint/consistent-type-imports': 'off',
|
|
'no-console': 'off',
|
|
},
|
|
},
|
|
)
|