diff options
Diffstat (limited to 'src/plugins/searchReply/index.tsx')
-rw-r--r-- | src/plugins/searchReply/index.tsx | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/src/plugins/searchReply/index.tsx b/src/plugins/searchReply/index.tsx new file mode 100644 index 0000000..9e53436 --- /dev/null +++ b/src/plugins/searchReply/index.tsx @@ -0,0 +1,79 @@ +/* + * 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 <https://www.gnu.org/licenses/>. +*/ + +import { addContextMenuPatch, findGroupChildrenByChildId, NavContextMenuPatchCallback, removeContextMenuPatch } from "@api/ContextMenu"; +import { Devs } from "@utils/constants"; +import { LazyComponent } from "@utils/react"; +import definePlugin from "@utils/types"; +import { findByCode, findByCodeLazy } from "@webpack"; +import { ChannelStore, i18n, Menu, SelectedChannelStore } from "@webpack/common"; +import { Message } from "discord-types/general"; + +const ReplyIcon = LazyComponent(() => findByCode("M10 8.26667V4L3 11.4667L10 18.9333V14.56C15 14.56 18.5 16.2667 21 20C20 14.6667 17 9.33333 10 8.26667Z")); + +const replyFn = findByCodeLazy("showMentionToggle", "TEXTAREA_FOCUS", "shiftKey"); + +const messageContextMenuPatch: NavContextMenuPatchCallback = (children, { message }: { message: Message; }) => () => { + // make sure the message is in the selected channel + if (SelectedChannelStore.getChannelId() !== message.channel_id) return; + + const channel = ChannelStore.getChannel(message?.channel_id); + if (!channel) return; + + // dms and group chats + const dmGroup = findGroupChildrenByChildId("pin", children); + if (dmGroup && !dmGroup.some(child => child?.props?.id === "reply")) { + const pinIndex = dmGroup.findIndex(c => c?.props.id === "pin"); + return dmGroup.splice(pinIndex + 1, 0, ( + <Menu.MenuItem + id="reply" + label={i18n.Messages.MESSAGE_ACTION_REPLY} + icon={ReplyIcon} + action={(e: React.MouseEvent) => replyFn(channel, message, e)} + /> + )); + } + + // servers + const serverGroup = findGroupChildrenByChildId("mark-unread", children); + if (serverGroup && !serverGroup.some(child => child?.props?.id === "reply")) { + return serverGroup.unshift(( + <Menu.MenuItem + id="reply" + label={i18n.Messages.MESSAGE_ACTION_REPLY} + icon={ReplyIcon} + action={(e: React.MouseEvent) => replyFn(channel, message, e)} + /> + )); + } +}; + + +export default definePlugin({ + name: "SearchReply", + description: "Adds a reply button to search results", + authors: [Devs.Aria], + + start() { + addContextMenuPatch("message", messageContextMenuPatch); + }, + + stop() { + removeContextMenuPatch("message", messageContextMenuPatch); + } +}); |