mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-05 06:10:07 -05:00
Fix inserting partial inlines in insertTreeFragmentIntoRange
Needs to account for browser "<br>"s inside blocks.
This commit is contained in:
parent
a1ff33da9f
commit
e90f18dba9
3 changed files with 22 additions and 10 deletions
|
@ -805,13 +805,16 @@ var insertTreeFragmentIntoRange = function ( range, frag ) {
|
||||||
endContainer = nodeAfterSplit,
|
endContainer = nodeAfterSplit,
|
||||||
endOffset = 0,
|
endOffset = 0,
|
||||||
parent = nodeAfterSplit.parentNode,
|
parent = nodeAfterSplit.parentNode,
|
||||||
child, node, prev, next;
|
child, node, prev, next, startAnchor;
|
||||||
|
|
||||||
// 2. Move down into edge either side of split and insert any inline
|
// 2. Move down into edge either side of split and insert any inline
|
||||||
// nodes at the beginning/end of the fragment
|
// nodes at the beginning/end of the fragment
|
||||||
while ( ( child = startContainer.lastChild ) &&
|
while ( ( child = startContainer.lastChild ) &&
|
||||||
child.nodeType === ELEMENT_NODE &&
|
child.nodeType === ELEMENT_NODE ) {
|
||||||
child.nodeName !== 'BR' ) {
|
if ( child.nodeName === 'BR' ) {
|
||||||
|
startOffset -= 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
startContainer = child;
|
startContainer = child;
|
||||||
startOffset = startContainer.childNodes.length;
|
startOffset = startContainer.childNodes.length;
|
||||||
}
|
}
|
||||||
|
@ -820,8 +823,9 @@ var insertTreeFragmentIntoRange = function ( range, frag ) {
|
||||||
child.nodeName !== 'BR' ) {
|
child.nodeName !== 'BR' ) {
|
||||||
endContainer = child;
|
endContainer = child;
|
||||||
}
|
}
|
||||||
|
startAnchor = startContainer.childNodes[ startOffset ] || null;
|
||||||
while ( ( child = frag.firstChild ) && isInline( child ) ) {
|
while ( ( child = frag.firstChild ) && isInline( child ) ) {
|
||||||
startContainer.appendChild( child );
|
startContainer.insertBefore( child, startAnchor );
|
||||||
}
|
}
|
||||||
while ( ( child = frag.lastChild ) && isInline( child ) ) {
|
while ( ( child = frag.lastChild ) && isInline( child ) ) {
|
||||||
endContainer.insertBefore( child, endContainer.firstChild );
|
endContainer.insertBefore( child, endContainer.firstChild );
|
||||||
|
@ -1049,6 +1053,7 @@ var rangeDoesStartAtBlockBoundary = function ( range ) {
|
||||||
startOffset = range.startOffset;
|
startOffset = range.startOffset;
|
||||||
|
|
||||||
// If in the middle or end of a text node, we're not at the boundary.
|
// If in the middle or end of a text node, we're not at the boundary.
|
||||||
|
contentWalker.root = null;
|
||||||
if ( startContainer.nodeType === TEXT_NODE ) {
|
if ( startContainer.nodeType === TEXT_NODE ) {
|
||||||
if ( startOffset ) {
|
if ( startOffset ) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1071,6 +1076,7 @@ var rangeDoesEndAtBlockBoundary = function ( range ) {
|
||||||
|
|
||||||
// If in a text node with content, and not at the end, we're not
|
// If in a text node with content, and not at the end, we're not
|
||||||
// at the boundary
|
// at the boundary
|
||||||
|
contentWalker.root = null;
|
||||||
if ( endContainer.nodeType === TEXT_NODE ) {
|
if ( endContainer.nodeType === TEXT_NODE ) {
|
||||||
length = endContainer.data.length;
|
length = endContainer.data.length;
|
||||||
if ( length && endOffset < length ) {
|
if ( length && endOffset < length ) {
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -204,13 +204,16 @@ var insertTreeFragmentIntoRange = function ( range, frag ) {
|
||||||
endContainer = nodeAfterSplit,
|
endContainer = nodeAfterSplit,
|
||||||
endOffset = 0,
|
endOffset = 0,
|
||||||
parent = nodeAfterSplit.parentNode,
|
parent = nodeAfterSplit.parentNode,
|
||||||
child, node, prev, next;
|
child, node, prev, next, startAnchor;
|
||||||
|
|
||||||
// 2. Move down into edge either side of split and insert any inline
|
// 2. Move down into edge either side of split and insert any inline
|
||||||
// nodes at the beginning/end of the fragment
|
// nodes at the beginning/end of the fragment
|
||||||
while ( ( child = startContainer.lastChild ) &&
|
while ( ( child = startContainer.lastChild ) &&
|
||||||
child.nodeType === ELEMENT_NODE &&
|
child.nodeType === ELEMENT_NODE ) {
|
||||||
child.nodeName !== 'BR' ) {
|
if ( child.nodeName === 'BR' ) {
|
||||||
|
startOffset -= 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
startContainer = child;
|
startContainer = child;
|
||||||
startOffset = startContainer.childNodes.length;
|
startOffset = startContainer.childNodes.length;
|
||||||
}
|
}
|
||||||
|
@ -219,8 +222,9 @@ var insertTreeFragmentIntoRange = function ( range, frag ) {
|
||||||
child.nodeName !== 'BR' ) {
|
child.nodeName !== 'BR' ) {
|
||||||
endContainer = child;
|
endContainer = child;
|
||||||
}
|
}
|
||||||
|
startAnchor = startContainer.childNodes[ startOffset ] || null;
|
||||||
while ( ( child = frag.firstChild ) && isInline( child ) ) {
|
while ( ( child = frag.firstChild ) && isInline( child ) ) {
|
||||||
startContainer.appendChild( child );
|
startContainer.insertBefore( child, startAnchor );
|
||||||
}
|
}
|
||||||
while ( ( child = frag.lastChild ) && isInline( child ) ) {
|
while ( ( child = frag.lastChild ) && isInline( child ) ) {
|
||||||
endContainer.insertBefore( child, endContainer.firstChild );
|
endContainer.insertBefore( child, endContainer.firstChild );
|
||||||
|
@ -448,6 +452,7 @@ var rangeDoesStartAtBlockBoundary = function ( range ) {
|
||||||
startOffset = range.startOffset;
|
startOffset = range.startOffset;
|
||||||
|
|
||||||
// If in the middle or end of a text node, we're not at the boundary.
|
// If in the middle or end of a text node, we're not at the boundary.
|
||||||
|
contentWalker.root = null;
|
||||||
if ( startContainer.nodeType === TEXT_NODE ) {
|
if ( startContainer.nodeType === TEXT_NODE ) {
|
||||||
if ( startOffset ) {
|
if ( startOffset ) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -470,6 +475,7 @@ var rangeDoesEndAtBlockBoundary = function ( range ) {
|
||||||
|
|
||||||
// If in a text node with content, and not at the end, we're not
|
// If in a text node with content, and not at the end, we're not
|
||||||
// at the boundary
|
// at the boundary
|
||||||
|
contentWalker.root = null;
|
||||||
if ( endContainer.nodeType === TEXT_NODE ) {
|
if ( endContainer.nodeType === TEXT_NODE ) {
|
||||||
length = endContainer.data.length;
|
length = endContainer.data.length;
|
||||||
if ( length && endOffset < length ) {
|
if ( length && endOffset < length ) {
|
||||||
|
|
Loading…
Reference in a new issue