mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-05 06:10:07 -05:00
Add accurate check for whether <br> breaks line.
When cleaning up <br> elements, we need to accurately determine whether there's text before and after it in the block to know whether it will introduce a visible line break.
This commit is contained in:
parent
327b48b9db
commit
a069e8305e
3 changed files with 40 additions and 7 deletions
File diff suppressed because one or more lines are too long
|
@ -1209,11 +1209,44 @@
|
||||||
return root;
|
return root;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var notWSTextNode = function ( node ) {
|
||||||
|
return notWS.test( node.data ) ? FILTER_ACCEPT : FILTER_SKIP;
|
||||||
|
};
|
||||||
|
var isLineBreak = function ( br ) {
|
||||||
|
var block = br.parentNode;
|
||||||
|
while ( block.isInline() ) {
|
||||||
|
block = block.parentNode;
|
||||||
|
}
|
||||||
|
var walker = new TreeWalker( block, SHOW_TEXT, notWSTextNode );
|
||||||
|
walker.currentNode = br;
|
||||||
|
if ( !walker.nextNode() ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
walker.currentNode = br;
|
||||||
|
return !!walker.previousNode();
|
||||||
|
};
|
||||||
|
|
||||||
|
// <br> elements are treated specially, and differently depending on the
|
||||||
|
// browser, when in rich text editor mode. When adding HTML from external
|
||||||
|
// sources, we must remove them, replacing the ones that actually affect
|
||||||
|
// line breaks with a split of the block element containing it (and wrapping
|
||||||
|
// any not inside a block). Browsers that want <br> elements at the end of
|
||||||
|
// each block will then have them added back in a later fixCursor method
|
||||||
|
// call.
|
||||||
var cleanupBRs = function ( root ) {
|
var cleanupBRs = function ( root ) {
|
||||||
var brs = root.querySelectorAll( 'BR' ),
|
var brs = root.querySelectorAll( 'BR' ),
|
||||||
|
brBreaksLine = [],
|
||||||
l = brs.length,
|
l = brs.length,
|
||||||
br, block;
|
i, br, block;
|
||||||
|
|
||||||
|
// Must calculate whether the <br> breaks a line first, because if we
|
||||||
|
// have two <br>s next to each other, after the first one is converted
|
||||||
|
// to a block split, the second will be at the end of a block and
|
||||||
|
// therefore seem to not be a line break. But in its original context it
|
||||||
|
// was, so we should also convert it to a block split.
|
||||||
|
for ( i = 0; i < l; i += 1 ) {
|
||||||
|
brBreaksLine[i] = isLineBreak( brs[i] );
|
||||||
|
}
|
||||||
while ( l-- ) {
|
while ( l-- ) {
|
||||||
br = brs[l];
|
br = brs[l];
|
||||||
// Cleanup may have removed it
|
// Cleanup may have removed it
|
||||||
|
@ -1231,12 +1264,12 @@
|
||||||
// is actual text content in the block. Otherwise, the <br> is a
|
// is actual text content in the block. Otherwise, the <br> is a
|
||||||
// placeholder to stop the block from collapsing, so we must leave
|
// placeholder to stop the block from collapsing, so we must leave
|
||||||
// it.
|
// it.
|
||||||
else if ( tagAfterSplit[ block.nodeName ] &&
|
else {
|
||||||
notWS.test( block.textContent ) ) {
|
if ( tagAfterSplit[ block.nodeName ] && brBreaksLine[l] ) {
|
||||||
splitBlock( block, br.parentNode, br );
|
splitBlock( block, br.parentNode, br );
|
||||||
|
}
|
||||||
br.detach();
|
br.detach();
|
||||||
}
|
}
|
||||||
// Otherwise leave the br alone.
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue