Remove incorrect ajax stuff from selectbox, just enhance taglist to support static options as well as ajax

This commit is contained in:
Nathan Gray 2016-02-09 20:19:16 +00:00
parent bde8fb9fae
commit 3895b4ca0e
3 changed files with 109 additions and 108 deletions

View File

@ -126,7 +126,7 @@ var et2_selectAccount = et2_selectbox.extend(
this._super.apply(this, arguments); this._super.apply(this, arguments);
// Add search button // Add search button
if(type == 'primary_group' && !this.options.tags) if(type == 'primary_group')
{ {
var button = jQuery(document.createElement("span")) var button = jQuery(document.createElement("span"))
.addClass("et2_clickable") .addClass("et2_clickable")
@ -165,7 +165,7 @@ var et2_selectAccount = et2_selectbox.extend(
this.options.select_options = this._get_accounts(); this.options.select_options = this._get_accounts();
if(type == 'primary_group' && !this.options.tags) if(type == 'primary_group')
{ {
// Allow search 'inside' this widget // Allow search 'inside' this widget
this.supportedWidgetClasses = [et2_link_entry]; this.supportedWidgetClasses = [et2_link_entry];

View File

@ -80,12 +80,6 @@ var et2_selectbox = et2_inputWidget.extend(
"default": false, "default": false,
"description": "For multi-selects, displays selected as a list of tags instead of a big list" "description": "For multi-selects, displays selected as a list of tags instead of a big list"
}, },
"source": {
"name": "AJAX data source",
"type": "any",
"default": et2_no_init,
"description": "Fetch options as needed from the server"
},
// Value can be string or integer // Value can be string or integer
"value": { "value": {
@ -414,10 +408,6 @@ var et2_selectbox = et2_inputWidget.extend(
this.set_tags(this.options.tags, this.options.width); this.set_tags(this.options.tags, this.options.width);
if(this.options.source)
{
this.set_source(this.options.source);
}
return true; return true;
}, },
@ -752,85 +742,6 @@ var et2_selectbox = et2_inputWidget.extend(
if(this.value || this.options.empty_label) this.set_value(this.value); if(this.value || this.options.empty_label) this.set_value(this.value);
}, },
/**
* Set a ajax source for options. Works best with search or tags options
* to enable Chosen.
*/
set_source: function(_url) {
if(!this.input) return false;
// Can't actually do this until attached, loadingFinished should call again
if(!this.isAttached()) return;
var widget = this;
var search = this.input.next()
.find('.search-field > input, .chzn-search > input');
var timeout = null;
if(!_url || !search || search && search.autocomplete('instance'))
{
search.autocomplete('destroy');
return;
}
this.options.source = _url;
search.on('keyup', function(e) {
var term = search.val().trim() || '';
if(term.length < 2)
{
return false;
}
if(timeout)
{
window.clearTimeout(timeout);
}
timeout = window.setTimeout(function()
{
timeout = null;
search.parent().addClass('loading');
widget.egw().json(widget.options.source,term, widget._ajax_fetch,widget, false,widget).sendRequest();
},200);
});
},
/*
* Fetch options via AJAX for use in tag lists
* @param {type} data
* @returns {undefined}
*/
_ajax_fetch: function _ajax_fetch(data) {
var found = false;
var search = this.input.next()
.find('.search-field > input, .chzn-search > input');
for(var i = 0; i < data.length; i++)
{
if(data[i] && typeof data[i].value === 'string' && typeof data[i].label === 'string')
{
var option = data[i];
if(jQuery("option[value='"+option.value+"']", this.input).length === 0)
{
found = true;
this._appendOptionElement(option.value, option.label,option.title);
}
}
}
search.parent()
.removeClass('loading');
if(found)
{
var term = search.val();
this.input.trigger('liszt:close');
this.input.trigger("liszt:updated");
// Updating clears the search term, restore it
search.val(term);
}
},
getValue: function() { getValue: function() {
if(this.input == null) if(this.input == null)
{ {

View File

@ -171,8 +171,8 @@ var et2_taglist = et2_selectbox.extend(
var options = jQuery.extend( { var options = jQuery.extend( {
// magisuggest can NOT work setting an empty autocomplete url, it will then call page url! // magisuggest can NOT work setting an empty autocomplete url, it will then call page url!
// --> setting an empty options list instead // --> setting an empty options list instead
data: this.options.select_options && !jQuery.isEmptyObject(this.options.select_options) || !this.options.autocomplete_url ? data: this.options.select_options && !jQuery.isEmptyObject(this.options.select_options) ?
this._options2data(this.options.select_options || {}) : this.options.autocomplete_url, this.options.select_options || {} : this.options.autocomplete_url,
dataUrlParams: this.options.autocomplete_params, dataUrlParams: this.options.autocomplete_params,
method: 'GET', method: 'GET',
displayField: "label", displayField: "label",
@ -191,11 +191,19 @@ var et2_taglist = et2_selectbox.extend(
maxSelection: this.options.maxSelection, maxSelection: this.options.maxSelection,
maxSelectionRenderer: jQuery.proxy(function(v) { this.egw().lang('You can not choose more then %1 item(s)!', v); }, this), maxSelectionRenderer: jQuery.proxy(function(v) { this.egw().lang('You can not choose more then %1 item(s)!', v); }, this),
width: this.options.width, // propagate width width: this.options.width, // propagate width
highlight: false // otherwise renderer have to return strings highlight: false, // otherwise renderer have to return strings,
value: this.options.value
}, this.lib_options); }, this.lib_options);
this.taglist = this.taglist.magicSuggest(options); this.taglist = this.taglist.magicSuggest(options);
this.set_value(this.options.value); // AJAX _and_ select options - use custom function
if(this.options.autocomplete_url && !jQuery.isEmptyObject(this.options.select_options))
{
var widget = this;
this.taglist.setData(function(query) {
return widget._data.call(widget,query)
});
}
// Display / hide a loading icon while fetching // Display / hide a loading icon while fetching
$j(this.taglist) $j(this.taglist)
@ -207,9 +215,9 @@ var et2_taglist = et2_selectbox.extend(
$j(this.getDOMNode()).unbind('change.et2_inputWidget'); $j(this.getDOMNode()).unbind('change.et2_inputWidget');
// onChange // onChange
if(this.options.onchange && typeof this.options.onchange == 'function') if(this.options.onchange && typeof this.onchange === 'function')
{ {
$j(this.taglist).on("selectionchange", this.options.onchange); $j(this.taglist).on("selectionchange", this.onchange);
} }
// onClick - pass more than baseWidget, so unbind it to avoid double callback // onClick - pass more than baseWidget, so unbind it to avoid double callback
@ -248,6 +256,7 @@ var et2_taglist = et2_selectbox.extend(
if (typeof options[id] == 'object') if (typeof options[id] == 'object')
{ {
jQuery.extend(option, options[id]); jQuery.extend(option, options[id]);
if(option.value) option.id = option.value
} }
else else
{ {
@ -258,6 +267,23 @@ var et2_taglist = et2_selectbox.extend(
return data; return data;
}, },
/**
* Custom data function to return local options if there is nothing
* typed, or query via AJAX if user typed something
*
* @returns {Array}
*/
_data: function(query) {
if(query.trim() ==='' || !this.options.autocomplete_url)
{
return this.options.select_options;
}
else
{
return this.options.autocomplete_url;
}
},
/** /**
* Set all options from current static select_options list * Set all options from current static select_options list
*/ */
@ -294,7 +320,11 @@ var et2_taglist = et2_selectbox.extend(
// do NOT set an empty autocomplete_url, magicsuggest would use page url instead! // do NOT set an empty autocomplete_url, magicsuggest would use page url instead!
if(this.taglist == null || !source) return; if(this.taglist == null || !source) return;
this.taglist.setData(source);
var widget = this;
this.taglist.setData(function(query) {
return widget._data.call(widget,query)
});
} }
}, },
@ -305,10 +335,13 @@ var et2_taglist = et2_selectbox.extend(
*/ */
set_select_options: function(_options) set_select_options: function(_options)
{ {
this.options.select_options = _options; this.options.select_options = this._options2data(_options);
if(this.taglist == null) return; if(this.taglist == null) return;
this.taglist.setData(this._options2data(this.options.select_options)); var widget = this;
this.taglist.setData(function(query) {
return widget._data.call(widget,query)
});
}, },
set_disabled: function(disabled) set_disabled: function(disabled)
@ -332,7 +365,8 @@ var et2_taglist = et2_selectbox.extend(
this.taglist.clear(true); this.taglist.clear(true);
if(!value) return; if(!value) return;
var values = jQuery.isArray(value) ? value : [value]; var values = jQuery.isArray(value) ? jQuery.extend([],value) : [value];
var result = [];
for(var i=0; i < values.length; ++i) for(var i=0; i < values.length; ++i)
{ {
var v = values[i]; var v = values[i];
@ -340,26 +374,30 @@ var et2_taglist = et2_selectbox.extend(
{ {
// alread in correct format // alread in correct format
} }
else if (this.options.select_options && typeof this.options.select_options[v] == 'undefined' || typeof v == 'string') else if (this.options.select_options &&
(result = $j.grep(this.options.select_options, function(e) {
return e.id == v;
}))
)
{ {
// Options should have been provided, but they weren't // Options should have been provided, but they weren't
// This can happen for ajax source with an existing value // This can happen for ajax source with an existing value
if(this.options.select_options == null) if(this.options.select_options == null)
{ {
this.options.select_options = {}; this.options.select_options = [];
} }
values[i] = { values[i] = result[0] ? result[0] : {
id: v, id: v,
label: v label: v
}; };
} }
else(this.options.select_options) else
{ {
if (typeof values[i].id == 'undefined') if (typeof values[i].id == 'undefined')
{ {
values[i] = { values[i] = {
id: v, id: v,
label: this.options.select_options[v] label: v
}; };
} }
} }
@ -423,7 +461,14 @@ var et2_taglist_account = et2_taglist.extend(
*/ */
set_account_type: function(value) set_account_type: function(value)
{ {
if(value != this.options.account_type)
{
this.options.select_options = [];
}
this.options.autocomplete_params.account_type = this.options.account_type = value; this.options.autocomplete_params.account_type = this.options.account_type = value;
this.options.select_options = this._get_accounts();
if(this.taglist != null) if(this.taglist != null)
{ {
// Update taglist too, since it already copied the params // Update taglist too, since it already copied the params
@ -431,6 +476,51 @@ var et2_taglist_account = et2_taglist.extend(
} }
}, },
/**
* Get account info for select options from common client-side account cache
*
* @return {Array} select options
*/
_get_accounts: function()
{
if (!jQuery.isArray(this.options.select_options))
{
var options = jQuery.extend({}, this.options.select_options);
this.options.select_options = [];
for(var key in options)
{
if (typeof options[key] == 'object')
{
if (typeof(options[key].key) == 'undefined')
{
options[key].value = key;
}
this.options.select_options.push(options[key]);
}
else
{
this.options.select_options.push({value: key, label: options[key]});
}
}
}
var type = this.egw().preference('account_selection', 'common');
var accounts = [];
// for primary_group we only display owngroups == own memberships, not other groups
if (type == 'primary_group' && this.options.account_type != 'accounts')
{
if (this.options.account_type == 'both')
{
accounts = this.egw().accounts('accounts');
}
accounts = accounts.concat(this.egw().accounts('owngroups'));
}
else
{
accounts = this.egw().accounts(this.options.account_type);
}
return this.options.select_options.concat(accounts);
},
int_reg_exp: /^-?[0-9]+$/, int_reg_exp: /^-?[0-9]+$/,
/** /**
@ -442,7 +532,7 @@ var et2_taglist_account = et2_taglist.extend(
{ {
if(!value) return this._super.call(this, value); if(!value) return this._super.call(this, value);
var values = jQuery.isArray(value) ? value : [value]; var values = jQuery.isArray(value) ? jQuery.extend([], value) : [value];
for(var i=0; i < values.length; ++i) for(var i=0; i < values.length; ++i)
{ {
var v = values[i]; var v = values[i];