This repository has been archived by the owner on Dec 26, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
111 lines (103 loc) · 8.69 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
const { app, shell, nativeImage, Tray, net, Notification, Menu } = require('electron')
const { createCanvas } = require('canvas')
let tray = null
// const iconImage = './icon.png'
const iconImage = nativeImage.createFromPath('./icon.png')
const base64ImageStr = ''
const icon = nativeImage.createFromDataURL(base64ImageStr)
app.on('ready', () => {
if (process.platform === 'darwin') {
app.dock.setIcon(iconImage);
}
tray = new Tray(icon)
const handleClick = (menuItem) => {
// console.log(menuItem)
url = 'https://chart.tubiaojia.com/tubiaojia.html?symbol=' + menuItem.label
shell.openExternal(url)
}
contextMenu = Menu.buildFromTemplate([
{ label: 'XAUUSD', click: handleClick }, // https://chart.tubiaojia.com/tubiaojia.html?symbol=XAUUSD
{ label: 'Au(T+D)', click: handleClick }, // https://chart.tubiaojia.com/tubiaojia.html?symbol=Au(T+D)
{ label: 'XAGUSD', click: handleClick }, // https://chart.tubiaojia.com/tubiaojia.html?symbol=XAGUSD
{ label: 'Ag(T+D)', click: handleClick }, // https://chart.tubiaojia.com/tubiaojia.html?symbol=Ag(T+D)
{ label: 'USDIDX', click: handleClick }, // https://chart.tubiaojia.com/tubiaojia.html?symbol=USDIDX
{ type:'separator' },
{ label: 'Exit', role: 'quit' }
])
tray.setContextMenu(contextMenu)
tray.setToolTip('Gold Price Listener')
tray.on('click', () => {
tray.popUpContextMenu(contextMenu)
})
var count = 0
setInterval(() => {
if (count++ % 2 == 0) {
handleRequest('xau')
} else {
handleRequest('autd')
}
}, 1000*10)
})
function getBase64ImageDataUrl(price) {
const canvas = createCanvas(96, 48)
// Copy the image contents to the canvas
const ctx = canvas.getContext('2d')
ctx.font = 'BOLD 32px LcdD'
// ctx.textAlign = 'left'
ctx.textBaseline = 'middle'
if (process.platform === 'darwin') {
ctx.fillStyle = 'black'
} else {
ctx.fillStyle = 'yellow'
}
ctx.fillText(price, 0, 20)
// Get the data-URL formatted image
// Firefox supports PNG and JPEG. You could check img.src to
// guess the original format, but be aware the using "image/jpg"
// will re-encode the image.
const dataURL = canvas.toDataURL('image/png')
return dataURL
}
function handleRequest(symbol) {
var url = tip = null;
if (symbol === 'xau') {
url = "https://hq.sinajs.cn/?_=" + Date.now() + "/&list=gds_AUTD"
tip = ' usd/oz'
} else {
url = "https://hq.sinajs.cn/?_=" + Date.now() + "/&list=hf_XAU"
tip = ' cny/g'
}
const request = net.request(url)
request.on('response', (response) => {
// console.log(`HEADERS: ${JSON.stringify(response.headers)}`)
response.on('data', (chunk) => {
var respStr = chunk.toString().replace('var hq_str_gds_AUTD="', '')
respStr = respStr.replace('var hq_str_hf_XAU="', '')
respStr = respStr.replace('"', '')
var prices = respStr.split(',')
var goldPrice = prices[0]
var imageDataURL = getBase64ImageDataUrl(goldPrice)
var dataURLImage = nativeImage.createFromDataURL(imageDataURL)
tray.setImage(dataURLImage)
tray.setToolTip(symbol + ': ' + goldPrice + tip)
// showMsg('金价提醒', symbol + ': ' + goldPrice + tip)
})
response.on('end', () => {
// console.log('No more data in response.')
})
})
request.end()
}
function showMsg(title, body) {
if (title || body) {
msg = new Notification({
title: title,
body: body + '\n' + new Date().toLocaleString(),
icon: iconImage,
})
}
if (msg != null) {
console.info("Message: " + msg.body)
msg.show()
}
}