- Abort pending autocomplete requests when max entries found, small code improvements

release-0.7
alecpl 13 years ago
parent d06e57fdf2
commit 48a06551da

@ -3619,6 +3619,8 @@ function rcube_webmail()
if (q == this.ksearch_value) if (q == this.ksearch_value)
return; return;
this.ksearch_destroy();
if (q.length && q.length < min) { if (q.length && q.length < min) {
if (!this.ksearch_info) { if (!this.ksearch_info) {
this.ksearch_info = this.display_message( this.ksearch_info = this.display_message(
@ -3629,7 +3631,6 @@ function rcube_webmail()
var old_value = this.ksearch_value; var old_value = this.ksearch_value;
this.ksearch_value = q; this.ksearch_value = q;
this.ksearch_destroy();
// ...string is empty // ...string is empty
if (!q.length) if (!q.length)
@ -3671,7 +3672,9 @@ function rcube_webmail()
return; return;
// display search results // display search results
var p, ul, li, text, init, s_val = this.ksearch_value, var ul, li, text, init,
value = this.ksearch_value,
data = this.ksearch_data,
maxlen = this.env.autocomplete_max ? this.env.autocomplete_max : 15; maxlen = this.env.autocomplete_max ? this.env.autocomplete_max : 15;
// create results pane if not present // create results pane if not present
@ -3704,7 +3707,7 @@ function rcube_webmail()
for (i=0; i < results.length && maxlen > 0; i++) { for (i=0; i < results.length && maxlen > 0; i++) {
text = typeof results[i] === 'object' ? results[i].name : results[i]; text = typeof results[i] === 'object' ? results[i].name : results[i];
li = document.createElement('LI'); li = document.createElement('LI');
li.innerHTML = text.replace(new RegExp('('+RegExp.escape(s_val)+')', 'ig'), '##$1%%').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/##([^%]+)%%/g, '<b>$1</b>'); li.innerHTML = text.replace(new RegExp('('+RegExp.escape(value)+')', 'ig'), '##$1%%').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/##([^%]+)%%/g, '<b>$1</b>');
li.onmouseover = function(){ ref.ksearch_select(this); }; li.onmouseover = function(){ ref.ksearch_select(this); };
li.onmouseup = function(){ ref.ksearch_click(this) }; li.onmouseup = function(){ ref.ksearch_click(this) };
li._rcm_id = this.env.contacts.length + i; li._rcm_id = this.env.contacts.length + i;
@ -3726,20 +3729,24 @@ function rcube_webmail()
this.env.contacts = this.env.contacts.concat(results); this.env.contacts = this.env.contacts.concat(results);
// run next parallel search // run next parallel search
if (this.ksearch_data.id == reqid) { if (data.id == reqid) {
if (maxlen > 0 && this.ksearch_data.sources.length) { if (maxlen > 0 && data.sources.length) {
var lock, xhr, props = this.ksearch_data, source = props.sources.shift(); var lock, xhr, source = data.sources.shift();
if (source) { if (source) {
lock = this.display_message(this.get_label('searching'), 'loading'); lock = this.display_message(this.get_label('searching'), 'loading');
xhr = this.http_post(props.action, '_search='+urlencode(s_val)+'&_id='+reqid xhr = this.http_post(data.action, '_search='+urlencode(value)+'&_id='+reqid
+'&_source='+urlencode(source), lock); +'&_source='+urlencode(source), lock);
this.ksearch_data.locks.push(lock); this.ksearch_data.locks.push(lock);
this.ksearch_data.requests.push(xhr); this.ksearch_data.requests.push(xhr);
} }
} }
else if (!maxlen && !this.ksearch_msg) else if (!maxlen) {
this.ksearch_msg = this.display_message(this.get_label('autocompletemore')); if (!this.ksearch_msg)
this.ksearch_msg = this.display_message(this.get_label('autocompletemore'));
// abort pending searches
this.ksearch_abort();
}
} }
}; };
@ -3772,16 +3779,10 @@ function rcube_webmail()
this.ksearch_destroy(); this.ksearch_destroy();
}; };
// Aborts pending autocomplete requests // Clears autocomplete data/requests
this.ksearch_destroy = function() this.ksearch_destroy = function()
{ {
var i, len, ac = this.ksearch_data; this.ksearch_abort();
if (!ac)
return;
for (i=0, len=ac.locks.length; i<len; i++)
this.abort_request({request: ac.requests[i], lock: ac.locks[i]});
if (this.ksearch_info) if (this.ksearch_info)
this.hide_message(this.ksearch_info); this.hide_message(this.ksearch_info);
@ -3794,6 +3795,19 @@ function rcube_webmail()
this.ksearch_msg = null; this.ksearch_msg = null;
} }
// Aborts pending autocomplete requests
this.ksearch_abort = function()
{
var i, len, ac = this.ksearch_data;
if (!ac)
return;
for (i=0, len=ac.locks.length; i<len; i++)
this.abort_request({request: ac.requests[i], lock: ac.locks[i]});
};
/*********************************************************/ /*********************************************************/
/********* address book methods *********/ /********* address book methods *********/
/*********************************************************/ /*********************************************************/

Loading…
Cancel
Save