1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- import type { Plugin } from 'vite';
- import Components from 'unplugin-vue-components/vite';
- import { NaiveUiResolver } from 'unplugin-vue-components/resolvers';
- import topLevelAwait from 'vite-plugin-top-level-await';
- import vue from '@vitejs/plugin-vue';
- import vueJsx from '@vitejs/plugin-vue-jsx';
- import { configHtmlPlugin } from './html';
- import { configMockPlugin } from './mock';
- import { configCompressPlugin } from './compress';
- export function createVitePlugins(viteEnv: ViteEnv, isBuild: boolean, prodMock) {
- const { VITE_USE_MOCK, VITE_BUILD_COMPRESS, VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE } = viteEnv;
- const vitePlugins: (Plugin | Plugin[])[] = [
- // have to
- vue(),
- // have to
- vueJsx(),
- // 按需引入NaiveUi且自动创建组件声明
- Components({
- dts: true,
- resolvers: [NaiveUiResolver()],
- }),
- // 支持顶级wait
- topLevelAwait({
- // The export name of top-level await promise for each chunk module
- promiseExportName: '__tla',
- // The function to generate import names of top-level await promise in each chunk module
- promiseImportName: (i) => `__tla_${i}`,
- }),
- ];
- // vite-plugin-html
- vitePlugins.push(configHtmlPlugin(viteEnv, isBuild));
- // vite-plugin-mock
- VITE_USE_MOCK && vitePlugins.push(configMockPlugin(isBuild, prodMock));
- if (isBuild) {
- // rollup-plugin-gzip
- vitePlugins.push(
- configCompressPlugin(VITE_BUILD_COMPRESS, VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE)
- );
- }
- return vitePlugins;
- }
|