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

Fix Firefox cursor disappears after calling modifyBlocks

Workaround for an old Firefox bug was causing it. Happily, that seems to no
longer be needed, so can just remove it and we're all good. :)
This commit is contained in:
Neil Jenkins 2014-06-26 16:13:54 +01:00
parent eed472b5ef
commit c09c5e98f7
3 changed files with 22 additions and 42 deletions

View file

@ -2006,48 +2006,38 @@ proto.modifyBlocks = function ( modify, range ) {
if ( !range && !( range = this.getSelection() ) ) { if ( !range && !( range = this.getSelection() ) ) {
return this; return this;
} }
// 1. Stop firefox adding an extra <BR> to <BODY>
// if we remove everything. Don't want to do this in Opera
// as it can cause focus problems.
var body = this._body;
if ( !isOpera ) {
body.setAttribute( 'contenteditable', 'false' );
}
// 2. Save undo checkpoint and bookmark selection // 1. Save undo checkpoint and bookmark selection
if ( this._isInUndoState ) { if ( this._isInUndoState ) {
this._saveRangeToBookmark( range ); this._saveRangeToBookmark( range );
} else { } else {
this._recordUndoState( range ); this._recordUndoState( range );
} }
// 3. Expand range to block boundaries // 2. Expand range to block boundaries
expandRangeToBlockBoundaries( range ); expandRangeToBlockBoundaries( range );
// 4. Remove range. // 3. Remove range.
var body = this._body,
frag;
moveRangeBoundariesUpTree( range, body ); moveRangeBoundariesUpTree( range, body );
var frag = extractContentsOfRange( range, body ); frag = extractContentsOfRange( range, body );
// 5. Modify tree of fragment and reinsert. // 4. Modify tree of fragment and reinsert.
insertNodeInRange( range, modify.call( this, frag ) ); insertNodeInRange( range, modify.call( this, frag ) );
// 6. Merge containers at edges // 5. Merge containers at edges
if ( range.endOffset < range.endContainer.childNodes.length ) { if ( range.endOffset < range.endContainer.childNodes.length ) {
mergeContainers( range.endContainer.childNodes[ range.endOffset ] ); mergeContainers( range.endContainer.childNodes[ range.endOffset ] );
} }
mergeContainers( range.startContainer.childNodes[ range.startOffset ] ); mergeContainers( range.startContainer.childNodes[ range.startOffset ] );
// 7. Make it editable again // 6. Restore selection
if ( !isOpera ) {
body.setAttribute( 'contenteditable', 'true' );
}
// 8. Restore selection
this._getRangeAndRemoveBookmark( range ); this._getRangeAndRemoveBookmark( range );
this.setSelection( range ); this.setSelection( range );
this._updatePath( range, true ); this._updatePath( range, true );
// 9. We're not still in an undo state // 7. We're not still in an undo state
this._docWasChanged(); this._docWasChanged();
return this; return this;

File diff suppressed because one or more lines are too long

View file

@ -893,48 +893,38 @@ proto.modifyBlocks = function ( modify, range ) {
if ( !range && !( range = this.getSelection() ) ) { if ( !range && !( range = this.getSelection() ) ) {
return this; return this;
} }
// 1. Stop firefox adding an extra <BR> to <BODY>
// if we remove everything. Don't want to do this in Opera
// as it can cause focus problems.
var body = this._body;
if ( !isOpera ) {
body.setAttribute( 'contenteditable', 'false' );
}
// 2. Save undo checkpoint and bookmark selection // 1. Save undo checkpoint and bookmark selection
if ( this._isInUndoState ) { if ( this._isInUndoState ) {
this._saveRangeToBookmark( range ); this._saveRangeToBookmark( range );
} else { } else {
this._recordUndoState( range ); this._recordUndoState( range );
} }
// 3. Expand range to block boundaries // 2. Expand range to block boundaries
expandRangeToBlockBoundaries( range ); expandRangeToBlockBoundaries( range );
// 4. Remove range. // 3. Remove range.
var body = this._body,
frag;
moveRangeBoundariesUpTree( range, body ); moveRangeBoundariesUpTree( range, body );
var frag = extractContentsOfRange( range, body ); frag = extractContentsOfRange( range, body );
// 5. Modify tree of fragment and reinsert. // 4. Modify tree of fragment and reinsert.
insertNodeInRange( range, modify.call( this, frag ) ); insertNodeInRange( range, modify.call( this, frag ) );
// 6. Merge containers at edges // 5. Merge containers at edges
if ( range.endOffset < range.endContainer.childNodes.length ) { if ( range.endOffset < range.endContainer.childNodes.length ) {
mergeContainers( range.endContainer.childNodes[ range.endOffset ] ); mergeContainers( range.endContainer.childNodes[ range.endOffset ] );
} }
mergeContainers( range.startContainer.childNodes[ range.startOffset ] ); mergeContainers( range.startContainer.childNodes[ range.startOffset ] );
// 7. Make it editable again // 6. Restore selection
if ( !isOpera ) {
body.setAttribute( 'contenteditable', 'true' );
}
// 8. Restore selection
this._getRangeAndRemoveBookmark( range ); this._getRangeAndRemoveBookmark( range );
this.setSelection( range ); this.setSelection( range );
this._updatePath( range, true ); this._updatePath( range, true );
// 9. We're not still in an undo state // 7. We're not still in an undo state
this._docWasChanged(); this._docWasChanged();
return this; return this;