/* eslint-disable @typescript-eslint/no-explicit-any */ import { app, Menu, shell, BrowserWindow, MenuItemConstructorOptions, } from 'electron'; // import config from './configs/app.lang.config'; import signalingServer from './server'; interface DarwinMenuItemConstructorOptions extends MenuItemConstructorOptions { selector?: string; submenu?: DarwinMenuItemConstructorOptions[] | Menu; } export default class MenuBuilder { mainWindow: BrowserWindow; i18n: any; constructor(mainWindow: BrowserWindow, i18n: any) { this.mainWindow = mainWindow; this.i18n = i18n; } buildMenu() { if ( process.env.NODE_ENV === 'development' || process.env.DEBUG_PROD === 'true' ) { this.setupDevelopmentEnvironment(); } if (process.platform === 'darwin') { const menu = Menu.buildFromTemplate(this.buildDarwinTemplate()); Menu.setApplicationMenu(menu); } else { // for production, no menu for non MacOS app Menu.setApplicationMenu(null); } } setupDevelopmentEnvironment(): void { this.mainWindow.webContents.on('context-menu', (_, props) => { const { x, y } = props; Menu.buildFromTemplate([ { label: 'Inspect element', click: () => { this.mainWindow.webContents.inspectElement(x, y); }, }, ]).popup({ window: this.mainWindow }); }); } buildDarwinTemplate(): MenuItemConstructorOptions[] { const subMenuAbout: DarwinMenuItemConstructorOptions = { label: 'Deskreen', submenu: [ { label: 'About Deskreen', selector: 'orderFrontStandardAboutPanel:', }, { type: 'separator' }, { label: 'Services', submenu: [] }, { type: 'separator' }, { label: 'Hide Deskreen', accelerator: 'Command+H', selector: 'hide:', }, { label: 'Hide Others', accelerator: 'Command+Shift+H', selector: 'hideOtherApplications:', }, { label: 'Show All', selector: 'unhideAllApplications:' }, { type: 'separator' }, { label: 'Quit', accelerator: 'Command+Q', click: () => { signalingServer.stop(); app.quit(); }, }, ], }; const subMenuEdit: DarwinMenuItemConstructorOptions = { label: 'Edit', submenu: [ { label: 'Undo', accelerator: 'Command+Z', selector: 'undo:' }, { label: 'Redo', accelerator: 'Shift+Command+Z', selector: 'redo:' }, { type: 'separator' }, { label: 'Cut', accelerator: 'Command+X', selector: 'cut:' }, { label: 'Copy', accelerator: 'Command+C', selector: 'copy:' }, { label: 'Paste', accelerator: 'Command+V', selector: 'paste:' }, { label: 'Select All', accelerator: 'Command+A', selector: 'selectAll:', }, ], }; const subMenuViewDev: MenuItemConstructorOptions = { label: 'View', submenu: [ { label: 'Reload', accelerator: 'Command+R', click: () => { this.mainWindow.webContents.reload(); }, }, { label: 'Toggle Full Screen', accelerator: 'Ctrl+Command+F', click: () => { this.mainWindow.setFullScreen(!this.mainWindow.isFullScreen()); }, }, { label: 'Toggle Developer Tools', accelerator: 'Alt+Command+I', click: () => { this.mainWindow.webContents.toggleDevTools(); }, }, ], }; const subMenuViewProd: MenuItemConstructorOptions = { label: 'View', submenu: [ { label: 'Toggle Full Screen', accelerator: 'Ctrl+Command+F', click: () => { this.mainWindow.setFullScreen(!this.mainWindow.isFullScreen()); }, }, ], }; const subMenuWindow: DarwinMenuItemConstructorOptions = { label: 'Window', submenu: [ { label: 'Minimize', accelerator: 'Command+M', selector: 'performMiniaturize:', }, { label: 'Close', accelerator: 'Command+W', selector: 'performClose:' }, { type: 'separator' }, { label: 'Bring All to Front', selector: 'arrangeInFront:' }, ], }; const subMenuHelp: MenuItemConstructorOptions = { label: 'Help', submenu: [ { label: 'Learn More', click() { shell.openExternal('https://www.deskreen.com/'); }, }, { label: 'Documentation', click() { shell.openExternal( 'https://github.com/pavlobu/deskreen/blob/master/README.md' ); }, }, { label: 'Community Discussions', click() { shell.openExternal('https://github.com/pavlobu/deskreen/issues'); }, }, { label: 'Search Issues', click() { shell.openExternal('https://github.com/pavlobu/deskreen/issues'); }, }, ], }; const subMenuView = process.env.NODE_ENV === 'development' || process.env.DEBUG_PROD === 'true' ? subMenuViewDev : subMenuViewProd; // const languageSubmenu = config.languages.map((languageCode) => { // return { // label: this.i18n.t(languageCode), // type: 'radio', // checked: this.i18n.language === languageCode, // click: () => { // this.i18n.changeLanguage(languageCode); // setTimeout(() => { // // to fix for MacOS bug, not picking up new language on first click // if (this.i18n.language !== languageCode) { // this.i18n.changeLanguage(languageCode); // } // }, 500); // }, // }; // }); // const languageMenu: MenuItemConstructorOptions = { // label: this.i18n.t('Language'), // submenu: languageSubmenu as MenuItemConstructorOptions[], // }; return [ subMenuAbout, subMenuEdit, subMenuView, subMenuWindow, subMenuHelp, // languageMenu, ]; } }