electron.vite.config.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. import { resolve } from 'path'
  2. import { defineConfig } from 'electron-vite'
  3. import vue from '@vitejs/plugin-vue'
  4. import AutoImport from 'unplugin-auto-import/vite'
  5. import Components from 'unplugin-vue-components/vite'
  6. import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
  7. import tailwindcss from '@tailwindcss/vite'
  8. import IconsResolver from 'unplugin-icons/resolver'
  9. export default defineConfig({
  10. main: {
  11. build: {
  12. rollupOptions: {
  13. input: {
  14. index: resolve(__dirname, 'electron/main/index.ts')
  15. }
  16. }
  17. }
  18. },
  19. preload: {
  20. build: {
  21. rollupOptions: {
  22. input: {
  23. index: resolve(__dirname, 'electron/preload/index.ts')
  24. }
  25. }
  26. }
  27. },
  28. renderer: {
  29. server: {
  30. cors: true
  31. },
  32. root: '.',
  33. build: {
  34. rollupOptions: {
  35. input: {
  36. index: resolve(__dirname, 'index.html')
  37. }
  38. }
  39. },
  40. resolve: {
  41. alias: {
  42. '@': resolve('src')
  43. }
  44. },
  45. plugins: [
  46. vue(),
  47. tailwindcss(),
  48. AutoImport({
  49. resolvers: [
  50. // 自动导入 Element Plus 相关函数,如:ElMessage, ElMessageBox... (带样式)
  51. ElementPlusResolver(),
  52. // 自动导入图标组件
  53. IconsResolver({})
  54. ],
  55. imports: ['vue', 'vue-router', '@vueuse/core'],
  56. dts: 'src/types/auto-imports.d.ts' // 自动生成 auto-imports.d.ts
  57. }),
  58. Components({
  59. resolvers: [
  60. ElementPlusResolver(),
  61. IconsResolver({
  62. // 图标库,其他图标库 https://icon-sets.iconify.design/
  63. enabledCollections: ['ep']
  64. })
  65. ],
  66. dirs: ['src/components', 'src/**/components', 'src/**/components/**/*.vue'],
  67. dts: 'src/types/auto-components.d.ts' // 自动生成 components.d.ts
  68. })
  69. ],
  70. optimizeDeps: {
  71. include: [
  72. 'vue',
  73. 'vue-router',
  74. 'axios',
  75. '@vueuse/core',
  76. 'nprogress',
  77. 'element-plus/es/components/tooltip/style/css',
  78. 'element-plus/es/components/tabs/style/css',
  79. 'element-plus/es/components/tab-pane/style/css',
  80. 'element-plus/es/components/select/style/css',
  81. 'element-plus/es/components/option/style/css',
  82. 'element-plus/es/components/input/style/css',
  83. 'element-plus/es/components/row/style/css',
  84. 'element-plus/es/components/slider/style/css',
  85. 'element-plus/es/components/col/style/css',
  86. 'element-plus/es/components/switch/style/css',
  87. 'element-plus/es/components/checkbox/style/css',
  88. '@vue/reactivity',
  89. 'element-plus/es/components/config-provider/style/css',
  90. 'element-plus/es/locale/lang/zh-cn',
  91. '@element-plus/icons-vue',
  92. 'element-plus/es/components/container/style/css',
  93. 'element-plus/es/components/footer/style/css',
  94. 'element-plus/es/components/main/style/css',
  95. 'element-plus/es/components/header/style/css',
  96. 'element-plus/es/components/button/style/css',
  97. 'element-plus/es/components/pagination/style/css',
  98. 'element-plus/es/components/table/style/css',
  99. 'element-plus/es/components/table-column/style/css',
  100. 'element-plus/es/components/form/style/css',
  101. 'element-plus/es/components/form-item/style/css'
  102. ]
  103. }
  104. }
  105. })