Code

Made current main base set up more early
[gosa.git] / include / class_MultiSelectWindow.inc
index 11c86d7c0a8ca29db5ed94aa01c49f2589076d71..6cb52c0f6651490c0c0d14a20502b9fd1726cc26 100644 (file)
@@ -9,35 +9,46 @@ class MultiSelectWindow{
        var $bool_DisplaySaveButton = true;     
 
        var $SaveButtonString           = "";
-       var $CloseButtonString          = "";
+       var $CloseButtonString  = "";
 
-       var $string_Title                       = "";
-       var $string_ListHeader          = "";
+       var $string_Title                         = "";
+       var $string_ListHeader  = "";
        var $string_Summary                     = "";
-       var $string_Information         = "";
+       var $string_Information = "";
 
-       var $array_Header                       = array();
+       var $array_Header                         = array();
        var $array_Elements                     = array();      
        var $array_Checkboxes           = array();      
        var $array_Regexes                      = array();      
 
-       var $config                                     = array("");
-
-       var $is_closed                          = false;
-       var $is_saved                           = false;
+       var $config                                         = array("");
+       var $is_closed                            = false;
+       var $is_saved                               = false;
+       var $is_headpage                          = false;      // if true the design changes
+       var $filterName                           = "Liste";
+       var $DepartmentsAdded           = false;
+       var $selectedBase       = "";
 
-       var $is_headpage                        = false;        // if true the design changes
+  var $DivHeight          = "";
 
-       var $filterName                         = "Liste";
+  var $HideFilterPart     = false;
 
-       var $DepartmentsAdded           = false;
-       var $selectedBase               = "";
+  var $SaveAdditionalVars = array();  // Additional Post vars to store 
 
        function ClearElementsList()
        {
                $this->array_Elements = array();
        }
 
+  function HideFilterPart($bool = true)
+  {
+    $this->HideFilterPart = $bool;
+  }
+
+  function SetHeight($height)
+  { 
+    $this->DivHeight=$height;
+  }
 
        /* Adds a regex input field to the current dialog */
        function AddRegex($name,$string,$value,$conn,$image="images/search.png")
@@ -68,11 +79,16 @@ class MultiSelectWindow{
                $this->CloseButtonString        = _("Close");
                $this->filterName                       = $filterName;
 
-               /* Set default base */
-               if(!isset($_SESSION['CurrentMainBase'])){
-                       $_SESSION['CurrentMainBase'] = $this->config->current['BASE'];
-               }
+               /* Set default base, to users base  */
                $this->selectedBase = $_SESSION['CurrentMainBase'];
+
+    /* Check default values for SaveAdditionalVars */
+    foreach($this->SaveAdditionalVars as $name){
+      if(isset($_SESSION['MultiDialogFilters'][$this->filterName][$name])){
+        $this->$name = $_SESSION['MultiDialogFilters'][$this->filterName][$name];
+      }
+    }
+    
        }
 
        /* Enables the headpage mode, which changes the list look */
@@ -152,16 +168,19 @@ class MultiSelectWindow{
                                $arr['default'] = $_SESSION['MultiDialogFilters'][$this->filterName][$name];
                                $this->$name = $arr['default'];
                        }else{
-                               $arr['default'] = $default;
+                               $arr['default'] = $default; 
+        $this->$name = $default;
                        }
-                       $arr['name']    = $name;
-                       $arr['string']  = $string;
-                       $arr['value']   = $value;
-                       $arr['enabled'] = true;
+                       $arr['name']          = $name;
+                       $arr['string']      = $string;
+                       $arr['value']         = $value;
+                       $arr['enabled']     = true;
+
                }
                $this->array_Checkboxes[] = $arr;
        }
 
