Blame view

build/vite/plugin/index.ts 1.32 KB
1
2
3
4
5
6
7
8
import type { Plugin as VitePlugin } from 'vite';
import type { Plugin as rollupPlugin } from 'rollup';

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

import visualizer from 'rollup-plugin-visualizer';
import gzipPlugin from './gzip/index';
vben authored
9
10
// @ts-ignore
import pkg from '../../../package.json';
11
import { isSiteMode, ViteEnv, isReportMode, isBuildGzip } from '../../utils';
12
13
14
import { setupHtmlPlugin } from './html';
import { setupPwaPlugin } from './pwa';
import { setupMockPlugin } from './mock';
15
16

// gen vite plugins
17
export function createVitePlugins(viteEnv: ViteEnv, mode: 'development' | 'production') {
18
19
20
  const vitePlugins: VitePlugin[] = [];

  // vite-plugin-html
21
  setupHtmlPlugin(vitePlugins, viteEnv, mode);
22
  // vite-plugin-pwa
23
  setupPwaPlugin(vitePlugins, viteEnv, mode);
24
  // vite-plugin-mock
25
  setupMockPlugin(vitePlugins, viteEnv, mode);
26
27
28
29
30
31
32
33
34
35
36

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

  return vitePlugins;
}

// gen rollup plugins
export function createRollupPlugin() {
  const rollupPlugins: rollupPlugin[] = [];
37
  if (isReportMode()) {
38
39
    // rollup-plugin-visualizer
    rollupPlugins.push(visualizer({ filename: './build/.cache/stats.html', open: true }) as Plugin);
40
  }
41
  if (isBuildGzip() || isSiteMode()) {
42
43
44
45
    // rollup-plugin-gizp
    rollupPlugins.push(gzipPlugin());
  }
46
47
  return rollupPlugins;
}