vite.config.ts 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import vue from '@vitejs/plugin-vue'
  2. import { resolve } from 'path'
  3. import { defineConfig, loadEnv, ConfigEnv } from 'vite'
  4. import vueSetupExtend from 'vite-plugin-vue-setup-extend'
  5. import vueJsx from '@vitejs/plugin-vue-jsx'
  6. import AutoImport from 'unplugin-auto-import/vite'
  7. import Components from 'unplugin-vue-components/vite'
  8. import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
  9. const pathResolve = (dir: string) => {
  10. return resolve(__dirname, '.', dir)
  11. }
  12. const alias: Record<string, string> = {
  13. '/@': pathResolve('./src/'),
  14. '@views': pathResolve('./src/views'),
  15. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js',
  16. }
  17. const viteConfig = defineConfig((mode: ConfigEnv) => {
  18. const env = loadEnv(mode.mode, process.cwd())
  19. return {
  20. plugins: [
  21. vue(),
  22. vueJsx(),
  23. vueSetupExtend(),
  24. AutoImport({
  25. imports: ['vue', 'vue-router', 'pinia'],
  26. // resolvers: [ElementPlusResolver()],
  27. }),
  28. // Components({
  29. // resolvers: [ElementPlusResolver()],
  30. // }),
  31. ],
  32. root: process.cwd(),
  33. resolve: { alias },
  34. base: mode.command === 'serve' ? './' : env.VITE_PUBLIC_PATH,
  35. optimizeDeps: {
  36. include: ['element-plus/es/locale/lang/zh-cn', 'element-plus/es/locale/lang/en', 'element-plus/es/locale/lang/zh-tw'],
  37. },
  38. server: {
  39. host: '0.0.0.0',
  40. port: env.VITE_PORT as unknown as number,
  41. open: true,
  42. hmr: true,
  43. proxy: {
  44. '/gitee': {
  45. target: 'https://gitee.com',
  46. ws: true,
  47. changeOrigin: true,
  48. rewrite: (path) => path.replace(/^\/gitee/, ''),
  49. },
  50. },
  51. },
  52. build: {
  53. outDir: 'dist',
  54. chunkSizeWarningLimit: 1500,
  55. rollupOptions: {
  56. output: {
  57. entryFileNames: `assets/[name].[hash].js`,
  58. chunkFileNames: `assets/[name].[hash].js`,
  59. assetFileNames: `assets/[name].[hash].[ext]`,
  60. compact: true,
  61. manualChunks: {
  62. vue: ['vue', 'vue-router', 'pinia'],
  63. elementPlus: ['element-plus'],
  64. echarts: ['echarts'],
  65. },
  66. },
  67. },
  68. },
  69. css: { preprocessorOptions: { css: { charset: false } } },
  70. define: {
  71. __VUE_I18N_LEGACY_API__: JSON.stringify(false),
  72. __VUE_I18N_FULL_INSTALL__: JSON.stringify(false),
  73. __INTLIFY_PROD_DEVTOOLS__: JSON.stringify(false),
  74. __VERSION__: JSON.stringify(process.env.npm_package_version),
  75. },
  76. }
  77. })
  78. export default viteConfig