snort/src/Element/Mention.tsx

26 lines
767 B
TypeScript
Raw Normal View History

2023-01-16 22:22:21 +00:00
import { useMemo } from "react";
import { Link } from "react-router-dom";
import { useUserProfile } from "Feed/ProfileFeed";
2023-01-20 11:11:50 +00:00
import { HexKey } from "Nostr";
import { hexToBech32, profileLink } from "Util";
2023-01-16 22:22:21 +00:00
export default function Mention({ pubkey }: { pubkey: HexKey }) {
const user = useUserProfile(pubkey);
2023-01-16 22:22:21 +00:00
const name = useMemo(() => {
let name = hexToBech32("npub", pubkey).substring(0, 12);
2023-02-07 19:47:57 +00:00
if (user?.display_name !== undefined && user.display_name.length > 0) {
name = user.display_name;
} else if (user?.name !== undefined && user.name.length > 0) {
name = user.name;
}
return name;
}, [user, pubkey]);
2023-01-16 22:22:21 +00:00
return (
<Link to={profileLink(pubkey)} onClick={(e) => e.stopPropagation()}>
@{name}
</Link>
);
}