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';

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

// gen vite plugins
V
vben 已提交
16
export function createVitePlugins(viteEnv: ViteEnv, isBuild: boolean) {
V
vben 已提交
17 18
  const { VITE_USE_IMAGEMIN, VITE_USE_MOCK } = viteEnv;

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
  VITE_USE_MOCK && vitePlugins.push(configMockPlugin(isBuild));
V
vben 已提交
26

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
  if (isBuild) {
    //vite-plugin-imagemin
V
vben 已提交
41
    VITE_USE_IMAGEMIN && vitePlugins.push(configImageminPlugin());
V
vben 已提交
42 43 44 45 46 47 48 49

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

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

V
vben 已提交
50
  return vitePlugins;
51
}