forked from extern/egroupware
- changing column selection preference now works if 'nextmatch-' prefix is included in the columnselection_pref setting
- change column selection popup to reload every time it opens, just in case something changes in the columns
This commit is contained in:
parent
001eab9159
commit
2e09cf1ab1
@ -50,7 +50,7 @@
|
|||||||
* 'total' => // O the total number of entries
|
* 'total' => // O the total number of entries
|
||||||
* 'sel_options' => // O additional or changed sel_options set by the callback and merged into $tmpl->sel_options
|
* 'sel_options' => // O additional or changed sel_options set by the callback and merged into $tmpl->sel_options
|
||||||
* 'no_columnselection' => // I turns off the columnselection completly, turned on by default
|
* 'no_columnselection' => // I turns off the columnselection completly, turned on by default
|
||||||
* 'columnselection-pref' => // I name of the preference (plus 'nextmatch-' prefix), default = template-name
|
* 'columnselection_pref' => // I name of the preference (plus 'nextmatch-' prefix), default = template-name
|
||||||
* 'default_cols' => // I columns to use if there's no user or default pref (! as first char uses all but the named columns), default all columns
|
* 'default_cols' => // I columns to use if there's no user or default pref (! as first char uses all but the named columns), default all columns
|
||||||
* 'options-selectcols' => // I array with name/label pairs for the column-selection, this gets autodetected by default. A name => false suppresses a column completly.
|
* 'options-selectcols' => // I array with name/label pairs for the column-selection, this gets autodetected by default. A name => false suppresses a column completly.
|
||||||
* 'return' => // IO allows to return something from the get_rows function if $query is a var-param!
|
* 'return' => // IO allows to return something from the get_rows function if $query is a var-param!
|
||||||
|
@ -684,11 +684,22 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
// Set preference name so changes are saved
|
// Set preference name so changes are saved
|
||||||
this.options.settings.columnselection_pref = this.options.template;
|
this.options.settings.columnselection_pref = this.options.template;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var app = '';
|
||||||
if(this.options.settings.columnselection_pref) {
|
if(this.options.settings.columnselection_pref) {
|
||||||
|
var pref = {};
|
||||||
var list = et2_csvSplit(this.options.settings.columnselection_pref, 2, ".");
|
var list = et2_csvSplit(this.options.settings.columnselection_pref, 2, ".");
|
||||||
var app = list[0];
|
if(this.options.settings.columnselection_pref.indexOf('nextmatch') == 0)
|
||||||
|
{
|
||||||
|
app = list[0].substring('nextmatch'.length+1);
|
||||||
|
pref = egw.preference(this.options.settings.columnselection_pref, app);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
app = list[0];
|
||||||
// 'nextmatch-' prefix is there in preference name, but not in setting, so add it in
|
// 'nextmatch-' prefix is there in preference name, but not in setting, so add it in
|
||||||
var pref = egw.preference("nextmatch-"+this.options.settings.columnselection_pref, list[0]);
|
pref = egw.preference("nextmatch-"+this.options.settings.columnselection_pref, app);
|
||||||
|
}
|
||||||
if(pref)
|
if(pref)
|
||||||
{
|
{
|
||||||
negated = (pref[0] == "!");
|
negated = (pref[0] == "!");
|
||||||
@ -710,7 +721,14 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
var size = {};
|
var size = {};
|
||||||
if(this.options.settings.columnselection_pref && app)
|
if(this.options.settings.columnselection_pref && app)
|
||||||
{
|
{
|
||||||
size = this.egw().preference("nextmatch-"+this.options.settings.columnselection_pref+"-size", app);
|
var size_pref = this.options.settings.columnselection_pref +"-size";
|
||||||
|
|
||||||
|
// If columnselection pref is missing prefix, add it in
|
||||||
|
if(size_pref.indexOf('nextmatch') == -1)
|
||||||
|
{
|
||||||
|
size_pref = 'nextmatch-'+size_pref;
|
||||||
|
}
|
||||||
|
size = this.egw().preference(size_pref, app);
|
||||||
}
|
}
|
||||||
if(!size) size = {};
|
if(!size) size = {};
|
||||||
return {
|
return {
|
||||||
@ -1272,12 +1290,14 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
{
|
{
|
||||||
self.getInstanceManager().submit();
|
self.getInstanceManager().submit();
|
||||||
}
|
}
|
||||||
|
self.selectPopup = null;
|
||||||
};
|
};
|
||||||
|
|
||||||
var cancelButton = et2_createWidget("buttononly", {}, this);
|
var cancelButton = et2_createWidget("buttononly", {}, this);
|
||||||
cancelButton.set_label(this.egw().lang("cancel"));
|
cancelButton.set_label(this.egw().lang("cancel"));
|
||||||
cancelButton.onclick = function() {
|
cancelButton.onclick = function() {
|
||||||
self.selectPopup.toggle();
|
self.selectPopup.toggle();
|
||||||
|
self.selectPopup = null;
|
||||||
};
|
};
|
||||||
|
|
||||||
this.selectPopup = jQuery(document.createElement("div"))
|
this.selectPopup = jQuery(document.createElement("div"))
|
||||||
|
Loading…
Reference in New Issue
Block a user