2022-11-11 17:50:09 -05:00
|
|
|
/*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2023-02-16 16:46:51 -05:00
|
|
|
import ErrorBoundary from "@components/ErrorBoundary";
|
2022-11-11 17:50:09 -05:00
|
|
|
import { User } from "discord-types/general";
|
2022-12-21 14:16:32 -05:00
|
|
|
import { ComponentType, HTMLProps } from "react";
|
2022-11-11 17:50:09 -05:00
|
|
|
|
2022-11-16 18:21:13 -05:00
|
|
|
import Plugins from "~plugins";
|
|
|
|
|
2022-11-11 17:50:09 -05:00
|
|
|
export enum BadgePosition {
|
|
|
|
START,
|
|
|
|
END
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ProfileBadge {
|
2022-12-21 14:16:32 -05:00
|
|
|
/** The tooltip to show on hover. Required for image badges */
|
|
|
|
tooltip?: string;
|
|
|
|
/** Custom component for the badge (tooltip not included) */
|
|
|
|
component?: ComponentType<ProfileBadge & BadgeUserArgs>;
|
2022-11-11 17:50:09 -05:00
|
|
|
/** The custom image to use */
|
|
|
|
image?: string;
|
|
|
|
/** Action to perform when you click the badge */
|
|
|
|
onClick?(): void;
|
|
|
|
/** Should the user display this badge? */
|
|
|
|
shouldShow?(userInfo: BadgeUserArgs): boolean;
|
2022-12-21 14:16:32 -05:00
|
|
|
/** Optional props (e.g. style) for the badge, ignored for component badges */
|
2022-11-11 17:50:09 -05:00
|
|
|
props?: HTMLProps<HTMLImageElement>;
|
|
|
|
/** Insert at start or end? */
|
|
|
|
position?: BadgePosition;
|
2022-12-21 14:16:32 -05:00
|
|
|
/** The badge name to display, Discord uses this. Required for component badges */
|
2022-11-11 17:50:09 -05:00
|
|
|
key?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const Badges = new Set<ProfileBadge>();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Register a new badge with the Badges API
|
|
|
|
* @param badge The badge to register
|
|
|
|
*/
|
|
|
|
export function addBadge(badge: ProfileBadge) {
|
2023-02-16 16:46:51 -05:00
|
|
|
badge.component &&= ErrorBoundary.wrap(badge.component, { noop: true });
|
2022-11-11 17:50:09 -05:00
|
|
|
Badges.add(badge);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unregister a badge from the Badges API
|
|
|
|
* @param badge The badge to remove
|
|
|
|
*/
|
|
|
|
export function removeBadge(badge: ProfileBadge) {
|
|
|
|
return Badges.delete(badge);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inject badges into the profile badges array.
|
|
|
|
* You probably don't need to use this.
|
|
|
|
*/
|
|
|
|
export function inject(badgeArray: ProfileBadge[], args: BadgeUserArgs) {
|
|
|
|
for (const badge of Badges) {
|
|
|
|
if (!badge.shouldShow || badge.shouldShow(args)) {
|
|
|
|
badge.position === BadgePosition.START
|
2022-12-21 14:16:32 -05:00
|
|
|
? badgeArray.unshift({ ...badge, ...args })
|
|
|
|
: badgeArray.push({ ...badge, ...args });
|
2022-11-11 17:50:09 -05:00
|
|
|
}
|
|
|
|
}
|
2022-11-16 18:21:13 -05:00
|
|
|
(Plugins.BadgeAPI as any).addDonorBadge(badgeArray, args.user.id);
|
|
|
|
|
2022-11-11 17:50:09 -05:00
|
|
|
return badgeArray;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface BadgeUserArgs {
|
|
|
|
user: User;
|
|
|
|
profile: Profile;
|
|
|
|
premiumSince: Date;
|
|
|
|
premiumGuildSince?: Date;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface ConnectedAccount {
|
|
|
|
type: string;
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
verified: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface Profile {
|
|
|
|
connectedAccounts: ConnectedAccount[];
|
|
|
|
premiumType: number;
|
|
|
|
premiumSince: string;
|
|
|
|
premiumGuildSince?: any;
|
|
|
|
lastFetched: number;
|
|
|
|
profileFetchFailed: boolean;
|
|
|
|
application?: any;
|
|
|
|
}
|