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

Fix invalid caching of selection nodes in paste handler.

Fixes error thrown when pasting text twice in succession (or more generally,
when pasting it into non-normalised text nodes).
This commit is contained in:
Neil Jenkins 2015-02-06 14:09:37 +07:00
parent 8f83ef32c3
commit 5b8e348232
4 changed files with 22 additions and 12 deletions

View file

@ -692,6 +692,7 @@ var insertNodeInRange = function ( range, node ) {
} else { } else {
startContainer.insertBefore( node, children[ startOffset ] ); startContainer.insertBefore( node, children[ startOffset ] );
} }
if ( startContainer === endContainer ) { if ( startContainer === endContainer ) {
endOffset += children.length - childCount; endOffset += children.length - childCount;
} }
@ -2598,16 +2599,20 @@ proto._onPaste = function ( event ) {
var self = this, var self = this,
body = this._body, body = this._body,
range = this.getSelection(), range = this.getSelection(),
startContainer = range.startContainer, startContainer, startOffset, endContainer, endOffset, startBlock;
startOffset = range.startOffset,
endContainer = range.endContainer,
endOffset = range.endOffset,
startBlock = getStartBlockOfRange( range );
// Record undo checkpoint // Record undo checkpoint
self._recordUndoState( range ); self._recordUndoState( range );
self._getRangeAndRemoveBookmark( range ); self._getRangeAndRemoveBookmark( range );
// Note current selection. We must do this AFTER recording the undo
// checkpoint, as this modifies the DOM.
startContainer = range.startContainer;
startOffset = range.startOffset;
endContainer = range.endContainer;
endOffset = range.endOffset;
startBlock = getStartBlockOfRange( range );
// We need to position the pasteArea in the visible portion of the screen // We need to position the pasteArea in the visible portion of the screen
// to stop the browser auto-scrolling. // to stop the browser auto-scrolling.
var pasteArea = this.createElement( 'DIV', { var pasteArea = this.createElement( 'DIV', {

File diff suppressed because one or more lines are too long

View file

@ -1525,16 +1525,20 @@ proto._onPaste = function ( event ) {
var self = this, var self = this,
body = this._body, body = this._body,
range = this.getSelection(), range = this.getSelection(),
startContainer = range.startContainer, startContainer, startOffset, endContainer, endOffset, startBlock;
startOffset = range.startOffset,
endContainer = range.endContainer,
endOffset = range.endOffset,
startBlock = getStartBlockOfRange( range );
// Record undo checkpoint // Record undo checkpoint
self._recordUndoState( range ); self._recordUndoState( range );
self._getRangeAndRemoveBookmark( range ); self._getRangeAndRemoveBookmark( range );
// Note current selection. We must do this AFTER recording the undo
// checkpoint, as this modifies the DOM.
startContainer = range.startContainer;
startOffset = range.startOffset;
endContainer = range.endContainer;
endOffset = range.endOffset;
startBlock = getStartBlockOfRange( range );
// We need to position the pasteArea in the visible portion of the screen // We need to position the pasteArea in the visible portion of the screen
// to stop the browser auto-scrolling. // to stop the browser auto-scrolling.
var pasteArea = this.createElement( 'DIV', { var pasteArea = this.createElement( 'DIV', {

View file

@ -108,6 +108,7 @@ var insertNodeInRange = function ( range, node ) {
} else { } else {
startContainer.insertBefore( node, children[ startOffset ] ); startContainer.insertBefore( node, children[ startOffset ] );
} }
if ( startContainer === endContainer ) { if ( startContainer === endContainer ) {
endOffset += children.length - childCount; endOffset += children.length - childCount;
} }