mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-30 18:33:30 +00:00 
			
		
		
		
	 7753ba2d37
			
		
	
	
		7753ba2d37
		
			
		
	
	
	
	
		
			
			Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Yeuoly <admin@srmxy.cn> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: StyleZhang <jasonapring2015@outlook.com> Co-authored-by: jyong <jyong@dify.ai> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: jyong <718720800@qq.com>
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   memo,
 | |
|   useCallback,
 | |
|   useEffect,
 | |
| } from 'react'
 | |
| import { $applyNodeReplacement } from 'lexical'
 | |
| import { mergeRegister } from '@lexical/utils'
 | |
| import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'
 | |
| import { decoratorTransform } from '../../utils'
 | |
| import { QUERY_PLACEHOLDER_TEXT } from '../../constants'
 | |
| import type { QueryBlockType } from '../../types'
 | |
| import {
 | |
|   $createQueryBlockNode,
 | |
|   QueryBlockNode,
 | |
| } from '../query-block/node'
 | |
| import { CustomTextNode } from '../custom-text/node'
 | |
| 
 | |
| const REGEX = new RegExp(QUERY_PLACEHOLDER_TEXT)
 | |
| 
 | |
| const QueryBlockReplacementBlock = ({
 | |
|   onInsert,
 | |
| }: QueryBlockType) => {
 | |
|   const [editor] = useLexicalComposerContext()
 | |
| 
 | |
|   useEffect(() => {
 | |
|     if (!editor.hasNodes([QueryBlockNode]))
 | |
|       throw new Error('QueryBlockNodePlugin: QueryBlockNode not registered on editor')
 | |
|   }, [editor])
 | |
| 
 | |
|   const createQueryBlockNode = useCallback((): QueryBlockNode => {
 | |
|     if (onInsert)
 | |
|       onInsert()
 | |
|     return $applyNodeReplacement($createQueryBlockNode())
 | |
|   }, [onInsert])
 | |
| 
 | |
|   const getMatch = useCallback((text: string) => {
 | |
|     const matchArr = REGEX.exec(text)
 | |
| 
 | |
|     if (matchArr === null)
 | |
|       return null
 | |
| 
 | |
|     const startOffset = matchArr.index
 | |
|     const endOffset = startOffset + QUERY_PLACEHOLDER_TEXT.length
 | |
|     return {
 | |
|       end: endOffset,
 | |
|       start: startOffset,
 | |
|     }
 | |
|   }, [])
 | |
| 
 | |
|   useEffect(() => {
 | |
|     REGEX.lastIndex = 0
 | |
|     return mergeRegister(
 | |
|       editor.registerNodeTransform(CustomTextNode, textNode => decoratorTransform(textNode, getMatch, createQueryBlockNode)),
 | |
|     )
 | |
|   }, [])
 | |
| 
 | |
|   return null
 | |
| }
 | |
| 
 | |
| export default memo(QueryBlockReplacementBlock)
 |