-
Notifications
You must be signed in to change notification settings - Fork 5
/
main-tray-two-windows.js
143 lines (124 loc) · 3.73 KB
/
main-tray-two-windows.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
const {app, BrowserWindow, Tray, nativeImage, screen } = require('electron')
const path = require('path')
let mainWindow = undefined;;
let tray = undefined;
//app.dock.hide();
function createWindow () {
// Create the browser window.
mainWindow = new BrowserWindow({
width: 700,
height: 500,
//-----tray----- end
webPreferences: {
}
})
// mainWindow.loadFile('index.html')
mainWindow.loadFile(path.join(__dirname, 'app', 'index.html'))
// Open the DevTools.
// mainWindow.webContents.openDevTools()
//-----tray----- start
mainWindow.on('closed',()=>mainWindow = null)
// Hide the window when it loses focus
mainWindow.on('blur', () => {
// if (!mainWindow.webContents.isDevToolsOpened()) {
// mainWindow.hide();
// }
});
//-----tray----- end
}
let w = undefined;
function createWindowTray () {
// Create the browser window.
w = new BrowserWindow({
width: 300,
height: 600,
//-----tray----- start
show: false,
frame: false,
fullscreen: false,
resizable: false,
transparent: false,
//-----tray----- end
webPreferences: {
backgroundThrottling: false
}
})
// w.loadFile('index.html')
w.loadFile(path.join(__dirname, 'app', 'index.html'))
// Open the DevTools.
// w.webContents.openDevTools()
//-----tray----- start
w.on('closed',()=>w = null)
// Hide the window when it loses focus
w.on('blur', () => {
// if (!w.webContents.isDevToolsOpened()) {
// w.hide();
// }
});
//-----tray----- end
}
//-----tray----- start
const createTray = () => {
const icon = path.join(__dirname, 'assets', 'tray.png')
const nimage = nativeImage.createFromPath(icon)
//tray is a app variable
tray = new Tray(nimage)
tray.on('click', (event)=>toggleWindow())
}
const toggleWindow = () => {
// mainWindow.loadFile('index.html')
w.loadFile(path.join(__dirname, 'app', 'index.html'))
//w.show();
w.isVisible() ? w.hide() : showWindow();
}
const showWindow = () => {
const position = getWindowPosition();
w.setPosition(position.x,position.y, false);
w.show();
}
const getWindowPosition = () => {
//console.log(process.platform);
//'aix'
//'darwin'
//'freebsd'
//'linux'
//'openbsd'
//'sunos'
//'win32'
const { screenWidth, screenHeight } = screen.getPrimaryDisplay().workAreaSize;
const windowBounds = w.getBounds();
const trayBounds = tray.getBounds();
// Center window horizontally below the tray icon
const x = Math.round(trayBounds.x + (trayBounds.width / 2) - (windowBounds.width / 2));
let y = undefined;
// Position window 4 pixels vertically below the tray icon
if(process.platform == 'win32')
y = Math.round(trayBounds.y - windowBounds.height);
else
y = Math.round(trayBounds.y + trayBounds.height + 4);
return {x,y}
}
//-----tray----- end
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.whenReady().then(() => {
//-----tray----- start
createTray()
createWindowTray()
//-----tray----- end
createWindow()
app.on('activate', function () {
// On macOS it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) createWindow()
})
})
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on('window-all-closed', function () {
if (process.platform !== 'darwin') app.quit()
})
// In this file you can include the rest of your app's specific main process
// code. You can also put them in separate files and require them here.