index.ts 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import type { Plugin as VitePlugin } from 'vite';
  2. import type { Plugin as rollupPlugin } from 'rollup';
  3. import { createMockServer } from 'vite-plugin-mock';
  4. import ViteHtmlPlugin from 'vite-plugin-html';
  5. import PurgeIcons from 'vite-plugin-purge-icons';
  6. import visualizer from 'rollup-plugin-visualizer';
  7. import gzipPlugin from './gzip/index';
  8. import { hmScript } from '../hm';
  9. const pkg = require('../../../package.json');
  10. import { isDevFn, isProdFn, isSiteMode, ViteEnv, isReportMode, isBuildGzip } from '../../utils';
  11. import { GLOB_CONFIG_FILE_NAME } from '../../constant';
  12. // gen vite plugins
  13. export function createVitePlugins(viteEnv: ViteEnv) {
  14. const { VITE_USE_MOCK, VITE_GLOB_APP_TITLE, VITE_PUBLIC_PATH } = viteEnv;
  15. const vitePlugins: VitePlugin[] = [];
  16. // vite-plugin-html
  17. vitePlugins.push(
  18. ViteHtmlPlugin({
  19. // html title
  20. title: VITE_GLOB_APP_TITLE,
  21. minify: isProdFn(),
  22. options: {
  23. // Package and insert additional configuration files
  24. injectConfig: isProdFn()
  25. ? `<script src='${VITE_PUBLIC_PATH || './'}${GLOB_CONFIG_FILE_NAME}?v=${
  26. pkg.version
  27. }-${new Date().getTime()}'></script>`
  28. : '',
  29. // Insert Baidu statistics code
  30. hmScript: isSiteMode() ? hmScript : '',
  31. },
  32. })
  33. );
  34. // vite-plugin-purge-icons
  35. vitePlugins.push(PurgeIcons());
  36. // vite-plugin-mock
  37. if (isDevFn() && VITE_USE_MOCK) {
  38. // open mock
  39. vitePlugins.push(
  40. createMockServer({
  41. ignore: /^\_/,
  42. mockPath: 'mock',
  43. })
  44. );
  45. }
  46. return vitePlugins;
  47. }
  48. // gen rollup plugins
  49. export function createRollupPlugin() {
  50. const rollupPlugins: rollupPlugin[] = [];
  51. if (isProdFn()) {
  52. if (isReportMode()) {
  53. // rollup-plugin-visualizer
  54. rollupPlugins.push(
  55. visualizer({ filename: './build/.cache/stats.html', open: true }) as Plugin
  56. );
  57. }
  58. if (isBuildGzip() || isSiteMode()) {
  59. // rollup-plugin-gizp
  60. rollupPlugins.push(gzipPlugin());
  61. }
  62. }
  63. return rollupPlugins;
  64. }