aboutsummaryrefslogtreecommitdiff
path: root/src/plugins/pinDms/contextMenus.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/pinDms/contextMenus.tsx')
-rw-r--r--src/plugins/pinDms/contextMenus.tsx74
1 files changed, 74 insertions, 0 deletions
diff --git a/src/plugins/pinDms/contextMenus.tsx b/src/plugins/pinDms/contextMenus.tsx
new file mode 100644
index 0000000..b04ba8c
--- /dev/null
+++ b/src/plugins/pinDms/contextMenus.tsx
@@ -0,0 +1,74 @@
+/*
+ * 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 { Menu } from "@webpack/common";
+
+import { isPinned, movePin, snapshotArray, togglePin } from "./settings";
+
+function PinMenuItem(channelId: string) {
+ const pinned = isPinned(channelId);
+
+ return (
+ <>
+ <Menu.MenuItem
+ id="pin-dm"
+ label={pinned ? "Unpin DM" : "Pin DM"}
+ action={() => togglePin(channelId)}
+ />
+ {pinned && snapshotArray[0] !== channelId && (
+ <Menu.MenuItem
+ id="move-pin-up"
+ label="Move Pin Up"
+ action={() => movePin(channelId, -1)}
+ />
+ )}
+ {pinned && snapshotArray[snapshotArray.length - 1] !== channelId && (
+ <Menu.MenuItem
+ id="move-pin-down"
+ label="Move Pin Down"
+ action={() => movePin(channelId, +1)}
+ />
+ )}
+ </>
+ );
+}
+
+const GroupDMContext: NavContextMenuPatchCallback = (children, props) => {
+ const container = findGroupChildrenByChildId("leave-channel", children);
+ if (container)
+ container.unshift(PinMenuItem(props.channel.id));
+};
+
+const UserContext: NavContextMenuPatchCallback = (children, props) => {
+ const container = findGroupChildrenByChildId("close-dm", children);
+ if (container) {
+ const idx = container.findIndex(c => c?.props?.id === "close-dm");
+ container.splice(idx, 0, PinMenuItem(props.channel.id));
+ }
+};
+
+export function addContextMenus() {
+ addContextMenuPatch("gdm-context", GroupDMContext);
+ addContextMenuPatch("user-context", UserContext);
+}
+
+export function removeContextMenus() {
+ removeContextMenuPatch("gdm-context", GroupDMContext);
+ removeContextMenuPatch("user-context", UserContext);
+}