29 lines
1.4 KiB
TypeScript
29 lines
1.4 KiB
TypeScript
|
import { UserStore } from "../../../webpack/common";
|
||
|
import { Settings } from "../../../Vencord";
|
||
|
import { PronounMapping, UserProfileProps } from "../types";
|
||
|
import { useAwaiter, classes } from "../../../utils";
|
||
|
import { fetchPronouns, formatPronouns } from "../utils";
|
||
|
|
||
|
export default function PronounsProfileWrapper(props: UserProfileProps, pronounsComponent: JSX.Element) {
|
||
|
// Don't bother fetching bot or system users
|
||
|
if (props.user.bot || props.user.system) return null;
|
||
|
// Respect showSelf options
|
||
|
if (!Settings.plugins.PronounDB.showSelf && props.user.id === UserStore.getCurrentUser().id) return null;
|
||
|
|
||
|
const [result, , isPending] = useAwaiter(
|
||
|
() => fetchPronouns(props.user.id),
|
||
|
null,
|
||
|
e => console.error("Fetching pronouns failed: ", e)
|
||
|
);
|
||
|
|
||
|
// If the promise completed, the result was not "unspecified", and there is a mapping for the code, then return a span with the pronouns
|
||
|
if (!isPending && result && result !== "unspecified" && PronounMapping[result]) {
|
||
|
// First child is the header, second is a div with the actual text
|
||
|
const [, pronounsBodyComponent] = pronounsComponent.props.children as [JSX.Element, JSX.Element];
|
||
|
pronounsBodyComponent.props.children = formatPronouns(result);
|
||
|
return pronounsComponent;
|
||
|
}
|
||
|
// Otherwise, return null so nothing else is rendered
|
||
|
else return null;
|
||
|
}
|