From 233125f586c2658be28dc6cf8e06ff2d7d2a4223 Mon Sep 17 00:00:00 2001 From: Jack Mallers Date: Wed, 31 Jan 2018 13:11:59 -0600 Subject: [PATCH] fix(input): give feature full menu for inputs --- app/menu.js | 44 ++++++++++++++++++++++++++++++++------------ 1 file changed, 32 insertions(+), 12 deletions(-) diff --git a/app/menu.js b/app/menu.js index b71fac01..8a8a493a 100644 --- a/app/menu.js +++ b/app/menu.js @@ -21,28 +21,48 @@ export default class MenuBuilder { template = this.buildDefaultTemplate() } + this.setupInputTemplate() + const menu = Menu.buildFromTemplate(template) Menu.setApplicationMenu(menu) + return menu } - setupDevelopmentEnvironment() { - this.mainWindow.openDevTools() + setupInputTemplate() { + const selectionMenu = Menu.buildFromTemplate([ + { role: 'copy' }, + { type: 'separator' }, + { role: 'selectall' }, + ]) + + const inputMenu = Menu.buildFromTemplate([ + { role: 'undo' }, + { role: 'redo' }, + { type: 'separator' }, + { role: 'cut' }, + { role: 'copy' }, + { role: 'paste' }, + { type: 'separator' }, + { role: 'selectall' }, + ]) + this.mainWindow.webContents.on('context-menu', (e, props) => { - const { x, y } = props - - Menu - .buildFromTemplate([{ - label: 'Inspect element', - click: () => { - this.mainWindow.inspectElement(x, y) - } - }]) - .popup(this.mainWindow) + const { selectionText, isEditable } = props; + + if (isEditable) { + inputMenu.popup(this.mainWindow); + } else if (selectionText && selectionText.trim() !== '') { + selectionMenu.popup(this.mainWindow); + } }) } + setupDevelopmentEnvironment() { + this.mainWindow.openDevTools() + } + buildDarwinTemplate() { const subMenuAbout = { label: 'Electron',