mirror of
https://github.com/pavlobu/deskreen.git
synced 2025-05-18 08:20:10 -07:00
231 lines
6.2 KiB
TypeScript
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,
|
|
];
|
|
}
|
|
}
|