import { ImageWithFallback } from '@components/imageWithFallback'; import { RelayContext } from '@components/relaysProvider'; import { truncate } from '@utils/truncate'; import Avatar from 'boring-avatars'; import destr from 'destr'; import Image from 'next/image'; import { Author } from 'nostr-relaypool'; import { useContext, useEffect, useState } from 'react'; const DEFAULT_BANNER = 'https://bafybeiacwit7hjmdefqggxqtgh6ht5dhth7ndptwn2msl5kpkodudsr7py.ipfs.w3s.link/banner-1.jpg'; export default function ProfileMetadata({ id }: { id: string }) { const [pool, relays]: any = useContext(RelayContext); const [profile, setProfile] = useState(null); useEffect(() => { const user = new Author(pool, relays, id); user.metaData((res) => setProfile(destr(res.content)), 0); }, [id, pool, relays]); return ( <>
user's banner
{profile?.picture ? ( ) : ( )}

{profile?.display_name || profile?.name}

{profile?.username || (id && truncate(id, 16, ' .... '))}
{profile?.about}
); }