IE7/8: Simplify textRange

This commit is contained in:
Eston Bond
2010-12-03 22:46:59 -08:00
parent 0d6c4e2f89
commit 8a954f4435
@@ -124,8 +124,7 @@
*/
var debug = function(m) {
if ( ActiveOptions.Debug
&& typeof console != 'undefined'
&& typeof console.log == 'function' ) {
&& typeof console != 'undefined' ) {
console.log( m );
}
};
@@ -503,8 +502,7 @@
*/
getFieldSelectionPosition: function( $field ) {
if ($field.length) {
var start = 0, end = 0, normalizedValue, range,
textInputRange, len, endRange;
var start = 0, end = 0;
var el = $field.get(0);
if (typeof el.selectionStart == "number" &&
@@ -512,30 +510,12 @@
start = el.selectionStart;
end = el.selectionEnd;
} else {
range = document.selection.createRange();
if (range && range.parentElement() == el) {
len = el.value.length;
normalizedValue = el.value.replace(/\r\n/g, "\n");
textInputRange = el.createTextRange();
textInputRange.moveToBookmark(range.getBookmark());
endRange = el.createTextRange();
endRange.collapse(false);
if (textInputRange.compareEndPoints("StartToEnd", endRange) > -1) {
start = end = len;
} else {
start = -textInputRange.moveStart("character", -len);
start += normalizedValue.slice(0, start).split("\n").length - 1;
if (textInputRange.compareEndPoints("EndToEnd", endRange) > -1) {
end = len;
} else {
end = -textInputRange.moveEnd("character", -len);
end += normalizedValue.slice(0, end).split("\n").length - 1;
}
}
}
var range = document.selection.createRange();
var stored_range = range.duplicate();
stored_range.moveToElementText( el );
stored_range.setEndPoint( 'EndToEnd', range );
start = stored_range.text.length - range.text.length;
end = start + range.text.length;
}
return {