2024-05-19 13:20:42 +00:00
|
|
|
import {
|
|
|
|
colors,
|
|
|
|
generatorContentHash,
|
|
|
|
readPackageJSON,
|
|
|
|
} from '@vben/node-utils';
|
|
|
|
import { type PluginOption } from 'vite';
|
|
|
|
|
|
|
|
import { getEnvConfig } from '../utils/env';
|
|
|
|
|
|
|
|
interface PluginOptions {
|
|
|
|
isBuild: boolean;
|
|
|
|
root: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const GLOBAL_CONFIG_FILE_NAME = '_app.config.js';
|
|
|
|
const VBEN_ADMIN_PRO_APP_CONF = '_VBEN_ADMIN_PRO_APP_CONF_';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 用于将配置文件抽离出来并注入到项目中
|
|
|
|
* @returns
|
|
|
|
*/
|
|
|
|
|
|
|
|
async function viteExtraAppConfigPlugin({
|
|
|
|
isBuild,
|
|
|
|
root,
|
|
|
|
}: PluginOptions): Promise<PluginOption | undefined> {
|
|
|
|
let publicPath: string;
|
|
|
|
let source: string;
|
|
|
|
|
|
|
|
if (!isBuild) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const { version = '' } = await readPackageJSON(root);
|
|
|
|
|
|
|
|
return {
|
|
|
|
async configResolved(config) {
|
2024-06-02 15:50:58 +00:00
|
|
|
publicPath = ensureTrailingSlash(config.base);
|
2024-05-19 13:20:42 +00:00
|
|
|
source = await getConfigSource();
|
|
|
|
},
|
|
|
|
async generateBundle() {
|
|
|
|
try {
|
|
|
|
this.emitFile({
|
|
|
|
fileName: GLOBAL_CONFIG_FILE_NAME,
|
|
|
|
source,
|
|
|
|
type: 'asset',
|
|
|
|
});
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-console
|
|
|
|
console.log(colors.cyan(`✨configuration file is build successfully!`));
|
|
|
|
} catch (error) {
|
|
|
|
// eslint-disable-next-line no-console
|
|
|
|
console.log(
|
|
|
|
colors.red(
|
|
|
|
`configuration file configuration file failed to package:\n${error}`,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
name: 'vite:extra-app-config',
|
|
|
|
async transformIndexHtml(html) {
|
|
|
|
const hash = `v=${version}-${generatorContentHash(source, 8)}`;
|
|
|
|
|
|
|
|
const appConfigSrc = `${publicPath}${GLOBAL_CONFIG_FILE_NAME}?${hash}`;
|
|
|
|
|
|
|
|
return {
|
|
|
|
html,
|
2024-06-02 15:50:58 +00:00
|
|
|
tags: [{ attrs: { src: appConfigSrc }, tag: 'script' }],
|
2024-05-19 13:20:42 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
async function getConfigSource() {
|
|
|
|
const config = await getEnvConfig();
|
|
|
|
const windowVariable = `window.${VBEN_ADMIN_PRO_APP_CONF}`;
|
|
|
|
// 确保变量不会被修改
|
|
|
|
let source = `${windowVariable}=${JSON.stringify(config)};`;
|
|
|
|
source += `
|
|
|
|
Object.freeze(${windowVariable});
|
|
|
|
Object.defineProperty(window, "${VBEN_ADMIN_PRO_APP_CONF}", {
|
|
|
|
configurable: false,
|
|
|
|
writable: false,
|
|
|
|
});
|
|
|
|
`.replaceAll(/\s/g, '');
|
|
|
|
return source;
|
|
|
|
}
|
|
|
|
|
2024-06-02 15:50:58 +00:00
|
|
|
function ensureTrailingSlash(path: string) {
|
|
|
|
return path.endsWith('/') ? path : `${path}/`;
|
|
|
|
}
|
|
|
|
|
2024-05-19 13:20:42 +00:00
|
|
|
export { viteExtraAppConfigPlugin };
|