This repository has been archived on 2023-12-22. You can view files and clone it, but cannot push or open issues or pull requests.
old-monorepo/Dashboard/app/main/index.js

107 lines
2.6 KiB
JavaScript
Raw Normal View History

2020-07-30 20:59:37 +02:00
import path from 'path';
2020-08-02 11:00:40 +02:00
import { app, BrowserWindow, Menu, Tray } from 'electron';
2020-08-07 16:09:15 +02:00
import screenz from 'screenz';
2020-07-30 20:59:37 +02:00
2020-08-07 16:09:15 +02:00
//App preferences
2020-08-01 20:58:36 +02:00
const windowSize = { width: 620, height: 320 };
2020-08-05 19:34:46 +02:00
const windowOffset = 40;
2020-08-07 16:29:02 +02:00
const appIconPath = '../../dist-assets/icon.ico';
2020-08-05 15:15:41 +02:00
const trayIconPath = '../../dist-assets/tray.ico';
2020-08-01 17:55:03 +02:00
2020-08-07 16:09:15 +02:00
let mainWindow = null;
let trayIcon = null;
2020-08-07 16:09:15 +02:00
const isDevelopment = process.env.NODE_ENV === 'development';
const gotTheLock = app.requestSingleInstanceLock();
app.allowRendererProcessReuse = false;
//Install chrome devtools extensions
2020-07-30 20:59:37 +02:00
const installExtensions = async () => {
const installer = require('electron-devtools-installer');
const extensions = ['REACT_DEVELOPER_TOOLS', 'REDUX_DEVTOOLS'];
const forceDownload = !!process.env.UPGRADE_EXTENSIONS;
for (const name of extensions) {
try {
await installer.default(installer[name], forceDownload);
} catch (e) {
console.log(`Error installing ${name} extension: ${e.message}`);
}
}
};
2020-08-07 16:09:15 +02:00
//Force single app instance
2020-08-05 15:15:41 +02:00
if (!gotTheLock) {
app.quit();
} else {
app.on('second-instance', () => {
2020-08-07 16:09:15 +02:00
mainWindow.show();
2020-07-30 20:59:37 +02:00
});
2020-08-05 15:15:41 +02:00
app.on('ready', async () => {
if (isDevelopment) {
await installExtensions();
}
2020-07-30 20:59:37 +02:00
2020-08-07 16:27:33 +02:00
//Initialize window
2020-08-05 15:15:41 +02:00
mainWindow = new BrowserWindow({
width: windowSize.width,
height: windowSize.height,
x: screenz.width - windowSize.width,
2020-08-05 19:34:46 +02:00
y: screenz.height - windowSize.height - windowOffset,
2020-08-05 15:15:41 +02:00
movable: false,
resizable: false,
frame: false,
show: false,
skipTaskbar: true,
alwaysOnTop: true,
webPreferences: {
nodeIntegration: true,
},
icon: path.join(__dirname, appIconPath),
});
2020-07-30 20:59:37 +02:00
2020-08-05 15:15:41 +02:00
mainWindow.setMenu(null);
mainWindow.loadFile(path.resolve(path.join(__dirname, '../renderer/index.html')));
2020-07-30 20:59:37 +02:00
2020-08-07 16:27:33 +02:00
//Create tray icon with context menu
trayIcon = createTray();
2020-08-07 16:27:33 +02:00
//Listen to tray icon onclick event
trayIcon.on('click', () => {
mainWindow.show();
});
2020-08-07 16:09:15 +02:00
2020-08-07 16:27:33 +02:00
//Open devtools on startup
2020-08-05 15:15:41 +02:00
mainWindow.webContents.on('did-finish-load', () => {
2020-08-07 16:09:15 +02:00
mainWindow.webContents.openDevTools();
2020-08-05 15:15:41 +02:00
});
2020-07-30 20:59:37 +02:00
});
2020-08-05 15:15:41 +02:00
}
2020-08-07 16:27:33 +02:00
//Tray creation
2020-08-05 15:15:41 +02:00
function createTray() {
const trayIcon = new Tray(path.join(__dirname, trayIconPath));
const contextMenu = Menu.buildFromTemplate([
{
label: 'Show',
click: () => {
mainWindow.show();
2020-08-01 17:55:03 +02:00
},
2020-08-05 15:15:41 +02:00
},
{
label: 'Exit',
click: () => {
app.quit();
2020-08-01 17:55:03 +02:00
},
2020-08-05 15:15:41 +02:00
},
]);
2020-08-01 17:55:03 +02:00
2020-08-05 15:15:41 +02:00
trayIcon.setToolTip('Light Control');
trayIcon.setContextMenu(contextMenu);
return trayIcon;
}
2020-08-01 17:55:03 +02:00
2020-08-07 16:09:15 +02:00
//Hide window when out of focus
2020-08-05 15:15:41 +02:00
app.on('browser-window-blur', () => {
mainWindow.hide();
});