diff options
author | Samuel Newman <mozzius@protonmail.com> | 2024-05-31 22:57:42 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-05-31 20:57:42 +0100 |
commit | b51640fbc099a1e9df1430b5a05bf913495008b7 (patch) | |
tree | cc772e1d303230d384b47ea19ec3dce9af8ee5ad /src/components/RichText.tsx | |
parent | 5cda807d9dcdbc5ed5dbb51a9c43123d60734c8a (diff) | |
download | voidsky-b51640fbc099a1e9df1430b5a05bf913495008b7.tar.zst |
[🐴] add emoji multiplier prop to RichText and bump it up for DMs (#4229)
* add emoji multiplier prop to RichText and bump it up for DMs * remove background if only emoji * Handle more emoji * Adjust emoji regex and length * Fix bad merge conflict res * Fix logic * Revert to emoji specific regex --------- Co-authored-by: Eric Bailey <git@esb.lol>
Diffstat (limited to 'src/components/RichText.tsx')
-rw-r--r-- | src/components/RichText.tsx | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/src/components/RichText.tsx b/src/components/RichText.tsx index ed69c199a..9ba44eabe 100644 --- a/src/components/RichText.tsx +++ b/src/components/RichText.tsx @@ -28,6 +28,7 @@ export function RichText({ authorHandle, onLinkPress, interactiveStyle, + emojiMultiplier = 1.85, }: TextStyleProp & Pick<TextProps, 'selectable'> & { value: RichTextAPI | string @@ -38,6 +39,7 @@ export function RichText({ authorHandle?: string onLinkPress?: LinkProps['onPress'] interactiveStyle?: TextStyle + emojiMultiplier?: number }) { const richText = React.useMemo( () => @@ -57,17 +59,14 @@ export function RichText({ const {text, facets} = richText if (!facets?.length) { - if (text.length <= 5 && /^\p{Extended_Pictographic}+$/u.test(text)) { + if (isOnlyEmoji(text)) { + const fontSize = + (flattenedStyle.fontSize ?? a.text_sm.fontSize) * emojiMultiplier return ( <Text selectable={selectable} testID={testID} - style={[ - { - fontSize: 26, - lineHeight: 30, - }, - ]} + style={[plainStyles, {fontSize}]} // @ts-ignore web only -prf dataSet={WORD_WRAP}> {text} @@ -247,3 +246,10 @@ function RichTextTag({ </React.Fragment> ) } + +export function isOnlyEmoji(text: string) { + return ( + text.length <= 15 && + /^[\p{Emoji_Presentation}\p{Extended_Pictographic}]+$/u.test(text) + ) +} |