Simplify rich text to string parsing logic
This commit is contained in:
		
							parent
							
								
									8bb9885aee
								
							
						
					
					
						commit
						863cc5653f
					
				|  | @ -51,8 +51,8 @@ export function parseMentions(data: JSONContent): string[] { | |||
|   return uniq(mentions) | ||||
| } | ||||
| 
 | ||||
| // can't just do [StarterKit, Image...] because it doesn't work with cjs imports
 | ||||
| const stringParseExts = [ | ||||
|   // StarterKit extensions
 | ||||
|   Blockquote, | ||||
|   Bold, | ||||
|   BulletList, | ||||
|  | @ -69,38 +69,20 @@ const stringParseExts = [ | |||
|   Paragraph, | ||||
|   Strike, | ||||
|   Text, | ||||
| 
 | ||||
|   Image, | ||||
|   // other extensions
 | ||||
|   Link, | ||||
|   Image.extend({ renderText: () => '[image]' }), | ||||
|   Mention, // user @mention
 | ||||
|   Mention.extend({ name: 'contract-mention' }), // market %mention
 | ||||
|   Iframe, | ||||
|   TiptapTweet, | ||||
|   TiptapSpoiler, | ||||
|   Iframe.extend({ | ||||
|     renderText: ({ node }) => | ||||
|       '[embed]' + node.attrs.src ? `(${node.attrs.src})` : '', | ||||
|   }), | ||||
|   TiptapTweet.extend({ renderText: () => '[tweet]' }), | ||||
|   TiptapSpoiler.extend({ renderHTML: () => ['span', '[spoiler]', 0] }), | ||||
| ] | ||||
| 
 | ||||
| export function richTextToString(text?: JSONContent) { | ||||
|   if (!text) return '' | ||||
|   // remove spoiler tags.
 | ||||
|   const newText = cloneDeep(text) | ||||
|   dfs(newText, (current) => { | ||||
|     if (current.marks?.some((m) => m.type === TiptapSpoiler.name)) { | ||||
|       current.text = '[spoiler]' | ||||
|     } else if (current.type === 'image') { | ||||
|       current.text = '[Image]' | ||||
|       // This is a hack, I've no idea how to change a tiptap extenstion's schema
 | ||||
|       current.type = 'text' | ||||
|     } else if (current.type === 'iframe') { | ||||
|       const src = current.attrs?.['src'] ? current.attrs['src'] : '' | ||||
|       current.text = '[Iframe]' + (src ? ` url:${src}` : '') | ||||
|       // This is a hack, I've no idea how to change a tiptap extenstion's schema
 | ||||
|       current.type = 'text' | ||||
|     } | ||||
|   }) | ||||
|   return generateText(newText, stringParseExts) | ||||
| } | ||||
| 
 | ||||
| const dfs = (data: JSONContent, f: (current: JSONContent) => any) => { | ||||
|   data.content?.forEach((d) => dfs(d, f)) | ||||
|   f(data) | ||||
|   return generateText(text, stringParseExts) | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user