+
        /* Hides or unhides the checkbox with the given name */
        function DisableCheckBox($name,$HideShow = false)
        {
@@ -173,7 +192,6 @@ class MultiSelectWindow{
        }
 
 
-
        /* Returns true if the close button was pressed */
        function isClosed()
        {
@@ -192,6 +210,15 @@ class MultiSelectWindow{
                $this->bool_DisplaySaveButton = $bool;
        }
 
+  /* Add a list specific filter object to position 
+      1 on top of Information 
+      2 Between Information && Filter
+      3 Below the Filter Part */
+  function AddUserBoxToFilter($position)
+  {
+    return("");
+  }
+
        /* Draw the list with all list elements and filters */
        function Draw()
        {
@@ -202,10 +229,17 @@ class MultiSelectWindow{
                }
 
                $smarty = get_smarty();
+               $smarty->assign("UserBox1",$this->AddUserBoxToFilter(1));
+               $smarty->assign("UserBox2",$this->AddUserBoxToFilter(2));
+               $smarty->assign("UserBox3",$this->AddUserBoxToFilter(3));
 
                $divlist = new divlist($this->string_Title);
                $divlist->SetSummary($this->string_Summary);
                $divlist->SetEntriesPerPage(0); // 0 for scrollable list 
+  
+    if($this->DivHeight != ""){
+      $divlist->SetHeight($this->DivHeight);
+    }
 
                /* set Header informations 
                 */
@@ -265,6 +299,13 @@ class MultiSelectWindow{
                }
                $smarty->assign("regexes"                       , $regexes );
 
+    /* Hide Filter Part if Requested or empty */
+    if((empty($boxes)) && (empty($regexes)) || ($this->HideFilterPart)){
+                 $smarty->assign("Skip_Filter_Part",   true);
+    }else{ 
+                 $smarty->assign("Skip_Filter_Part",   false);
+    }
+
                /* Assign alphabet and display it 
                 */     
                $smarty->assign("Display_alphabet",     $this->bool_DisplayAlpahabet);
@@ -340,16 +381,20 @@ class MultiSelectWindow{
 
                        /* Homebutton is posted */
                        if($s_action=="home"){
-                               $ui= get_userinfo();
-                               $this->selectedBase=(preg_replace("/^[^,]+,/","",$ui->dn));
-                               $this->selectedBase=(preg_replace("/^[^,]+,/","",$this->selectedBase));
+        $ui= get_userinfo();
+        $base = get_base_from_people($ui->dn);
+                               $this->selectedBase= $base;
                        }
 
                        /* Open selected department
                           this is posted by the parent class MultiSelectWindow */
                        if(isset($_GET['act'])&& ($_GET['act'] == "dep_open")){
                                $s_entry = base64_decode($_GET['dep_id']);
-                               $this->selectedBase = $this->config->departments[trim($s_entry)];
+        if (!isset($this->config->departments[$s_entry])){
+          print_red(_("Error: The requested subtree has an inconsistent DN encoding, check your LDAP!"));
+        } else {
+                               $this->selectedBase = $this->config->departments[$s_entry];
+        }
                        }
 
                        /* back to the roots ^^ */
@@ -359,7 +404,7 @@ class MultiSelectWindow{
 
 
                        /* If Back-button is pressed, move back one step in DN */
-                       if($s_action == "back"){
+                       if($s_action=="back"){
                                //FIXME: This is not 100% correct. We'll only display ou's, but there may be
                                //       a step between. You'll stumble in a "hidden" department in this case.
                                $base_back= preg_replace("/^[^,]+,/", "", $_SESSION['CurrentMainBase']);
@@ -370,14 +415,26 @@ class MultiSelectWindow{
 
                                /* Check if the department exists, otherwise revert to the configure base DN */
                                if(isset($this->config->departments[$base_back])){
-                                       $_SESSION['CurrentMainBase']= $this->config->departments[$base_back];
+                                       $this->selectedBase= $this->config->departments[$base_back];
                                }else{
-                                       $_SESSION['CurrentMainBase']= $this->config->departments['/'];
+                                       $this->selectedBase= $this->config->departments['/'];
                                }
                        }
+      $_SESSION['CurrentMainBase'] = $this->selectedBase;
                }
+
                if(isset($_POST['MultiSelectWindow'.$this->filterName])){
 
+      /* Save some additional vars */
+      foreach($this->SaveAdditionalVars as $name){
+        if(isset($_POST[$name])){
+          if(isset($this->$name)){
+            $this->$name = $_POST[$name];
+            $_SESSION['MultiDialogFilters'][$this->filterName][$name] = $_POST[$name];
+          }
+        }
+      }
+
                        /* Check posts from checkboxes 
                         */
                        foreach($this->array_Checkboxes as $key => $box){
@@ -483,19 +540,18 @@ class MultiSelectWindow{
                                }
                        }
 
-
                        /* Add to divlist */
                        $row = array();
-                       $row[] = $field1 = array("string" => "<img src='images/".$non_empty."folder.png' alt='department'>", "attach" => "style='text-align:center;width:20px;'");
-                       $row[] = $field2 = array("string" => sprintf($linkopen,base64_encode($key),$val), "attach" => "style=''");
+                       $row[]=$field1=array("string"=>"<img src='images/".$non_empty."folder.png' alt='department'>","attach"=>"style='text-align:center;width:20px;'");
+                       $row[]=$field2=array("string"=>sprintf($linkopen,base64_encode($key),$val), "attach" => "style=''");
 
                        if($numtabs > 2){       
                                for($i = 2 ; $i <$numtabs;$i++){
-                                       if($i ==($numtabs-1)){
-                                               $row[] = array("string"=>"&nbsp;","attach" => "style='width:60px;border-right:0px;text-align:right;'");
-                                       }else{
-                                               $row[] = array("string"=>"&nbsp;");
-                                       }
+          if(isset( $this->array_Header[$i]['attach'])){
+            $row[] = array("string"=>"&nbsp;","attach" => $this->array_Header[$i]['attach']);
+          }else{
+            $row[] = array("string"=>"&nbsp;");
+          }
                                }
                        }
 
@@ -503,5 +559,5 @@ class MultiSelectWindow{
                }
        }
 }
-
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
 ?>