X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_MultiSelectWindow.inc;h=bb67e2698dade915e3d81e45c054eb95260c9384;hb=dc43e93accd4cbba7c509d879579701e48c9d3be;hp=08e47a82fcdb1cd5730357d2172e513abb0b300d;hpb=e79b3cdfb979fd270d2fd1a53d2991f1ec4df5ec;p=gosa.git diff --git a/gosa-core/include/class_MultiSelectWindow.inc b/gosa-core/include/class_MultiSelectWindow.inc index 08e47a82f..bb67e2698 100644 --- a/gosa-core/include/class_MultiSelectWindow.inc +++ b/gosa-core/include/class_MultiSelectWindow.inc @@ -33,7 +33,7 @@ class MultiSelectWindow{ var $string_Title = ""; var $string_ListHeader = ""; - var $string_ListDropDown= ""; + var $string_ListDropDown= ""; var $string_Summary = ""; var $string_Information = ""; @@ -48,9 +48,11 @@ class MultiSelectWindow{ var $is_headpage = false; // if true the design changes var $filterName = "Liste"; var $DepartmentsAdded = false; - var $Added_Departments = array(); + var $Added_Departments = array(); var $selectedBase = ""; + private $departments= array(); + var $DivHeight = ""; var $HideFilterPart = false; @@ -63,6 +65,11 @@ class MultiSelectWindow{ function ClearElementsList() { + $ui =get_userinfo(); + $deps = $ui->get_module_departments($this->module); + if(!in_array($this->selectedBase, $deps)){ + $this->selectedBase = array_shift($deps); + } $this->array_Elements = array(); } @@ -550,16 +557,8 @@ class MultiSelectWindow{ $base_back= preg_replace("/^[^,]+,/", "", session::get('CurrentMainBase')); $dep_id = $this->ui->get_module_departments($this->module); if(in_array_ics($base_back,$dep_id)){ - - /* The department array keeps non DN entries as index. We need to convert - it before checking the existance. */ - $base_back= trim(convert_department_dn($base_back)); - - /* Check if the department exists, otherwise revert to the configure base DN */ - if(isset($this->config->departments[$base_back])){ - $this->selectedBase= $this->config->departments[$base_back]; - }else{ - $this->selectedBase= $this->config->departments['/']; + if(in_array($base_back,$this->config->departments)){ + $this->selectedBase = $base_back; } } } @@ -658,34 +657,49 @@ class MultiSelectWindow{ /* Get all departments within this subtree */ $deps= get_list("(&(|(ou=*)(description=*))(objectClass=gosaDepartment))", $this->module, $base, - array("ou", "description"), GL_SIZELIMIT ); + array("ou", "description","objectClass"), GL_SIZELIMIT ); /* Edit delete link for system types */ $linkopen = "%s"; /* Create an array with all visible (in the list) departments */ + $types = departmentManagement::get_support_departments(); + $departments = array(); foreach($deps as $value){ $name = $value['ou'][0]." -".$value['dn']; - $this->departments[$name]= $value; + foreach($types as $type){ + if(in_array($type['OC'],$value['objectClass'])){ + $value['type'] = $type; + break; + } + } + $this->departments[$name]= $value; } uksort($this->departments, 'strnatcasecmp'); - $this->departments = array_values($this->departments); + + $ui = get_userinfo(); + $module_deps = $ui->get_module_departments($this->module); /* Add deps to this dialog object list */ + $this->departments = array_values($this->departments); foreach($this->departments as $key=> $val){ + if(!in_array($val['dn'],$module_deps)) continue; + /* Check if this department contains sub-departments Display different image in this case */ - $non_empty=""; + $img = $val['type']['IMG']; foreach($this->config->departments as $keyd){ if(preg_match("/,".normalizePreg($val['dn'])."$/",$keyd)){ - $non_empty="-full"; + $img = $val['type']['IMG_FULL']; } } + $img = ""; + /* Add spacer cols to divlist */ $row = array(); @@ -704,7 +718,6 @@ class MultiSelectWindow{ /* Add departments */ - $img = "department"; $row[]=$field1=array("string"=> $img,"attach"=>"style='text-align:center;width:20px;'"); $row[]=$field2=array("string"=>sprintf($linkopen,$key,$name), "attach" => "style=''"); @@ -724,6 +737,61 @@ class MultiSelectWindow{ } } + + function create_department_list($modules) + { + /* Load possible departments */ + $ui= get_userinfo(); + $first = ""; + $found = FALSE; + + if(!is_array($modules)){ + $modules = array($modules); + } + + $department = $departments = array(); + $ids = $this->config->idepartments; + foreach($modules as $module){ + $d = $ui->get_module_departments($module); + + foreach($ids as $department => $desc){ + if(in_array($department,$d)){ + $departments[$department] = $department; + } + } + } + + $first = ""; + $found = FALSE; + $options =""; + foreach($departments as $dep => $name){ + + /* Keep first base dn in mind, we could need this + * info if no valid base was found + */ + if(empty($first)) { + $first = $dep['dn']; + } + + $value = $ids[$dep]; + if ($this->selectedBase == $dep){ + $found = TRUE; + $options.= ""; + } else { + $options.= ""; + } + } + + /* The currently used base is not visible with your acl setup. + * Set base to first useable base. + */ + if(!$found){ + $this->selectedBase = $first; + } + + return($options); + } + function set_List_Bottom_Info($str) { $this->List_Bottom_Info = $str;