import react from '@vitejs/plugin-react' import path from 'node:path' import { defineConfig, loadEnv, normalizePath } from 'vite' import { viteStaticCopy } from 'vite-plugin-static-copy' import tsconfigPaths from 'vite-tsconfig-paths' const monacoEditorPath = normalizePath( path.resolve(__dirname, 'node_modules/monaco-editor/min/vs') ) // https://vitejs.dev/config/ export default defineConfig(({ mode }) => { const env = loadEnv(mode, process.cwd()) const backendDebugUrl = env.VITE_DEBUG_BACKEND_URL console.log('backendDebugUrl', backendDebugUrl) return { plugins: [ react(), tsconfigPaths(), viteStaticCopy({ targets: [ { src: monacoEditorPath, dest: 'monaco-editor/min' } ] }) ], base: '/webui/', server: { proxy: { '/api/ws/terminal': { target: backendDebugUrl, ws: true, changeOrigin: true }, '/api': backendDebugUrl, '/files': backendDebugUrl } }, build: { assetsInlineLimit: 0, rollupOptions: { output: { manualChunks: { 'monaco-editor': ['monaco-editor'], 'react-dom': ['react-dom'], 'react-router-dom': ['react-router-dom'], 'react-hook-form': ['react-hook-form'], 'react-icons': ['react-icons'], 'react-hot-toast': ['react-hot-toast'], qface: ['qface'] } } } } } })