diff options
Diffstat (limited to 'src/view/com/post/Post.tsx')
-rw-r--r-- | src/view/com/post/Post.tsx | 39 |
1 files changed, 15 insertions, 24 deletions
diff --git a/src/view/com/post/Post.tsx b/src/view/com/post/Post.tsx index 19017f30f..6079f5c10 100644 --- a/src/view/com/post/Post.tsx +++ b/src/view/com/post/Post.tsx @@ -1,4 +1,4 @@ -import React, {useMemo, useState} from 'react' +import {useCallback, useMemo, useState} from 'react' import {type StyleProp, StyleSheet, View, type ViewStyle} from 'react-native' import { type AppBskyFeedDefs, @@ -9,8 +9,7 @@ import { RichText as RichTextAPI, } from '@atproto/api' import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' -import {msg, Trans} from '@lingui/macro' -import {useLingui} from '@lingui/react' +import {Trans} from '@lingui/macro' import {useQueryClient} from '@tanstack/react-query' import {MAX_POST_LINES} from '#/lib/constants' @@ -27,7 +26,7 @@ import { import {useModerationOpts} from '#/state/preferences/moderation-opts' import {precacheProfile} from '#/state/queries/profile' import {useSession} from '#/state/session' -import {Link, TextLink} from '#/view/com/util/Link' +import {Link} from '#/view/com/util/Link' import {PostMeta} from '#/view/com/util/PostMeta' import {Text} from '#/view/com/util/text/Text' import {PreviewableUserAvatar} from '#/view/com/util/UserAvatar' @@ -37,6 +36,7 @@ import {ContentHider} from '#/components/moderation/ContentHider' import {LabelsOnMyPost} from '#/components/moderation/LabelsOnMe' import {PostAlerts} from '#/components/moderation/PostAlerts' import {Embed, PostEmbedViewContext} from '#/components/Post/Embed' +import {ShowMoreTextButton} from '#/components/Post/ShowMoreTextButton' import {PostControls} from '#/components/PostControls' import {ProfileHoverCard} from '#/components/ProfileHoverCard' import {RichText} from '#/components/RichText' @@ -115,7 +115,6 @@ function PostInner({ }) { const queryClient = useQueryClient() const pal = usePalette('default') - const {_} = useLingui() const {openComposer} = useOpenComposer() const [limitLines, setLimitLines] = useState( () => countLines(richText?.text) >= MAX_POST_LINES, @@ -128,7 +127,7 @@ function PostInner({ replyAuthorDid = urip.hostname } - const onPressReply = React.useCallback(() => { + const onPressReply = useCallback(() => { openComposer({ replyTo: { uri: post.uri, @@ -141,18 +140,18 @@ function PostInner({ }) }, [openComposer, post, record, moderation]) - const onPressShowMore = React.useCallback(() => { + const onPressShowMore = useCallback(() => { setLimitLines(false) }, [setLimitLines]) - const onBeforePress = React.useCallback(() => { + const onBeforePress = useCallback(() => { precacheProfile(queryClient, post.author) }, [queryClient, post.author]) const {currentAccount} = useSession() const isMe = replyAuthorDid === currentAccount?.did - const [hover, setHover] = React.useState(false) + const [hover, setHover] = useState(false) return ( <Link href={itemHref} @@ -227,7 +226,7 @@ function PostInner({ style={[a.py_xs]} /> {richText.text ? ( - <View style={styles.postTextContainer}> + <View> <RichText enableTags testID="postText" @@ -237,16 +236,14 @@ function PostInner({ authorHandle={post.author.handle} shouldProxyLinks={true} /> + {limitLines && ( + <ShowMoreTextButton + style={[a.text_md]} + onPress={onPressShowMore} + /> + )} </View> ) : undefined} - {limitLines ? ( - <TextLink - text={_(msg`Show More`)} - style={pal.link} - onPress={onPressShowMore} - href="#" - /> - ) : undefined} {post.embed ? ( <Embed embed={post.embed} @@ -290,12 +287,6 @@ const styles = StyleSheet.create({ alert: { marginBottom: 6, }, - postTextContainer: { - flexDirection: 'row', - alignItems: 'center', - flexWrap: 'wrap', - overflow: 'hidden', - }, replyLine: { position: 'absolute', left: 36, |