* Copyright (C) 2007-2008 Laurent Destailleur * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /** \file htdocs/admin/menus/edit.php \ingroup core \brief Edition des menus \version $Id$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/html.formadmin.class.php"); require_once(DOL_DOCUMENT_ROOT."/core/menubase.class.php"); $langs->load("admin"); if (! $user->admin) accessforbidden(); $dirtop = "../../includes/menus/barre_top"; $dirleft = "../../includes/menus/barre_left"; $mesg=$_GET["mesg"]; $menu_handler_top=$conf->global->MAIN_MENU_BARRETOP; $menu_handler_left=$conf->global->MAIN_MENU_BARRELEFT; $menu_handler_top=eregi_replace('_backoffice\.php','',$menu_handler_top); $menu_handler_top=eregi_replace('_frontoffice\.php','',$menu_handler_top); $menu_handler_left=eregi_replace('_backoffice\.php','',$menu_handler_left); $menu_handler_left=eregi_replace('_frontoffice\.php','',$menu_handler_left); $menu_handler=$menu_handler_left; if ($_REQUEST["handler_origine"]) $menu_handler=$_REQUEST["handler_origine"]; if ($_REQUEST["menu_handler"]) $menu_handler=$_REQUEST["menu_handler"]; /* * Actions */ if (isset($_GET["action"]) && $_GET["action"] == 'update') { if (! $_POST['cancel']) { $menu = new Menubase($db); $result=$menu->fetch($_POST['menuId']); if ($result > 0) { $menu->titre=$_POST['titre']; $menu->leftmenu=$_POST['leftmenu']; $menu->url=$_POST['url']; $menu->langs=$_POST['langs']; $menu->position=$_POST['position']; $menu->perms=$_POST['perms']; $menu->target=$_POST['target']; $menu->user=$_POST['user']; $result=$menu->update($user); if ($result > 0) { $mesg='
'.$langs->trans("RecordModifiedSuccessfully").'
'; } else { $mesg='
'.$menu->error.'
'; } } else { $mesg='
'.$menu->error.'
'; } $_GET["menuId"]=$_POST['menuId']; $_GET["action"]="edit"; } else { header("Location: ".DOL_URL_ROOT."/admin/menus/index.php?menu_handler=".$menu_handler); exit; } if ($_GET['return']) { header("Location: ".DOL_URL_ROOT."/admin/menus/index.php?menu_handler=".$menu_handler); exit; } } if (isset($_GET["action"]) && $_GET["action"] == 'add') { if ($_POST['cancel']) { header("Location: ".DOL_URL_ROOT."/admin/menus/index.php?menu_handler=".$menu_handler); exit; } $langs->load("errors"); $error=0; if (! $error && ! $_POST['menu_handler']) { $mesg='
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("MenuHandler")).'
'; $_GET["action"] = 'create'; $error++; } if (! $error && ! $_POST['type']) { $mesg='
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("Type")).'
'; $_GET["action"] = 'create'; $error++; } if (! $error && ! $_POST['url']) { $mesg='
'.$langs->trans("ErrorFieldRequired",$langs->trans("Url")).'
'; $_GET["action"] = 'create'; $error++; } if (! $error && ! $_POST['titre']) { $mesg='
'.$langs->trans("ErrorFieldRequired",$langs->trans("Title")).'
'; $_GET["action"] = 'create'; $error++; } if (! $error && $_POST['menuId'] && $_POST['type'] == 'top') { $mesg='
'.$langs->trans("ErrorTopMenuMustHaveAParentWithId0").'
'; $_GET["action"] = 'create'; $error++; } if (! $error && ! $_POST['menuId'] && $_POST['type'] == 'left') { $mesg='
'.$langs->trans("ErrorLeftMenuMustHaveAParentId").'
'; $_GET["action"] = 'create'; $error++; } if (! $error) { $menu = new Menubase($db); $menu->fk_menu=$_POST['menuId']; $menu->menu_handler=$_POST['menu_handler']; $menu->type=$_POST['type']; $menu->titre=$_POST['titre']; $menu->leftmenu=$_POST['leftmenu']; $menu->url=$_POST['url']; $menu->langs=$_POST['langs']; $menu->position=$_POST['position']; $menu->perms=$_POST['perms']; $menu->target=$_POST['target']; $menu->user=$_POST['user']; $result=$menu->create($user); if ($result > 0) { header("Location: ".DOL_URL_ROOT."/admin/menus/index.php?menu_handler=".$_POST['menu_handler']); exit; } else { $_GET["action"] = 'create'; $mesg='
'.$menu->error.'
'; } } } if (isset($_GET["action"]) && $_GET["action"] == 'add_const') { if($_POST['type'] == 'prede') { $sql = "INSERT INTO ".MAIN_DB_PREFIX."menu_const(fk_menu, fk_constraint) VALUES(".$_POST['menuId'].",".$_POST['constraint'].")"; } else { $sql = "SELECT max(rowid) as maxId FROM ".MAIN_DB_PREFIX."menu_constraint"; $result = $db->query($sql); $objc = $db->fetch_object($result); $constraint = ($objc->maxId) + 1; $sql = "INSERT INTO ".MAIN_DB_PREFIX."menu_constraint(rowid,action) VALUES(".$constraint.",'".$_POST['constraint']."')"; $db->query($sql); $sql = "INSERT INTO ".MAIN_DB_PREFIX."menu_const(fk_menu, fk_constraint) VALUES(".$_POST['menuId'].",".$constraint.")"; } $db->query($sql); header("location:edit.php?action=edit&menuId=".$_POST['menuId']); exit; } if (isset($_GET["action"]) && $_GET["action"] == 'del_const') { $sql = "DELETE FROM ".MAIN_DB_PREFIX."menu_const WHERE fk_menu = ".$_GET['menuId']." AND fk_constraint = ".$_GET['constId']; $db->query($sql); $sql = "SELECT count(rowid) as countId FROM ".MAIN_DB_PREFIX."menu_const WHERE fk_constraint = ".$_GET['constId']; $result = $db->query($sql); $objc = $db->fetch_object($result); if($objc->countId == 0) { $sql = "DELETE FROM ".MAIN_DB_PREFIX."menu_constraint WHERE rowid = ".$_GET['constId']; $db->query($sql); } header("location:edit.php?action=edit&menuId=".$_GET['menuId']); exit; } // Suppression if ($_POST["action"] == 'confirm_delete' && $_POST["confirm"] == 'yes') { $this->db->begin(); $sql = "SELECT c.rowid, c.fk_constraint FROM ".MAIN_DB_PREFIX."menu_const as c WHERE c.fk_menu = ".$_GET['menuId']; $res = $db->query($sql); if ($res) { while ($obj = $db->fetch_object($res)) { $sql = "DELETE FROM ".MAIN_DB_PREFIX."menu_const WHERE rowid = ".$obj->rowid; $result = $db->query($sql); $sql = "SELECT count(rowid) as countId FROM ".MAIN_DB_PREFIX."menu_const WHERE fk_constraint = ".$obj->fk_constraint; $result = $db->query($sql); $objc = $db->fetch_object($result); if($objc->countId == 0) { $sql = "DELETE FROM ".MAIN_DB_PREFIX."menu_constraint WHERE rowid = ".$obj->fk_constraint; $db->query($sql); } } } $sql = "DELETE FROM ".MAIN_DB_PREFIX."menu WHERE rowid = ".$_GET['menuId']; $db->query($sql); if ($result == 0) { $this->db->commit(); llxHeader(); print '
'.$langs->trans("MenuDeleted").'
'; llxFooter(); exit ; } else { $this->db->rollback(); $reload = 0; $_GET["action"]=''; } } /* * Affichage page */ $html=new Form($db); $htmladmin=new FormAdmin($db); llxHeader(); if (isset($_GET["action"]) && $_GET["action"] == 'create') { print_titre($langs->trans("NewMenu"),'','setup'); if ($mesg) print $mesg; else print '
'; print '
'; print ''; // Id $parent_rowid = $_GET['menuId']; if ($_GET['menuId']) { $sql = "SELECT m.rowid, m.mainmenu, m.level, m.langs FROM ".MAIN_DB_PREFIX."menu as m WHERE m.rowid = ".$_GET['menuId']; $res = $db->query($sql); if ($res) { while ($menu = $db->fetch_array ($res)) { $parent_rowid = $menu['rowid']; $parent_mainmenu = $menu['mainmenu']; $parent_langs = $menu['langs']; $parent_level = $menu['level']; } } } // MenuId Parent print ''; if ($parent_rowid) { print ''; } else { print ''; } print ''; // Handler print ''; print ''; print ''; //User print ''; print ''; print ''; // Type print ''; //Titre print ''; //Langs print ''; //Position print ''; //URL print ''; //Target print ''; //Perms print ''; // Boutons print ''; print '
'.$langs->trans('MenuIdParent').''.$parent_rowid.''.$langs->trans('DetailMenuIdParent').'
'.$langs->trans('MenuHandler').''; print $htmladmin->select_menu_families($menu_handler,'menu_handler',$dirleft); print ''.$langs->trans('DetailMenuHandler').'
'.$langs->trans('MenuForUsers').''.$langs->trans('DetailUser').'
'.$langs->trans('Type').''; if ($parent_rowid) { print 'Left'; print ''; } else { print ''; } // print ''; print ''.$langs->trans('DetailType').'
'.$langs->trans('Title').''.$langs->trans('DetailTitre').'
'.$langs->trans('LangFile').''.$langs->trans('DetailLangs').'
'.$langs->trans('Position').''.$langs->trans('DetailPosition').'
'.$langs->trans('URL').''.$langs->trans('DetailUrl').'
'.$langs->trans('Target').''.$langs->trans('DetailTarget').'
'.$langs->trans('Rights').''.$langs->trans('DetailRight').'
'; print '     '; print '
'; print '
'; } elseif (isset($_GET["action"]) && $_GET["action"] == 'edit') { print_titre($langs->trans("ModifMenu"),'','setup'); print '
'; print '
'; print ''; print ''; $menu = new Menubase($db); $result=$menu->fetch($_GET['menuId']); // MenuId Parent print ''; //$menu_handler //print ''; print ''; print ''; print ''; // Id print ''; // Handler print ''; // Module print ''; // Type print ''; // User print ''; // Niveau //print ''; // Titre print ''; // Langs print ''; // Position print ''; // Url print ''; // Target print ''; // Perms print ''; // Bouton print ''; print '
'.$langs->trans('MenuIdParent').''.$menu->fk_menu.''.$langs->trans('DetailMenuIdParent').'
'.$langs->trans('Id').''.$menu->id.''.$langs->trans('DetailId').'
'.$langs->trans('MenuHandler').''.$menu->menu_handler.''.$langs->trans('DetailMenuHandler').'
'.$langs->trans('MenuModule').''.$menu->module.''.$langs->trans('DetailMenuModule').'
'.$langs->trans('Type').''.$menu->type.''.$langs->trans('DetailType').'
'.$langs->trans('MenuForUsers').''.$langs->trans('DetailUser').'
'.$langs->trans('Level').''.$menu->level.''.$langs->trans('DetailLevel').'
'.$langs->trans('Title').''.$langs->trans('DetailTitre').'
'.$langs->trans('LangFile').''.$langs->trans('DetailLangs').'
'.$langs->trans('Position').''.$langs->trans('DetailPosition').'
'.$langs->trans('URL').''.$langs->trans('DetailUrl').'
'.$langs->trans('Target').''.$langs->trans('DetailTarget').'
'.$langs->trans('Rights').''.$langs->trans('DetailRight').'
'; print '     '; print '
'; print '
'; print '
'; if ($mesg) print $mesg.'
'; /* * Lignes de contraintes */ $sql = 'SELECT c.rowid, c.action'; $sql.= ' FROM '.MAIN_DB_PREFIX.'menu_constraint as c, '.MAIN_DB_PREFIX.'menu_const as mc'; $sql.= ' WHERE c.rowid = mc.fk_constraint'; $sql.= ' AND mc.fk_menu = '.$_GET['menuId']; dolibarr_syslog("Edit: sql=".$sql, LOG_DEBUG); $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; print ''; if ($num) { print ''; print ''; print ''; print "\n"; } $var=true; $var = true; while ($i < $num) { $objc = $db->fetch_object($resql); $var = !$var; print ''; print ''; print ''; $i++; } print ''; print ''; print ''; print "\n"; // Ajout de contraintes personalisees print ''; print ''; print ''; $var=true; print ''; print ' '; print ' '; print ''; print ''; // Ajout de contraintes predefinis print ''; print ''; print ''; $var=!$var; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans('ConstraintsToShowOrNotEntry').' ('.$langs->trans("AllMustBeOk").') 
'.$objc->action.''.img_delete().'
'.$langs->trans('ConstraintsToShowOrNotEntry').' 
'; print ''; print '
'; $db->free($resql); } print ''; } print ''; $db->close(); llxFooter('$Date$ - $Revision$'); ?>