Remove unnecessary .trimEnd() and fix facet detection (#3672)
				
					
				
			* Fix link facet detection Exclude the trailing period from the link, similar as done in the atproto package * Fix JSON to text conversion The trimEnd() call was only needed because we were always appending \n\n at the end. Fix that by only adding line breaks after non-final paragraphs. * Detect paste reliably --------- Co-authored-by: Dan Abramov <dan.abramov@gmail.com>
This commit is contained in:
		
							parent
							
								
									05beb1bbad
								
							
						
					
					
						commit
						b3df0b177f
					
				
					 2 changed files with 25 additions and 14 deletions
				
			
		|  | @ -61,7 +61,6 @@ export const TextInput = React.forwardRef(function TextInputImpl( | |||
|   ref, | ||||
| ) { | ||||
|   const autocomplete = useActorAutocompleteFn() | ||||
|   const prevLength = React.useRef(0) | ||||
|   const prevAddedLinks = useRef(new Set<string>()) | ||||
| 
 | ||||
|   const pal = usePalette('default') | ||||
|  | @ -185,8 +184,8 @@ export const TextInput = React.forwardRef(function TextInputImpl( | |||
|       }, | ||||
|       onUpdate({editor: editorProp}) { | ||||
|         const json = editorProp.getJSON() | ||||
|         const newText = editorJsonToText(json).trimEnd() | ||||
|         const mayBePaste = newText.length > prevLength.current + 1 | ||||
|         const newText = editorJsonToText(json) | ||||
|         const mayBePaste = window.event?.type === 'paste' | ||||
| 
 | ||||
|         const newRt = new RichText({text: newText}) | ||||
|         newRt.detectFacetsWithoutResolution() | ||||
|  | @ -219,8 +218,6 @@ export const TextInput = React.forwardRef(function TextInputImpl( | |||
|             prevAddedLinks.current.delete(uri) | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         prevLength.current = newText.length | ||||
|       }, | ||||
|     }, | ||||
|     [modeClass], | ||||
|  | @ -277,15 +274,29 @@ export const TextInput = React.forwardRef(function TextInputImpl( | |||
|   ) | ||||
| }) | ||||
| 
 | ||||
| function editorJsonToText(json: JSONContent): string { | ||||
| function editorJsonToText( | ||||
|   json: JSONContent, | ||||
|   isLastDocumentChild: boolean = false, | ||||
| ): string { | ||||
|   let text = '' | ||||
|   if (json.type === 'doc' || json.type === 'paragraph') { | ||||
|   if (json.type === 'doc') { | ||||
|     if (json.content?.length) { | ||||
|       for (const node of json.content) { | ||||
|       for (let i = 0; i < json.content.length; i++) { | ||||
|         const node = json.content[i] | ||||
|         const isLastNode = i === json.content.length - 1 | ||||
|         text += editorJsonToText(node, isLastNode) | ||||
|       } | ||||
|     } | ||||
|   } else if (json.type === 'paragraph') { | ||||
|     if (json.content?.length) { | ||||
|       for (let i = 0; i < json.content.length; i++) { | ||||
|         const node = json.content[i] | ||||
|         text += editorJsonToText(node) | ||||
|       } | ||||
|     } | ||||
|     text += '\n' | ||||
|     if (!isLastDocumentChild) { | ||||
|       text += '\n' | ||||
|     } | ||||
|   } else if (json.type === 'hardBreak') { | ||||
|     text += '\n' | ||||
|   } else if (json.type === 'text') { | ||||
|  |  | |||
|  | @ -14,11 +14,11 @@ | |||
|  * the facet-set. | ||||
|  */ | ||||
| 
 | ||||
| import {Mark} from '@tiptap/core' | ||||
| import {Plugin, PluginKey} from '@tiptap/pm/state' | ||||
| import {Node as ProsemirrorNode} from '@tiptap/pm/model' | ||||
| import {Decoration, DecorationSet} from '@tiptap/pm/view' | ||||
| import {URL_REGEX} from '@atproto/api' | ||||
| import {Mark} from '@tiptap/core' | ||||
| import {Node as ProsemirrorNode} from '@tiptap/pm/model' | ||||
| import {Plugin, PluginKey} from '@tiptap/pm/state' | ||||
| import {Decoration, DecorationSet} from '@tiptap/pm/view' | ||||
| 
 | ||||
| import {isValidDomain} from 'lib/strings/url-helpers' | ||||
| 
 | ||||
|  | @ -91,7 +91,7 @@ function iterateUris(str: string, cb: (from: number, to: number) => void) { | |||
|       uri = `https://${uri}` | ||||
|     } | ||||
|     let from = str.indexOf(match[2], match.index) | ||||
|     let to = from + match[2].length + 1 | ||||
|     let to = from + match[2].length | ||||
|     // strip ending puncuation
 | ||||
|     if (/[.,;!?]$/.test(uri)) { | ||||
|       uri = uri.slice(0, -1) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue