From f252c514bc8a24cd6e6ad1525dc8de3d4aaad8bd Mon Sep 17 00:00:00 2001
From: thororen1234 <78185467+thororen1234@users.noreply.github.com>
Date: Thu, 20 Jun 2024 15:20:56 -0400
Subject: [PATCH] More Fixes
---
README.md | 2 +-
src/equicordplugins/keywordNotify/index.tsx | 6 ------
src/equicordplugins/purgeMessages/index.ts | 23 +++++++++++++--------
src/plugins/mutualGroupDMs/index.tsx | 18 ++++++++++++----
4 files changed, 29 insertions(+), 20 deletions(-)
diff --git a/README.md b/README.md
index 777c00aa..06c734f2 100644
--- a/README.md
+++ b/README.md
@@ -62,7 +62,7 @@ An enhanced version of [Vencord](https://github.com/Vendicated/Vencord) by [Vend
- NotifyUserChanges by D3SOX
- OnePingPerDM by ProffDea
- PlatformSpoofer by Drag
-- MessagePurge by bhop and nyx
+- PurgeMessages by bhop and nyx
- QuestionMarkReplacement (QuestionMarkReplace) by nyx
- Quoter by Samwich
- RepeatMessage by Tolgchu
diff --git a/src/equicordplugins/keywordNotify/index.tsx b/src/equicordplugins/keywordNotify/index.tsx
index 2f7a237c..e2bed51a 100644
--- a/src/equicordplugins/keywordNotify/index.tsx
+++ b/src/equicordplugins/keywordNotify/index.tsx
@@ -411,12 +411,6 @@ export default definePlugin({
return [msg];
};
- /* return (
- <>
-
hi uwu
- >
- );*/
-
return (
<>
{
+ let deleted = 0;
const userId = UserStore.getCurrentUser().id;
- const messages: Message[] = MessageStore.getMessages(channel.id)._array.filter((m: Message) => m.author.id === userId).reverse();
- const parsedMessages: Message[] = JSON.parse(JSON.stringify(messages));
- const uniqueMessages: Message[] = parsedMessages.filter(message => !loggedMessages.deletedMessages[channel.id].includes(message.id));
+ const messages: Message[] = JSON.parse(JSON.stringify(MessageStore.getMessages(channel.id)._array.filter((m: Message) => m.author.id === userId).reverse()));
+ const uniqueMessages: Message[] = !loggedMessages.deletedMessages[channel.id] ? messages : messages.filter(message => !loggedMessages.deletedMessages[channel.id].includes(message.id));
for (const message of uniqueMessages) {
MessageActions.deleteMessage(channel.id, message.id);
amount--;
+ deleted++;
if (amount === 0) break;
await new Promise(resolve => setTimeout(resolve, delay));
}
+
+ return deleted;
}
+migratePluginSettings("PurgeMessages", "MessagePurge");
export default definePlugin({
- name: "MessagePurge",
+ name: "PurgeMessages",
description: "Purges messages from a channel",
dependencies: ["CommandsAPI"],
- authors: [EquicordDevs.bhop, Devs.nyx],
+ authors: [EquicordDevs.bhop, EquicordDevs.nyx],
commands: [
{
name: "purge",
@@ -80,10 +85,10 @@ export default definePlugin({
content: `> deleting ${amount} messages.`
});
- DeleteMessages(amount, channel, delay).then(() => {
+ deleteMessages(amount, channel, delay).then((deleted: number) => {
sendBotMessage(ctx.channel.id,
{
- content: `> deleted ${amount} messages`
+ content: `> deleted ${deleted} messages`
}
);
});
diff --git a/src/plugins/mutualGroupDMs/index.tsx b/src/plugins/mutualGroupDMs/index.tsx
index 32e94fed..211910f0 100644
--- a/src/plugins/mutualGroupDMs/index.tsx
+++ b/src/plugins/mutualGroupDMs/index.tsx
@@ -19,9 +19,10 @@
import ErrorBoundary from "@components/ErrorBoundary";
import { Devs } from "@utils/constants";
import { isNonNullish } from "@utils/guards";
+import { pluralise } from "@utils/misc";
import definePlugin from "@utils/types";
import { findByPropsLazy } from "@webpack";
-import { Avatar, ChannelStore, Clickable, IconUtils, RelationshipStore, ScrollerThin, UserStore } from "@webpack/common";
+import { Avatar, ChannelStore, Clickable, IconUtils, RelationshipStore, ScrollerThin, UserStore, useStateFromStores } from "@webpack/common";
import { Channel, User } from "discord-types/general";
const SelectedChannelActionCreators = findByPropsLazy("selectPrivateChannel");
@@ -39,6 +40,10 @@ function getGroupDMName(channel: Channel) {
.join(", ");
}
+function useGroupDMs(userId: string) {
+ return useStateFromStores([ChannelStore], () => ChannelStore.getSortedPrivateChannels().filter(c => c.isGroupDM() && c.recipients.includes(userId)));
+}
+
export default definePlugin({
name: "MutualGroupDMs",
description: "Shows mutual group dms in profiles",
@@ -64,8 +69,8 @@ export default definePlugin({
group: true,
replacement: [
{
- match: /(?<=(\i\.push)\(\{section:\i\.UserProfileSections\.MUTUAL_GUILDS,text:.{0,250}\}\)\)\}\))/,
- replace: ',$1({section:"MUTUAL_GDMS",text:"Mutual Groups"})'
+ match: /(user:(\i),.+?=\i,)(.+?)(\i\.push)(.+?UserProfileSections\.MUTUAL_GUILDS,text:.{0,250}}\)\)}\))/,
+ replace: '$1vencordMutualGroupsTabLabel=$self.useGDMCount($2.id),$3$5,$4({section:"MUTUAL_GDMS",text:vencordMutualGroupsTabLabel})'
},
{
match: /(?<=(\i)===\i\.UserProfileSections\.MUTUAL_GUILDS?.{0,150}\}\):)/,
@@ -75,8 +80,13 @@ export default definePlugin({
},
],
+ useGDMCount(userId: string) {
+ const state = useGroupDMs(userId).length;
+ const label = "Mutual Group";
+ return state > 0 ? pluralise(state, label) : `No ${label}s`;
+ },
renderMutualGDMs: ErrorBoundary.wrap(({ user, onClose }: { user: User, onClose: () => void; }) => {
- const entries = ChannelStore.getSortedPrivateChannels().filter(c => c.isGroupDM() && c.recipients.includes(user.id)).map(c => (
+ const entries = useGroupDMs(user.id).map(c => (
{