2024-11-17 17:17:40 +08:00
|
|
|
import { vitePlugin as remix } from "@remix-run/dev";
|
2024-11-27 01:02:05 +08:00
|
|
|
import { defineConfig, loadEnv } from "vite";
|
2024-11-17 17:17:40 +08:00
|
|
|
import tsconfigPaths from "vite-tsconfig-paths";
|
2024-11-27 19:52:49 +08:00
|
|
|
import { resolve } from "path";
|
2024-11-30 02:15:46 +08:00
|
|
|
import { readEnvFile } from "./server/env";
|
|
|
|
import { DEFAULT_CONFIG, EnvConfig } from "./app/env";
|
|
|
|
|
|
|
|
// 修改为异步函数来读取最新的环境变量
|
|
|
|
async function getLatestEnv() {
|
|
|
|
try {
|
|
|
|
const envData = await readEnvFile();
|
|
|
|
return {
|
|
|
|
...DEFAULT_CONFIG,
|
|
|
|
...envData,
|
|
|
|
} as EnvConfig;
|
|
|
|
} catch (error) {
|
|
|
|
console.error("读取环境变量失败:", error);
|
|
|
|
return DEFAULT_CONFIG;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const createDefineConfig = (config: EnvConfig) => {
|
|
|
|
return Object.entries(config).reduce(
|
|
|
|
(acc, [key, value]) => {
|
|
|
|
acc[`import.meta.env.${key}`] =
|
|
|
|
typeof value === "string" ? JSON.stringify(value) : value;
|
|
|
|
return acc;
|
|
|
|
},
|
|
|
|
{} as Record<string, any>,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default defineConfig(async ({ mode }) => {
|
|
|
|
// 确保每次都读取最新的环境变量
|
|
|
|
const currentConfig = await getLatestEnv();
|
|
|
|
const env = loadEnv(mode, process.cwd(), "VITE_");
|
2024-11-17 17:17:40 +08:00
|
|
|
|
2024-11-27 01:02:05 +08:00
|
|
|
return {
|
|
|
|
plugins: [
|
|
|
|
remix({
|
|
|
|
future: {
|
|
|
|
v3_fetcherPersist: true,
|
|
|
|
v3_relativeSplatPath: true,
|
|
|
|
v3_throwAbortReason: true,
|
|
|
|
v3_singleFetch: true,
|
|
|
|
v3_lazyRouteDiscovery: true,
|
|
|
|
},
|
2024-11-30 02:15:46 +08:00
|
|
|
routes: async (defineRoutes) => {
|
|
|
|
// 每次路由配置时重新读取环境变量
|
|
|
|
const latestConfig = await getLatestEnv();
|
|
|
|
|
2024-11-27 01:02:05 +08:00
|
|
|
return defineRoutes((route) => {
|
2024-11-30 02:15:46 +08:00
|
|
|
if (Number(latestConfig.VITE_INIT_STATUS) < 3) {
|
2024-11-27 01:02:05 +08:00
|
|
|
route("/", "init.tsx", { id: "index-route" });
|
|
|
|
route("*", "init.tsx", { id: "catch-all-route" });
|
2024-11-27 19:52:49 +08:00
|
|
|
} else {
|
2024-11-27 01:02:05 +08:00
|
|
|
route("/", "routes.tsx", { id: "index-route" });
|
|
|
|
route("*", "routes.tsx", { id: "catch-all-route" });
|
|
|
|
}
|
|
|
|
});
|
2024-11-27 19:52:49 +08:00
|
|
|
},
|
2024-11-27 01:02:05 +08:00
|
|
|
}),
|
|
|
|
tsconfigPaths(),
|
|
|
|
],
|
2024-11-30 02:15:46 +08:00
|
|
|
define: createDefineConfig(currentConfig),
|
2024-11-27 01:02:05 +08:00
|
|
|
server: {
|
2024-11-27 19:52:49 +08:00
|
|
|
host: true,
|
2024-11-30 02:15:46 +08:00
|
|
|
address: currentConfig.VITE_ADDRESS,
|
|
|
|
port: Number(env.VITE_SYSTEM_PORT ?? currentConfig.VITE_PORT),
|
2024-11-27 01:02:05 +08:00
|
|
|
strictPort: true,
|
2024-11-30 02:15:46 +08:00
|
|
|
hmr: true,
|
2024-11-27 19:52:49 +08:00
|
|
|
watch: {
|
2024-11-30 02:15:46 +08:00
|
|
|
usePolling: true,
|
|
|
|
},
|
|
|
|
proxy: {
|
|
|
|
"/__/api": {
|
|
|
|
target: currentConfig.VITE_API_BASE_URL,
|
|
|
|
changeOrigin: true,
|
|
|
|
rewrite: (path: string) => path.replace(/^\/__\/api/, ""),
|
|
|
|
},
|
|
|
|
"/__/express": {
|
|
|
|
target: `http://${currentConfig.VITE_ADDRESS}:${Number(currentConfig.VITE_PORT) + 1}`,
|
|
|
|
changeOrigin: true,
|
|
|
|
rewrite: (path: string) => path.replace(/^\/__\/express/, ""),
|
|
|
|
},
|
2024-11-27 19:52:49 +08:00
|
|
|
},
|
2024-11-27 01:02:05 +08:00
|
|
|
},
|
2024-11-27 19:52:49 +08:00
|
|
|
publicDir: resolve(__dirname, "public"),
|
2024-11-30 02:15:46 +08:00
|
|
|
envPrefix: "VITE_",
|
2024-12-08 00:55:12 +08:00
|
|
|
build: {
|
|
|
|
rollupOptions: {
|
2024-12-08 19:19:54 +08:00
|
|
|
// 移除 manualChunks 配置
|
2024-12-08 00:55:12 +08:00
|
|
|
},
|
2024-12-08 19:19:54 +08:00
|
|
|
chunkSizeWarningLimit: 1500
|
|
|
|
},
|
|
|
|
ssr: {
|
|
|
|
noExternal: ['three', '@react-three/fiber', '@react-three/drei', 'gsap']
|
2024-12-08 00:55:12 +08:00
|
|
|
}
|
2024-11-27 01:02:05 +08:00
|
|
|
};
|
2024-11-27 19:52:49 +08:00
|
|
|
});
|