mirror of
https://github.com/discordeno/discordeno.git
synced 2026-06-16 11:28:15 +00:00
fix(handlers/messages): reaction remove event handler logic
This commit is contained in:
@@ -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,36 +10,15 @@ 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 = {
|
|
||||||
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);
|
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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const uncachedOptions = {
|
const uncachedOptions = {
|
||||||
|
|||||||
Reference in New Issue
Block a user