From 618af90442b3fa58d7feda3fc4ef923836d87159 Mon Sep 17 00:00:00 2001 From: WubzyGD Date: Thu, 29 Apr 2021 18:29:10 -0600 Subject: [PATCH] add voice to monit --- commands/utility/monitor.js | 58 ++++++++++++++++++++++++++----------- 1 file changed, 41 insertions(+), 17 deletions(-) diff --git a/commands/utility/monitor.js b/commands/utility/monitor.js index 3ce1c33..7ae15ff 100644 --- a/commands/utility/monitor.js +++ b/commands/utility/monitor.js @@ -24,26 +24,50 @@ module.exports = { if (!args.length || (args.length && ['v', 'view', 'stats'].includes(args[0].toLowerCase()))) { if (!tm) {return message.channel.send("Your server doesn't have monitoring enabled. If it's something you actually think you'll use, feel free to run `setup` on this command to enable it!");} + + if (!Object.keys(tm.messages.members).length && !Object.keys(tm.voice.members).length) {return message.channel.send("Your server doesn't have any monitoring data available yet. Send some messages or hop in a VC, wait a few minutes, and try again.");} + + let ch; let chs; let u; let us; + let vch; let vchs; let vu; let vus; + let thm = false; let tv = false; - let ch = Object.keys(tm.messages.channels).sort((a, b) => {return tm.messages.channels[a] - tm.messages.channels[b];}).reverse().slice(0, Object.keys(tm.messages.channels).length >= 5 ? 5 : Object.keys(tm.messages.channels).length); - let chs = ``; - let i; for (i=0; i -> **${tm.messages.channels[ch[i]]} Messages**\n`;} + if (Object.keys(tm.messages.members).length) { + thm = true; + ch = Object.keys(tm.messages.channels).sort((a, b) => {return tm.messages.channels[a] - tm.messages.channels[b];}).reverse().slice(0, Object.keys(tm.messages.channels).length >= 5 ? 5 : Object.keys(tm.messages.channels).length); + chs = ``; + let i; for (i=0; i -> **${tm.messages.channels[ch[i]]} Messages**\n`;} - let u = Object.keys(tm.messages.members).sort((a, b) => {return tm.messages.members[a] - tm.messages.members[b];}).reverse().slice(0, Object.keys(tm.messages.members).length >= 5 ? 5 : Object.keys(tm.messages.members).length); - let us = ``; - let i2; for (i2=0; i2 -> **${tm.messages.members[u[i2]]} Messages**\n`;} + u = Object.keys(tm.messages.members).sort((a, b) => {return tm.messages.members[a] - tm.messages.members[b];}).reverse().slice(0, Object.keys(tm.messages.members).length >= 5 ? 5 : Object.keys(tm.messages.members).length); + us = ``; + let i2; for (i2=0; i2 -> **${tm.messages.members[u[i2]]} Messages**\n`;} + } - return message.channel.send(new Discord.MessageEmbed() - .setTitle(`Activity stats for ${message.guild.name}`) - .setThumbnail(message.guild.iconURL({size: 1024})) - .setDescription("*These statistics have an accuracy of about 10 minutes.*") - .addField("Top Channels", chs) - .addField("Top Members", us) - .addField("Total Messages in Server", tm.messages.total) - .setColor('c375f0') - .setFooter("Natsuki", client.user.avatarURL()) - .setTimestamp() - ); + if (Object.keys(tm.voice.members).length) { + tv = true; + vch = Object.keys(tm.voice.channels).sort((a, b) => {return tm.voice.channels[a] - tm.voice.channels[b];}).reverse().slice(0, Object.keys(tm.voice.channels).length >= 5 ? 5 : Object.keys(tm.voice.channels).length); + vchs = ``; + let i; for (i=0; i **${(tm.voice.channels[vch[i]] / 60).toFixed(1)} Hours**\n`;} + + vu = Object.keys(tm.voice.members).sort((a, b) => {return tm.voice.members[a] - tm.voice.members[b];}).reverse().slice(0, Object.keys(tm.voice.members).length >= 5 ? 5 : Object.keys(tm.voice.members).length); + vus = ``; + let i2; for (i2=0; i2 -> **${(tm.voice.members[vu[i2]] / 60).toFixed(1)} Hours**\n`;} + } + + let emb = new Discord.MessageEmbed() + .setTitle(`Activity stats for ${message.guild.name}`) + .setThumbnail(message.guild.iconURL({size: 1024})) + .setDescription("*These statistics have an accuracy of about 10 minutes.*") + .setColor('c375f0') + .setFooter("Natsuki", client.user.avatarURL()) + .setTimestamp(); + + if (thm) {emb.addField("Top Channels", chs).addField("Top Members", us);} + if (tv) {emb.addField("Top Voice Channels", vchs).addField("Top VC Members", vus);} + + if (thm) {emb.addField("Total Messages", tm.messages.total, true);} + if (tv) {emb.addField("Total Voice Hours", (tm.voice.total / 60).toFixed(1), true);} + + return message.channel.send(emb); } if (['s', 'setup', 'config', 'configure', 'enable', 'e'].includes(args[0].toLowerCase())) {