Commit a81547d5 authored by Steven Wittens's avatar Steven Wittens

#57255: Cancel autocomplete requests when the user tabs out of the field

parent 34eefb70
......@@ -47,7 +47,7 @@ function jsAC(input, db) {
this.db = db;
this.input.onkeydown = function (event) { return ac.onkeydown(this, event); };
this.input.onkeyup = function (event) { ac.onkeyup(this, event) };
this.input.onblur = function () { ac.hidePopup() };
this.input.onblur = function () { ac.hidePopup(); ac.db.cancel(); };
this.popup = document.createElement('div');
this.popup.id = 'autocomplete';
this.popup.owner = this;
......@@ -240,7 +240,7 @@ ACDB.prototype.search = function(searchString) {
var db = this;
this.timer = setTimeout(function() {
addClass(db.owner.input, 'throbbing');
HTTPGet(db.uri +'/'+ encodeURIComponent(searchString), db.receive, db);
db.transport = HTTPGet(db.uri +'/'+ encodeURIComponent(searchString), db.receive, db);
}, this.delay);
}
......@@ -263,3 +263,15 @@ ACDB.prototype.receive = function(string, xmlhttp, acdb) {
acdb.cache[acdb.searchString] = matches;
acdb.owner.found(matches);
}
/**
* Cancels the current autocomplete request
*/
ACDB.prototype.cancel = function() {
if (this.owner) removeClass(this.owner.input, 'throbbing');
if (this.timer) clearTimeout(this.timer);
if (this.transport) {
this.transport.onreadystatechange = function() {};
this.transport.abort();
}
}
......@@ -59,7 +59,7 @@ function HTTPGet(uri, callbackFunction, callbackParameter) {
}
}
}
return true;
return xmlHttp;
}
else {
return xmlHttp.responseText;
......@@ -100,7 +100,7 @@ function HTTPPost(uri, callbackFunction, callbackParameter, object) {
}
}
}
return true;
return xmlHttp;
}
else {
return xmlHttp.responseText;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment