X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_tabs.inc;h=6d1b5e871781daf574a885a21751473dd6e8ffe6;hb=198fc11cacca32ca2c0dc33505bde39a38b999e6;hp=f277f815bd7c0d5455838d15bfdee31ced4c82de;hpb=306fc4eb76b37c68d4dd3dd84b289e3813abaaf5;p=gosa.git diff --git a/gosa-core/include/class_tabs.inc b/gosa-core/include/class_tabs.inc index f277f815b..6d1b5e871 100644 --- a/gosa-core/include/class_tabs.inc +++ b/gosa-core/include/class_tabs.inc @@ -37,6 +37,8 @@ class tabs var $acl_category; var $multiple_support_active = FALSE; + var $parent = null; // A parent object if available, e.g. a management class. + var $read_only = FALSE; // Used when the entry is opened as "readonly" due to locks. var $hide_refs = FALSE; var $hide_acls = FALSE; @@ -52,7 +54,7 @@ class tabs if(!count($data)) { $data[] = array("CLASS" => 'plugin',"NAME" => 'Error'); msg_dialog::display(_("Error"), - sprintf(_("No plugin definitions found to initialize '%s', please check your configuration file."),get_class($this)), + sprintf(_("No plugin definition for %s found: please check the configuration file!"), bold(get_class($this))), "ERROR_DIALOG"); } @@ -61,8 +63,10 @@ class tabs foreach ($data as &$tab){ if (!plugin_available($tab['CLASS'])){ + trigger_error(sprintf("Unknown class %s!", bold($tab['CLASS']))); continue; } + if ($this->current == "") $this->current= $tab['CLASS']; $this->by_name[$tab['CLASS']]= $tab['NAME']; @@ -77,11 +81,6 @@ class tabs $this->read_only |= $this->by_object[$tab['CLASS']]->read_only; $this->by_object[$tab['CLASS']]->parent= &$this; $this->by_object[$tab['CLASS']]->set_acl_category($this->acl_category); - - /* Initialize current */ - if ($this->current == ""){ - $this->current= $tab['CLASS']; - } } } @@ -110,13 +109,17 @@ class tabs function execute() { - /* Ensure that the currently selected tab is valid. */ - if(!isset($this->by_name[$this->current])) $this->current = key($this->by_name); + // Ensure that the currently selected tab is valid. + if(!isset($this->by_name[$this->current])) { + $this->current = key($this->by_name); + } + + pathNavigator::registerPlugin($this); - /* Rotate current to last */ + // Rotate current to last $this->last= $this->current; - /* Look for pressed tab button */ + // Look for pressed tab button foreach ($this->by_object as $class => &$obj){ if (isset($_POST[$class]) || (isset($_POST['arg']) && $_POST['arg'] == "$class")){ $this->current= $class; @@ -124,33 +127,36 @@ class tabs } } - /* Save last tab object */ + // Save last tab object if ($this->last == $this->current){ $this->save_object(TRUE); } else { $this->save_object(FALSE); } - /* Show object */ - $display = "
\n"; - /* If multiple edit is enabled for this tab, we have tho display different templates */ if(!$this->multiple_support_active){ - $display.= $this->by_object[$this->current]->execute(); + $display= $this->by_object[$this->current]->execute(); }else{ - $display.= $this->by_object[$this->current]->multiple_execute(); + $display= $this->by_object[$this->current]->multiple_execute(); } - $modal_dialog = $this->by_object[$this->current]->is_modal_dialog(); - - /* Build tab line */ - $modal = TRUE; - $tabs= $this->gen_tabs($modal_dialog); + $tabs= $this->gen_tabs(); - /* Footer for tabbed dialog */ - $display = $tabs.$display." |
";
+ foreach ($this->by_name as $class => $name){
- /* Shorten string if its too long for the tab headers*/
+ // Shorten string if its too long for the tab headers
$title= _($name);
if (mb_strlen($title, 'UTF-8') > 28){
$title= mb_substr($title,0, 25, 'UTF-8')."...";
}
- /* nobr causes w3c warnings so we use to keep the tab name in one line */
+ // nobr causes w3c warnings so we use to keep the tab name in one line
$title= str_replace(" "," ",$title);
- /* Take care about notifications */
+ // Take care about notifications
$obj = $this->by_object[$class];
+ $tabClass = ($this->current == $class) ? "current" :"";
if ( $this->by_object[$class]->pl_notify && ($obj->is_account || $obj->ignore_account)){
- $notify= "id=\"notify\"";
- } else {
- $notify= "";
- }
-
- if($disabled){
- $display.= " ".$title." ";
- }elseif (session::global_get('js')==FALSE){
- $display.= " | ";
- } else {
- $display.= "";
+ $tabClass .= " info";
}
+ if(!empty($tabClass)) $tabClass="class='{$tabClass}'";
+ $onClick = "document.mainform.arg.value='{$class}'; document.mainform.submit();";
+ $display.= "\n \n";
- $display.= " |
"; + $ret .= "