feat: explore (#85)

This commit is contained in:
Cody Tseng 2025-02-11 16:33:31 +08:00 committed by GitHub
parent 80893ec033
commit b91f46723e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
35 changed files with 811 additions and 179 deletions

View file

@ -0,0 +1,40 @@
import { Badge } from '@/components/ui/badge'
import { TRelayInfo } from '@/types'
import { useMemo } from 'react'
import { useTranslation } from 'react-i18next'
export default function RelayBadges({ relayInfo }: { relayInfo: TRelayInfo }) {
const { t } = useTranslation()
const badges = useMemo(() => {
const b: string[] = []
if (relayInfo.limitation?.auth_required) {
b.push('Auth')
}
if (relayInfo.supported_nips?.includes(50)) {
b.push('Search')
}
if (relayInfo.limitation?.payment_required) {
b.push('Payment')
}
return b
}, [relayInfo])
if (!badges.length) {
return null
}
return (
<div className="flex gap-2">
{badges.includes('Auth') && (
<Badge className="bg-green-400 hover:bg-green-400/80">{t('relayInfoBadgeAuth')}</Badge>
)}
{badges.includes('Search') && (
<Badge className="bg-pink-400 hover:bg-pink-400/80">{t('relayInfoBadgeSearch')}</Badge>
)}
{badges.includes('Payment') && (
<Badge className="bg-orange-400 hover:bg-orange-400/80">{t('relayInfoBadgePayment')}</Badge>
)}
</div>
)
}