2022-04-27 19:01:54 +08:00
|
|
|
import type { PluginOption } from 'vite';
|
2021-09-20 02:48:53 +08:00
|
|
|
import vue from './vue';
|
2021-05-28 02:22:49 +08:00
|
|
|
import html from './html';
|
2022-04-27 19:01:54 +08:00
|
|
|
import unplugin from './unplugin';
|
2022-04-22 12:26:11 +08:00
|
|
|
import unocss from './unocss';
|
2021-12-25 01:23:44 +08:00
|
|
|
import mock from './mock';
|
2022-01-03 22:20:10 +08:00
|
|
|
import visualizer from './visualizer';
|
2022-04-27 19:01:54 +08:00
|
|
|
import compress from './compress';
|
2022-01-03 22:20:10 +08:00
|
|
|
|
2022-03-05 01:55:21 +08:00
|
|
|
/**
|
2022-04-23 02:21:02 +08:00
|
|
|
* vite插件
|
2022-03-05 01:55:21 +08:00
|
|
|
* @param viteEnv - 环境变量配置
|
|
|
|
*/
|
2022-06-16 01:17:31 +08:00
|
|
|
export function setupVitePlugins(viteEnv: ImportMetaEnv): (PluginOption | PluginOption[])[] {
|
|
|
|
const plugins = [...vue, html(viteEnv), ...unplugin, unocss, mock];
|
2021-05-28 02:22:49 +08:00
|
|
|
|
2022-07-10 00:41:35 +08:00
|
|
|
if (viteEnv.VITE_VISUALIZER === '1') {
|
2022-01-03 22:20:10 +08:00
|
|
|
plugins.push(visualizer);
|
|
|
|
}
|
2022-07-10 00:41:35 +08:00
|
|
|
if (viteEnv.VITE_COMPRESS === '1') {
|
2022-04-27 19:01:54 +08:00
|
|
|
plugins.push(compress(viteEnv));
|
|
|
|
}
|
2021-05-28 02:22:49 +08:00
|
|
|
|
2022-01-03 22:20:10 +08:00
|
|
|
return plugins;
|
|
|
|
}
|