forked from EKKOLearnAI/hermes-web-ui
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvite.config.ts
More file actions
109 lines (106 loc) · 3.01 KB
/
vite.config.ts
File metadata and controls
109 lines (106 loc) · 3.01 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
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
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import type { ProxyOptions } from 'vite'
import { resolve } from 'path'
import pkg from './package.json'
const FRONTEND_PORT = Number(process.env.HERMES_WEB_UI_FRONTEND_PORT || 8649)
const BACKEND_PORT = process.env.HERMES_WEB_UI_BACKEND_PORT || '8648'
const BACKEND = `http://127.0.0.1:${BACKEND_PORT}`
function createProxyConfig(): ProxyOptions {
return {
target: BACKEND,
changeOrigin: true,
ws: true,
configure: (proxy) => {
proxy.on('proxyReq', (proxyReq) => {
proxyReq.removeHeader('origin')
proxyReq.removeHeader('referer')
})
proxy.on('proxyRes', (proxyRes) => {
proxyRes.headers['cache-control'] = 'no-cache'
proxyRes.headers['x-accel-buffering'] = 'no'
})
},
}
}
export default defineConfig({
root: 'packages/client',
plugins: [vue()],
define: {
__APP_VERSION__: JSON.stringify(pkg.version),
},
resolve: {
alias: {
'@': resolve(__dirname, 'packages/client/src'),
},
},
build: {
outDir: '../../dist/client',
emptyOutDir: true,
// Use esbuild for minification (much faster than terser)
minify: 'esbuild',
// Disable sourcemap generation for faster builds
sourcemap: false,
target: 'es2020',
// Increase chunk size warning limit (default: 500KB)
chunkSizeWarningLimit: 1000,
// CSS code splitting for better caching
cssCodeSplit: true,
rollupOptions: {
output: {
// Manual chunk splitting to speed up rendering
manualChunks(id) {
// Separate large heavy packages to avoid blocking other chunks
if (id.includes('node_modules/monaco-editor')) {
return 'monaco-editor'
}
if (id.includes('node_modules/mermaid')) {
return 'mermaid'
}
if (id.includes('node_modules/@xterm')) {
return 'xterm'
}
if (id.includes('node_modules')) {
if (id.includes('vue') || id.includes('pinia') || id.includes('vue-router')) {
return 'vue-vendor'
}
if (id.includes('naive-ui')) {
return 'ui-vendor'
}
return 'vendor'
}
},
// Optimize chunk file names for better caching
chunkFileNames: 'assets/js/[name]-[hash].js',
entryFileNames: 'assets/js/[name]-[hash].js',
assetFileNames: 'assets/[ext]/[name]-[hash].[ext]',
},
},
},
optimizeDeps: {
// Pre-bundle all large dependencies for faster builds
include: [
'monaco-editor',
'mermaid',
'vue',
'vue-router',
'pinia',
'naive-ui',
],
},
server: {
port: FRONTEND_PORT,
strictPort: true,
proxy: {
'/api': createProxyConfig(),
'/v1': createProxyConfig(),
'/health': createProxyConfig(),
'/upload': createProxyConfig(),
'/webhook': createProxyConfig(),
'/socket.io': {
target: BACKEND,
ws: true,
},
},
},
})