import type { FC } from 'react' import { useCallback, useEffect, } from 'react' import { $applyNodeReplacement } from 'lexical' import { mergeRegister } from '@lexical/utils' import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext' import { decoratorTransform } from '../utils' import { HISTORY_PLACEHOLDER_TEXT } from '../constants' import { $createHistoryBlockNode, HistoryBlockNode, } from './history-block/node' import type { HistoryBlockProps } from './history-block/index' import { CustomTextNode } from './custom-text/node' const REGEX = new RegExp(HISTORY_PLACEHOLDER_TEXT) const HistoryBlockReplacementBlock: FC = ({ roleName, onEditRole, onInsert, }) => { const [editor] = useLexicalComposerContext() useEffect(() => { if (!editor.hasNodes([HistoryBlockNode])) throw new Error('HistoryBlockNodePlugin: HistoryBlockNode not registered on editor') }, [editor]) const createHistoryBlockNode = useCallback((): HistoryBlockNode => { if (onInsert) onInsert() return $applyNodeReplacement($createHistoryBlockNode(roleName, onEditRole)) }, [roleName, onEditRole, onInsert]) const getMatch = useCallback((text: string) => { const matchArr = REGEX.exec(text) if (matchArr === null) return null const startOffset = matchArr.index const endOffset = startOffset + HISTORY_PLACEHOLDER_TEXT.length return { end: endOffset, start: startOffset, } }, []) useEffect(() => { return mergeRegister( editor.registerNodeTransform(CustomTextNode, textNode => decoratorTransform(textNode, getMatch, createHistoryBlockNode)), ) }, []) return null } export default HistoryBlockReplacementBlock