import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; import svgr from 'vite-plugin-svgr'; import wasm from 'vite-plugin-wasm'; import { visualizer } from 'rollup-plugin-visualizer'; import { compression } from 'vite-plugin-compression2'; import usePluginImport from 'vite-plugin-importer'; import { totalBundleSize } from 'vite-plugin-total-bundle-size'; const isDev = process.env.NODE_ENV === 'development'; // https://vitejs.dev/config/ export default defineConfig({ plugins: [ react(), wasm(), svgr({ svgrOptions: { prettier: false, plugins: ['@svgr/plugin-svgo', '@svgr/plugin-jsx'], icon: true, svgoConfig: { multipass: true, plugins: [ { name: 'preset-default', params: { overrides: { removeViewBox: false, }, }, }, ], }, svgProps: { role: 'img', }, replaceAttrValues: { '#333': 'currentColor', }, }, }), usePluginImport({ libraryName: '@mui/material', libraryDirectory: '', camel2DashComponentName: false, style: false, }), usePluginImport({ libraryName: '@mui/icons-material', libraryDirectory: '', camel2DashComponentName: false, style: false, }), process.env.ANALYZE_MODE ? visualizer({ emitFile: true, }) : undefined, process.env.ANALYZE_MODE ? totalBundleSize({ fileNameRegex: /\.(js|css)$/, calculateGzip: false, }) : undefined, !process.env.ANALYZE_MODE ? compression({ threshold: 1024, deleteOriginalAssets: true, }) : undefined, ], // Vite options tailored for Tauri development and only applied in `tauri dev` or `tauri build` // prevent vite from obscuring rust errors clearScreen: false, // tauri expects a fixed port, fail if that port is not available server: { port: process.env.TAURI_MODE ? 5173 : process.env.PORT ? parseInt(process.env.PORT) : 3000, strictPort: true, watch: { ignored: ['**/__tests__/**'], }, cors: false, }, envPrefix: ['AF', 'TAURI_'], build: process.env.TAURI_MODE ? { // Tauri supports es2021 target: process.env.TAURI_PLATFORM === 'windows' ? 'chrome105' : 'safari13', // don't minify for debug builds minify: !process.env.TAURI_DEBUG ? 'esbuild' : false, // produce sourcemaps for debug builds sourcemap: !!process.env.TAURI_DEBUG, } : { target: `esnext`, terserOptions: !isDev ? { compress: { keep_infinity: true, drop_console: true, drop_debugger: true, }, } : {}, reportCompressedSize: false, sourcemap: isDev, rollupOptions: !isDev ? { output: { chunkFileNames: 'js/[name]-[hash].js', entryFileNames: 'js/[name]-[hash].js', assetFileNames: '[ext]/[name]-[hash].[ext]', manualChunks (id) { if (id.includes(('@mui'))) { return 'mui'; } if (id.includes('react-dom') || id.includes('react-is') || id.includes('react')) { return 'react-framework'; } if (id.includes('@tauri-apps')) { return 'tauri-api'; } if (id.includes('node_modules')) { return id.toString().split('node_modules/')[1].split('/')[0].toString(); } }, }, } : {}, }, resolve: { alias: [ { find: 'src/', replacement: `${__dirname}/src/` }, { find: '@/', replacement: `${__dirname}/src/` }, { find: '$client-services', replacement: process.env.TAURI_MODE ? `${__dirname}/src/application/services/tauri-services` : `${__dirname}/src/application/services/js-services`, }, ], }, optimizeDeps: { include: ['@mui/material/Tooltip'], }, });