38 lines
960 B
TypeScript
38 lines
960 B
TypeScript
import { defineConfig } from "vite";
|
|
import react from "@vitejs/plugin-react";
|
|
import { resolve } from "path";
|
|
import { readFileSync } from "node:fs";
|
|
|
|
const appVersion = readFileSync(
|
|
resolve(__dirname, "../Docker/VERSION"),
|
|
"utf-8",
|
|
)
|
|
.trim()
|
|
.replace(/^v/, "");
|
|
|
|
// https://vitejs.dev/config/
|
|
export default defineConfig({
|
|
plugins: [react()],
|
|
define: {
|
|
/** BanGUI application version injected at build time from Docker/VERSION. */
|
|
__APP_VERSION__: JSON.stringify(appVersion),
|
|
},
|
|
resolve: {
|
|
alias: {
|
|
"@": resolve(__dirname, "src"),
|
|
},
|
|
},
|
|
server: {
|
|
port: 5173,
|
|
proxy: {
|
|
"/api": {
|
|
// In the dev compose stack the backend is reachable via its service
|
|
// name on the shared Docker/Podman network. Using "localhost" would
|
|
// resolve to the frontend container itself and cause ECONNREFUSED.
|
|
target: "http://backend:8000",
|
|
changeOrigin: true,
|
|
},
|
|
},
|
|
},
|
|
});
|