fix(core): InputRules does not work for ranges containing multiple text nodes (#3205)
* fix: InputRules does not work for ranges containing multiple text nodes. #3071 * chore: rename `to` to `sliceEndPos`
This commit is contained in:
@@ -3,13 +3,17 @@ import { ResolvedPos } from 'prosemirror-model'
|
|||||||
export const getTextContentFromNodes = ($from: ResolvedPos, maxMatch = 500) => {
|
export const getTextContentFromNodes = ($from: ResolvedPos, maxMatch = 500) => {
|
||||||
let textBefore = ''
|
let textBefore = ''
|
||||||
|
|
||||||
|
const sliceEndPos = $from.parentOffset
|
||||||
|
|
||||||
$from.parent.nodesBetween(
|
$from.parent.nodesBetween(
|
||||||
Math.max(0, $from.parentOffset - maxMatch),
|
Math.max(0, sliceEndPos - maxMatch),
|
||||||
$from.parentOffset,
|
sliceEndPos,
|
||||||
(node, pos, parent, index) => {
|
(node, pos, parent, index) => {
|
||||||
textBefore += node.type.spec.toText?.({
|
const chunk = node.type.spec.toText?.({
|
||||||
node, pos, parent, index,
|
node, pos, parent, index,
|
||||||
}) || $from.nodeBefore?.text || '%leaf%'
|
}) || node.textContent || '%leaf%'
|
||||||
|
|
||||||
|
textBefore += chunk.slice(0, Math.max(0, sliceEndPos - pos))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user