nanobot/webui/vite.config.ts
Xubin Ren e5be4dac7a Optimize WebUI streaming and long history rendering
Batch stream deltas, window long transcripts, lazy-load syntax highlighting, and refine activity/composer interactions.

Add title refresh retries plus tests for streaming, windowing, code blocks, and live activity behavior.
2026-05-17 17:04:57 +08:00

96 lines
3.2 KiB
TypeScript

import { defineConfig, loadEnv } from "vite";
import react from "@vitejs/plugin-react";
import path from "node:path";
export default defineConfig(({ mode }) => {
const env = loadEnv(mode, process.cwd(), "");
const target = env.NANOBOT_API_URL ?? "http://127.0.0.1:8765";
const wsTarget = target.replace(/^http/, "ws");
return {
plugins: [react()],
resolve: {
alias: {
"@": path.resolve(__dirname, "./src"),
},
},
optimizeDeps: {
// Radix dialog was introduced mid-session for the mobile sidebar sheet.
// When Vite re-optimizes it on a running dev server, the browser can race
// and request stale chunk paths from `.vite/deps`. Excluding it keeps dev
// reloads stable instead of rewriting those chunk filenames under us.
exclude: ["@radix-ui/react-dialog"],
},
build: {
outDir: path.resolve(__dirname, "../nanobot/web/dist"),
emptyOutDir: true,
sourcemap: false,
rollupOptions: {
output: {
manualChunks(id) {
if (id.includes("node_modules/refractor/lang/")) {
return;
}
if (
id.includes("node_modules/react-syntax-highlighter")
|| id.includes("node_modules/refractor/core")
) {
return "syntax-highlight";
}
if (
id.includes("node_modules/react-markdown")
|| id.includes("node_modules/remark-")
|| id.includes("node_modules/rehype-")
|| id.includes("node_modules/unified")
|| id.includes("node_modules/mdast-")
|| id.includes("node_modules/hast-")
|| id.includes("node_modules/micromark")
|| id.includes("node_modules/unist-")
) {
return "markdown-vendor";
}
if (id.includes("node_modules/katex")) {
return "katex";
}
},
},
},
},
server: {
host: "127.0.0.1",
port: 5173,
strictPort: true,
// Move Vite's HMR socket to a dedicated port so it doesn't collide with
// the ``/`` proxy below (Vite HMR and the nanobot ws upgrade both sit on
// the root path, which triggers spurious write-after-end errors as each
// side tries to close the other's socket).
hmr: {
host: "127.0.0.1",
port: 5174,
},
proxy: {
"/webui": { target, changeOrigin: true },
"/api": { target, changeOrigin: true },
"/auth": { target, changeOrigin: true },
// Forward only WebSocket upgrades on ``/`` to the nanobot gateway;
// plain HTTP GETs on ``/`` must stay with Vite so it can serve the SPA.
// ``bypass`` returning the original URL skips the proxy for that
// request; returning undefined lets the proxy (and ws upgrade handler)
// take it.
"/": {
target: wsTarget,
ws: true,
changeOrigin: true,
bypass: (req) =>
req.headers.upgrade === "websocket" ? undefined : req.url,
},
},
},
test: {
environment: "happy-dom",
globals: true,
setupFiles: ["./src/tests/setup.ts"],
},
};
});