refactor: `vite-plugin-electron` instead `vite-electron-plugin`

This commit is contained in:
草鞋没号 2023-03-30 19:39:42 +08:00
parent 1c707b40bb
commit e93d649340
2 changed files with 46 additions and 107 deletions

View File

@ -2,8 +2,7 @@ import { rmSync } from 'node:fs'
import path from 'node:path'
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import electron from 'vite-electron-plugin'
import { customStart, loadViteEnv } from 'vite-electron-plugin/plugin'
import electron from 'vite-plugin-electron'
import renderer from 'vite-plugin-electron-renderer'
import pkg from './package.json'
@ -11,7 +10,9 @@ import pkg from './package.json'
export default defineConfig(({ command }) => {
rmSync('dist-electron', { recursive: true, force: true })
const sourcemap = command === 'serve' || !!process.env.VSCODE_DEBUG
const isServe = command === 'serve'
const isBuild = command === 'build'
const sourcemap = isServe || !!process.env.VSCODE_DEBUG
return {
resolve: {
@ -21,34 +22,57 @@ export default defineConfig(({ command }) => {
},
plugins: [
react(),
electron({
include: [
'electron'
],
transformOptions: {
sourcemap,
electron([
{
// Main-Process entry file of the Electron App.
entry: 'electron/main/index.ts',
onstart(options) {
if (process.env.VSCODE_DEBUG) {
console.log(/* For `.vscode/.debug.script.mjs` */'[startup] Electron App')
} else {
options.startup()
}
},
vite: {
build: {
sourcemap,
minify: isBuild,
outDir: 'dist-electron/main',
rollupOptions: {
external: Object.keys('dependencies' in pkg ? pkg.dependencies : {}),
},
},
},
},
plugins: [
...(!!process.env.VSCODE_DEBUG
? [
// Will start Electron via VSCode Debug
customStart(() => console.log(/* For `.vscode/.debug.script.mjs` */'[startup] Electron App')),
]
: []),
// Allow use `import.meta.env.VITE_SOME_KEY` in Electron-Main
loadViteEnv(),
],
}),
{
entry: 'electron/preload/index.ts',
onstart(options) {
// Notify the Renderer-Process to reload the page when the Preload-Scripts build is complete,
// instead of restarting the entire Electron App.
options.reload()
},
vite: {
build: {
sourcemap: sourcemap ? 'inline' : undefined, // #332
minify: isBuild,
outDir: 'dist-electron/preload',
rollupOptions: {
external: Object.keys('dependencies' in pkg ? pkg.dependencies : {}),
},
},
},
}
]),
// Use Node.js API in the Renderer-process
renderer(),
],
server: !!process.env.VSCODE_DEBUG ? (() => {
server: process.env.VSCODE_DEBUG && (() => {
const url = new URL(pkg.debug.env.VITE_DEV_SERVER_URL)
return {
host: url.hostname,
port: +url.port,
}
})() : undefined,
})(),
clearScreen: false,
}
})

View File

@ -1,85 +0,0 @@
import { rmSync } from 'node:fs'
import path from 'node:path'
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import electron from 'vite-electron-plugin'
import { customStart, loadViteEnv } from 'vite-electron-plugin/plugin'
import preload from 'vite-plugin-electron'
import renderer from 'vite-plugin-electron-renderer'
import pkg from './package.json'
let preloadHasReady = false
// https://vitejs.dev/config/
export default defineConfig(({ command }) => {
rmSync('dist-electron', { recursive: true, force: true })
const sourcemap = command === 'serve' || !!process.env.VSCODE_DEBUG
return {
resolve: {
alias: {
'@': path.join(__dirname, 'src')
},
},
plugins: [
react(),
electron({
include: [
'electron/main'
],
transformOptions: {
sourcemap,
},
plugins: [
customStart(args => {
if (process.env.VSCODE_DEBUG) {
// Start Electron via VSCode
console.log(/* For `.vscode/.debug.script.mjs` */'[startup] Electron App')
} else {
if (preloadHasReady) {
args?.startup()
} else {
console.log('[startup] waiting for preload')
}
}
}),
// Allow use `import.meta.env.VITE_SOME_KEY` in Main process
loadViteEnv(),
],
}),
// Preload scripts
preload({
entry: [
'electron/preload/index.ts'
],
vite: {
build: {
minify: false,
outDir: 'dist-electron/preload',
},
},
onstart(args) {
if (preloadHasReady) {
args.reload()
} else {
preloadHasReady = true
args.startup()
}
},
}),
// Use Node.js API in the Renderer process
renderer({
nodeIntegration: true,
}),
],
server: !!process.env.VSCODE_DEBUG ? (() => {
const url = new URL(pkg.debug.env.VITE_DEV_SERVER_URL)
return {
host: url.hostname,
port: +url.port,
}
})() : undefined,
clearScreen: false,
}
})