forked from kevinsawicki/tray-example
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.js
124 lines (105 loc) · 3.08 KB
/
main.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
const {app, BrowserWindow, ipcMain, Tray} = require('electron')
const path = require('path')
const assetsDirectory = path.join(__dirname, 'assets')
let tray = undefined
let window = undefined
// Don't show the app in the doc
app.dock.hide()
app.on('ready', () => {
createTray()
createWindow()
})
// Quit the app when the window is closed
app.on('window-all-closed', () => {
app.quit()
})
const createTray = () => {
tray = new Tray(path.join(assetsDirectory, 'sunTemplate.png'))
tray.on('right-click', toggleWindow)
tray.on('double-click', toggleWindow)
tray.on('click', function (event) {
toggleWindow()
// Show devtools when command clicked
if (window.isVisible() && process.defaultApp && event.metaKey) {
window.openDevTools({mode: 'detach'})
}
})
}
const getWindowPosition = () => {
const windowBounds = window.getBounds()
const trayBounds = tray.getBounds()
// Center window horizontally below the tray icon
const x = Math.round(trayBounds.x + (trayBounds.width / 2) - (windowBounds.width / 2))
// Position window 4 pixels vertically below the tray icon
const y = Math.round(trayBounds.y + trayBounds.height + 4)
return {x: x, y: y}
}
const createWindow = () => {
window = new BrowserWindow({
width: 300,
height: 450,
show: false,
frame: false,
fullscreenable: false,
resizable: false,
transparent: true,
webPreferences: {
// Prevents renderer process code from not running when window is
// hidden
backgroundThrottling: false
}
})
window.loadURL(`file://${path.join(__dirname, 'index.html')}`)
// Hide the window when it loses focus
window.on('blur', () => {
if (!window.webContents.isDevToolsOpened()) {
window.hide()
}
})
}
const toggleWindow = () => {
if (window.isVisible()) {
window.hide()
} else {
showWindow()
}
}
const showWindow = () => {
const position = getWindowPosition()
window.setPosition(position.x, position.y, false)
window.show()
window.focus()
}
ipcMain.on('show-window', () => {
showWindow()
})
ipcMain.on('weather-updated', (event, weather) => {
// Show "feels like" temperature in tray
tray.setTitle(`${Math.round(weather.currently.apparentTemperature)}°`)
// Show summary and last refresh time as hover tooltip
const time = new Date(weather.currently.time).toLocaleTimeString()
tray.setToolTip(`${weather.currently.summary} at ${time}`)
// Update icon for different weather types
switch (weather.currently.icon) {
case 'cloudy':
case 'fog':
case 'partly-cloudy-day':
case 'partly-cloudy-night':
tray.setImage(path.join(assetsDirectory, 'cloudTemplate.png'))
break
case 'rain':
case 'sleet':
case 'snow':
tray.setImage(path.join(assetsDirectory, 'umbrellaTemplate.png'))
break
case 'clear-night':
tray.setImage(path.join(assetsDirectory, 'moonTemplate.png'))
break
case 'wind':
tray.setImage(path.join(assetsDirectory, 'flagTemplate.png'))
break
case 'clear-day':
default:
tray.setImage(path.join(assetsDirectory, 'sunTemplate.png'))
}
})