33 lines
1001 B
TypeScript
33 lines
1001 B
TypeScript
import type { PluginOption } from 'vite';
|
|
import vue from '@vitejs/plugin-vue';
|
|
import vueJsx from '@vitejs/plugin-vue-jsx';
|
|
import unocss from '@unocss/vite';
|
|
import progress from 'vite-plugin-progress';
|
|
import routerPage from '@soybeanjs/router-page';
|
|
import html from './html';
|
|
import unplugin from './unplugin';
|
|
import mock from './mock';
|
|
import visualizer from './visualizer';
|
|
import compress from './compress';
|
|
import pwa from './pwa';
|
|
|
|
/**
|
|
* vite插件
|
|
* @param viteEnv - 环境变量配置
|
|
*/
|
|
export function setupVitePlugins(viteEnv: ImportMetaEnv): (PluginOption | PluginOption[])[] {
|
|
const plugins = [vue(), vueJsx(), html(viteEnv), ...unplugin(viteEnv), unocss(), mock, progress(), routerPage()];
|
|
|
|
if (viteEnv.VITE_VISUALIZER === 'Y') {
|
|
plugins.push(visualizer as PluginOption);
|
|
}
|
|
if (viteEnv.VITE_COMPRESS === 'Y') {
|
|
plugins.push(compress(viteEnv));
|
|
}
|
|
if (viteEnv.VITE_PWA === 'Y' || viteEnv.VITE_VERCEL === 'Y') {
|
|
plugins.push(pwa());
|
|
}
|
|
|
|
return plugins;
|
|
}
|