Files
xiao/commands/util-public/command-leaderboard.js
T
2024-07-02 01:16:09 -04:00

69 lines
1.8 KiB
JavaScript

const Command = require('../../framework/Command');
const { stripIndents } = require('common-tags');
const { formatNumber } = require('../../util/Util');
module.exports = class CommandLeaderboardCommand extends Command {
constructor(client) {
super(client, {
name: 'command-leaderboard',
aliases: ['cmd-lb', 'cmd-leaderboard', 'command-lb'],
group: 'util-public',
description: 'Responds with the bot\'s most used commands.',
guarded: true,
args: [
{
key: 'page',
type: 'integer',
default: 1,
min: 1
}
]
});
}
run(msg, { page }) {
const commands = this.filterCommands(
this.client.registry.commands,
this.client.isOwner(msg.author),
msg.channel.nsfw
);
const totalPages = Math.ceil(commands.size / 10);
if (page > totalPages) return msg.say(`Page ${page} does not exist (yet).`);
return msg.say(stripIndents`
__**Command Usage Leaderboard (Page ${page}/${totalPages}):**__
${this.makeLeaderboard(commands, page).join('\n')}
_Total Uses: ${formatNumber(this.client.registry.totalUses)}_
`);
}
makeLeaderboard(commands, page) {
let i = 0;
let previousPts = null;
let positionsMoved = 1;
return commands
.sort((a, b) => b.uses - a.uses)
.map(command => {
if (previousPts === command.uses) {
positionsMoved++;
} else {
i += positionsMoved;
positionsMoved = 1;
}
previousPts = command.uses;
return `**${i}.** ${command.name} (${formatNumber(command.uses)} Use${command.uses === 1 ? '' : 's'})`;
})
.slice((page - 1) * 10, page * 10);
}
filterCommands(commands, owner, nsfw) {
return commands.filter(command => {
if (command.uses === undefined || command.unknown) return false;
if (command.hidden) return false;
if (command.ownerOnly) return false;
if (!owner && command.nsfw && !nsfw) return false;
return true;
});
}
};