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:
parent
eed472b5ef
commit
c09c5e98f7
3 changed files with 22 additions and 42 deletions
|
@ -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
|
@ -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;
|
||||||
|
|
Loading…
Add table
Reference in a new issue