| 12345678910111213141516171819202122232425262728293031323334353637383940414243 | import { $insertNodes } from 'lexical'import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'import { textToEditorState } from '../utils'import { CustomTextNode } from './custom-text/node'import { CLEAR_HIDE_MENU_TIMEOUT } from './workflow-variable-block'import { useEventEmitterContextContext } from '@/context/event-emitter'export const PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER = 'PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER'export const PROMPT_EDITOR_INSERT_QUICKLY = 'PROMPT_EDITOR_INSERT_QUICKLY'type UpdateBlockProps = {  instanceId?: string}const UpdateBlock = ({  instanceId,}: UpdateBlockProps) => {  const { eventEmitter } = useEventEmitterContextContext()  const [editor] = useLexicalComposerContext()  eventEmitter?.useSubscription((v: any) => {    if (v.type === PROMPT_EDITOR_UPDATE_VALUE_BY_EVENT_EMITTER && v.instanceId === instanceId) {      const editorState = editor.parseEditorState(textToEditorState(v.payload))      editor.setEditorState(editorState)    }  })  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)      })    }  })  return null}export default UpdateBlock
 |