electron-vite-vue/script/build-preload.ts

43 lines
1.2 KiB
TypeScript
Raw Normal View History

2021-09-09 09:35:21 +08:00
import { watch, rollup, OutputOptions } from 'rollup'
2021-08-05 09:25:34 +08:00
import minimist from 'minimist'
import chalk from 'chalk'
2021-09-09 09:35:21 +08:00
import ora from 'ora'
import WebSocket from 'ws'
2021-09-09 09:35:21 +08:00
import options from './rollup.config'
import { createWsServer, formatWsSendData } from './ws'
2021-08-05 09:25:34 +08:00
const argv = minimist(process.argv.slice(2))
2021-09-09 09:35:21 +08:00
const opt = options({ proc: 'preload', env: argv.env })
2021-08-05 09:25:34 +08:00
const TAG = '[build-preload.ts]'
2021-09-09 09:35:21 +08:00
const spinner = ora(`${TAG} Electron preload build...`)
2021-08-05 09:25:34 +08:00
2021-09-09 09:35:21 +08:00
; (async () => {
if (argv.watch) {
const watcher = watch(opt)
const wssObj = createWsServer({ TAG })
2021-09-09 09:35:21 +08:00
watcher.on('change', filename => {
const log = chalk.yellow(`change -- ${filename}`)
console.log(TAG, log)
// Hot reload renderer process !!!
if (wssObj.instance?.readyState === WebSocket.OPEN) {
console.log(TAG, 'Hot reload renderer process')
wssObj.instance.send(formatWsSendData({ cmd: 'reload', data: Date.now() }))
}
2021-08-05 09:25:34 +08:00
})
2021-09-09 09:35:21 +08:00
} else {
spinner.start()
try {
const build = await rollup(opt)
await build.write(opt.output as OutputOptions)
spinner.succeed()
process.exit()
} catch (error) {
2021-08-05 09:25:34 +08:00
console.log(`\n${TAG} ${chalk.red('构建报错')}\n`, error, '\n')
2021-09-09 09:35:21 +08:00
spinner.fail()
process.exit(1)
}
2021-08-05 09:25:34 +08:00
}
2021-09-09 09:35:21 +08:00
})();