Remove dangerous derived state from RichText (#3007)
* Remove facet resolution from RichText * Remove derived state
This commit is contained in:
		
							parent
							
								
									603f3c0be9
								
							
						
					
					
						commit
						2d14d0e2db
					
				
					 2 changed files with 8 additions and 23 deletions
				
			
		|  | @ -7,7 +7,6 @@ import {atoms as a, TextStyleProp, flatten, useTheme, web, native} from '#/alf' | |||
| import {InlineLink} from '#/components/Link' | ||||
| import {Text, TextProps} from '#/components/Typography' | ||||
| import {toShortUrl} from 'lib/strings/url-helpers' | ||||
| import {getAgent} from '#/state/session' | ||||
| import {TagMenu, useTagMenuControl} from '#/components/TagMenu' | ||||
| import {isNative} from '#/platform/detection' | ||||
| import {useInteractionState} from '#/components/hooks/useInteractionState' | ||||
|  | @ -20,7 +19,6 @@ export function RichText({ | |||
|   style, | ||||
|   numberOfLines, | ||||
|   disableLinks, | ||||
|   resolveFacets = false, | ||||
|   selectable, | ||||
|   enableTags = false, | ||||
|   authorHandle, | ||||
|  | @ -30,31 +28,16 @@ export function RichText({ | |||
|     testID?: string | ||||
|     numberOfLines?: number | ||||
|     disableLinks?: boolean | ||||
|     resolveFacets?: boolean | ||||
|     enableTags?: boolean | ||||
|     authorHandle?: string | ||||
|   }) { | ||||
|   const detected = React.useRef(false) | ||||
|   const [richText, setRichText] = React.useState<RichTextAPI>(() => | ||||
|   const richText = React.useMemo( | ||||
|     () => | ||||
|       value instanceof RichTextAPI ? value : new RichTextAPI({text: value}), | ||||
|     [value], | ||||
|   ) | ||||
|   const styles = [a.leading_snug, flatten(style)] | ||||
| 
 | ||||
|   React.useEffect(() => { | ||||
|     if (!resolveFacets) return | ||||
| 
 | ||||
|     async function detectFacets() { | ||||
|       const rt = new RichTextAPI({text: richText.text}) | ||||
|       await rt.detectFacets(getAgent()) | ||||
|       setRichText(rt) | ||||
|     } | ||||
| 
 | ||||
|     if (!detected.current) { | ||||
|       detected.current = true | ||||
|       detectFacets() | ||||
|     } | ||||
|   }, [richText, setRichText, resolveFacets]) | ||||
| 
 | ||||
|   const {text, facets} = richText | ||||
| 
 | ||||
|   if (!facets?.length) { | ||||
|  |  | |||
|  | @ -22,12 +22,14 @@ export function Typography() { | |||
|       <Text style={[a.text_2xs]}>atoms.text_2xs</Text> | ||||
| 
 | ||||
|       <RichText | ||||
|         resolveFacets | ||||
|         // TODO: This only supports already resolved facets.
 | ||||
|         // Resolving them on read is bad anyway.
 | ||||
|         value={`This is rich text. It can have mentions like @bsky.app or links like https://bsky.social`} | ||||
|       /> | ||||
|       <RichText | ||||
|         selectable | ||||
|         resolveFacets | ||||
|         // TODO: This only supports already resolved facets.
 | ||||
|         // Resolving them on read is bad anyway.
 | ||||
|         value={`This is rich text. It can have mentions like @bsky.app or links like https://bsky.social`} | ||||
|         style={[a.text_xl]} | ||||
|       /> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue