mirror of
https://github.com/Equicord/Equicord.git
synced 2025-06-08 14:13:01 -04:00
More Fixes
This commit is contained in:
parent
cd96099b3d
commit
f252c514bc
4 changed files with 29 additions and 20 deletions
|
@ -62,7 +62,7 @@ An enhanced version of [Vencord](https://github.com/Vendicated/Vencord) by [Vend
|
||||||
- NotifyUserChanges by D3SOX
|
- NotifyUserChanges by D3SOX
|
||||||
- OnePingPerDM by ProffDea
|
- OnePingPerDM by ProffDea
|
||||||
- PlatformSpoofer by Drag
|
- PlatformSpoofer by Drag
|
||||||
- MessagePurge by bhop and nyx
|
- PurgeMessages by bhop and nyx
|
||||||
- QuestionMarkReplacement (QuestionMarkReplace) by nyx
|
- QuestionMarkReplacement (QuestionMarkReplace) by nyx
|
||||||
- Quoter by Samwich
|
- Quoter by Samwich
|
||||||
- RepeatMessage by Tolgchu
|
- RepeatMessage by Tolgchu
|
||||||
|
|
|
@ -411,12 +411,6 @@ export default definePlugin({
|
||||||
return [msg];
|
return [msg];
|
||||||
};
|
};
|
||||||
|
|
||||||
/* return (
|
|
||||||
<>
|
|
||||||
<p>hi uwu</p>
|
|
||||||
</>
|
|
||||||
);*/
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Popout
|
<Popout
|
||||||
|
|
|
@ -17,7 +17,8 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { ApplicationCommandInputType, ApplicationCommandOptionType, findOption, sendBotMessage } from "@api/Commands";
|
import { ApplicationCommandInputType, ApplicationCommandOptionType, findOption, sendBotMessage } from "@api/Commands";
|
||||||
import { Devs, EquicordDevs } from "@utils/constants";
|
import { migratePluginSettings } from "@api/Settings";
|
||||||
|
import { EquicordDevs } from "@utils/constants";
|
||||||
import definePlugin from "@utils/types";
|
import definePlugin from "@utils/types";
|
||||||
import { findByPropsLazy } from "@webpack";
|
import { findByPropsLazy } from "@webpack";
|
||||||
import { MessageStore, UserStore } from "@webpack/common";
|
import { MessageStore, UserStore } from "@webpack/common";
|
||||||
|
@ -27,25 +28,29 @@ import { loggedMessages } from "../messageLoggerEnhanced/LoggedMessageManager";
|
||||||
|
|
||||||
const MessageActions = findByPropsLazy("deleteMessage", "startEditMessage");
|
const MessageActions = findByPropsLazy("deleteMessage", "startEditMessage");
|
||||||
|
|
||||||
async function DeleteMessages(amount: number, channel: Channel, delay: number = 1500) {
|
async function deleteMessages(amount: number, channel: Channel, delay: number = 1500): Promise<number> {
|
||||||
|
let deleted = 0;
|
||||||
const userId = UserStore.getCurrentUser().id;
|
const userId = UserStore.getCurrentUser().id;
|
||||||
const messages: Message[] = MessageStore.getMessages(channel.id)._array.filter((m: Message) => m.author.id === userId).reverse();
|
const messages: Message[] = JSON.parse(JSON.stringify(MessageStore.getMessages(channel.id)._array.filter((m: Message) => m.author.id === userId).reverse()));
|
||||||
const parsedMessages: Message[] = JSON.parse(JSON.stringify(messages));
|
const uniqueMessages: Message[] = !loggedMessages.deletedMessages[channel.id] ? messages : messages.filter(message => !loggedMessages.deletedMessages[channel.id].includes(message.id));
|
||||||
const uniqueMessages: Message[] = parsedMessages.filter(message => !loggedMessages.deletedMessages[channel.id].includes(message.id));
|
|
||||||
|
|
||||||
for (const message of uniqueMessages) {
|
for (const message of uniqueMessages) {
|
||||||
MessageActions.deleteMessage(channel.id, message.id);
|
MessageActions.deleteMessage(channel.id, message.id);
|
||||||
amount--;
|
amount--;
|
||||||
|
deleted++;
|
||||||
if (amount === 0) break;
|
if (amount === 0) break;
|
||||||
await new Promise(resolve => setTimeout(resolve, delay));
|
await new Promise(resolve => setTimeout(resolve, delay));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return deleted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
migratePluginSettings("PurgeMessages", "MessagePurge");
|
||||||
export default definePlugin({
|
export default definePlugin({
|
||||||
name: "MessagePurge",
|
name: "PurgeMessages",
|
||||||
description: "Purges messages from a channel",
|
description: "Purges messages from a channel",
|
||||||
dependencies: ["CommandsAPI"],
|
dependencies: ["CommandsAPI"],
|
||||||
authors: [EquicordDevs.bhop, Devs.nyx],
|
authors: [EquicordDevs.bhop, EquicordDevs.nyx],
|
||||||
commands: [
|
commands: [
|
||||||
{
|
{
|
||||||
name: "purge",
|
name: "purge",
|
||||||
|
@ -80,10 +85,10 @@ export default definePlugin({
|
||||||
content: `> deleting ${amount} messages.`
|
content: `> deleting ${amount} messages.`
|
||||||
});
|
});
|
||||||
|
|
||||||
DeleteMessages(amount, channel, delay).then(() => {
|
deleteMessages(amount, channel, delay).then((deleted: number) => {
|
||||||
sendBotMessage(ctx.channel.id,
|
sendBotMessage(ctx.channel.id,
|
||||||
{
|
{
|
||||||
content: `> deleted ${amount} messages`
|
content: `> deleted ${deleted} messages`
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
|
@ -19,9 +19,10 @@
|
||||||
import ErrorBoundary from "@components/ErrorBoundary";
|
import ErrorBoundary from "@components/ErrorBoundary";
|
||||||
import { Devs } from "@utils/constants";
|
import { Devs } from "@utils/constants";
|
||||||
import { isNonNullish } from "@utils/guards";
|
import { isNonNullish } from "@utils/guards";
|
||||||
|
import { pluralise } from "@utils/misc";
|
||||||
import definePlugin from "@utils/types";
|
import definePlugin from "@utils/types";
|
||||||
import { findByPropsLazy } from "@webpack";
|
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";
|
import { Channel, User } from "discord-types/general";
|
||||||
|
|
||||||
const SelectedChannelActionCreators = findByPropsLazy("selectPrivateChannel");
|
const SelectedChannelActionCreators = findByPropsLazy("selectPrivateChannel");
|
||||||
|
@ -39,6 +40,10 @@ function getGroupDMName(channel: Channel) {
|
||||||
.join(", ");
|
.join(", ");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function useGroupDMs(userId: string) {
|
||||||
|
return useStateFromStores([ChannelStore], () => ChannelStore.getSortedPrivateChannels().filter(c => c.isGroupDM() && c.recipients.includes(userId)));
|
||||||
|
}
|
||||||
|
|
||||||
export default definePlugin({
|
export default definePlugin({
|
||||||
name: "MutualGroupDMs",
|
name: "MutualGroupDMs",
|
||||||
description: "Shows mutual group dms in profiles",
|
description: "Shows mutual group dms in profiles",
|
||||||
|
@ -64,8 +69,8 @@ export default definePlugin({
|
||||||
group: true,
|
group: true,
|
||||||
replacement: [
|
replacement: [
|
||||||
{
|
{
|
||||||
match: /(?<=(\i\.push)\(\{section:\i\.UserProfileSections\.MUTUAL_GUILDS,text:.{0,250}\}\)\)\}\))/,
|
match: /(user:(\i),.+?=\i,)(.+?)(\i\.push)(.+?UserProfileSections\.MUTUAL_GUILDS,text:.{0,250}}\)\)}\))/,
|
||||||
replace: ',$1({section:"MUTUAL_GDMS",text:"Mutual Groups"})'
|
replace: '$1vencordMutualGroupsTabLabel=$self.useGDMCount($2.id),$3$5,$4({section:"MUTUAL_GDMS",text:vencordMutualGroupsTabLabel})'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
match: /(?<=(\i)===\i\.UserProfileSections\.MUTUAL_GUILDS?.{0,150}\}\):)/,
|
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; }) => {
|
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 => (
|
||||||
<Clickable
|
<Clickable
|
||||||
className={ProfileListClasses.listRow}
|
className={ProfileListClasses.listRow}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue