1
0
Files
nex/frontend/vite.config.ts
lanyuanxiaoyao 52007c9461 feat: 前端 ESLint 规则增强,自动检测 LLM 编码违规
- 启用 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 编写自定义规则集成测试
2026-04-23 22:47:32 +08:00

81 lines
2.2 KiB
TypeScript

import path from 'node:path'
import react from '@vitejs/plugin-react'
import { defineConfig } from 'vite'
import obfuscatorPlugin from 'vite-plugin-javascript-obfuscator'
const vendorChunks: Record<string, string[]> = {
'vendor-react': ['react', 'react-dom', 'react-router'],
'vendor-tdesign': ['tdesign-react', 'tdesign-icons-react'],
'vendor-recharts': ['recharts'],
}
// https://vite.dev/config/
export default defineConfig({
plugins: [
react(),
obfuscatorPlugin({
apply: 'build',
include: ['src/**/*.ts', 'src/**/*.tsx', 'src/**/*.js', 'src/**/*.jsx'],
exclude: [/node_modules/],
options: {
compact: true,
simplify: true,
identifierNamesGenerator: 'mangled-shuffled',
stringArray: true,
stringArrayCallsTransform: true,
stringArrayCallsTransformThreshold: 0.5,
stringArrayEncoding: ['base64'],
stringArrayIndexShift: true,
stringArrayRotate: true,
stringArrayShuffle: true,
stringArrayWrappersCount: 2,
stringArrayWrappersChainedCalls: true,
stringArrayThreshold: 0.75,
splitStrings: true,
splitStringsChunkLength: 10,
numbersToExpressions: true,
transformObjectKeys: true,
unicodeEscapeSequence: true,
debugProtection: true,
debugProtectionInterval: 2000,
disableConsoleOutput: true,
ignoreImports: true,
controlFlowFlattening: false,
deadCodeInjection: false,
selfDefending: false,
log: false,
},
}),
],
resolve: {
alias: {
'@': path.resolve(__dirname, './src'),
},
},
server: {
proxy: {
'/api': {
target: `http://localhost:${process.env.NEX_BACKEND_PORT || '9826'}`,
changeOrigin: true,
},
},
},
build: {
chunkSizeWarningLimit: 700,
sourcemap: false,
rollupOptions: {
output: {
manualChunks(id) {
for (const [chunkName, modules] of Object.entries(vendorChunks)) {
for (const mod of modules) {
if (id.includes(`/node_modules/${mod}/`)) {
return chunkName
}
}
}
},
},
},
},
})