1
0
Fork 1
mirror of https://github.com/Vendicated/Vencord.git synced 2025-01-25 08:46:25 +00:00

feat(plugin): sort friend requests by date received (#280)

This commit is contained in:
megumin 2022-12-08 22:53:12 +00:00 committed by GitHub
parent 022bf17140
commit ee24439795
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 80 additions and 1 deletions

View file

@ -0,0 +1,74 @@
/*
* Vencord, a modification for Discord's desktop app
* Copyright (c) 2022 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 { Flex } from "@components/Flex";
import { Devs } from "@utils/constants";
import definePlugin, { OptionType } from "@utils/types";
import { RelationshipStore } from "@webpack/common";
import { User } from "discord-types/general";
import { Settings } from "Vencord";
export default definePlugin({
name: "SortFriendRequests",
authors: [Devs.Megu],
description: "Sorts friend requests by date of receipt",
patches: [{
find: ".PENDING_INCOMING||",
replacement: [{
match: /\.sortBy\(\(function\((\w)\){return \w{1,3}\.comparator}\)\)/,
// If the row type is 3 or 4 (pendinng incoming or outgoing), sort by date of receipt
// Otherwise, use the default comparator
replace: (_, row) => `.sortBy((function(${row}) {
return ${row}.type === 3 || ${row}.type === 4
? -Vencord.Plugins.plugins.SortFriendRequests.getSince(${row}.user)
: ${row}.comparator
}))`
}, {
predicate: () => Settings.plugins.SortFriendRequests.showDates,
match: /(user:(\w{1,3}),.{10,30}),subText:(\w{1,3}),(.{10,30}userInfo}\))/,
// Show dates in the friend request list
replace: (_, pre, user, subText, post) => `${pre},
subText: Vencord.Plugins.plugins.SortFriendRequests.makeSubtext(${subText}, ${user}),
${post}`
}]
}],
getSince(user: User) {
return new Date(RelationshipStore.getSince(user.id));
},
makeSubtext(text: string, user: User) {
const since = this.getSince(user);
return (
<Flex flexDirection="row" style={{ gap: 0, flexWrap: "wrap", lineHeight: "0.9rem" }}>
<span>{text}</span>
{!isNaN(since.getTime()) && <span>Received &mdash; {since.toDateString()}</span>}
</Flex>
);
},
options: {
showDates: {
type: OptionType.BOOLEAN,
description: "Show dates on friend requests",
default: false,
restartNeeded: true
}
}
});

View file

@ -27,6 +27,7 @@ export default function definePlugin<P extends PluginDef>(p: P & Record<string,
export interface PatchReplacement { export interface PatchReplacement {
match: string | RegExp; match: string | RegExp;
replace: string | ((match: string, ...groups: string[]) => string); replace: string | ((match: string, ...groups: string[]) => string);
predicate?(): boolean;
} }
export interface Patch { export interface Patch {

View file

@ -52,7 +52,10 @@ export let UserStore: Stores.UserStore;
export let SelectedChannelStore: Stores.SelectedChannelStore; export let SelectedChannelStore: Stores.SelectedChannelStore;
export let SelectedGuildStore: any; export let SelectedGuildStore: any;
export let ChannelStore: Stores.ChannelStore; export let ChannelStore: Stores.ChannelStore;
export let RelationshipStore: Stores.RelationshipStore; export let RelationshipStore: Stores.RelationshipStore & {
/** Get the date (as a string) that the relationship was created */
getSince(userId: string): string;
};
export const Forms = {} as { export const Forms = {} as {
FormTitle: Components.FormTitle; FormTitle: Components.FormTitle;

View file

@ -137,6 +137,7 @@ function patchPush() {
// @ts-ignore we change all patch.replacement to array in plugins/index // @ts-ignore we change all patch.replacement to array in plugins/index
for (const replacement of patch.replacement) { for (const replacement of patch.replacement) {
if (replacement.predicate && !replacement.predicate()) continue;
const lastMod = mod; const lastMod = mod;
const lastCode = code; const lastCode = code;