From c861aaeb331869172a6245f06a29fad8125d6e94 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=8D=89=E9=9E=8B=E6=B2=A1=E5=8F=B7?= <308487730@qq.com> Date: Wed, 29 Jun 2022 08:36:04 +0800 Subject: [PATCH] chore: optimize code --- electron/main/index.ts | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/electron/main/index.ts b/electron/main/index.ts index 76cf34d..1b376f1 100644 --- a/electron/main/index.ts +++ b/electron/main/index.ts @@ -12,32 +12,42 @@ if (!app.requestSingleInstanceLock()) { app.quit() process.exit(0) } + process.env['ELECTRON_DISABLE_SECURITY_WARNINGS'] = 'true' +export const ROOT_PATH = { + // /dist + dist: join(__dirname, '../..'), + // /dist or /public + public: join(__dirname, app.isPackaged ? '../..' : '../../../public'), +} + let win: BrowserWindow | null = null // Here, you can also use other preload -const splash = join(__dirname, '../preload/splash.js') +const preload = join(__dirname, '../preload/index.js') // 🚧 Use ['ENV_NAME'] avoid vite:define plugin const url = `http://${process.env['VITE_DEV_SERVER_HOST']}:${process.env['VITE_DEV_SERVER_PORT']}` +const indexHtml = join(ROOT_PATH.dist, 'index.html') async function createWindow() { win = new BrowserWindow({ title: 'Main window', + icon: join(ROOT_PATH.public, 'favicon.ico'), webPreferences: { - preload: splash, + preload, nodeIntegration: true, contextIsolation: false, }, }) if (app.isPackaged) { - win.loadFile(join(__dirname, '../../index.html')) + win.loadFile(indexHtml) } else { win.loadURL(url) // win.webContents.openDevTools() } - // Test active push message to Renderer-process + // Test actively push message to the Electron-Renderer win.webContents.on('did-finish-load', () => { win?.webContents.send('main-process-message', new Date().toLocaleString()) }) @@ -74,17 +84,15 @@ app.on('activate', () => { }) // new window example arg: new windows url -ipcMain.handle("open-win", (event, arg) => { +ipcMain.handle('open-win', (event, arg) => { const childWindow = new BrowserWindow({ webPreferences: { - preload: splash, + preload, }, }) if (app.isPackaged) { - childWindow.loadFile(join(__dirname, `../renderer/index.html`), { - hash: `${arg}`, - }) + childWindow.loadFile(indexHtml, { hash: arg }) } else { childWindow.loadURL(`${url}/#${arg}`) // childWindow.webContents.openDevTools({ mode: "undocked", activate: true })