style: make minor adjustments to styling
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
import Username from '../Username'
|
import Username from '../Username'
|
||||||
|
|
||||||
export function EmbeddedMention({ userId }: { userId: string }) {
|
export function EmbeddedMention({ userId }: { userId: string }) {
|
||||||
return <Username userId={userId} showAt className="text-highlight font-normal" />
|
return <Username userId={userId} showAt className="text-highlight font-normal inline-block" />
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,19 +4,22 @@ import { BadgeAlert, BadgeCheck } from 'lucide-react'
|
|||||||
export default function Nip05({ nip05, pubkey }: { nip05: string; pubkey: string }) {
|
export default function Nip05({ nip05, pubkey }: { nip05: string; pubkey: string }) {
|
||||||
const { nip05IsVerified, nip05Name, nip05Domain } = useFetchNip05(nip05, pubkey)
|
const { nip05IsVerified, nip05Name, nip05Domain } = useFetchNip05(nip05, pubkey)
|
||||||
return (
|
return (
|
||||||
<div className="flex items-center space-x-1">
|
nip05Name &&
|
||||||
{nip05Name !== '_' ? (
|
nip05Domain && (
|
||||||
<div className="text-sm text-muted-foreground truncate">@{nip05Name}</div>
|
<div className="flex items-center space-x-1">
|
||||||
) : null}
|
{nip05Name !== '_' ? (
|
||||||
<a
|
<div className="text-sm text-muted-foreground truncate">@{nip05Name}</div>
|
||||||
href={`https://${nip05Domain}`}
|
) : null}
|
||||||
target="_blank"
|
<a
|
||||||
className={`flex items-center space-x-1 hover:underline ${nip05IsVerified ? 'text-highlight' : 'text-muted-foreground'}`}
|
href={`https://${nip05Domain}`}
|
||||||
rel="noreferrer"
|
target="_blank"
|
||||||
>
|
className={`flex items-center space-x-1 hover:underline ${nip05IsVerified ? 'text-highlight' : 'text-muted-foreground'}`}
|
||||||
{nip05IsVerified ? <BadgeCheck size={16} /> : <BadgeAlert size={16} />}
|
rel="noreferrer"
|
||||||
<div className="text-sm">{nip05Domain}</div>
|
>
|
||||||
</a>
|
{nip05IsVerified ? <BadgeCheck size={16} /> : <BadgeAlert size={16} />}
|
||||||
</div>
|
<div className="text-sm">{nip05Domain}</div>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import { getParentEventId, getRootEventId } from '@renderer/lib/event'
|
|||||||
export default function ShortTextNoteCard({
|
export default function ShortTextNoteCard({
|
||||||
event,
|
event,
|
||||||
className,
|
className,
|
||||||
size,
|
size = 'normal',
|
||||||
hideStats = false
|
hideStats = false
|
||||||
}: {
|
}: {
|
||||||
event: Event
|
event: Event
|
||||||
@@ -29,7 +29,9 @@ export default function ShortTextNoteCard({
|
|||||||
push(toNote(rootEvent ?? event))
|
push(toNote(rootEvent ?? event))
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Card className="p-4 hover:bg-muted/50 text-left cursor-pointer">
|
<Card
|
||||||
|
className={`hover:bg-muted/50 text-left cursor-pointer ${size === 'normal' ? 'p-4' : 'p-2'}`}
|
||||||
|
>
|
||||||
<Note
|
<Note
|
||||||
size={size}
|
size={size}
|
||||||
event={event}
|
event={event}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cn } from '@renderer/lib/utils'
|
|||||||
import { useNostr } from '@renderer/providers/NostrProvider'
|
import { useNostr } from '@renderer/providers/NostrProvider'
|
||||||
import { useNoteStats } from '@renderer/providers/NoteStatsProvider'
|
import { useNoteStats } from '@renderer/providers/NoteStatsProvider'
|
||||||
import client from '@renderer/services/client.service'
|
import client from '@renderer/services/client.service'
|
||||||
import { Heart } from 'lucide-react'
|
import { Heart, Loader } from 'lucide-react'
|
||||||
import { Event } from 'nostr-tools'
|
import { Event } from 'nostr-tools'
|
||||||
import { useEffect, useMemo, useState } from 'react'
|
import { useEffect, useMemo, useState } from 'react'
|
||||||
import { formatCount } from './utils'
|
import { formatCount } from './utils'
|
||||||
@@ -74,7 +74,11 @@ export default function LikeButton({
|
|||||||
disabled={!canLike}
|
disabled={!canLike}
|
||||||
title="like"
|
title="like"
|
||||||
>
|
>
|
||||||
<Heart size={16} className={hasLiked ? 'fill-red-400' : ''} />
|
{liking ? (
|
||||||
|
<Loader className="animate-spin" size={16} />
|
||||||
|
) : (
|
||||||
|
<Heart size={16} className={hasLiked ? 'fill-red-400' : ''} />
|
||||||
|
)}
|
||||||
<div className="text-xs">{formatCount(likeCount)}</div>
|
<div className="text-xs">{formatCount(likeCount)}</div>
|
||||||
</button>
|
</button>
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ import { cn } from '@renderer/lib/utils'
|
|||||||
import { useNostr } from '@renderer/providers/NostrProvider'
|
import { useNostr } from '@renderer/providers/NostrProvider'
|
||||||
import { useNoteStats } from '@renderer/providers/NoteStatsProvider'
|
import { useNoteStats } from '@renderer/providers/NoteStatsProvider'
|
||||||
import client from '@renderer/services/client.service'
|
import client from '@renderer/services/client.service'
|
||||||
import { Repeat } from 'lucide-react'
|
import { Loader, Repeat } from 'lucide-react'
|
||||||
import { Event } from 'nostr-tools'
|
import { Event } from 'nostr-tools'
|
||||||
import { useEffect, useMemo, useState } from 'react'
|
import { useEffect, useMemo, useState } from 'react'
|
||||||
import { formatCount } from './utils'
|
import { formatCount } from './utils'
|
||||||
@@ -85,7 +85,7 @@ export default function RepostButton({
|
|||||||
disabled={!canRepost}
|
disabled={!canRepost}
|
||||||
title="repost"
|
title="repost"
|
||||||
>
|
>
|
||||||
<Repeat size={16} />
|
{reposting ? <Loader className="animate-spin" size={16} /> : <Repeat size={16} />}
|
||||||
<div className="text-xs">{formatCount(repostCount)}</div>
|
<div className="text-xs">{formatCount(repostCount)}</div>
|
||||||
</button>
|
</button>
|
||||||
</AlertDialogTrigger>
|
</AlertDialogTrigger>
|
||||||
|
|||||||
@@ -22,12 +22,12 @@ export default function ReplyNote({
|
|||||||
>
|
>
|
||||||
<UserAvatar userId={event.pubkey} size="small" className="shrink-0" />
|
<UserAvatar userId={event.pubkey} size="small" className="shrink-0" />
|
||||||
<div className="w-full overflow-hidden">
|
<div className="w-full overflow-hidden">
|
||||||
<div className="flex gap-1 items-end">
|
<div className="flex items-end gap-2">
|
||||||
<Username
|
<Username
|
||||||
userId={event.pubkey}
|
userId={event.pubkey}
|
||||||
className="text-xs font-semibold text-muted-foreground hover:text-foreground truncate"
|
className="text-sm font-semibold text-muted-foreground hover:text-foreground truncate"
|
||||||
/>
|
/>
|
||||||
<div className="text-xs text-muted-foreground shrink-0">
|
<div className="text-xs text-muted-foreground shrink-0 -top-[1px] relative">
|
||||||
{formatTimestamp(event.created_at)}
|
{formatTimestamp(event.created_at)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ export default function Username({
|
|||||||
return (
|
return (
|
||||||
<HoverCard>
|
<HoverCard>
|
||||||
<HoverCardTrigger asChild>
|
<HoverCardTrigger asChild>
|
||||||
<div className={cn('inline-block', className)}>
|
<div className={className}>
|
||||||
<SecondaryPageLink
|
<SecondaryPageLink
|
||||||
to={toProfile(pubkey)}
|
to={toProfile(pubkey)}
|
||||||
className={cn('truncate hover:underline')}
|
className={cn('truncate hover:underline')}
|
||||||
|
|||||||
Reference in New Issue
Block a user