Bpistle/src/components/Note/FollowPack.tsx
2026-01-22 22:28:07 +08:00

55 lines
1.8 KiB
TypeScript

import { Button } from '@/components/ui/button'
import { getFollowPackInfoFromEvent } from '@/lib/event-metadata'
import { toFollowPack } from '@/lib/link'
import { useSecondaryPage } from '@/PageManager'
import { Event } from 'nostr-tools'
import { useMemo } from 'react'
import { useTranslation } from 'react-i18next'
import Image from '../Image'
export default function FollowPack({ event, className }: { event: Event; className?: string }) {
const { t } = useTranslation()
const { push } = useSecondaryPage()
const { title, description, image, pubkeys } = useMemo(
() => getFollowPackInfoFromEvent(event),
[event]
)
const handleViewDetails = (e: React.MouseEvent) => {
e.stopPropagation()
push(toFollowPack(event))
}
return (
<div className={className}>
<div className="mb-2 flex items-start gap-2">
{image && (
<Image
image={{ url: image, pubkey: event.pubkey }}
className="h-20 w-24 object-cover"
classNames={{
wrapper: 'w-24 h-20 flex-shrink-0',
errorPlaceholder: 'w-24 h-20'
}}
hideIfError
/>
)}
<div className="min-w-0 flex-1">
<div className="flex items-center gap-2">
<h3 className="mb-1 truncate text-xl font-semibold">{title}</h3>
<span className="shrink-0 text-xs text-muted-foreground">
{t('n users', { count: pubkeys.length })}
</span>
</div>
{description && (
<p className="line-clamp-2 text-sm text-muted-foreground">{description}</p>
)}
</div>
</div>
<Button onClick={handleViewDetails} variant="outline" className="w-full">
{t('View Details')}
</Button>
</div>
)
}