summaryrefslogtreecommitdiff
path: root/misc/autocomplete.js
diff options
context:
space:
mode:
Diffstat (limited to 'misc/autocomplete.js')
-rw-r--r--misc/autocomplete.js16
1 files changed, 14 insertions, 2 deletions
diff --git a/misc/autocomplete.js b/misc/autocomplete.js
index 4d72005e1..93d5bf55d 100644
--- a/misc/autocomplete.js
+++ b/misc/autocomplete.js
@@ -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();
+ }
+}