mirror of
https://github.com/Vendicated/Vencord.git
synced 2024-09-20 06:30:35 +00:00
Compare commits
18 commits
6fb63116b9
...
ead6195434
Author | SHA1 | Date | |
---|---|---|---|
|
ead6195434 | ||
|
513eccb70a | ||
|
11dd4cf3b0 | ||
|
1755c2cf6f | ||
|
4d9acac992 | ||
|
24fa55bbbe | ||
|
3bf235d115 | ||
|
6b952c24be | ||
|
ecfc09ac3f | ||
|
608fdd4f96 | ||
|
2b887fda18 | ||
|
18c2b7d730 | ||
|
35bc98b2b5 | ||
|
73a6d43840 | ||
|
cd2568cfcd | ||
|
bc655d673b | ||
|
e7a233f1d3 | ||
|
cdc2055e78 |
3 changed files with 101 additions and 0 deletions
13
src/plugins/filterBotMentions/README.md
Normal file
13
src/plugins/filterBotMentions/README.md
Normal file
|
@ -0,0 +1,13 @@
|
|||
# FilterBotMentions
|
||||
Allows you to filter bot mentions in recent mentions panel.
|
||||
|
||||
# Usage
|
||||
You can include/exclude mentions by bots in the box either using the checkbox in recent mentions panel, or in the plugin settings.
|
||||
|
||||
Include mentions by bots:
|
||||
![image](https://github.com/user-attachments/assets/a80a41fc-9bae-4612-a23a-b1894e0f8fd2)
|
||||
|
||||
Excluded mentions by bots:
|
||||
![image](https://github.com/user-attachments/assets/fdf973eb-23ef-4101-b4de-e3fb6663f41b)
|
||||
|
||||
|
84
src/plugins/filterBotMentions/index.tsx
Normal file
84
src/plugins/filterBotMentions/index.tsx
Normal file
|
@ -0,0 +1,84 @@
|
|||
/*
|
||||
* Vencord, a Discord client mod
|
||||
* Copyright (c) 2024 Vendicated and contributors
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*/
|
||||
|
||||
import { definePluginSettings } from "@api/Settings";
|
||||
import { Devs } from "@utils/constants";
|
||||
import { getCurrentGuild } from "@utils/discord";
|
||||
import definePlugin, { OptionType } from "@utils/types";
|
||||
import { findByPropsLazy, findStoreLazy } from "@webpack";
|
||||
import { Menu } from "@webpack/common";
|
||||
import { Message } from "discord-types/general";
|
||||
|
||||
|
||||
const settings = definePluginSettings({
|
||||
toggle: {
|
||||
type: OptionType.BOOLEAN,
|
||||
description: "Include mentions by bots in inbox",
|
||||
default: true,
|
||||
},
|
||||
});
|
||||
|
||||
type RecentMentionsStore = { guildFilter: string, roleFilter: boolean, everyoneFilter: boolean; };
|
||||
type fetchRecentMentionsType = (before: BigInt | null, limit: Number | null, all_servers: string | null | undefined, role: boolean, everyone: boolean,) => void;
|
||||
|
||||
const { fetchRecentMentions } = findByPropsLazy("fetchRecentMentions") as { fetchRecentMentions: fetchRecentMentionsType; };
|
||||
const recentMentionsStore = findStoreLazy("RecentMentionsStore") as RecentMentionsStore;
|
||||
|
||||
|
||||
export default definePlugin({
|
||||
name: "FilterBotMentions",
|
||||
description: "Filter mentions by bots in inbox",
|
||||
authors: [Devs.Taran],
|
||||
|
||||
patches: [
|
||||
{
|
||||
find: "get lastLoaded",
|
||||
replacement: {
|
||||
match: /getMentions.{0,30}\?\i/,
|
||||
replace: "$&.filter($self.filterMessages)"
|
||||
}
|
||||
},
|
||||
{
|
||||
find: "mentions-filter",
|
||||
replacement: {
|
||||
match: /children:\[\(0,\i\.jsx\).{0,600}\}\)\]/,
|
||||
replace: "$&.concat($self.patchMenu())"
|
||||
}
|
||||
}
|
||||
|
||||
],
|
||||
settings,
|
||||
reloadMentions(): void {
|
||||
const all_servers: boolean = recentMentionsStore.guildFilter === "ALL_SERVERS";
|
||||
const { roleFilter: role, everyoneFilter: everyone } = recentMentionsStore;
|
||||
const serverToFilter: string | undefined | null = all_servers ? null : getCurrentGuild()?.id;
|
||||
fetchRecentMentions(null, null, serverToFilter, role, everyone);
|
||||
},
|
||||
|
||||
toggleBotMentions(): void {
|
||||
settings.store.toggle = !settings.store.toggle;
|
||||
},
|
||||
|
||||
filterMessages(message: Message): boolean {
|
||||
return !message.author.bot || settings.store.toggle;
|
||||
|
||||
},
|
||||
|
||||
patchMenu() {
|
||||
return (
|
||||
<Menu.MenuCheckboxItem
|
||||
id="Bots"
|
||||
label="Include mentions by bots"
|
||||
action={() => {
|
||||
this.toggleBotMentions();
|
||||
this.reloadMentions();
|
||||
}}
|
||||
checked={settings.store.toggle}
|
||||
/>
|
||||
);
|
||||
}
|
||||
|
||||
});
|
|
@ -575,6 +575,10 @@ export const Devs = /* #__PURE__*/ Object.freeze({
|
|||
name: "RamziAH",
|
||||
id: 1279957227612147747n,
|
||||
},
|
||||
Taran: {
|
||||
name: "Taran",
|
||||
id: 482951588055351306n
|
||||
},
|
||||
} satisfies Record<string, Dev>);
|
||||
|
||||
// iife so #__PURE__ works correctly
|
||||
|
|
Loading…
Reference in a new issue