index.ts 1.4 KB
Newer Older
V
vben 已提交
1
import type { Plugin } from 'vite';
2 3 4

import PurgeIcons from 'vite-plugin-purge-icons';

V
vben 已提交
5 6
// @ts-ignore
import pkg from '../../../package.json';
7
import { ViteEnv } from '../../utils';
V
vben 已提交
8 9 10 11
import { configHtmlPlugin } from './html';
import { configPwaConfig } from './pwa';
import { configMockPlugin } from './mock';
import { configGzipPlugin } from './gzip';
V
vben 已提交
12
import { configStyleImportPlugin } from './styleImport';
13
import { configVisualizerConfig } from './visualizer';
V
vben 已提交
14
import { configThemePlugin } from './theme';
V
vben 已提交
15
import { configImageminPlugin } from './imagemin';
16 17

// gen vite plugins
V
vben 已提交
18
export function createVitePlugins(viteEnv: ViteEnv, isBuild: boolean) {
V
vben 已提交
19
  const vitePlugins: (Plugin | Plugin[])[] = [];
20 21

  // vite-plugin-html
V
vben 已提交
22 23
  vitePlugins.push(configHtmlPlugin(viteEnv, isBuild));

V
vben 已提交
24
  // vite-plugin-mock
V
vben 已提交
25 26
  vitePlugins.push(configMockPlugin(viteEnv, isBuild));

27 28 29
  // vite-plugin-purge-icons
  vitePlugins.push(PurgeIcons());

V
vben 已提交
30
  // vite-plugin-style-import
V
vben 已提交
31
  vitePlugins.push(configStyleImportPlugin());
V
vben 已提交
32

V
vben 已提交
33
  // rollup-plugin-visualizer
34
  vitePlugins.push(configVisualizerConfig());
V
vben 已提交
35

V
vben 已提交
36 37 38
  //vite-plugin-theme
  vitePlugins.push(configThemePlugin());

V
vben 已提交
39 40 41 42 43 44 45 46 47 48 49
  if (isBuild) {
    //vite-plugin-imagemin
    viteEnv.VITE_USE_IMAGEMIN && vitePlugins.push(configImageminPlugin());

    // rollup-plugin-gzip
    vitePlugins.push(configGzipPlugin(isBuild));

    // vite-plugin-pwa
    vitePlugins.push(configPwaConfig(viteEnv));
  }

V
vben 已提交
50
  return vitePlugins;
51
}