X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-plugins%2Fgoto%2Fadmin%2Fmimetypes%2Fclass_divListMimeTypes.inc;h=7c80b55ed5c53e33785bfd51bc71912689c00d7f;hb=d075a8c302c3b5b967bc70d7943e87f0f9c019a4;hp=c93a8cc07e9b3543a720b8cea6dbefc83119e4ed;hpb=e493d90e29285bff7dd805f86e1be2cb71c7a745;p=gosa.git
diff --git a/gosa-plugins/goto/admin/mimetypes/class_divListMimeTypes.inc b/gosa-plugins/goto/admin/mimetypes/class_divListMimeTypes.inc
index c93a8cc07..7c80b55ed 100644
--- a/gosa-plugins/goto/admin/mimetypes/class_divListMimeTypes.inc
+++ b/gosa-plugins/goto/admin/mimetypes/class_divListMimeTypes.inc
@@ -4,8 +4,6 @@ class divListMimeTypes extends MultiSelectWindow
{
/* Current base */
var $selectedBase = "";
- var $selectedRelease = "main";
- var $AvailableReleases = array();
var $departments = array();
var $parent ;
var $ui ;
@@ -16,20 +14,14 @@ class divListMimeTypes extends MultiSelectWindow
/* Subsearch checkbox */
var $SubSearch;
- /* These vars should be saved too */
- var $SaveAdditionalVars = array("selectedRelease");
-
-
function divListMimeTypes (&$config, &$parent)
{
/* Create divlist and setup */
MultiSelectWindow::MultiSelectWindow($config, "Mimetypes", "mimetypes");
/* initialize required attributes */
- $this->selectedRelease = get_ou('mimetypeou').session::get('CurrentMainBase');
$this->parent = &$parent;
$this->ui = get_userinfo();
- $this->AvailableReleases= $this->parent->getReleases($this->selectedBase);
/* Set list strings */
$this->SetTitle (_("List of defined mime types"));
@@ -50,7 +42,7 @@ class divListMimeTypes extends MultiSelectWindow
}
/* Toggle all selected / deselected */
- $chk = "";
/* set Page header */
@@ -60,23 +52,24 @@ class divListMimeTypes extends MultiSelectWindow
$this->AddHeader(array("string" => _("Actions"), "attach" => "style='width:".$action_col_size."px;border-right:0px;text-align:right;'"));
/* Add SubSearch checkbox */
- $this->AddCheckBox("SubSearch", _("Select to search within subtrees"), _("Search in subtrees"), false);
+ $this->AddCheckBox("SubSearch", msgPool::selectToView("","subsearch"), msgPool::selectToView("","subsearch_small"), false);
/* Name ,Text ,Default , Connect with alphabet */
$this->AddRegex ("Regex", _("Display mime types matching"),"*" , true);
}
- /* This function allows us to add a user defined filter part at position $position*/
function AddUserBoxToFilter($position)
{
$str = "";
if(($position == 2) && ($this->parent->IsReleaseManagementActivated($this->config))){
$smarty = get_smarty();
- $smarty->assign("selectedRelease",$this->selectedRelease);
+ $releases = $this->parent->getReleases();
+ $smarty->assign("mime_release" , $releases[$this->parent->mime_release]);
+ $smarty->assign("mime_base" , $releases[$this->parent->mime_base]);
$smarty->assign("branchimage","images/branch.png");
- $smarty->assign("releases",$this->AvailableReleases);
- $str = $smarty->fetch(get_template_path('release_select.tpl', TRUE,dirname(__FILE__)));
+ $smarty->assign("mime_releases", $releases);
+ $str = $smarty->fetch(get_template_path('release_select.tpl', TRUE));
}
return($str);
}
@@ -85,123 +78,54 @@ class divListMimeTypes extends MultiSelectWindow
/* Create list header, with create / copy & paste etc*/
function GenHeader()
{
- /* Prepare departments,
- which are shown in the listbox on top of the listbox
- */
- $options= "";
-
- /* Get all departments within this subtree */
- $ui= get_userinfo();
- $first = "";
- $found = FALSE;
- $base = $this->config->current['BASE'];
-
- /* Add base */
- $tmp = array();
- $tmp[] = array("dn"=>$this->config->current['BASE']);
- $tmp= array_merge($tmp,get_list("(&(|(ou=*)(description=*))(objectClass=gosaDepartment))", $this->module, $base,
- array("ou", "description"), GL_SIZELIMIT | GL_SUBSEARCH));
-
- $deps = array();
- foreach($tmp as $tm){
- $deps[$tm['dn']] = $tm['dn'];
- }
-
- /* Load possible departments */
- $ui= get_userinfo();
- $tdeps= $ui->get_module_departments($this->module);
- $ids = $this->config->idepartments;
- $first = "";
- $found = FALSE;
- foreach($ids as $dep => $name){
- if(isset($deps[$dep]) && in_array_ics($dep, $tdeps)){
-
- /* 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.= "";
- }
- }
- }
+ /* Add default header */
+ $listhead = MultiSelectWindow::get_default_header(false);
+ if(!$this->parent->IsReleaseManagementActivated()){
+
+ /* Get all departments within this subtree */
+ $ui= get_userinfo();
+ $first = "";
+ $found = FALSE;
+ $base = $this->config->current['BASE'];
+ $options = $this->create_department_list($this->module);
+
+ /* And at least add a department selection box */
+ $listhead .= _("Base")." ".
+ " ";
- /* The currently used base is not visible with your acl setup.
- * Set base to first useable base.
- */
- if(!$found){
- $this->selectedBase = $first;
}
/* Get acls */
$ui = get_userinfo();
- $acl = $ui->get_permissions("cn=dummy,".get_ou('mimetypeou').$this->selectedBase,"mimetypes/mimetype");
- $acl_all = $ui->has_complete_category_acls($this->selectedBase,"mimetypes") ;
+ $acl = $ui->get_permissions($this->parent->mime_base,"mimetypes/mimetype");
+ $acl_all = $ui->has_complete_category_acls($this->parent->mime_base,"mimetypes") ;
/* If this is true we add an additional seperator. Just look a few lines below */
$add_sep = false;
- /* Get copy & paste icon */
- $Copy_Paste ="";
- if(preg_match("/(c.*w|w.*c)/",$acl_all) && $this->parent->CopyPasteHandler){
- $Copy_Paste = $this->parent->CopyPasteHandler->generatePasteIcon();
- $add_sep = true;
- }
-
- /* Add default header */
- $listhead = MultiSelectWindow::get_default_header();
-
- /* And at least add a department selection box */
- $listhead .= _("Base")." ".
- " ";
-
/* Create Layers menu */
$s = ".|"._("Actions")."|\n";
- $s .= "..|".
- " "._("Create")."|\n";
/* Append create options */
if(preg_match("/c/",$acl)) {
+ $s .= "..|".
+ " "._("Create")."|\n";
$s.= "...|".
" "._("Mime type")."|mime_new|\n";
+ $s.= "..|---|\n";
}
/* Multiple options */
- $s.= "..|---|\n";
- $s.= "..|".
+ $s.= "..|".
" "._("Remove")."|"."remove_multiple|\n";
- /* Add multiple copy & cut icons */
- if(is_object($this->parent->CopyPasteHandler) && preg_match("/(c.*w|w.*c)/",$acl_all)){
- $s.= "..|---|\n";
- $s.= "..|".
- " "._("Copy")."|"."multiple_copy_systems|\n";
- $s.= "..|".
- " "._("Cut")."|"."multiple_cut_systems|\n";
-
- if($this->parent->CopyPasteHandler->entries_queued()){
- $img = "";
- $s.="..|".$img." "._("Paste")."|editPaste|\n";
- }else{
- $img = "";
- $s.="..|".$img." "._("Paste")."\n";
- }
- }
+ /* Add Copy & Paste header */
+ $s .= $this->parent->get_copypaste_header($this->selectedBase,$this->module);
/* Add snapshot icons */
- if(preg_match("/(c.*w|w.*c)/",$acl_all)){
- $s .= "..|---|\n";
- $s .= $this->get_snapshot_header(TRUE);
- }
+ $s .= $this->parent->get_snapshot_header($this->selectedBase,$this->module);
$this->SetDropDownHeaderMenu($s);
$this->SetListHeader($listhead);
@@ -223,9 +147,8 @@ class divListMimeTypes extends MultiSelectWindow
********************/
/* Create links */
- $linkopen = "%s";
$editlink = "%s";
- $userimg = "";
+ $userimg = "";
$mimeimg = "";
$empty = "";
@@ -241,33 +164,43 @@ class divListMimeTypes extends MultiSelectWindow
foreach($list as $key => $val){
+ /* Check FAI state
+ */
+ $FAIstate = $val['FAIstate'][0];
+
$ui = get_userinfo();
$acl = $ui->get_permissions($val['dn'],"mimetypes/mimetype");
$acl_all = $ui->has_complete_category_acls($val['dn'],"mimetypes") ;
- /* Create action icons */
- $actions = "";
- if(preg_match("/(c.*w|w.*c)/",$acl_all)){
- $actions .= $this->GetSnapShotActions($val['dn']);
- }
+ $action = "";
- /* Get copy Paste icons */
- if(($this->parent->CopyPasteHandler) && preg_match("/(c.*w|w.*c)/",$acl_all)){
- $actions.= " ";
- $actions.= " ";
+ /* Add copy & cut functionality */
+ if(!preg_match("/freeze/i",$FAIstate)){
+ $action.= $this->parent->get_copypaste_action($val['dn'],"mimetypes","mimetype");
+ }else{
+ $action.= " ";
+ $action.= " ";
}
- $actions.= "";
+ $action.= "";
+
+ /* Add snapshot icon */
+ if(!preg_match("/freeze/i",$FAIstate)){
+ $action.= $this->parent->get_snapshot_action($val['dn'],$this->module);
+ }else{
+ $action.= " ";
+ $action.= " ";
+ }
/* Add delete button */
- if(preg_match("/d/",$acl)){
- $actions.= "";
+ if(preg_match("/freeze/i",$FAIstate)){
+ $action .= "";
+ }elseif(preg_match("/d/",$acl)){
+ $action.= "";
}else{
- $actions.= "";
+ $action.= "";
}
$title = "title='".preg_replace('/ /', ' ', @LDAP::fix($val['dn']))."'";
@@ -295,7 +228,7 @@ class divListMimeTypes extends MultiSelectWindow
"attach" => "style='width:20px;'");
$field1 = array("string" => sprintf($mimeimg,$val['dn']), "attach" => "style='text-align:center;width:20px;'");
$field2 = array("string" => sprintf($editlink,$key,$display), "attach" => "style='' ".$title);
- $field3 = array("string" => preg_replace("/%KEY%/", $key, $actions), "attach" => "style='width:".$action_col_size."px;border-right:0px;text-align:right;'");
+ $field3 = array("string" => preg_replace("/%KEY%/", $key, $action), "attach" => "style='width:".$action_col_size."px;border-right:0px;text-align:right;'");
$this->AddElement(array($field0,$field1,$field2,$field3));
}
@@ -312,7 +245,7 @@ class divListMimeTypes extends MultiSelectWindow
$str = " ".$num_objs." ";
- $str.= " ".$num_deps." ";
$this->set_List_Bottom_Info($str);
@@ -327,16 +260,6 @@ class divListMimeTypes extends MultiSelectWindow
{
/* Save automatic created POSTs like regex, checkboxes */
MultiSelectWindow::save_object();
-
- /* check if returned selectedRelease is a valid release.
- If it isn't set to a valid release */
- $this->AvailableReleases = $this->parent->getReleases($this->selectedBase);
- if(!isset($this->AvailableReleases[$this->selectedRelease])){
- $this->selectedRelease =key($this->AvailableReleases);
- }
- $mimefilter = session::get('mimefilter');
- $mimefilter['release'] = $this->selectedRelease;
- session::set('mimefilter',$mimefilter);
}
}