import path from 'node:path' import { fileURLToPath, URL } from 'node:url' import { defineConfig } from 'vite' import electron from 'vite-plugin-electron/simple' import vue from '@vitejs/plugin-vue' import vueDevTools from 'vite-plugin-vue-devtools' import UnoCSS from 'unocss/vite' // https://vitejs.dev/config/ export default defineConfig({ plugins: [ vue(), vueDevTools(), UnoCSS(), electron({ main: { // Shortcut of `build.lib.entry`. entry: 'electron/main.ts', vite: { build: { rollupOptions: { external: ['better-sqlite3'], }, }, }, }, preload: { // Shortcut of `build.rollupOptions.input`. // Preload scripts may contain Web assets, so use the `build.rollupOptions.input` instead `build.lib.entry`. input: path.join(__dirname, 'electron/preload.ts'), }, // Ployfill the Electron and Node.js API for Renderer process. // If you want use Node.js in Renderer process, the `nodeIntegration` needs to be enabled in the Main process. // See 👉 https://github.com/electron-vite/vite-plugin-electron-renderer renderer: process.env.NODE_ENV === 'test' ? // https://github.com/electron-vite/vite-plugin-electron-renderer/issues/78#issuecomment-2053600808 undefined : {}, }), ], resolve: { alias: { '@': fileURLToPath(new URL('./src', import.meta.url)), '~': fileURLToPath(new URL('./', import.meta.url)), }, }, build: { rollupOptions: {}, chunkSizeWarningLimit: 2048, }, })