/
minidashboard.js
30 lines (29 loc) · 1.01 KB
/
minidashboard.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
async function dashboard(apiClient, db) {
const results = [];
const { rows } = await db.query('SELECT channel FROM mini_vanilla');
for (row of rows) {
const channel = row.channel;
const { rows: rs } = await db.query('select done, count(1) from minirequests where channel = $1 group by done', [channel]);
let result = { channel, queue: 0, complete: 0, live: '' };
for (r of rs) {
if (r.done) {
result.complete = r.count;
} else {
result.queue = r.count;
}
}
const stream = await apiClient.streams.getStreamByUserName(channel);
if (stream) {
if (stream.gameName == 'Spin Rhythm XD') {
result.live = `🟢 (${stream.viewers})`;
} else {
result.live = `🟡 (${stream.viewers})`;
}
} else {
result.live = '🔴';
}
results.push(result);
}
return results;
}
module.exports = { dashboard };