1
0
mirror of https://github.com/pavlobu/deskreen.git synced 2025-05-18 08:20:10 -07:00
deskreen/app/menu.ts
2021-01-17 23:45:59 +02:00

231 lines
6.2 KiB
TypeScript

/* 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,
];
}
}