| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { $insertNodes } from 'lexical' | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  | import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext' | 
					
						
							|  |  |  | import { textToEditorState } from '../utils' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { CustomTextNode } from './custom-text/node' | 
					
						
							|  |  |  | import { CLEAR_HIDE_MENU_TIMEOUT } from './workflow-variable-block' | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  | import { useEventEmitterContextContext } from '@/context/event-emitter' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER = 'PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | export const PROMPT_EDITOR_INSERT_QUICKLY = 'PROMPT_EDITOR_INSERT_QUICKLY' | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | type UpdateBlockProps = { | 
					
						
							|  |  |  |   instanceId?: string | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | const UpdateBlock = ({ | 
					
						
							|  |  |  |   instanceId, | 
					
						
							|  |  |  | }: UpdateBlockProps) => { | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  |   const { eventEmitter } = useEventEmitterContextContext() | 
					
						
							|  |  |  |   const [editor] = useLexicalComposerContext() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   eventEmitter?.useSubscription((v: any) => { | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     if (v.type === PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER && v.instanceId === instanceId) { | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  |       const editorState = editor.parseEditorState(textToEditorState(v.payload)) | 
					
						
							|  |  |  |       editor.setEditorState(editorState) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   eventEmitter?.useSubscription((v: any) => { | 
					
						
							|  |  |  |     if (v.type === PROMPT_EDITOR_INSERT_QUICKLY && v.instanceId === instanceId) { | 
					
						
							|  |  |  |       editor.focus() | 
					
						
							|  |  |  |       editor.update(() => { | 
					
						
							|  |  |  |         const textNode = new CustomTextNode('/') | 
					
						
							|  |  |  |         $insertNodes([textNode]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         editor.dispatchCommand(CLEAR_HIDE_MENU_TIMEOUT, undefined) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-09 18:36:58 +08:00
										 |  |  |   return null | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default UpdateBlock |