update and test something

This commit is contained in:
Kenta420 2024-01-11 17:49:43 +07:00
parent 3e3c92b0af
commit ed90e1fd85
10 changed files with 147 additions and 15 deletions

View file

@ -1,4 +1,4 @@
import { app, BrowserWindow } from 'electron'
import { app, BrowserWindow, ipcMain, shell } from 'electron'
import path from 'node:path'
// The built directory structure
@ -11,8 +11,9 @@ import path from 'node:path'
// │ │ └── preload.js
// │
process.env.DIST = path.join(__dirname, '../dist')
process.env.VITE_PUBLIC = app.isPackaged ? process.env.DIST : path.join(process.env.DIST, '../public')
process.env.VITE_PUBLIC = app.isPackaged
? process.env.DIST
: path.join(process.env.DIST, '../public')
let win: BrowserWindow | null
// 🚧 Use ['ENV_NAME'] avoid vite:define plugin - Vite@2.x
@ -22,15 +23,25 @@ function createWindow() {
win = new BrowserWindow({
icon: path.join(process.env.VITE_PUBLIC, 'electron-vite.svg'),
webPreferences: {
preload: path.join(__dirname, 'preload.js'),
},
preload: path.join(__dirname, 'preload.js')
}
})
// Test active push message to Renderer-process.
win.webContents.on('did-finish-load', () => {
win?.webContents.send('main-process-message', (new Date).toLocaleString())
win?.webContents.send('main-process-message', new Date().toLocaleString())
})
if (process.defaultApp) {
if (process.argv.length >= 2) {
app.setAsDefaultProtocolClient('taobin-electron', process.execPath, [
path.resolve(process.argv[1])
])
}
} else {
app.setAsDefaultProtocolClient('taobin-electron')
}
if (VITE_DEV_SERVER_URL) {
win.loadURL(VITE_DEV_SERVER_URL)
} else {
@ -57,4 +68,17 @@ app.on('activate', () => {
}
})
app.whenReady().then(createWindow)
app.on('open-url', (_event, url) => {
win?.webContents.send('deeplink', url)
})
// Create mainWindow, load the rest of the app, etc...
app.whenReady().then(() => {
createWindow()
})
// deeplink
ipcMain.on('deeplink', (_event, url) => {
// open browser
shell.openExternal(url)
})