mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-20 12:58:46 +01:00
new sub-type for the nextmatch widget: custom filter. It allows to use any (select-)widget (specified as 1. option) as filterheader for the nextmatch widget. The accountfilter is now only a special case for the customfilter or filterheader.
This commit is contained in:
parent
aeb51ceee2
commit
03a7efb8a0
@ -886,14 +886,15 @@ function index($content = 0)
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><b>Nextmatch-<br />SortHeader</b><p><b>Nextmatch-<br />FilterHeader</b><p><b>Nextmatch-<br />AccountFilter</b></td>
|
<td><b>Nextmatch-<br />SortHeader</b><p><b>Nextmatch-<br />FilterHeader</b><p><b>Nextmatch-<br />Custom FilterHeader</b><p><b>Nextmatch-<br />AccountFilter</b></td>
|
||||||
<td>
|
<td>
|
||||||
<nextmatch type="nextmatch-sortheader" id="col-name" options="DESC" label="ColLabel"/><p>
|
<nextmatch type="nextmatch-sortheader" id="col-name" options="DESC" label="ColLabel"/><p>
|
||||||
<nextmatch type="nextmatch-filterheader" id="col-name"/><p>
|
<nextmatch type="nextmatch-filterheader" id="col-name"/><p>
|
||||||
|
<nextmatch type="nextmatch-customfilter" id="col-name" options="select-precent"/><p>
|
||||||
<nextmatch type="nextmatch-accountfilter" id="col-name"/>
|
<nextmatch type="nextmatch-accountfilter" id="col-name"/>
|
||||||
</td>
|
</td>
|
||||||
<td>no</td>
|
<td>no</td>
|
||||||
<td>nextmatch-<br />sortheader<p>nextmatch-<br />filterheader<p>nextmatch-<br />accountfilter</td>
|
<td>nextmatch-<br />sortheader<p>nextmatch-<br />filterheader<p>nextmatch-<br />customfilter<p>nextmatch-<br />accountfilter</td>
|
||||||
<td>
|
<td>
|
||||||
These widget are an optional part of the nextmatch widget.<p>
|
These widget are an optional part of the nextmatch widget.<p>
|
||||||
<b>nextmatch-sortheader</b><br />
|
<b>nextmatch-sortheader</b><br />
|
||||||
@ -907,10 +908,13 @@ function index($content = 0)
|
|||||||
(xml:id), the options of the displayed selectbox need to be set as for an ordinary selectbox (eg. in the options
|
(xml:id), the options of the displayed selectbox need to be set as for an ordinary selectbox (eg. in the options
|
||||||
parameter to the uietemplate::exec function). If no extra-label is given in options, lang('all') will be used for
|
parameter to the uietemplate::exec function). If no extra-label is given in options, lang('all') will be used for
|
||||||
the empty value, which means no filter activ. An (optional) <b>label</b> can be given.<p>
|
the empty value, which means no filter activ. An (optional) <b>label</b> can be given.<p>
|
||||||
|
<b>nextmatch-customfilter</b><br />
|
||||||
|
The custom filterheader allows to use other (select-)widgets to filter by them. They have to be specified as the first
|
||||||
|
parameter in the comma-separated options attribute. In all other aspects it is identical to the filterheader.<p>
|
||||||
<b>nextmatch-accountfilter</b><br />
|
<b>nextmatch-accountfilter</b><br />
|
||||||
The Accountfilter allows to select users (via the prefered user-selection-method) to filter by them. In all other aspects
|
The Accountfilter allows to select users (via the prefered user-selection-method) to filter by them.
|
||||||
it is identical to the filterheader.<p>
|
It's identical to a <b>nextmatch-customfilter</b> with options="select-account".<p>
|
||||||
<i><u>Note</u>:</i> All three widgets interoperate with the nextmatch-widget which passes the set values as part if
|
<i><u>Note</u>:</i> All four widgets interoperate with the nextmatch-widget which passes the set values as part if
|
||||||
the query-parameter to its get_rows function, they are <u>not</u> returned in the rows sub-array.
|
the query-parameter to its get_rows function, they are <u>not</u> returned in the rows sub-array.
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@ -66,10 +66,11 @@
|
|||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
var $human_name = array(
|
var $human_name = array(
|
||||||
'nextmatch' => 'Nextmatch',
|
'nextmatch' => 'Nextmatch',
|
||||||
'nextmatch-sortheader' => 'Nextmatch Sortheader',
|
'nextmatch-sortheader' => 'Nextmatch Sortheader',
|
||||||
'nextmatch-filterheader' => 'Nextmatch Filterheader',
|
'nextmatch-filterheader' => 'Nextmatch Filterheader',
|
||||||
'nextmatch-accountfilter' => 'Nextmatch Accountfilter',
|
'nextmatch-accountfilter' => 'Nextmatch Accountfilter',
|
||||||
|
'nextmatch-customfilter' => 'Nextmatch Custom Filterheader',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -139,8 +140,15 @@
|
|||||||
}
|
}
|
||||||
return True;
|
return True;
|
||||||
|
|
||||||
|
case 'nextmatch-accountfilter': // Option: as for selectbox: [extra-label(default ALL)[,#lines(default 1)]]
|
||||||
|
$cell['size'] = 'select-account,'.$cell['size'];
|
||||||
|
// fall through
|
||||||
|
case 'nextmatch-customfilter': // Option: widget-name, options as for selectbox
|
||||||
|
list($type,$cell['size']) = explode(',',$cell['size'],2);
|
||||||
|
// fall through
|
||||||
case 'nextmatch-filterheader': // Option: as for selectbox: [extra-label(default ALL)[,#lines(default 1)]]
|
case 'nextmatch-filterheader': // Option: as for selectbox: [extra-label(default ALL)[,#lines(default 1)]]
|
||||||
$cell['type'] = 'select';
|
if (!$type) $type = 'select';
|
||||||
|
$cell['type'] = $type;
|
||||||
if (!$cell['size'])
|
if (!$cell['size'])
|
||||||
{
|
{
|
||||||
$cell['size'] = 'All';
|
$cell['size'] = 'All';
|
||||||
@ -152,21 +160,6 @@
|
|||||||
$cell['onchange'] = $cell['noprint'] = True;
|
$cell['onchange'] = $cell['noprint'] = True;
|
||||||
$extension_data['old_value'] = $value = $nm_global['col_filter'][$this->last_part($name)];
|
$extension_data['old_value'] = $value = $nm_global['col_filter'][$this->last_part($name)];
|
||||||
return True;
|
return True;
|
||||||
|
|
||||||
case 'nextmatch-accountfilter': // Option: as for selectbox: [extra-label(default ALL)[,#lines(default 1)]]
|
|
||||||
$cell['type'] = 'select-account';
|
|
||||||
$cell['name'] .= '[account]';
|
|
||||||
if (!$cell['size'])
|
|
||||||
{
|
|
||||||
$cell['size'] = 'All';
|
|
||||||
}
|
|
||||||
if (!$cell['help'])
|
|
||||||
{
|
|
||||||
$cell['help'] = 'select which accounts to show';
|
|
||||||
}
|
|
||||||
$cell['onchange'] = $cell['noprint'] = True;
|
|
||||||
$extension_data['old_value'] = $value = $nm_global['col_filter'][$this->last_part($name)];
|
|
||||||
return True;
|
|
||||||
}
|
}
|
||||||
if (!$value['filter_onchange']) $value['filter_onchange'] = 'this.form.submit();';
|
if (!$value['filter_onchange']) $value['filter_onchange'] = 'this.form.submit();';
|
||||||
if (!$value['filter2_onchange']) $value['filter2_onchange'] = 'this.form.submit();';
|
if (!$value['filter2_onchange']) $value['filter2_onchange'] = 'this.form.submit();';
|
||||||
@ -365,6 +358,9 @@
|
|||||||
//echo "<p>nextmatch_widget.post_process(type='$extension_data[type]', name='$name',value_in=".print_r($value_in,true).",order='$nm_global[order]'): value = "; _debug_array($value);
|
//echo "<p>nextmatch_widget.post_process(type='$extension_data[type]', name='$name',value_in=".print_r($value_in,true).",order='$nm_global[order]'): value = "; _debug_array($value);
|
||||||
switch($extension_data['type'])
|
switch($extension_data['type'])
|
||||||
{
|
{
|
||||||
|
case 'nextmatch':
|
||||||
|
break;
|
||||||
|
|
||||||
case 'nextmatch-sortheader':
|
case 'nextmatch-sortheader':
|
||||||
if ($value_in)
|
if ($value_in)
|
||||||
{
|
{
|
||||||
@ -373,9 +369,10 @@
|
|||||||
}
|
}
|
||||||
return False; // dont report value back, as it's in the wrong location (rows)
|
return False; // dont report value back, as it's in the wrong location (rows)
|
||||||
|
|
||||||
|
default:
|
||||||
case 'select-account': // used by nextmatch-accountfilter
|
case 'select-account': // used by nextmatch-accountfilter
|
||||||
case 'nextmatch-filterheader':
|
case 'nextmatch-filterheader':
|
||||||
if ($value_in != $extension_data['old_value'] && !(!$value_in && !$extension_data['old_value']))
|
if ((string)$value_in != (string)$extension_data['old_value'])
|
||||||
{
|
{
|
||||||
//echo "<p>setting nm_global[filter][".$this->last_part($name)."]='$value_in' (was '$extension_data[old_value]')</p>\n";
|
//echo "<p>setting nm_global[filter][".$this->last_part($name)."]='$value_in' (was '$extension_data[old_value]')</p>\n";
|
||||||
$nm_global['filter'][$this->last_part($name)] = $value_in;
|
$nm_global['filter'][$this->last_part($name)] = $value_in;
|
||||||
|
Loading…
Reference in New Issue
Block a user