12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- /**
- * Generate additional configuration files when used for packaging. The file can be configured with some global variables, so that it can be changed directly externally without repackaging
- */
- import fs, { writeFileSync } from 'fs-extra'
- import colors from 'picocolors'
- import { GLOB_CONFIG_FILE_NAME, OUTPUT_DIR } from '../constant'
- import { getEnvConfig, getRootPath } from '../utils'
- import { getConfigFileName } from '../getConfigFileName'
- import pkg from '../../package.json'
- interface CreateConfigParams {
- configName: string
- config: any
- configFileName?: string
- }
- function createConfig(params: CreateConfigParams) {
- const { configName, config, configFileName } = params
- try {
- const windowConf = `window.${configName}`
- // Ensure that the variable will not be modified
- let configStr = `${windowConf}=${JSON.stringify(config)};`
- configStr += `
- Object.freeze(${windowConf});
- Object.defineProperty(window, "${configName}", {
- configurable: false,
- writable: false,
- });
- `.replace(/\s/g, '')
- fs.mkdirp(getRootPath(OUTPUT_DIR))
- writeFileSync(getRootPath(`${OUTPUT_DIR}/${configFileName}`), configStr)
- console.log(`${colors.cyan(`✨ [${pkg.name}]`)} - configuration file is build successfully:`)
- console.log(`${colors.gray(`${OUTPUT_DIR}/${colors.green(configFileName)}`)}\n`)
- }
- catch (error: any) {
- console.log(colors.red(`configuration file configuration file failed to package:\n${error}`))
- }
- }
- export function runBuildConfig() {
- const config = getEnvConfig()
- const configFileName = getConfigFileName(config)
- createConfig({ config, configName: configFileName, configFileName: GLOB_CONFIG_FILE_NAME })
- }
|