Essem
40223ec8b5
* Load commands recursively * Sort commands * Missed a couple of spots * missed even more spots apparently * Ported commands in "fun" category to new class-based format, added babel eslint plugin * Ported general commands, removed old/unneeded stuff, replaced moment with day, many more fixes I lost track of * Missed a spot * Removed unnecessary abort-controller package, add deprecation warning for mongo database * Added imagereload, clarified premature end message * Fixed docker-compose path issue, added total bot uptime to stats, more fixes for various parts * Converted image commands into classes, fixed reload, ignore another WS event, cleaned up command handler and image runner * Converted music/soundboard commands to class format * Cleanup unnecessary logs * awful tag command class port * I literally somehow just learned that you can leave out the constructor in classes * Pass client directly to commands/events, cleaned up command handler * Migrated bot to eris-sharder, fixed some error handling stuff * Remove unused modules * Fixed type returning * Switched back to Eris stable * Some fixes and cleanup * might wanna correct this * Implement image command ratelimiting * Added Bot token prefix, added imagestats, added running endpoint to API
63 lines
2.7 KiB
JavaScript
63 lines
2.7 KiB
JavaScript
const ReactionCollector = require("./awaitreactions.js");
|
|
const MessageCollector = require("./awaitmessages.js");
|
|
|
|
module.exports = async (client, message, pages, timeout = 120000) => {
|
|
const manageMessages = message.channel.guild && message.channel.permissionsOf(client.user.id).has("manageMessages") ? true : false;
|
|
let page = 0;
|
|
let currentPage = await message.channel.createMessage(pages[page]);
|
|
const emojiList = ["◀", "🔢", "▶", "🗑"];
|
|
for (const emoji of emojiList) {
|
|
await currentPage.addReaction(emoji);
|
|
}
|
|
const reactionCollector = new ReactionCollector(client, currentPage, (message, reaction, member) => emojiList.includes(reaction.name) && !member.bot, { time: timeout });
|
|
reactionCollector.on("reaction", async (msg, reaction, member) => {
|
|
if (member === message.author.id) {
|
|
switch (reaction.name) {
|
|
case "◀":
|
|
page = page > 0 ? --page : pages.length - 1;
|
|
currentPage = await currentPage.edit(pages[page]);
|
|
if (manageMessages) msg.removeReaction("◀", member);
|
|
break;
|
|
case "🔢":
|
|
message.channel.createMessage(`${message.author.mention}, what page do you want to jump to?`).then(askMessage => {
|
|
const messageCollector = new MessageCollector(client, askMessage.channel, (response) => response.author.id === message.author.id && !isNaN(response.content) && Number(response.content) <= pages.length && Number(response.content) > 0, {
|
|
time: timeout,
|
|
maxMatches: 1
|
|
});
|
|
return messageCollector.on("message", async (response) => {
|
|
if (askMessage.channel.messages.get(askMessage.id)) askMessage.delete();
|
|
if (manageMessages) await response.delete();
|
|
page = Number(response.content) - 1;
|
|
currentPage = await currentPage.edit(pages[page]);
|
|
if (manageMessages) msg.removeReaction("🔢", member);
|
|
});
|
|
}).catch(error => {
|
|
throw error;
|
|
});
|
|
break;
|
|
case "▶":
|
|
page = page + 1 < pages.length ? ++page : 0;
|
|
currentPage = await currentPage.edit(pages[page]);
|
|
if (manageMessages) msg.removeReaction("▶", member);
|
|
break;
|
|
case "🗑":
|
|
reactionCollector.emit("end");
|
|
if (currentPage.channel.messages.get(currentPage.id)) await currentPage.delete();
|
|
return;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
});
|
|
reactionCollector.once("end", async () => {
|
|
try {
|
|
await currentPage.channel.getMessage(currentPage.id);
|
|
if (manageMessages) {
|
|
await currentPage.removeReactions();
|
|
}
|
|
} catch {
|
|
return;
|
|
}
|
|
});
|
|
return currentPage;
|
|
};
|