/* * Vencord, a modification for Discord's desktop app * Copyright (c) 2023 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 . */ import { ChatBarButton, ChatBarButtonFactory } from "@api/ChatButtons"; import { addMessagePreSendListener, MessageSendListener, removeMessagePreSendListener } from "@api/MessageEvents"; import { definePluginSettings } from "@api/Settings"; import { Devs, EquicordDevs } from "@utils/constants"; import definePlugin, { OptionType } from "@utils/types"; import { React, useEffect, useState } from "@webpack/common"; let lastState = false; export { lastState }; const settings = definePluginSettings({ persistState: { type: OptionType.SELECT, description: "How to persist the silent message toggle state", options: [ { label: "Don't persist (reset on channel change)", value: "none", default: true }, { label: "Persist between channels", value: "channels" }, { label: "Persist between channels and restarts", value: "restarts" } ], onChange(newValue: string) { lastState = newValue !== "none" && lastState; } }, autoDisable: { type: OptionType.BOOLEAN, description: "Automatically disable the silent message toggle again after sending one", default: true } }); const SilentMessageToggle: ChatBarButtonFactory = ({ isMainChat }) => { const [enabled, setEnabled] = useState(settings.store.persistState === "restarts" || lastState); function setEnabledValue(value: boolean) { if (settings.store.persistState !== "none") lastState = value; setEnabled(value); } useEffect(() => { const listener: MessageSendListener = (_, message) => { if (enabled) { if (settings.store.autoDisable) setEnabledValue(false); if (!message.content.startsWith("@silent ")) message.content = "@silent " + message.content; } }; addMessagePreSendListener(listener); return () => void removeMessagePreSendListener(listener); }, [enabled]); if (!isMainChat) return null; return ( setEnabledValue(!enabled)} > {!enabled && <> } ); }; export default definePlugin({ name: "SilentMessageToggle", authors: [Devs.Nuckyz, Devs.CatNoir, EquicordDevs.Z1xus], description: "Adds a button to the chat bar to toggle sending a silent message.", settings, renderChatBarButton: SilentMessageToggle, });