Spaces:
Running
Running
import { useEffect } from 'react' | |
import { | |
$insertNodes, | |
COMMAND_PRIORITY_EDITOR, | |
createCommand, | |
} from 'lexical' | |
import { mergeRegister } from '@lexical/utils' | |
import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext' | |
import { CustomTextNode } from '../custom-text/node' | |
export const INSERT_VARIABLE_BLOCK_COMMAND = createCommand('INSERT_VARIABLE_BLOCK_COMMAND') | |
export const INSERT_VARIABLE_VALUE_BLOCK_COMMAND = createCommand('INSERT_VARIABLE_VALUE_BLOCK_COMMAND') | |
const VariableBlock = () => { | |
const [editor] = useLexicalComposerContext() | |
useEffect(() => { | |
return mergeRegister( | |
editor.registerCommand( | |
INSERT_VARIABLE_BLOCK_COMMAND, | |
() => { | |
const textNode = new CustomTextNode('{') | |
$insertNodes([textNode]) | |
return true | |
}, | |
COMMAND_PRIORITY_EDITOR, | |
), | |
editor.registerCommand( | |
INSERT_VARIABLE_VALUE_BLOCK_COMMAND, | |
(value: string) => { | |
const textNode = new CustomTextNode(value) | |
$insertNodes([textNode]) | |
return true | |
}, | |
COMMAND_PRIORITY_EDITOR, | |
), | |
) | |
}, [editor]) | |
return null | |
} | |
export default VariableBlock | |