You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
95 lines
3.4 KiB
95 lines
3.4 KiB
import type { CapacitorElectronConfig } from '@capacitor-community/electron';
|
|
import { getCapacitorElectronConfig, setupElectronDeepLinking } from '@capacitor-community/electron';
|
|
import type { MenuItemConstructorOptions } from 'electron';
|
|
import { app, MenuItem } from 'electron';
|
|
import electronIsDev from 'electron-is-dev';
|
|
import unhandled from 'electron-unhandled';
|
|
import { autoUpdater } from 'electron-updater';
|
|
|
|
import { ElectronCapacitorApp, setupContentSecurityPolicy, setupReloadWatcher } from './setup';
|
|
|
|
// Graceful handling of unhandled errors.
|
|
unhandled({
|
|
logger: (error) => {
|
|
// Suppress EPIPE errors which are common in AppImages due to console output issues
|
|
if (error.message && error.message.includes('EPIPE')) {
|
|
return; // Don't log EPIPE errors
|
|
}
|
|
console.error('Unhandled error:', error);
|
|
}
|
|
});
|
|
|
|
// Handle EPIPE errors on stdout/stderr to prevent crashes
|
|
process.stdout.on('error', (err) => {
|
|
if (err.code === 'EPIPE') {
|
|
// Ignore EPIPE errors on stdout
|
|
return;
|
|
}
|
|
console.error('stdout error:', err);
|
|
});
|
|
|
|
process.stderr.on('error', (err) => {
|
|
if (err.code === 'EPIPE') {
|
|
// Ignore EPIPE errors on stderr
|
|
return;
|
|
}
|
|
console.error('stderr error:', err);
|
|
});
|
|
|
|
// Define our menu templates (these are optional)
|
|
const trayMenuTemplate: (MenuItemConstructorOptions | MenuItem)[] = [new MenuItem({ label: 'Quit App', role: 'quit' })];
|
|
const appMenuBarMenuTemplate: (MenuItemConstructorOptions | MenuItem)[] = [
|
|
{ role: process.platform === 'darwin' ? 'appMenu' : 'fileMenu' },
|
|
{ role: 'viewMenu' },
|
|
];
|
|
|
|
// Get Config options from capacitor.config
|
|
const capacitorFileConfig: CapacitorElectronConfig = getCapacitorElectronConfig();
|
|
|
|
// Initialize our app. You can pass menu templates into the app here.
|
|
// const myCapacitorApp = new ElectronCapacitorApp(capacitorFileConfig);
|
|
const myCapacitorApp = new ElectronCapacitorApp(capacitorFileConfig, trayMenuTemplate, appMenuBarMenuTemplate);
|
|
|
|
// If deeplinking is enabled then we will set it up here.
|
|
if (capacitorFileConfig.electron?.deepLinkingEnabled) {
|
|
setupElectronDeepLinking(myCapacitorApp, {
|
|
customProtocol: capacitorFileConfig.electron.deepLinkingCustomProtocol ?? 'mycapacitorapp',
|
|
});
|
|
}
|
|
|
|
// If we are in Dev mode, use the file watcher components.
|
|
if (electronIsDev) {
|
|
setupReloadWatcher(myCapacitorApp);
|
|
}
|
|
|
|
// Run Application
|
|
(async () => {
|
|
// Wait for electron app to be ready.
|
|
await app.whenReady();
|
|
// Security - Set Content-Security-Policy based on whether or not we are in dev mode.
|
|
setupContentSecurityPolicy(myCapacitorApp.getCustomURLScheme());
|
|
// Initialize our app, build windows, and load content.
|
|
await myCapacitorApp.init();
|
|
// Check for updates if we are in a packaged app.
|
|
autoUpdater.checkForUpdatesAndNotify();
|
|
})();
|
|
|
|
// Handle when all of our windows are close (platforms have their own expectations).
|
|
app.on('window-all-closed', function () {
|
|
// On OS X it is common for applications and their menu bar
|
|
// to stay active until the user quits explicitly with Cmd + Q
|
|
if (process.platform !== 'darwin') {
|
|
app.quit();
|
|
}
|
|
});
|
|
|
|
// When the dock icon is clicked.
|
|
app.on('activate', async function () {
|
|
// 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 (myCapacitorApp.getMainWindow().isDestroyed()) {
|
|
await myCapacitorApp.init();
|
|
}
|
|
});
|
|
|
|
// Place all ipc or other electron api calls and custom functionality under this line
|
|
|