Taobin-Recipe-Manager/client-electron/electron/main.ts
2024-03-15 14:10:24 +07:00

153 lines
4.6 KiB
TypeScript

import type { WebRequestFilter } from 'electron'
import { app, BrowserWindow, ipcMain, session, shell } from 'electron'
import path from 'node:path'
import deeplink from './deeplink'
import { eventGetKeyChain } from './keychain'
import { AdbTcpSocket } from './adb'
// The built directory structure
//
// ├─┬─┬ dist
// │ │ └── index.html
// │ │
// │ ├─┬ dist-electron
// │ │ ├── main.js
// │ │ └── preload.js
// │
process.env.DIST = path.join(__dirname, '../dist-renderer')
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
const VITE_DEV_SERVER_URL = process.env['VITE_DEV_SERVER_URL']
function createWindow() {
win = new BrowserWindow({
icon: path.join(process.env.VITE_PUBLIC, 'electron-vite.svg'),
webPreferences: {
preload: path.join(__dirname, 'preload.js')
},
width: 1270,
height: 720
})
// Test active push message to Renderer-process.
win.webContents.on('did-finish-load', () => {
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')
}
let grantedDeviceThroughPermHandler: Electron.USBDevice
win.webContents.session.on('select-usb-device', (event, details, callback) => {
// Add events to handle devices being added or removed before the callback on
// `select-usb-device` is called.
win?.webContents.session.on('usb-device-added', (_event, device) => {
console.log('usb-device-added FIRED WITH', device)
// Optionally update details.deviceList
})
win?.webContents.session.on('usb-device-removed', (_event, device) => {
console.log('usb-device-removed FIRED WITH', device)
// Optionally update details.deviceList
})
event.preventDefault()
if (details.deviceList && details.deviceList.length > 0) {
const deviceToReturn = details.deviceList.find(device => device.vendorId === 1478)
if (deviceToReturn) {
callback(deviceToReturn.deviceId)
} else {
callback()
}
}
})
win.webContents.session.setPermissionCheckHandler((_webContents, permission) => {
if (permission === 'usb') {
return true
}
return false
})
win.webContents.session.setDevicePermissionHandler(details => {
console.log(details)
if (details.deviceType === 'usb' && details.device.vendorId == 1478) {
if (!grantedDeviceThroughPermHandler) {
grantedDeviceThroughPermHandler = details.device as Electron.USBDevice
return true
} else if (grantedDeviceThroughPermHandler.vendorId === 1478) {
return true
} else {
return false
}
}
return false
})
if (VITE_DEV_SERVER_URL) {
win.loadURL(VITE_DEV_SERVER_URL)
} else {
// win.loadFile('dist/index.html')
win.loadFile(path.join(process.env.DIST, 'index.html'))
}
}
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit()
win = null
}
})
app.on('activate', () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})
// Create MainWindow, load the rest of the app, etc...
app.whenReady().then(() => {
createWindow()
// deeplink
deeplink(app, win, ipcMain, shell)
// adb
AdbTcpSocket(win, ipcMain)
//keychain
eventGetKeyChain(ipcMain)
const filter: WebRequestFilter = {
urls: ['http://localhost:8080/*']
}
session.defaultSession.webRequest.onBeforeSendHeaders(filter, (details, callback) => {
details.requestHeaders['Origin'] = 'http://localhost:8080'
callback({ requestHeaders: details.requestHeaders })
})
session.defaultSession.webRequest.onHeadersReceived(filter, (details, callback) => {
if (details.responseHeaders) {
details.responseHeaders['Access-Control-Allow-Origin'] = ['*']
}
callback({ responseHeaders: details.responseHeaders })
})
})
process.on('unhandledRejection', () => {
console.error('Unhandled Rejection ignoring')
// Application specific logging, throwing an error, or other logic here
})