123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- /**
- * Plugin to minimize and use ejs template syntax in index.html.
- * https://github.com/anncwb/vite-plugin-html
- */
- import type { PluginOption } from 'vite';
- import { createHtmlPlugin } from 'vite-plugin-html';
- import pkg from '../../../package.json';
- import { GLOB_CONFIG_FILE_NAME } from '../../constant';
- export function configHtmlPlugin(env: ViteEnv, isBuild: boolean, isQiankunMicro: boolean) {
- const { VITE_GLOB_APP_TITLE, VITE_PUBLIC_PATH } = env;
- const path = VITE_PUBLIC_PATH.endsWith('/') ? VITE_PUBLIC_PATH : `${VITE_PUBLIC_PATH}/`;
- const getAppConfigSrc = () => {
- return `${path || '/'}${GLOB_CONFIG_FILE_NAME}?v=${pkg.version}-${new Date().getTime()}`;
- };
- // 【JEECG作为乾坤子应用】补充静态资源前缀
- const {VITE_GLOB_QIANKUN_MICRO_APP_ENTRY} = env;
- const basePublicPath = isQiankunMicro ? VITE_GLOB_QIANKUN_MICRO_APP_ENTRY : '';
- const htmlPlugin: PluginOption[] = createHtmlPlugin({
- minify: isBuild,
- inject: {
- // 修改模板html的标题
- data: {
- title: VITE_GLOB_APP_TITLE,
- basePublicPath: basePublicPath,
- },
- // 将app.config.js文件注入到模板html中
- tags: isBuild
- ? [
- {
- tag: 'script',
- attrs: {
- src: getAppConfigSrc(),
- },
- },
- ]
- : [],
- },
- });
- return htmlPlugin;
- }
|