diff --git a/htdocs/core/lib/company.lib.php b/htdocs/core/lib/company.lib.php index 5eb45fcca67..cebfbcb4991 100644 --- a/htdocs/core/lib/company.lib.php +++ b/htdocs/core/lib/company.lib.php @@ -89,34 +89,30 @@ function societe_prepare_head($object) // $this->tabs = array('entity:-tabname:Title:@mymodule:/mymodule/mypage.php?id=__ID__'); to remove a tab complete_head_from_modules($conf,$langs,$object,$head,$h,'thirdparty'); - // Notes if ($user->societe_id == 0) { + // Notes $head[$h][0] = DOL_URL_ROOT.'/societe/socnote.php?socid='.$object->id; $head[$h][1] = $langs->trans("Note"); $head[$h][2] = 'note'; $h++; - } - // Attached files - if ($user->societe_id == 0) - { + + // Attached files $head[$h][0] = DOL_URL_ROOT.'/societe/document.php?socid='.$object->id; $head[$h][1] = $langs->trans("Documents"); $head[$h][2] = 'document'; $h++; - } - // Notifications - if (! empty($conf->notification->enabled) && $user->societe_id == 0) - { - $head[$h][0] = DOL_URL_ROOT.'/societe/notify/fiche.php?socid='.$object->id; - $head[$h][1] = $langs->trans("Notifications"); - $head[$h][2] = 'notify'; - $h++; - } - - // Log - if ($user->societe_id == 0) - { + + // Notifications + if (! empty($conf->notification->enabled)) + { + $head[$h][0] = DOL_URL_ROOT.'/societe/notify/fiche.php?socid='.$object->id; + $head[$h][1] = $langs->trans("Notifications"); + $head[$h][2] = 'notify'; + $h++; + } + + // Log $head[$h][0] = DOL_URL_ROOT.'/societe/info.php?socid='.$object->id; $head[$h][1] = $langs->trans("Info"); $head[$h][2] = 'info'; diff --git a/htdocs/core/lib/functions.lib.php b/htdocs/core/lib/functions.lib.php index 18fa9a2dbaa..d9a59a6a483 100644 --- a/htdocs/core/lib/functions.lib.php +++ b/htdocs/core/lib/functions.lib.php @@ -4307,62 +4307,61 @@ function picto_from_langcode($codelang) */ function complete_head_from_modules($conf,$langs,$object,&$head,&$h,$type,$mode='add') { - if (is_array($conf->tabs_modules[$type])) - { - foreach ($conf->tabs_modules[$type] as $value) - { - $values=explode(':',$value); - - if ($mode == 'add') - { - if (count($values) == 6) // new declaration with permissions - { - if ($values[0] != $type) continue; - //print 'ee'.$values[4]; - if (verifCond($values[4])) - { - if ($values[3]) $langs->load($values[3]); - $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[5]),1); - $head[$h][1] = $langs->trans($values[2]); - $head[$h][2] = str_replace('+','',$values[1]); - $h++; - } - } - else if (count($values) == 5) // new declaration - { - if ($values[0] != $type) continue; - if ($values[3]) $langs->load($values[3]); - $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[4]),1); - $head[$h][1] = $langs->trans($values[2]); - $head[$h][2] = str_replace('+','',$values[1]); - $h++; - } - else if (count($values) == 4) // old declaration, for backward compatibility - { - if ($values[0] != $type) continue; - if ($values[2]) $langs->load($values[2]); - $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[3]),1); - $head[$h][1] = $langs->trans($values[1]); - $head[$h][2] = 'tab'.$values[1]; - $h++; - } - } - else if ($mode == 'remove') - { - if ($values[0] != $type) continue; - $tabname=str_replace('-','',$values[1]); - foreach($head as $key => $val) - { - if ($head[$key][2]==$tabname) - { - //print 'on vire '.$tabname.' key='.$key; - unset($head[$key]); - break; - } - } - } - } - } + if (is_array($conf->tabs_modules[$type])) + { + foreach ($conf->tabs_modules[$type] as $value) + { + $values=explode(':',$value); + + if ($mode == 'add' && ! preg_match('/^\-/',$values[1])) + { + if (count($values) == 6) // new declaration with permissions + { + if ($values[0] != $type) continue; + if (verifCond($values[4])) + { + if ($values[3]) $langs->load($values[3]); + $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[5]),1); + $head[$h][1] = $langs->trans($values[2]); + $head[$h][2] = str_replace('+','',$values[1]); + $h++; + } + } + else if (count($values) == 5) // new declaration + { + if ($values[0] != $type) continue; + if ($values[3]) $langs->load($values[3]); + $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[4]),1); + $head[$h][1] = $langs->trans($values[2]); + $head[$h][2] = str_replace('+','',$values[1]); + $h++; + } + else if (count($values) == 4) // old declaration, for backward compatibility + { + if ($values[0] != $type) continue; + if ($values[2]) $langs->load($values[2]); + $head[$h][0] = dol_buildpath(preg_replace('/__ID__/i',$object->id,$values[3]),1); + $head[$h][1] = $langs->trans($values[1]); + $head[$h][2] = 'tab'.$values[1]; + $h++; + } + } + else if ($mode == 'remove') + { + if ($values[0] != $type) continue; + $tabname=str_replace('-','',$values[1]); + foreach($head as $key => $val) + { + $condition = (! empty($values[3]) ? verifCond($values[3]) : 1); + if ($head[$key][2]==$tabname && $condition) + { + unset($head[$key]); + break; + } + } + } + } + } } /**