diff options
author | Samuel Newman <mozzius@protonmail.com> | 2025-06-14 00:41:12 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-06-13 16:41:12 -0500 |
commit | ed9691511beb26bdb799bbcb9a973a8b8df3433c (patch) | |
tree | d36687f42ed488a7079028abf3f81529887d1fd0 /src/screens/PostThread/components/ThreadItemAnchor.tsx | |
parent | 7cd607f523b715bdea4b01d9203610e764b4fbe3 (diff) | |
download | voidsky-ed9691511beb26bdb799bbcb9a973a8b8df3433c.tar.zst |
Hover card on anchor displayName/handle (#8479)
* add hover to anchor display name / handle * use newer link component * Wrap using a single hover element --------- Co-authored-by: Eric Bailey <git@esb.lol>
Diffstat (limited to 'src/screens/PostThread/components/ThreadItemAnchor.tsx')
-rw-r--r-- | src/screens/PostThread/components/ThreadItemAnchor.tsx | 85 |
1 files changed, 49 insertions, 36 deletions
diff --git a/src/screens/PostThread/components/ThreadItemAnchor.tsx b/src/screens/PostThread/components/ThreadItemAnchor.tsx index d1e3518cc..f6bc5871c 100644 --- a/src/screens/PostThread/components/ThreadItemAnchor.tsx +++ b/src/screens/PostThread/components/ThreadItemAnchor.tsx @@ -17,7 +17,6 @@ import {makeProfileLink} from '#/lib/routes/links' import {sanitizeDisplayName} from '#/lib/strings/display-names' import {sanitizeHandle} from '#/lib/strings/handles' import {niceDate} from '#/lib/strings/time' -import {s} from '#/lib/styles' import {getTranslatorLink, isPostInLanguage} from '#/locale/helpers' import {logger} from '#/logger' import { @@ -34,7 +33,6 @@ import {type OnPostSuccessData} from '#/state/shell/composer' import {useMergedThreadgateHiddenReplies} from '#/state/threadgate-hidden-replies' import {type PostSource} from '#/state/unstable-post-source' import {PostThreadFollowBtn} from '#/view/com/post-thread/PostThreadFollowBtn' -import {Link} from '#/view/com/util/Link' import {formatCount} from '#/view/com/util/numeric/format' import {PreviewableUserAvatar} from '#/view/com/util/UserAvatar' import { @@ -47,13 +45,14 @@ import {colors} from '#/components/Admonition' import {Button} from '#/components/Button' import {CalendarClock_Stroke2_Corner0_Rounded as CalendarClockIcon} from '#/components/icons/CalendarClock' import {Trash_Stroke2_Corner0_Rounded as TrashIcon} from '#/components/icons/Trash' -import {InlineLinkText} from '#/components/Link' +import {InlineLinkText, Link} from '#/components/Link' import {ContentHider} from '#/components/moderation/ContentHider' import {LabelsOnMyPost} from '#/components/moderation/LabelsOnMe' import {PostAlerts} from '#/components/moderation/PostAlerts' import {type AppModerationCause} from '#/components/Pills' import {Embed, PostEmbedViewContext} from '#/components/Post/Embed' import {PostControls} from '#/components/PostControls' +import {ProfileHoverCard} from '#/components/ProfileHoverCard' import * as Prompt from '#/components/Prompt' import {RichText} from '#/components/RichText' import * as Skele from '#/components/Skeleton' @@ -197,7 +196,6 @@ const ThreadItemAnchorInner = memo(function ThreadItemAnchorInner({ const threadRootUri = record.reply?.root?.uri || post.uri const authorHref = makeProfileLink(post.author) - const authorTitle = post.author.handle const isThreadAuthor = getThreadAuthor(post, record) === currentAccount?.did const likesHref = useMemo(() => { @@ -321,42 +319,57 @@ const ThreadItemAnchorInner = memo(function ThreadItemAnchorInner({ live={live} onBeforePress={onOpenAuthor} /> - <View style={[a.flex_1]}> - <View style={[a.flex_row, a.align_center]}> - <Link - style={[a.flex_shrink]} - href={authorHref} - title={authorTitle} - onBeforePress={onOpenAuthor}> - <Text - emoji - style={[a.text_lg, a.font_bold, a.leading_snug, a.self_start]} - numberOfLines={1}> - {sanitizeDisplayName( + <ProfileHoverCard did={post.author.did}> + <View style={[a.flex_1]}> + <View style={[a.flex_row, a.align_center]}> + <Link + to={authorHref} + style={[a.flex_shrink]} + label={sanitizeDisplayName( post.author.displayName || sanitizeHandle(post.author.handle), moderation.ui('displayName'), )} - </Text> - </Link> + onPress={onOpenAuthor}> + <Text + emoji + style={[ + a.text_lg, + a.font_bold, + a.leading_snug, + a.self_start, + ]} + numberOfLines={1}> + {sanitizeDisplayName( + post.author.displayName || + sanitizeHandle(post.author.handle), + moderation.ui('displayName'), + )} + </Text> + </Link> - <View style={[{paddingLeft: 3, top: -1}]}> - <VerificationCheckButton profile={authorShadow} size="md" /> + <View style={[{paddingLeft: 3, top: -1}]}> + <VerificationCheckButton profile={authorShadow} size="md" /> + </View> + </View> + <View style={[a.align_start]}> + <Link + style={[a.flex_shrink]} + to={authorHref} + label={sanitizeHandle(post.author.handle, '@')}> + <Text + style={[ + a.text_md, + a.leading_snug, + t.atoms.text_contrast_medium, + ]} + numberOfLines={1}> + {sanitizeHandle(post.author.handle, '@')} + </Text> + </Link> </View> </View> - <Link style={s.flex1} href={authorHref} title={authorTitle}> - <Text - emoji - style={[ - a.text_md, - a.leading_snug, - t.atoms.text_contrast_medium, - ]} - numberOfLines={1}> - {sanitizeHandle(post.author.handle, '@')} - </Text> - </Link> - </View> + </ProfileHoverCard> {showFollowButton && ( <View> <PostThreadFollowBtn did={post.author.did} /> @@ -417,7 +430,7 @@ const ThreadItemAnchorInner = memo(function ThreadItemAnchorInner({ t.atoms.border_contrast_low, ]}> {post.repostCount != null && post.repostCount !== 0 ? ( - <Link href={repostsHref} title={_(msg`Reposts of this post`)}> + <Link to={repostsHref} label={_(msg`Reposts of this post`)}> <Text testID="repostCount-expanded" style={[a.text_md, t.atoms.text_contrast_medium]}> @@ -435,7 +448,7 @@ const ThreadItemAnchorInner = memo(function ThreadItemAnchorInner({ {post.quoteCount != null && post.quoteCount !== 0 && !post.viewer?.embeddingDisabled ? ( - <Link href={quotesHref} title={_(msg`Quotes of this post`)}> + <Link to={quotesHref} label={_(msg`Quotes of this post`)}> <Text testID="quoteCount-expanded" style={[a.text_md, t.atoms.text_contrast_medium]}> @@ -451,7 +464,7 @@ const ThreadItemAnchorInner = memo(function ThreadItemAnchorInner({ </Link> ) : null} {post.likeCount != null && post.likeCount !== 0 ? ( - <Link href={likesHref} title={_(msg`Likes on this post`)}> + <Link to={likesHref} label={_(msg`Likes on this post`)}> <Text testID="likeCount-expanded" style={[a.text_md, t.atoms.text_contrast_medium]}> |