Files
MosaicIQ/MosaicIQ/vite.config.ts

75 lines
1.8 KiB
TypeScript

import { defineConfig } from "vite";
import react from "@vitejs/plugin-react";
import tailwindcss from "@tailwindcss/vite";
// @ts-expect-error process is a nodejs global
const host = process.env.TAURI_DEV_HOST;
// https://vite.dev/config/
export default defineConfig(async () => ({
plugins: [react(), tailwindcss()],
// Vite options tailored for Tauri development and only applied in `tauri dev` or `tauri build`
//
// 1. prevent Vite from obscuring rust errors
clearScreen: false,
// 2. tauri expects a fixed port, fail if that port is not available
server: {
port: 1420,
strictPort: true,
host: host || false,
hmr: host
? {
protocol: "ws",
host,
port: 1421,
}
: undefined,
watch: {
// 3. tell Vite to ignore watching `src-tauri`
ignored: ["**/src-tauri/**"],
},
},
build: {
chunkSizeWarningLimit: 400,
rollupOptions: {
output: {
manualChunks(id) {
if (!id.includes("node_modules")) {
return undefined;
}
if (
id.includes("react-markdown") ||
id.includes("remark-gfm") ||
id.includes("mdast") ||
id.includes("micromark") ||
id.includes("hast") ||
id.includes("unist")
) {
return "markdown";
}
if (id.includes("recharts") || id.includes("/d3-")) {
return "charts";
}
if (
id.includes("/react/") ||
id.includes("react-dom") ||
id.includes("scheduler")
) {
return "react-vendor";
}
if (id.includes("@tauri-apps")) {
return "tauri";
}
return undefined;
},
},
},
},
}));