fix(handlers/messages): reaction remove event handler logic

This commit is contained in:
ITOH
2021-04-10 11:15:06 +02:00
parent 81c85eb337
commit eac62c6bb0
@@ -1,6 +1,5 @@
import { botId, eventHandlers } from "../../bot.ts"; import { eventHandlers } from "../../bot.ts";
import { cacheHandlers } from "../../cache.ts"; import { cacheHandlers } from "../../cache.ts";
import { structures } from "../../structures/mod.ts";
import { DiscordGatewayPayload } from "../../types/gateway/gateway_payload.ts"; import { DiscordGatewayPayload } from "../../types/gateway/gateway_payload.ts";
import { DiscordMessageReactionRemove } from "../../types/messages/message_reaction_remove.ts"; import { DiscordMessageReactionRemove } from "../../types/messages/message_reaction_remove.ts";
@@ -11,35 +10,14 @@ export async function handleMessageReactionRemove(
const message = await cacheHandlers.get("messages", payload.message_id); const message = await cacheHandlers.get("messages", payload.message_id);
if (message) { if (message) {
const reactionExisted = message.reactions?.find( const reaction = message.reactions?.find((reaction) =>
(reaction) => reaction.emoji.id === payload.emoji.id &&
reaction.emoji.id === payload.emoji.id && reaction.emoji.name === payload.emoji.name
reaction.emoji.name === payload.emoji.name,
); );
if (reactionExisted) reactionExisted.count--; if (reaction) {
else { reaction.count--;
const newReaction = { await cacheHandlers.set("messages", payload.message_id, message);
count: 1,
me: payload.user_id === botId,
emoji: { ...payload.emoji, id: payload.emoji.id || undefined },
};
message.reactions = message.reactions
? [...message.reactions, newReaction]
: [newReaction];
}
await cacheHandlers.set("messages", payload.message_id, message);
}
if (payload.member && payload.guild_id) {
const guild = await cacheHandlers.get("guilds", payload.guild_id);
if (guild) {
const discordenoMember = await structures.createDiscordenoMember(
payload.member,
guild.id,
);
await cacheHandlers.set("members", discordenoMember.id, discordenoMember);
} }
} }