aboutsummaryrefslogtreecommitdiff
path: root/src/plugins/onePingPerDM/index.ts
diff options
context:
space:
mode:
authorDea <dea-banana@riseup.net>2023-10-02 23:53:14 +0000
committerGitHub <noreply@github.com>2023-10-03 01:53:14 +0200
commit9891791fa76d25db5f312622b1a7d34a6c2734b8 (patch)
treecd0856042cb345f0f424a3677c8c7685ca42d4e0 /src/plugins/onePingPerDM/index.ts
parent8dd5eeead2f4f48ec7dfa3dd812475e97b322146 (diff)
downloadVencord-9891791fa76d25db5f312622b1a7d34a6c2734b8.tar.gz
Vencord-9891791fa76d25db5f312622b1a7d34a6c2734b8.tar.bz2
Vencord-9891791fa76d25db5f312622b1a7d34a6c2734b8.zip
feat(plugin): onePingPerDM (#1757)
Co-authored-by: V <vendicated@riseup.net>
Diffstat (limited to 'src/plugins/onePingPerDM/index.ts')
-rw-r--r--src/plugins/onePingPerDM/index.ts39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/plugins/onePingPerDM/index.ts b/src/plugins/onePingPerDM/index.ts
new file mode 100644
index 0000000..47502eb
--- /dev/null
+++ b/src/plugins/onePingPerDM/index.ts
@@ -0,0 +1,39 @@
+/*
+ * Vencord, a Discord client mod
+ * Copyright (c) 2023 Vendicated and contributors
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+import { Devs } from "@utils/constants";
+import definePlugin from "@utils/types";
+import { ChannelStore, ReadStateStore } from "@webpack/common";
+import { Message } from "discord-types/general";
+
+const enum ChannelType {
+ DM = 1,
+ GROUP_DM = 3
+}
+
+export default definePlugin({
+ name: "OnePingPerDM",
+ description: "If unread messages are sent by a user in DMs multiple times, you'll only receive one audio ping. Read the messages to reset the limit",
+ authors: [Devs.ProffDea],
+ patches: [{
+ find: ".getDesktopType()===",
+ replacement: [{
+ match: /if\((\i\.\i\.getDesktopType\(\)===\i\.\i\.NEVER)\){/,
+ replace: "if($1){if(!$self.isPrivateChannelRead(arguments[0]?.message))return;"
+ },
+ {
+ match: /sound:(\i\?\i:void 0,volume:\i,onClick:)/,
+ replace: "sound:!$self.isPrivateChannelRead(arguments[0]?.message)?undefined:$1"
+ }]
+ }],
+ isPrivateChannelRead(message: Message) {
+ const channelType = ChannelStore.getChannel(message.channel_id)?.type;
+ if (channelType !== ChannelType.DM && channelType !== ChannelType.GROUP_DM) {
+ return false;
+ }
+ return ReadStateStore.getOldestUnreadMessageId(message.channel_id) === message.id;
+ },
+});