From bb7332cefdf3c021635291c39f3068b4deaf7a4b Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sun, 9 Oct 2022 19:48:22 +0200 Subject: [PATCH] Moyai: Support Reactions, ignore bots --- src/plugins/moyai.ts | 124 +++++++++++++++++++++++++++---------------- 1 file changed, 77 insertions(+), 47 deletions(-) diff --git a/src/plugins/moyai.ts b/src/plugins/moyai.ts index 938864c14..6b77a4e13 100644 --- a/src/plugins/moyai.ts +++ b/src/plugins/moyai.ts @@ -1,75 +1,105 @@ import definePlugin from "../utils/types"; import { Devs } from "../utils/constants"; -import { Message } from "discord-types/general"; -import { FluxDispatcher } from "../webpack/common"; +import { Message, ReactionEmoji } from "discord-types/general"; +import { FluxDispatcher, SelectedChannelStore } from "../webpack/common"; +import { sleep } from "../utils/misc"; interface IMessageCreate { type: "MESSAGE_CREATE"; - channelId: string; - isPushNotification: boolean; optimistic: boolean; + isPushNotification: boolean; + channelId: string; message: Message; } +interface IReactionAdd { + type: "MESSAGE_REACTION_ADD"; + optimistic: boolean; + channelId: string; + messageId: string; + userId: "195136840355807232"; + emoji: ReactionEmoji; +} + +const MOYAI = "🗿"; const MOYAI_URL = "https://github.com/MeguminSama/VencordPlugins/raw/main/plugins/moyai/moyai.mp3"; +// Implement once Settings are a thing +const ignoreBots = true; + export default definePlugin({ name: "Moyai", authors: [Devs.Megu], description: "🗿🗿🗿🗿🗿🗿🗿🗿", - execute: async (event: IMessageCreate) => { - if (event?.type !== "MESSAGE_CREATE") return; - if (!event.message?.content) return; - if (event.message.state === "SENDING") return; - if (event.optimistic) return; - const isInChannel = - window.location.pathname.startsWith("/channels/"); - if (!isInChannel) return; + async onMessage(e: IMessageCreate) { + if (e.optimistic || e.type !== "MESSAGE_CREATE") return; + if (e.message.state === "SENDING") return; + if (ignoreBots && e.message.author?.bot) return; + if (!e.message.content) return; + if (e.channelId !== SelectedChannelStore.getChannelId()) return; - const channelId = window.location.pathname.split("/")[3]; - if (!channelId || channelId !== event.channelId) return; - - const moyaiCount = messageContainsMoyai(event.message.content); - if (!moyaiCount) return; + const moyaiCount = getMoyaiCount(e.message.content); for (let i = 0; i < moyaiCount; i++) { - const audioElement = document.createElement("audio"); - audioElement.src = MOYAI_URL; - audioElement.play(); - await new Promise(resolve => setTimeout(resolve, 300)); + boom(); + await sleep(300); } }, - start() { - FluxDispatcher.subscribe("MESSAGE_CREATE", this.execute); + + onReaction(e: IReactionAdd) { + if (e.optimistic || e.type !== "MESSAGE_REACTION_ADD") return; + if (e.channelId !== SelectedChannelStore.getChannelId()) return; + + const name = e.emoji.name.toLowerCase(); + if (name !== MOYAI && !name.includes("moyai") && !name.includes("moai")) return; + + boom(); }, + + start() { + FluxDispatcher.subscribe("MESSAGE_CREATE", this.onMessage); + FluxDispatcher.subscribe("MESSAGE_REACTION_ADD", this.onReaction); + }, + stop() { - FluxDispatcher.unsubscribe("MESSAGE_CREATE", this.execute); - } + FluxDispatcher.unsubscribe("MESSAGE_CREATE", this.onMessage); + FluxDispatcher.unsubscribe("MESSAGE_REACTION_ADD", this.onReaction); + }, }); -const EMOJI_NAME_REGEX = //g; +function countOccurrences(sourceString: string, subString: string) { + let i = 0; + let lastIdx = 0; + while ((lastIdx = sourceString.indexOf(subString, lastIdx) + 1) !== 0) + i++; -function messageContainsMoyai(message: string): number { - // get number of 🗿 in a string - let moyaiCount = (message.match(/🗿/g) || []).length; - - // get number of emojis in message that are called "moyai" or "moai" - const emojiNames = message.matchAll(EMOJI_NAME_REGEX); - - if (emojiNames) { - for (const emojiName of emojiNames) { - if (!emojiName[1]) continue; - let name = emojiName[1]; - - // If emoji starts or ends with (moyai|moai) - if (/^(moyai|moai)/i.test(name) || /(moyai|moai)$/i.test(name)) { - moyaiCount++; - } - } - } - - // Maximum moyai... - return Math.min(moyaiCount, 10); + return i; +} + +function countMatches(sourceString: string, pattern: RegExp) { + if (!pattern.global) + throw new Error("pattern must be global"); + + let i = 0; + while (pattern.test(sourceString)) + i++; + + return i; +} + +const customMoyaiRe = //gi; + +function getMoyaiCount(message: string) { + let count = countOccurrences(message, MOYAI) + + countMatches(message, customMoyaiRe); + + return Math.min(count, 10); +} + +function boom() { + const audioElement = document.createElement("audio"); + audioElement.src = MOYAI_URL; + audioElement.play(); }