import React from 'react' import {TextStyle} from 'react-native' import {AppBskyRichtextFacet, RichText as RichTextAPI} from '@atproto/api' import {toShortUrl} from '#/lib/strings/url-helpers' import {atoms as a, flatten, TextStyleProp} from '#/alf' import {isOnlyEmoji} from '#/alf/typography' import {InlineLinkText, LinkProps} from '#/components/Link' import {ProfileHoverCard} from '#/components/ProfileHoverCard' import {RichTextTag} from '#/components/RichTextTag' import {Text, TextProps} from '#/components/Typography' const WORD_WRAP = {wordWrap: 1} export type RichTextProps = TextStyleProp & Pick & { value: RichTextAPI | string testID?: string numberOfLines?: number disableLinks?: boolean enableTags?: boolean authorHandle?: string onLinkPress?: LinkProps['onPress'] interactiveStyle?: TextStyle emojiMultiplier?: number shouldProxyLinks?: boolean } export function RichText({ testID, value, style, numberOfLines, disableLinks, selectable, enableTags = false, authorHandle, onLinkPress, interactiveStyle, emojiMultiplier = 1.85, onLayout, onTextLayout, shouldProxyLinks, }: RichTextProps) { const richText = React.useMemo( () => value instanceof RichTextAPI ? value : new RichTextAPI({text: value}), [value], ) const flattenedStyle = flatten(style) const plainStyles = [a.leading_snug, flattenedStyle] const interactiveStyles = [ a.leading_snug, flatten(interactiveStyle), flattenedStyle, ] const {text, facets} = richText if (!facets?.length) { if (isOnlyEmoji(text)) { const fontSize = (flattenedStyle.fontSize ?? a.text_sm.fontSize) * emojiMultiplier return ( {text} ) } return ( {text} ) } const els = [] let key = 0 // N.B. must access segments via `richText.segments`, not via destructuring for (const segment of richText.segments()) { const link = segment.link const mention = segment.mention const tag = segment.tag if ( mention && AppBskyRichtextFacet.validateMention(mention).success && !disableLinks ) { els.push( {segment.text} , ) } else if (link && AppBskyRichtextFacet.validateLink(link).success) { if (disableLinks) { els.push(toShortUrl(segment.text)) } else { els.push( {toShortUrl(segment.text)} , ) } } else if ( !disableLinks && enableTags && tag && AppBskyRichtextFacet.validateTag(tag).success ) { els.push( , ) } else { els.push(segment.text) } key++ } return ( {els} ) }