mirror of
https://github.com/ueberdosis/tiptap.git
synced 2025-06-07 17:43:49 +08:00
revert: reverts a52118c34b
to fix centering extension issue #5254
https://github.com/ueberdosis/tiptap/issues/5254
This commit is contained in:
parent
9ec0cd550a
commit
1175b9c110
@ -1,7 +1,4 @@
|
|||||||
import {
|
import { MarkType, NodeType } from '@tiptap/pm/model'
|
||||||
Mark, MarkType, Node, NodeType,
|
|
||||||
} from '@tiptap/pm/model'
|
|
||||||
import { SelectionRange } from '@tiptap/pm/state'
|
|
||||||
|
|
||||||
import { getMarkType } from '../helpers/getMarkType.js'
|
import { getMarkType } from '../helpers/getMarkType.js'
|
||||||
import { getNodeType } from '../helpers/getNodeType.js'
|
import { getNodeType } from '../helpers/getNodeType.js'
|
||||||
@ -54,49 +51,37 @@ export const updateAttributes: RawCommands['updateAttributes'] = (typeOrName, at
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (dispatch) {
|
if (dispatch) {
|
||||||
let lastPos: number | undefined
|
tr.selection.ranges.forEach(range => {
|
||||||
let lastNode: Node | undefined
|
|
||||||
let trimmedFrom: number
|
|
||||||
let trimmedTo: number
|
|
||||||
|
|
||||||
tr.selection.ranges.forEach((range: SelectionRange) => {
|
|
||||||
const from = range.$from.pos
|
const from = range.$from.pos
|
||||||
const to = range.$to.pos
|
const to = range.$to.pos
|
||||||
|
|
||||||
state.doc.nodesBetween(from, to, (node: Node, pos: number) => {
|
state.doc.nodesBetween(from, to, (node, pos) => {
|
||||||
if (nodeType && nodeType === node.type) {
|
if (nodeType && nodeType === node.type) {
|
||||||
trimmedFrom = Math.max(pos, from)
|
tr.setNodeMarkup(pos, undefined, {
|
||||||
trimmedTo = Math.min(pos + node.nodeSize, to)
|
...node.attrs,
|
||||||
lastPos = pos
|
...attributes,
|
||||||
lastNode = node
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if (markType && node.marks.length) {
|
||||||
|
node.marks.forEach(mark => {
|
||||||
|
if (markType === mark.type) {
|
||||||
|
const trimmedFrom = Math.max(pos, from)
|
||||||
|
const trimmedTo = Math.min(pos + node.nodeSize, to)
|
||||||
|
|
||||||
|
tr.addMark(
|
||||||
|
trimmedFrom,
|
||||||
|
trimmedTo,
|
||||||
|
markType.create({
|
||||||
|
...mark.attrs,
|
||||||
|
...attributes,
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
if (lastNode) {
|
|
||||||
|
|
||||||
if (lastPos !== undefined) {
|
|
||||||
tr.setNodeMarkup(lastPos, undefined, {
|
|
||||||
...lastNode.attrs,
|
|
||||||
...attributes,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if (markType && lastNode.marks.length) {
|
|
||||||
lastNode.marks.forEach((mark: Mark) => {
|
|
||||||
if (markType === mark.type) {
|
|
||||||
tr.addMark(
|
|
||||||
trimmedFrom,
|
|
||||||
trimmedTo,
|
|
||||||
markType.create({
|
|
||||||
...mark.attrs,
|
|
||||||
...attributes,
|
|
||||||
}),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
|
Loading…
Reference in New Issue
Block a user