fixed edge formatting case
This commit is contained in:
parent
04009f0d42
commit
2d1e3fde43
@ -338,14 +338,16 @@ const formatText = (transaction, parent, currPos, length, attributes) => {
|
|||||||
*
|
*
|
||||||
* @param {Transaction} transaction
|
* @param {Transaction} transaction
|
||||||
* @param {Item} start
|
* @param {Item} start
|
||||||
* @param {Item|null} end exclusive end, automatically iterates to the next Content Item
|
* @param {Item|null} curr exclusive end, automatically iterates to the next Content Item
|
||||||
* @param {Map<string,any>} startAttributes
|
* @param {Map<string,any>} startAttributes
|
||||||
* @param {Map<string,any>} endAttributes This attribute is modified!
|
* @param {Map<string,any>} currAttributes
|
||||||
* @return {number} The amount of formatting Items deleted.
|
* @return {number} The amount of formatting Items deleted.
|
||||||
*
|
*
|
||||||
* @function
|
* @function
|
||||||
*/
|
*/
|
||||||
const cleanupFormattingGap = (transaction, start, end, startAttributes, endAttributes) => {
|
const cleanupFormattingGap = (transaction, start, curr, startAttributes, currAttributes) => {
|
||||||
|
let end = curr
|
||||||
|
const endAttributes = map.copy(currAttributes)
|
||||||
while (end && (!end.countable || end.deleted)) {
|
while (end && (!end.countable || end.deleted)) {
|
||||||
if (!end.deleted && end.content.constructor === ContentFormat) {
|
if (!end.deleted && end.content.constructor === ContentFormat) {
|
||||||
updateCurrentAttributes(endAttributes, /** @type {ContentFormat} */ (end.content))
|
updateCurrentAttributes(endAttributes, /** @type {ContentFormat} */ (end.content))
|
||||||
@ -353,7 +355,11 @@ const cleanupFormattingGap = (transaction, start, end, startAttributes, endAttri
|
|||||||
end = end.right
|
end = end.right
|
||||||
}
|
}
|
||||||
let cleanups = 0
|
let cleanups = 0
|
||||||
|
let reachedEndOfCurr = false
|
||||||
while (start !== end) {
|
while (start !== end) {
|
||||||
|
if (curr === start) {
|
||||||
|
reachedEndOfCurr = true
|
||||||
|
}
|
||||||
if (!start.deleted) {
|
if (!start.deleted) {
|
||||||
const content = start.content
|
const content = start.content
|
||||||
switch (content.constructor) {
|
switch (content.constructor) {
|
||||||
@ -363,6 +369,9 @@ const cleanupFormattingGap = (transaction, start, end, startAttributes, endAttri
|
|||||||
// Either this format is overwritten or it is not necessary because the attribute already existed.
|
// Either this format is overwritten or it is not necessary because the attribute already existed.
|
||||||
start.delete(transaction)
|
start.delete(transaction)
|
||||||
cleanups++
|
cleanups++
|
||||||
|
if (!reachedEndOfCurr && (currAttributes.get(key) || null) === value) {
|
||||||
|
currAttributes.delete(key)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user