mirror of
https://github.com/Equicord/Equicord.git
synced 2025-06-08 14:13:01 -04:00
Delete Moyai plugin
This plugin is funny but ultimately useless and leads to a lot of confusion from users enabling it by mistake
This commit is contained in:
parent
d7e6fcd3ae
commit
600a95f751
1 changed files with 0 additions and 177 deletions
|
@ -1,177 +0,0 @@
|
||||||
/*
|
|
||||||
* Vencord, a modification for Discord's desktop app
|
|
||||||
* Copyright (c) 2022 Vendicated and contributors
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { definePluginSettings } from "@api/Settings";
|
|
||||||
import { makeRange } from "@components/PluginSettings/components/SettingSliderComponent";
|
|
||||||
import { Devs } from "@utils/constants";
|
|
||||||
import { sleep } from "@utils/misc";
|
|
||||||
import definePlugin, { OptionType } from "@utils/types";
|
|
||||||
import { RelationshipStore, SelectedChannelStore, UserStore } from "@webpack/common";
|
|
||||||
import { Message, ReactionEmoji } from "discord-types/general";
|
|
||||||
|
|
||||||
interface IMessageCreate {
|
|
||||||
type: "MESSAGE_CREATE";
|
|
||||||
optimistic: boolean;
|
|
||||||
isPushNotification: boolean;
|
|
||||||
channelId: string;
|
|
||||||
message: Message;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface IReactionAdd {
|
|
||||||
type: "MESSAGE_REACTION_ADD";
|
|
||||||
optimistic: boolean;
|
|
||||||
channelId: string;
|
|
||||||
messageId: string;
|
|
||||||
messageAuthorId: string;
|
|
||||||
userId: "195136840355807232";
|
|
||||||
emoji: ReactionEmoji;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface IVoiceChannelEffectSendEvent {
|
|
||||||
type: string;
|
|
||||||
emoji?: ReactionEmoji; // Just in case...
|
|
||||||
channelId: string;
|
|
||||||
userId: string;
|
|
||||||
animationType: number;
|
|
||||||
animationId: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
const MOYAI = "🗿";
|
|
||||||
const MOYAI_URL =
|
|
||||||
"https://raw.githubusercontent.com/MeguminSama/VencordPlugins/main/plugins/moyai/moyai.mp3";
|
|
||||||
const MOYAI_URL_HD =
|
|
||||||
"https://raw.githubusercontent.com/MeguminSama/VencordPlugins/main/plugins/moyai/moyai_hd.wav";
|
|
||||||
|
|
||||||
const settings = definePluginSettings({
|
|
||||||
volume: {
|
|
||||||
description: "Volume of the 🗿🗿🗿",
|
|
||||||
type: OptionType.SLIDER,
|
|
||||||
markers: makeRange(0, 1, 0.1),
|
|
||||||
default: 0.5,
|
|
||||||
stickToMarkers: false
|
|
||||||
},
|
|
||||||
quality: {
|
|
||||||
description: "Quality of the 🗿🗿🗿",
|
|
||||||
type: OptionType.SELECT,
|
|
||||||
options: [
|
|
||||||
{ label: "Normal", value: "Normal", default: true },
|
|
||||||
{ label: "HD", value: "HD" }
|
|
||||||
],
|
|
||||||
},
|
|
||||||
triggerWhenUnfocused: {
|
|
||||||
description: "Trigger the 🗿 even when the window is unfocused",
|
|
||||||
type: OptionType.BOOLEAN,
|
|
||||||
default: true
|
|
||||||
},
|
|
||||||
ignoreBots: {
|
|
||||||
description: "Ignore bots",
|
|
||||||
type: OptionType.BOOLEAN,
|
|
||||||
default: true
|
|
||||||
},
|
|
||||||
ignoreBlocked: {
|
|
||||||
description: "Ignore blocked users",
|
|
||||||
type: OptionType.BOOLEAN,
|
|
||||||
default: true
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export default definePlugin({
|
|
||||||
name: "Moyai",
|
|
||||||
authors: [Devs.Megu, Devs.Nuckyz],
|
|
||||||
description: "🗿🗿🗿🗿🗿🗿🗿🗿",
|
|
||||||
settings,
|
|
||||||
|
|
||||||
flux: {
|
|
||||||
async MESSAGE_CREATE({ optimistic, type, message, channelId }: IMessageCreate) {
|
|
||||||
if (optimistic || type !== "MESSAGE_CREATE") return;
|
|
||||||
if (message.state === "SENDING") return;
|
|
||||||
if (settings.store.ignoreBots && message.author?.bot) return;
|
|
||||||
if (settings.store.ignoreBlocked && RelationshipStore.isBlocked(message.author?.id)) return;
|
|
||||||
if (!message.content) return;
|
|
||||||
if (channelId !== SelectedChannelStore.getChannelId()) return;
|
|
||||||
|
|
||||||
const moyaiCount = getMoyaiCount(message.content);
|
|
||||||
|
|
||||||
for (let i = 0; i < moyaiCount; i++) {
|
|
||||||
boom();
|
|
||||||
await sleep(300);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
MESSAGE_REACTION_ADD({ optimistic, type, channelId, userId, messageAuthorId, emoji }: IReactionAdd) {
|
|
||||||
if (optimistic || type !== "MESSAGE_REACTION_ADD") return;
|
|
||||||
if (settings.store.ignoreBots && UserStore.getUser(userId)?.bot) return;
|
|
||||||
if (settings.store.ignoreBlocked && RelationshipStore.isBlocked(messageAuthorId)) return;
|
|
||||||
if (channelId !== SelectedChannelStore.getChannelId()) return;
|
|
||||||
|
|
||||||
const name = emoji.name.toLowerCase();
|
|
||||||
if (name !== MOYAI && !name.includes("moyai") && !name.includes("moai")) return;
|
|
||||||
|
|
||||||
boom();
|
|
||||||
},
|
|
||||||
|
|
||||||
VOICE_CHANNEL_EFFECT_SEND({ emoji }: IVoiceChannelEffectSendEvent) {
|
|
||||||
if (!emoji?.name) return;
|
|
||||||
const name = emoji.name.toLowerCase();
|
|
||||||
if (name !== MOYAI && !name.includes("moyai") && !name.includes("moai")) return;
|
|
||||||
|
|
||||||
boom();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
function countOccurrences(sourceString: string, subString: string) {
|
|
||||||
let i = 0;
|
|
||||||
let lastIdx = 0;
|
|
||||||
while ((lastIdx = sourceString.indexOf(subString, lastIdx) + 1) !== 0)
|
|
||||||
i++;
|
|
||||||
|
|
||||||
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 = /<a?:\w*moy?ai\w*:\d{17,20}>/gi;
|
|
||||||
|
|
||||||
function getMoyaiCount(message: string) {
|
|
||||||
const count = countOccurrences(message, MOYAI)
|
|
||||||
+ countMatches(message, customMoyaiRe);
|
|
||||||
|
|
||||||
return Math.min(count, 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
function boom() {
|
|
||||||
if (!settings.store.triggerWhenUnfocused && !document.hasFocus()) return;
|
|
||||||
const audioElement = document.createElement("audio");
|
|
||||||
|
|
||||||
audioElement.src = settings.store.quality === "HD"
|
|
||||||
? MOYAI_URL_HD
|
|
||||||
: MOYAI_URL;
|
|
||||||
|
|
||||||
audioElement.volume = settings.store.volume;
|
|
||||||
audioElement.play();
|
|
||||||
}
|
|
Loading…
Add table
Add a link
Reference in a new issue