diff --git a/phpgwapi/inc/class.html.inc.php b/phpgwapi/inc/class.html.inc.php index 3fe8db73ea..82f611500b 100644 --- a/phpgwapi/inc/class.html.inc.php +++ b/phpgwapi/inc/class.html.inc.php @@ -256,9 +256,10 @@ class html * @param boolean $no_lang NOT run the labels of the options through lang(), default false=use lang() * @param string $options additional options (e.g. 'width') * @param int $multiple number of lines for a multiselect, default 3 + * @param boolean $selected_first show the selected items before the not selected ones, default true * @return string to set for a template or to echo into html page */ - function checkbox_multiselect($name, $key, $arr=0,$no_lang=false,$options='',$multiple=3) + function checkbox_multiselect($name, $key, $arr=0,$no_lang=false,$options='',$multiple=3,$selected_first=true) { if (!is_array($arr)) { @@ -279,6 +280,23 @@ class html } $html = ''; $options_no_id = preg_replace('/id="[^"]+"/i','',$options); + + if ($selected_first) + { + $selected = $not_selected = array(); + foreach($arr as $val => $label) + { + if (in_array($val,$key)) + { + $selected[$val] = $label; + } + else + { + $not_selected[$val] = $label; + } + } + $arr = $selected + $not_selected; + } foreach($arr as $val => $label) { if ($label && !$no_lang) $label = lang($label); @@ -288,7 +306,7 @@ class html $html .= $this->label($this->checkbox($name,in_array($val,$key),$val,$options_no_id.' id="'.$base_name.'['.$val.']'.'" '). $this->htmlspecialchars($label),$base_name.'['.$val.']')."
\n"; } - $style = 'height: '.(1.7*$multiple).'em; width: '.(4+0.6*$max_len).'em; background-color: white; overflow: auto; border: lightgray 2px inset;'; + $style = 'height: '.(1.7*$multiple).'em; width: '.(4+0.65*$max_len).'em; background-color: white; overflow: auto; border: lightgray 2px inset;'; return $this->div($html,$options,'',$style); }