mirror of
https://github.com/HKUDS/nanobot.git
synced 2026-06-13 14:23:58 +00:00
* feat(webui): add project workspaces and access controls * feat(webui): add project workspaces and access controls * refactor(tools): centralize workspace access resolution * refactor(webui): remove unused workspace host state * fix(webui): hide estimated file edit label * fix(webui): clarify file edit deletion feedback * fix(webui): label deleted file activity * fix(webui): flatten file edit activity rows * fix(core): remove path-only patch deletion * fix(core): keep apply patch non-destructive * refactor(webui): trim workspace host plumbing * fix(tools): register exec with tools config
83 lines
2.6 KiB
TypeScript
83 lines
2.6 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 hmrPath = "/__nanobot_vite_hmr";
|
|
|
|
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,
|
|
// Keep Vite's HMR socket on a dedicated path. Nanobot's app WebSocket is
|
|
// opened directly from the browser to the gateway, so the dev server
|
|
// should never proxy WebSocket upgrades.
|
|
hmr: {
|
|
host: "127.0.0.1",
|
|
path: hmrPath,
|
|
},
|
|
proxy: {
|
|
"/webui": { target, changeOrigin: true },
|
|
"/api": { target, changeOrigin: true },
|
|
"/auth": { target, changeOrigin: true },
|
|
},
|
|
},
|
|
test: {
|
|
environment: "happy-dom",
|
|
globals: true,
|
|
setupFiles: ["./src/tests/setup.ts"],
|
|
},
|
|
};
|
|
});
|