'use strict'; const electron = require('electron'); const { getConfigField, updateConfigField } = require('../config.js'); const AutoLaunch = require('auto-launch'); const isMac = require('../utils/misc.js').isMac; const log = require('../log.js'); const logLevels = require('../enums/logLevels.js'); const eventEmitter = require('../eventEmitter'); let minimizeOnClose = false; let launchOnStartup = false; let isAlwaysOnTop = false; setCheckboxValues(); let symphonyAutoLauncher; if (isMac) { symphonyAutoLauncher = new AutoLaunch({ name: 'Symphony', mac: { useLaunchAgent: true, }, path: process.execPath, }); } else { symphonyAutoLauncher = new AutoLaunch({ name: 'Symphony', path: process.execPath, }); } const template = [{ label: 'Edit', submenu: [ { role: 'undo' }, { role: 'redo' }, { type: 'separator' }, { role: 'cut' }, { role: 'copy' }, { role: 'paste' }, { role: 'pasteandmatchstyle' }, { role: 'delete' }, { role: 'selectall' } ] }, { label: 'View', submenu: [{ label: 'Reload', accelerator: 'CmdOrCtrl+R', click(item, focusedWindow) { if (focusedWindow) { focusedWindow.reload(); } } }, { label: 'Toggle Developer Tools', accelerator: isMac ? 'Alt+Command+I' : 'Ctrl+Shift+I', click(item, focusedWindow) { if (focusedWindow) { focusedWindow.webContents.toggleDevTools(); } } }, { type: 'separator' }, { role: 'resetzoom' }, { role: 'zoomin' }, { role: 'zoomout' }, { type: 'separator' }, { role: 'togglefullscreen' } ] }, { role: 'window', submenu: [{ role: 'minimize' }, { role: 'close' } ] }, { role: 'help', submenu: [{ label: 'Learn More', click() { electron.shell.openExternal('https://www.symphony.com'); } }] } ]; function getTemplate(app) { if (isMac && template[0].label !== app.getName()) { template.unshift({ label: app.getName(), submenu: [{ role: 'about' }, { type: 'separator' }, { role: 'services', submenu: [] }, { type: 'separator' }, { role: 'hide' }, { role: 'hideothers' }, { role: 'unhide' }, { type: 'separator' }, { role: 'quit' } ] }); // Edit menu. template[1].submenu.push({ type: 'separator' }, { label: 'Speech', submenu: [{ role: 'startspeaking' }, { role: 'stopspeaking' } ] }); // Window menu. template[3].submenu = [{ label: 'Close', accelerator: 'CmdOrCtrl+W', role: 'close' }, { label: 'Minimize', accelerator: 'CmdOrCtrl+M', role: 'minimize' }, { label: 'Zoom', role: 'zoom' }, { type: 'separator' }, { label: 'Bring All to Front', role: 'front' } ]; } let index = 2; if (isMac && template[0].label !== app.getName()) { index = 3; } // Window menu -> launchOnStartup. template[index].submenu.push({ label: 'Auto Launch On Startup', type: 'checkbox', checked: launchOnStartup, click: function(item) { if (item.checked) { symphonyAutoLauncher.enable() .catch(function(err) { let title = 'Error setting AutoLaunch configuration'; log.send(logLevels.ERROR, 'MenuTemplate: ' + title + ': auto launch error ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); } else { symphonyAutoLauncher.disable() .catch(function(err) { let title = 'Error setting AutoLaunch configuration'; log.send(logLevels.ERROR, 'MenuTemplate: ' + title + ': auto launch error ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); } launchOnStartup = item.checked; updateConfigField('launchOnStartup', launchOnStartup); } }); // Window menu -> alwaysOnTop. template[index].submenu.push({ label: 'Always on top', type: 'checkbox', checked: isAlwaysOnTop, click: (item) => { isAlwaysOnTop = item.checked; eventEmitter.emit('isAlwaysOnTop', isAlwaysOnTop); updateConfigField('alwaysOnTop', isAlwaysOnTop); } }); // Window menu -> minimizeOnClose. // ToDo: Add behavior on Close. template[index].submenu.push({ label: 'Minimize on Close', type: 'checkbox', checked: minimizeOnClose, click: function(item) { minimizeOnClose = item.checked; updateConfigField('minimizeOnClose', minimizeOnClose); } }); if (!isMac) { template[index].submenu.push({ label: 'Quit Symphony', click: function() { app.quit(); } }); } return template; } /** * Sets the checkbox values for different menu items * based on configuration */ function setCheckboxValues() { getConfigField('minimizeOnClose').then(function(mClose) { minimizeOnClose = mClose; }).catch(function(err) { let title = 'Error loading configuration'; log.send(logLevels.ERROR, 'MenuTemplate: error getting config field minimizeOnClose, error: ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); getConfigField('launchOnStartup').then(function(lStartup) { launchOnStartup = lStartup; }).catch(function(err) { let title = 'Error loading configuration'; log.send(logLevels.ERROR, 'MenuTemplate: error getting config field launchOnStartup, error: ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); getConfigField('alwaysOnTop').then(function(mAlwaysOnTop) { isAlwaysOnTop = mAlwaysOnTop; eventEmitter.emit('isAlwaysOnTop', isAlwaysOnTop); }).catch(function(err) { let title = 'Error loading configuration'; log.send(logLevels.ERROR, 'MenuTemplate: error getting config field alwaysOnTop, error: ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); getConfigField('notificationSettings').then(function(notfObject) { eventEmitter.emit('notificationSettings', notfObject); }).catch(function(err) { let title = 'Error loading configuration'; log.send(logLevels.ERROR, 'MenuTemplate: error getting config field notificationSettings, error: ' + err); electron.dialog.showErrorBox(title, title + ': ' + err); }); } function getMinimizeOnClose() { return minimizeOnClose; } module.exports = { getTemplate: getTemplate, getMinimizeOnClose: getMinimizeOnClose };