import path from 'path' import { fileURLToPath } from 'url' import { defineConfig, loadEnv } from 'vite' import vue from '@vitejs/plugin-vue' import tailwindcss from '@tailwindcss/vite' import AutoImport from 'unplugin-auto-import/vite' import ElementPlus from 'unplugin-element-plus/vite' import Components from 'unplugin-vue-components/vite' import { ElementPlusResolver } from 'unplugin-vue-components/resolvers' import viteCompression from 'vite-plugin-compression' import vueDevTools from 'vite-plugin-vue-devtools' import { createManualChunks } from './build/manualChunks.js' // import { visualizer } from 'rollup-plugin-visualizer' export default ({ mode }) => { const root = process.cwd() const env = loadEnv(mode, root) const { VITE_VERSION, VITE_PORT, VITE_BASE_URL, VITE_API_URL, VITE_API_PROXY_URL } = env console.log(`API_URL = ${VITE_API_URL}`) console.log(`VERSION = ${VITE_VERSION}`) return defineConfig({ define: { __APP_VERSION__: JSON.stringify(VITE_VERSION) }, base: VITE_BASE_URL, server: { port: Number(VITE_PORT), proxy: { '/api': { target: VITE_API_PROXY_URL, changeOrigin: true } }, host: true }, resolve: { alias: { '@': fileURLToPath(new URL('./src', import.meta.url)), '@views': resolvePath('src/views'), '@imgs': resolvePath('src/assets/images'), '@icons': resolvePath('src/assets/icons'), '@utils': resolvePath('src/utils'), '@stores': resolvePath('src/store'), '@styles': resolvePath('src/assets/styles') } }, build: { target: 'es2015', outDir: 'dist', chunkSizeWarningLimit: 2000, rollupOptions: { output: { manualChunks: createManualChunks } }, minify: 'terser', terserOptions: { compress: { drop_console: true, drop_debugger: true } }, dynamicImportVarsOptions: { warnOnError: true, exclude: [], include: ['src/views/**/*.vue'] } }, plugins: [ vue(), tailwindcss(), AutoImport({ imports: ['vue', 'vue-router', 'pinia', '@vueuse/core'], dts: false, resolvers: [ElementPlusResolver()], eslintrc: { enabled: true, filepath: './.auto-import.json', globalsPropValue: true } }), Components({ dts: false, resolvers: [ElementPlusResolver()] }), ElementPlus({ useSource: true }), viteCompression({ verbose: false, disable: false, algorithm: 'gzip', ext: '.gz', threshold: 10240, deleteOriginFile: false }), vueDevTools() // visualizer({ // open: true, // gzipSize: true, // brotliSize: true, // filename: 'dist/stats.html' // }), ], optimizeDeps: { include: [ 'echarts/core', 'echarts/charts', 'echarts/components', 'echarts/renderers', 'xlsx', 'xgplayer', 'crypto-js', 'file-saver', 'vue-img-cutter', 'element-plus/es', 'element-plus/es/components/*/style/css', 'element-plus/es/components/*/style/index' ] }, css: { preprocessorOptions: { scss: { additionalData: ` @use "@styles/core/el-light.scss" as *; @use "@styles/core/mixin.scss" as *; ` } }, postcss: { plugins: [ { postcssPlugin: 'internal:charset-removal', AtRule: { charset: (atRule) => { if (atRule.name === 'charset') { atRule.remove() } } } } ] } } }) } function resolvePath(targetPath) { return path.resolve(path.dirname(fileURLToPath(import.meta.url)), targetPath) }