The in-app changelog page reads from public/CHANGELOG*.md which were stale (last synced at 0.6.3). Add automatic sync via Vite config (runs on dev/build start) and npm prebuild script so public/ copies are always up to date without manual intervention. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
54 lines
1.5 KiB
TypeScript
54 lines
1.5 KiB
TypeScript
import { defineConfig } from "vite";
|
|
import react from "@vitejs/plugin-react";
|
|
import tailwindcss from "@tailwindcss/vite";
|
|
import { copyFileSync } from "fs";
|
|
import { resolve, dirname } from "path";
|
|
import { fileURLToPath } from "url";
|
|
|
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
|
|
// Sync root CHANGELOG files to public/ so the app always shows the latest version history
|
|
function syncChangelogs() {
|
|
const files = ["CHANGELOG.md", "CHANGELOG.fr.md"];
|
|
for (const file of files) {
|
|
try {
|
|
copyFileSync(resolve(__dirname, file), resolve(__dirname, "public", file));
|
|
} catch {
|
|
// Ignore if source file doesn't exist
|
|
}
|
|
}
|
|
}
|
|
|
|
// @ts-expect-error process is a nodejs global
|
|
const host = process.env.TAURI_DEV_HOST;
|
|
|
|
// https://vite.dev/config/
|
|
export default defineConfig(async () => {
|
|
// Sync changelogs before starting dev server or building
|
|
syncChangelogs();
|
|
|
|
return {
|
|
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/**"],
|
|
},
|
|
},
|
|
}});
|