import { cdn } from "./cdn"; import vue from "@vitejs/plugin-vue"; import { viteBuildInfo } from "./info"; import svgLoader from "vite-svg-loader"; import type { PluginOption } from "vite"; import vueJsx from "@vitejs/plugin-vue-jsx"; import { configCompressPlugin } from "./compress"; import { createSvgIconsPlugin } from "vite-plugin-svg-icons"; import { visualizer } from "rollup-plugin-visualizer"; import removeConsole from "vite-plugin-remove-console"; import { themePreprocessorPlugin } from "@pureadmin/theme"; import { genScssMultipleScopeVars } from "../src/layout/theme"; import path from "path"; export function getPluginsList( command: string, VITE_CDN: boolean, VITE_COMPRESSION: ViteCompression ): PluginOption[] { const lifecycle = process.env.npm_lifecycle_event; return [ vue(), // jsx、tsx语法支持 vueJsx(), VITE_CDN ? cdn : null, configCompressPlugin(VITE_COMPRESSION), // 线上环境删除console removeConsole({ external: ["src/assets/iconfont/iconfont.js"] }), viteBuildInfo(), // 自定义主题 themePreprocessorPlugin({ scss: { multipleScopeVars: genScssMultipleScopeVars(), extract: true } }), // svg组件化支持 svgLoader(), // ElementPlus({}), createSvgIconsPlugin({ // 指定需要缓存的图标文件夹 iconDirs: [path.resolve(process.cwd(), "src/assets/icons")], // 指定symbolId格式 symbolId: "icon-[dir]-[name]" }), // 打包分析 lifecycle === "report" ? visualizer({ open: true, brotliSize: true, filename: "report.html" }) : null ]; }