mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-20 05:32:46 -05:00
Replace feature test w/ UA sniff for buggy splitText. *sigh*
The feature test is sometimes passing in IE9, but then the buggy behaviour still appears later. FFS IE.
This commit is contained in:
parent
805f3cffff
commit
4a264a52c7
4 changed files with 14 additions and 20 deletions
|
@ -35,13 +35,6 @@ var ctrlKey = isMac ? 'meta-' : 'ctrl-';
|
||||||
var useTextFixer = isIElt11 || isPresto;
|
var useTextFixer = isIElt11 || isPresto;
|
||||||
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
||||||
var losesSelectionOnBlur = isIElt11;
|
var losesSelectionOnBlur = isIElt11;
|
||||||
var hasBuggySplit = function ( doc ) {
|
|
||||||
var div = doc.createElement( 'DIV' ),
|
|
||||||
text = doc.createTextNode( '12' );
|
|
||||||
div.appendChild( text );
|
|
||||||
text.splitText( 2 );
|
|
||||||
return div.childNodes.length !== 2;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Use [^ \t\r\n] instead of \S so that nbsp does not count as white-space
|
// Use [^ \t\r\n] instead of \S so that nbsp does not count as white-space
|
||||||
var notWS = /[^ \t\r\n]/;
|
var notWS = /[^ \t\r\n]/;
|
||||||
|
@ -1136,13 +1129,17 @@ function Squire ( doc ) {
|
||||||
// Opera does not fire keydown repeatedly.
|
// Opera does not fire keydown repeatedly.
|
||||||
this.addEventListener( isPresto ? 'keypress' : 'keydown', this._onKey );
|
this.addEventListener( isPresto ? 'keypress' : 'keydown', this._onKey );
|
||||||
|
|
||||||
// Fix IE8/9's buggy implementation of Text#splitText.
|
// Fix IE<10's buggy implementation of Text#splitText.
|
||||||
// If the split is at the end of the node, it doesn't insert the newly split
|
// If the split is at the end of the node, it doesn't insert the newly split
|
||||||
// node into the document, and sets its value to undefined rather than ''.
|
// node into the document, and sets its value to undefined rather than ''.
|
||||||
// And even if the split is not at the end, the original node is removed
|
// And even if the split is not at the end, the original node is removed
|
||||||
// from the document and replaced by another, rather than just having its
|
// from the document and replaced by another, rather than just having its
|
||||||
// data shortened.
|
// data shortened.
|
||||||
if ( hasBuggySplit( doc ) ) {
|
// We used to feature test for this, but then found the feature test would
|
||||||
|
// sometimes pass, but later on the buggy behaviour would still appear.
|
||||||
|
// I think IE10 does not have the same bug, but it doesn't hurt to replace
|
||||||
|
// its native fn too and then we don't need yet another UA category.
|
||||||
|
if ( isIElt11 ) {
|
||||||
win.Text.prototype.splitText = function ( offset ) {
|
win.Text.prototype.splitText = function ( offset ) {
|
||||||
var afterSplit = this.ownerDocument.createTextNode(
|
var afterSplit = this.ownerDocument.createTextNode(
|
||||||
this.data.slice( offset ) ),
|
this.data.slice( offset ) ),
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -30,13 +30,6 @@ var ctrlKey = isMac ? 'meta-' : 'ctrl-';
|
||||||
var useTextFixer = isIElt11 || isPresto;
|
var useTextFixer = isIElt11 || isPresto;
|
||||||
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
var cantFocusEmptyTextNodes = isIElt11 || isWebKit;
|
||||||
var losesSelectionOnBlur = isIElt11;
|
var losesSelectionOnBlur = isIElt11;
|
||||||
var hasBuggySplit = function ( doc ) {
|
|
||||||
var div = doc.createElement( 'DIV' ),
|
|
||||||
text = doc.createTextNode( '12' );
|
|
||||||
div.appendChild( text );
|
|
||||||
text.splitText( 2 );
|
|
||||||
return div.childNodes.length !== 2;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Use [^ \t\r\n] instead of \S so that nbsp does not count as white-space
|
// Use [^ \t\r\n] instead of \S so that nbsp does not count as white-space
|
||||||
var notWS = /[^ \t\r\n]/;
|
var notWS = /[^ \t\r\n]/;
|
||||||
|
|
|
@ -50,13 +50,17 @@ function Squire ( doc ) {
|
||||||
// Opera does not fire keydown repeatedly.
|
// Opera does not fire keydown repeatedly.
|
||||||
this.addEventListener( isPresto ? 'keypress' : 'keydown', this._onKey );
|
this.addEventListener( isPresto ? 'keypress' : 'keydown', this._onKey );
|
||||||
|
|
||||||
// Fix IE8/9's buggy implementation of Text#splitText.
|
// Fix IE<10's buggy implementation of Text#splitText.
|
||||||
// If the split is at the end of the node, it doesn't insert the newly split
|
// If the split is at the end of the node, it doesn't insert the newly split
|
||||||
// node into the document, and sets its value to undefined rather than ''.
|
// node into the document, and sets its value to undefined rather than ''.
|
||||||
// And even if the split is not at the end, the original node is removed
|
// And even if the split is not at the end, the original node is removed
|
||||||
// from the document and replaced by another, rather than just having its
|
// from the document and replaced by another, rather than just having its
|
||||||
// data shortened.
|
// data shortened.
|
||||||
if ( hasBuggySplit( doc ) ) {
|
// We used to feature test for this, but then found the feature test would
|
||||||
|
// sometimes pass, but later on the buggy behaviour would still appear.
|
||||||
|
// I think IE10 does not have the same bug, but it doesn't hurt to replace
|
||||||
|
// its native fn too and then we don't need yet another UA category.
|
||||||
|
if ( isIElt11 ) {
|
||||||
win.Text.prototype.splitText = function ( offset ) {
|
win.Text.prototype.splitText = function ( offset ) {
|
||||||
var afterSplit = this.ownerDocument.createTextNode(
|
var afterSplit = this.ownerDocument.createTextNode(
|
||||||
this.data.slice( offset ) ),
|
this.data.slice( offset ) ),
|
||||||
|
|
Loading…
Add table
Reference in a new issue