feat: others relays
This commit is contained in:
24
src/pages/secondary/OthersRelaySettingsPage/index.tsx
Normal file
24
src/pages/secondary/OthersRelaySettingsPage/index.tsx
Normal file
@@ -0,0 +1,24 @@
|
||||
import OthersRelayList from '@/components/OthersRelayList'
|
||||
import { useFetchProfile } from '@/hooks'
|
||||
import SecondaryPageLayout from '@/layouts/SecondaryPageLayout'
|
||||
import { useTranslation } from 'react-i18next'
|
||||
|
||||
export default function RelaySettingsPage({ id, index }: { id?: string; index?: number }) {
|
||||
const { t } = useTranslation()
|
||||
const { profile } = useFetchProfile(id)
|
||||
|
||||
if (!id || !profile) {
|
||||
return null
|
||||
}
|
||||
|
||||
return (
|
||||
<SecondaryPageLayout
|
||||
index={index}
|
||||
title={t("username's used relays", { username: profile.username })}
|
||||
>
|
||||
<div className="px-4">
|
||||
<OthersRelayList userId={id} />
|
||||
</div>
|
||||
</SecondaryPageLayout>
|
||||
)
|
||||
}
|
||||
@@ -11,7 +11,12 @@ import { Skeleton } from '@/components/ui/skeleton'
|
||||
import { useFetchFollowings, useFetchProfile } from '@/hooks'
|
||||
import { useFetchRelayList } from '@/hooks/useFetchRelayList'
|
||||
import SecondaryPageLayout from '@/layouts/SecondaryPageLayout'
|
||||
import { toFollowingList, toProfileEditor } from '@/lib/link'
|
||||
import {
|
||||
toFollowingList,
|
||||
toOthersRelaySettings,
|
||||
toProfileEditor,
|
||||
toRelaySettings
|
||||
} from '@/lib/link'
|
||||
import { generateImageByPubkey } from '@/lib/pubkey'
|
||||
import { SecondaryPageLink, useSecondaryPage } from '@/PageManager'
|
||||
import { useFeed } from '@/providers/FeedProvider'
|
||||
@@ -46,6 +51,10 @@ export default function ProfilePage({ id, index }: { id?: string; index?: number
|
||||
() => (profile?.pubkey ? generateImageByPubkey(profile?.pubkey) : ''),
|
||||
[profile]
|
||||
)
|
||||
const relayCount = useMemo(
|
||||
() => new Set(relayList.write.concat(relayList.read)).size,
|
||||
[relayList]
|
||||
)
|
||||
const isSelf = accountPubkey === profile?.pubkey
|
||||
|
||||
if (!profile && isFetching) {
|
||||
@@ -107,13 +116,22 @@ export default function ProfilePage({ id, index }: { id?: string; index?: number
|
||||
<QrCodePopover pubkey={pubkey} />
|
||||
</div>
|
||||
<ProfileAbout about={about} className="text-wrap break-words whitespace-pre-wrap mt-2" />
|
||||
<SecondaryPageLink
|
||||
to={toFollowingList(pubkey)}
|
||||
className="mt-2 flex gap-1 hover:underline text-sm w-fit"
|
||||
>
|
||||
{isSelf ? selfFollowings.length : followings.length}
|
||||
<div className="text-muted-foreground">{t('Following')}</div>
|
||||
</SecondaryPageLink>
|
||||
<div className="flex gap-4 items-center mt-2 text-sm">
|
||||
<SecondaryPageLink
|
||||
to={toFollowingList(pubkey)}
|
||||
className="flex gap-1 hover:underline w-fit"
|
||||
>
|
||||
{isSelf ? selfFollowings.length : followings.length}
|
||||
<div className="text-muted-foreground">{t('Following')}</div>
|
||||
</SecondaryPageLink>
|
||||
<SecondaryPageLink
|
||||
to={isSelf ? toRelaySettings() : toOthersRelaySettings(pubkey)}
|
||||
className="flex gap-1 hover:underline w-fit"
|
||||
>
|
||||
{relayCount}
|
||||
<div className="text-muted-foreground">{t('Relays')}</div>
|
||||
</SecondaryPageLink>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{!isFetchingRelayInfo && (
|
||||
|
||||
Reference in New Issue
Block a user