UNPKG

@tiptap/core

Version:

headless rich text editor

37 lines (30 loc) 883 B
import { InputRule, InputRuleFinder } from '../InputRule.js' /** * Build an input rule that replaces text when the * matched text is typed into it. * @see https://tiptap.dev/guide/custom-extensions/#input-rules */ export function textInputRule(config: { find: InputRuleFinder, replace: string, }) { return new InputRule({ find: config.find, handler: ({ state, range, match }) => { let insert = config.replace let start = range.from const end = range.to if (match[1]) { const offset = match[0].lastIndexOf(match[1]) insert += match[0].slice(offset + match[1].length) start += offset const cutOff = start - end if (cutOff > 0) { insert = match[0].slice(offset - cutOff, offset) + insert start = end } } state.tr.insertText(insert, start, end) }, }) }