vite.config.base.ts 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import { resolve } from 'path';
  2. import { defineConfig } from 'vite';
  3. import vue from '@vitejs/plugin-vue';
  4. import vueJsx from '@vitejs/plugin-vue-jsx';
  5. import svgLoader from 'vite-svg-loader';
  6. import configArcoStyleImportPlugin from './plugin/arcoStyleImport';
  7. import WindiCSS from 'vite-plugin-windicss';
  8. export default defineConfig({
  9. plugins: [
  10. vue(),
  11. vueJsx(),
  12. svgLoader({ svgoConfig: {} }),
  13. configArcoStyleImportPlugin(),
  14. WindiCSS(),
  15. ],
  16. resolve: {
  17. alias: [
  18. {
  19. find: '@',
  20. replacement: resolve(__dirname, '../src'),
  21. },
  22. {
  23. find: 'assets',
  24. replacement: resolve(__dirname, '../src/assets'),
  25. },
  26. {
  27. find: 'vue-i18n',
  28. replacement: 'vue-i18n/dist/vue-i18n.cjs.js', // Resolve the i18n warning issue
  29. },
  30. {
  31. find: 'vue',
  32. replacement: 'vue/dist/vue.esm-bundler.js', // compile template
  33. },
  34. ],
  35. extensions: ['.ts', '.js'],
  36. },
  37. define: {
  38. 'process.env': {},
  39. },
  40. css: {
  41. preprocessorOptions: {
  42. less: {
  43. modifyVars: {
  44. hack: `true; @import (reference) "${resolve(
  45. 'src/assets/style/breakpoint.less'
  46. )}";`,
  47. },
  48. javascriptEnabled: true,
  49. },
  50. },
  51. },
  52. });