mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-18 20:43:30 +01:00
refactor(MessageReaction): ReactionUserStore (#2078)
* refactor(MessageReactions): fetchUsers() is now users.fetch() made a lovely class for it and all happify linter stuff i know how to code i swear i lied * bdistin suggestions * space suggestions, rename store * fix count * documentation update
This commit is contained in:
@@ -29,6 +29,7 @@ module.exports = {
|
|||||||
GuildChannelStore: require('./stores/GuildChannelStore'),
|
GuildChannelStore: require('./stores/GuildChannelStore'),
|
||||||
GuildMemberStore: require('./stores/GuildMemberStore'),
|
GuildMemberStore: require('./stores/GuildMemberStore'),
|
||||||
GuildStore: require('./stores/GuildStore'),
|
GuildStore: require('./stores/GuildStore'),
|
||||||
|
ReactionUserStore: require('./stores/ReactionUserStore'),
|
||||||
MessageStore: require('./stores/MessageStore'),
|
MessageStore: require('./stores/MessageStore'),
|
||||||
PresenceStore: require('./stores/PresenceStore'),
|
PresenceStore: require('./stores/PresenceStore'),
|
||||||
RoleStore: require('./stores/RoleStore'),
|
RoleStore: require('./stores/RoleStore'),
|
||||||
|
|||||||
33
src/stores/ReactionUserStore.js
Normal file
33
src/stores/ReactionUserStore.js
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
const DataStore = require('./DataStore');
|
||||||
|
/**
|
||||||
|
* A data store to store User models who reacted to a MessageReaction.
|
||||||
|
* @extends {DataStore}
|
||||||
|
*/
|
||||||
|
class ReactionUserStore extends DataStore {
|
||||||
|
constructor(client, iterable, reaction) {
|
||||||
|
super(client, iterable, require('../structures/User'));
|
||||||
|
this.reaction = reaction;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetches all the users that gave this reaction. Resolves with a collection of users, mapped by their IDs.
|
||||||
|
* @param {Object} [options] Options for fetching the users
|
||||||
|
* @param {number} [options.limit=100] The maximum amount of users to fetch, defaults to 100
|
||||||
|
* @param {Snowflake} [options.before] Limit fetching users to those with an id lower than the supplied id
|
||||||
|
* @param {Snowflake} [options.after] Limit fetching users to those with an id greater than the supplied id
|
||||||
|
* @returns {Promise<ReactionUserStore<Snowflake, User>>}
|
||||||
|
*/
|
||||||
|
async fetch({ limit = 100, after, before } = {}) {
|
||||||
|
const message = this.reaction.message;
|
||||||
|
const users = await this.client.api.channels[message.channel.id].messages[message.id]
|
||||||
|
.reactions[this.reaction.emoji.identifier]
|
||||||
|
.get({ query: { limit, before, after } });
|
||||||
|
for (const rawUser of users) {
|
||||||
|
const user = this.client.users.create(rawUser);
|
||||||
|
this.set(user.id, user);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = ReactionUserStore;
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
const Collection = require('../util/Collection');
|
|
||||||
const Emoji = require('./Emoji');
|
const Emoji = require('./Emoji');
|
||||||
const ReactionEmoji = require('./ReactionEmoji');
|
const ReactionEmoji = require('./ReactionEmoji');
|
||||||
|
const ReactionUserStore = require('../stores/ReactionUserStore');
|
||||||
const { Error } = require('../errors');
|
const { Error } = require('../errors');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -28,9 +28,9 @@ class MessageReaction {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* The users that have given this reaction, mapped by their ID
|
* The users that have given this reaction, mapped by their ID
|
||||||
* @type {Collection<Snowflake, User>}
|
* @type {ReactionUserStore<Snowflake, User>}
|
||||||
*/
|
*/
|
||||||
this.users = new Collection();
|
this.users = new ReactionUserStore(client, undefined, this);
|
||||||
|
|
||||||
this._emoji = new ReactionEmoji(this, data.emoji.name, data.emoji.id);
|
this._emoji = new ReactionEmoji(this, data.emoji.name, data.emoji.id);
|
||||||
}
|
}
|
||||||
@@ -77,26 +77,6 @@ class MessageReaction {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Fetches all the users that gave this reaction. Resolves with a collection of users, mapped by their IDs.
|
|
||||||
* @param {Object} [options] Options for fetching the users
|
|
||||||
* @param {number} [options.limit=100] The maximum amount of users to fetch, defaults to 100
|
|
||||||
* @param {Snowflake} [options.after] Limit fetching users to those with an id greater than the supplied id
|
|
||||||
* @returns {Promise<Collection<Snowflake, User>>}
|
|
||||||
*/
|
|
||||||
async fetchUsers({ limit = 100, after } = {}) {
|
|
||||||
const message = this.message;
|
|
||||||
const users = await message.client.api.channels[message.channel.id].messages[message.id]
|
|
||||||
.reactions[this.emoji.identifier]
|
|
||||||
.get({ query: { limit, after } });
|
|
||||||
for (const rawUser of users) {
|
|
||||||
const user = message.client.users.create(rawUser);
|
|
||||||
this.users.set(user.id, user);
|
|
||||||
}
|
|
||||||
this.count = this.users.size;
|
|
||||||
return this.users;
|
|
||||||
}
|
|
||||||
|
|
||||||
_add(user) {
|
_add(user) {
|
||||||
if (!this.users.has(user.id)) {
|
if (!this.users.has(user.id)) {
|
||||||
this.users.set(user.id, user);
|
this.users.set(user.id, user);
|
||||||
|
|||||||
Reference in New Issue
Block a user