import react from '@vitejs/plugin-react-swc' import { defineConfig, externalizeDepsPlugin } from 'electron-vite' import { resolve } from 'path' import { visualizer } from 'rollup-plugin-visualizer' const visualizerPlugin = (type: 'renderer' | 'main') => { return process.env[`VISUALIZER_${type.toUpperCase()}`] ? [visualizer({ open: true })] : [] } export default defineConfig({ main: { plugins: [externalizeDepsPlugin(), ...visualizerPlugin('main')], resolve: { alias: { '@main': resolve('src/main'), '@types': resolve('src/renderer/src/types'), '@shared': resolve('packages/shared') } }, build: { rollupOptions: { external: ['@libsql/client', 'bufferutil', 'utf-8-validate'] }, sourcemap: process.env.NODE_ENV === 'development' }, optimizeDeps: { noDiscovery: process.env.NODE_ENV === 'development' } }, preload: { plugins: [externalizeDepsPlugin()], resolve: { alias: { '@shared': resolve('packages/shared') } }, build: { sourcemap: process.env.NODE_ENV === 'development' } }, renderer: { plugins: [ react({ plugins: [ [ '@swc/plugin-styled-components', { displayName: true, // 开发环境下启用组件名称 fileName: false, // 不在类名中包含文件名 pure: true, // 优化性能 ssr: false // 不需要服务端渲染 } ] ] }), ...visualizerPlugin('renderer') ], resolve: { alias: { '@renderer': resolve('src/renderer/src'), '@shared': resolve('packages/shared') } }, optimizeDeps: { exclude: ['pyodide'] }, worker: { format: 'es' }, build: { rollupOptions: { input: { index: resolve(__dirname, 'src/renderer/index.html'), miniWindow: resolve(__dirname, 'src/renderer/miniWindow.html'), selectionToolbar: resolve(__dirname, 'src/renderer/selectionToolbar.html'), selectionAction: resolve(__dirname, 'src/renderer/selectionAction.html') } } } } })