2019-09-13 20:02:41 +00:00
|
|
|
// eris doesn't come with an awaitReactions method by default, so we make our own
|
|
|
|
const EventEmitter = require("events").EventEmitter;
|
2020-09-01 22:10:19 +00:00
|
|
|
|
2019-09-13 20:02:41 +00:00
|
|
|
class ReactionCollector extends EventEmitter {
|
Class commands, improved sharding, and many other changes (#88)
* 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
2021-04-12 16:16:12 +00:00
|
|
|
constructor(client, message, filter, options = {}) {
|
2019-09-13 20:02:41 +00:00
|
|
|
super();
|
|
|
|
this.filter = filter;
|
|
|
|
this.message = message;
|
|
|
|
this.options = options;
|
|
|
|
this.ended = false;
|
|
|
|
this.collected = [];
|
2020-09-01 22:10:19 +00:00
|
|
|
this.bot = client;
|
2021-02-07 17:08:55 +00:00
|
|
|
this.listener = async (message, emoji, member) => await this.verify(message, emoji, member);
|
2019-09-13 20:02:41 +00:00
|
|
|
this.bot.on("messageReactionAdd", this.listener);
|
|
|
|
if (options.time) setTimeout(() => this.stop("time"), options.time);
|
|
|
|
}
|
|
|
|
|
2021-02-07 17:08:55 +00:00
|
|
|
async verify(message, emoji, member) {
|
2019-09-13 20:02:41 +00:00
|
|
|
if (this.message.id !== message.id) return false;
|
2021-02-07 17:08:55 +00:00
|
|
|
if (this.filter(message, emoji, member)) {
|
|
|
|
this.collected.push({ message: message, emoji: emoji, member: member });
|
2021-07-14 22:23:50 +00:00
|
|
|
const msg = await this.bot.getMessage(message.channel.id, message.id);
|
|
|
|
this.emit("reaction", msg, emoji, member);
|
2019-09-13 20:02:41 +00:00
|
|
|
if (this.collected.length >= this.options.maxMatches) this.stop("maxMatches");
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
stop(reason) {
|
|
|
|
if (this.ended) return;
|
|
|
|
this.ended = true;
|
|
|
|
this.bot.removeListener("messageReactionAdd", this.listener);
|
|
|
|
this.emit("end", this.collected, reason);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = ReactionCollector;
|