mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-03 05:00:13 -05:00
Remove support for pre-Chromium Opera
This commit is contained in:
parent
b36a35faf4
commit
58321e5504
6 changed files with 6 additions and 47 deletions
|
@ -670,18 +670,6 @@ function mergeWithBlock ( block, next, range, root ) {
|
||||||
range.setStart( block, offset );
|
range.setStart( block, offset );
|
||||||
range.collapse( true );
|
range.collapse( true );
|
||||||
mergeInlines( block, range );
|
mergeInlines( block, range );
|
||||||
|
|
||||||
// Opera inserts a BR if you delete the last piece of text
|
|
||||||
// in a block-level element. Unfortunately, it then gets
|
|
||||||
// confused when setting the selection subsequently and
|
|
||||||
// refuses to accept the range that finishes just before the
|
|
||||||
// BR. Removing the BR fixes the bug.
|
|
||||||
// Steps to reproduce bug: Type "a-b-c" (where - is return)
|
|
||||||
// then backspace twice. The cursor goes to the top instead
|
|
||||||
// of after "b".
|
|
||||||
if ( isPresto && ( last = block.lastChild ) && last.nodeName === 'BR' ) {
|
|
||||||
block.removeChild( last );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function mergeContainers ( node, root ) {
|
function mergeContainers ( node, root ) {
|
||||||
|
@ -1311,12 +1299,6 @@ var onKey = function ( event ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// On keypress, delete and '.' both have event.keyCode 46
|
|
||||||
// Must check event.which to differentiate.
|
|
||||||
if ( isPresto && event.which === 46 ) {
|
|
||||||
key = '.';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Function keys
|
// Function keys
|
||||||
if ( 111 < code && code < 124 ) {
|
if ( 111 < code && code < 124 ) {
|
||||||
key = 'f' + ( code - 111 );
|
key = 'f' + ( code - 111 );
|
||||||
|
@ -1568,7 +1550,7 @@ var handleEnter = function ( self, shiftKey, range ) {
|
||||||
// If you try to select the contents of a 'BR', FF will not let
|
// If you try to select the contents of a 'BR', FF will not let
|
||||||
// you type anything!
|
// you type anything!
|
||||||
if ( !child || child.nodeName === 'BR' ||
|
if ( !child || child.nodeName === 'BR' ||
|
||||||
( child.nodeType === TEXT_NODE && !isPresto ) ) {
|
child.nodeType === TEXT_NODE ) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
nodeAfterSplit = child;
|
nodeAfterSplit = child;
|
||||||
|
@ -2644,9 +2626,7 @@ function Squire ( root, config ) {
|
||||||
this.addEventListener( 'keyup', monitorShiftKey );
|
this.addEventListener( 'keyup', monitorShiftKey );
|
||||||
this.addEventListener( isIElt11 ? 'beforepaste' : 'paste', onPaste );
|
this.addEventListener( isIElt11 ? 'beforepaste' : 'paste', onPaste );
|
||||||
this.addEventListener( 'drop', onDrop );
|
this.addEventListener( 'drop', onDrop );
|
||||||
|
this.addEventListener( 'keydown', onKey );
|
||||||
// Opera does not fire keydown repeatedly.
|
|
||||||
this.addEventListener( isPresto ? 'keypress' : 'keydown', onKey );
|
|
||||||
|
|
||||||
// Add key handlers
|
// Add key handlers
|
||||||
this._keyHandlers = Object.create( keyHandlers );
|
this._keyHandlers = Object.create( keyHandlers );
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -27,14 +27,13 @@ var isIOS = /iP(?:ad|hone|od)/.test( ua ) ||
|
||||||
|
|
||||||
var isGecko = /Gecko\//.test( ua );
|
var isGecko = /Gecko\//.test( ua );
|
||||||
var isIElt11 = /Trident\/[456]\./.test( ua );
|
var isIElt11 = /Trident\/[456]\./.test( ua );
|
||||||
var isPresto = !!win.opera;
|
|
||||||
var isEdge = /Edge\//.test( ua );
|
var isEdge = /Edge\//.test( ua );
|
||||||
var isWebKit = !isEdge && /WebKit\//.test( ua );
|
var isWebKit = !isEdge && /WebKit\//.test( ua );
|
||||||
var isIE = /Trident\/[4567]\./.test( ua );
|
var isIE = /Trident\/[4567]\./.test( ua );
|
||||||
|
|
||||||
var ctrlKey = isMac ? 'meta-' : 'ctrl-';
|
var ctrlKey = isMac ? 'meta-' : 'ctrl-';
|
||||||
|
|
||||||
var useTextFixer = isIElt11 || isPresto;
|
var useTextFixer = isIElt11;
|
||||||
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
||||||
var losesSelectionOnBlur = isIElt11;
|
var losesSelectionOnBlur = isIElt11;
|
||||||
|
|
||||||
|
|
|
@ -93,9 +93,7 @@ function Squire ( root, config ) {
|
||||||
this.addEventListener( 'keyup', monitorShiftKey );
|
this.addEventListener( 'keyup', monitorShiftKey );
|
||||||
this.addEventListener( isIElt11 ? 'beforepaste' : 'paste', onPaste );
|
this.addEventListener( isIElt11 ? 'beforepaste' : 'paste', onPaste );
|
||||||
this.addEventListener( 'drop', onDrop );
|
this.addEventListener( 'drop', onDrop );
|
||||||
|
this.addEventListener( 'keydown', onKey );
|
||||||
// Opera does not fire keydown repeatedly.
|
|
||||||
this.addEventListener( isPresto ? 'keypress' : 'keydown', onKey );
|
|
||||||
|
|
||||||
// Add key handlers
|
// Add key handlers
|
||||||
this._keyHandlers = Object.create( keyHandlers );
|
this._keyHandlers = Object.create( keyHandlers );
|
||||||
|
|
|
@ -33,12 +33,6 @@ var onKey = function ( event ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// On keypress, delete and '.' both have event.keyCode 46
|
|
||||||
// Must check event.which to differentiate.
|
|
||||||
if ( isPresto && event.which === 46 ) {
|
|
||||||
key = '.';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Function keys
|
// Function keys
|
||||||
if ( 111 < code && code < 124 ) {
|
if ( 111 < code && code < 124 ) {
|
||||||
key = 'f' + ( code - 111 );
|
key = 'f' + ( code - 111 );
|
||||||
|
@ -290,7 +284,7 @@ var handleEnter = function ( self, shiftKey, range ) {
|
||||||
// If you try to select the contents of a 'BR', FF will not let
|
// If you try to select the contents of a 'BR', FF will not let
|
||||||
// you type anything!
|
// you type anything!
|
||||||
if ( !child || child.nodeName === 'BR' ||
|
if ( !child || child.nodeName === 'BR' ||
|
||||||
( child.nodeType === TEXT_NODE && !isPresto ) ) {
|
child.nodeType === TEXT_NODE ) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
nodeAfterSplit = child;
|
nodeAfterSplit = child;
|
||||||
|
|
|
@ -499,18 +499,6 @@ function mergeWithBlock ( block, next, range, root ) {
|
||||||
range.setStart( block, offset );
|
range.setStart( block, offset );
|
||||||
range.collapse( true );
|
range.collapse( true );
|
||||||
mergeInlines( block, range );
|
mergeInlines( block, range );
|
||||||
|
|
||||||
// Opera inserts a BR if you delete the last piece of text
|
|
||||||
// in a block-level element. Unfortunately, it then gets
|
|
||||||
// confused when setting the selection subsequently and
|
|
||||||
// refuses to accept the range that finishes just before the
|
|
||||||
// BR. Removing the BR fixes the bug.
|
|
||||||
// Steps to reproduce bug: Type "a-b-c" (where - is return)
|
|
||||||
// then backspace twice. The cursor goes to the top instead
|
|
||||||
// of after "b".
|
|
||||||
if ( isPresto && ( last = block.lastChild ) && last.nodeName === 'BR' ) {
|
|
||||||
block.removeChild( last );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function mergeContainers ( node, root ) {
|
function mergeContainers ( node, root ) {
|
||||||
|
|
Loading…
Reference in a new issue