0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2025-01-18 04:32:28 -05:00

Added option to persist splits in inline nodes when fetching range from bookmark.

This commit is contained in:
Gert K. Sønderby 2015-06-15 16:00:30 +02:00 committed by Neil Jenkins
parent 83a1b4c520
commit d16de00a23
2 changed files with 14 additions and 10 deletions

View file

@ -1983,7 +1983,7 @@ proto._saveRangeToBookmark = function ( range ) {
range.setEndBefore( endNode ); range.setEndBefore( endNode );
}; };
proto._getRangeAndRemoveBookmark = function ( range ) { proto._getRangeAndRemoveBookmark = function ( range, persistSplits ) {
var doc = this._doc, var doc = this._doc,
start = doc.getElementById( startSelectionId ), start = doc.getElementById( startSelectionId ),
end = doc.getElementById( endSelectionId ); end = doc.getElementById( endSelectionId );
@ -2007,10 +2007,12 @@ proto._getRangeAndRemoveBookmark = function ( range ) {
detach( start ); detach( start );
detach( end ); detach( end );
// Merge any text nodes we split if ( !persistSplits ) {
mergeInlines( startContainer, _range ); // Merge any text nodes we split
if ( startContainer !== endContainer ) { mergeInlines( startContainer, _range );
mergeInlines( endContainer, _range ); if ( startContainer !== endContainer ) {
mergeInlines( endContainer, _range );
}
} }
if ( !range ) { if ( !range ) {

View file

@ -525,7 +525,7 @@ proto._saveRangeToBookmark = function ( range ) {
range.setEndBefore( endNode ); range.setEndBefore( endNode );
}; };
proto._getRangeAndRemoveBookmark = function ( range ) { proto._getRangeAndRemoveBookmark = function ( range, persistSplits ) {
var doc = this._doc, var doc = this._doc,
start = doc.getElementById( startSelectionId ), start = doc.getElementById( startSelectionId ),
end = doc.getElementById( endSelectionId ); end = doc.getElementById( endSelectionId );
@ -549,10 +549,12 @@ proto._getRangeAndRemoveBookmark = function ( range ) {
detach( start ); detach( start );
detach( end ); detach( end );
// Merge any text nodes we split if ( !persistSplits ) {
mergeInlines( startContainer, _range ); // Merge any text nodes we split
if ( startContainer !== endContainer ) { mergeInlines( startContainer, _range );
mergeInlines( endContainer, _range ); if ( startContainer !== endContainer ) {
mergeInlines( endContainer, _range );
}
} }
if ( !range ) { if ( !range ) {