* 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. * * $Id$ */ /** \file htdocs/admin/menus/index.php \ingroup core \brief Gestion des menus */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/html.formadmin.class.php"); $langs->load("other"); $langs->load("admin"); if (! $user->admin) accessforbidden(); $dirtop = "../../includes/menus/barre_top"; $dirleft = "../../includes/menus/barre_left"; $mesg=$_GET["mesg"]; $menu_handler_top=eregi_replace('\.php','',$conf->global->MAIN_MENU_BARRETOP); $menu_handler_left=eregi_replace('\.php','',$conf->global->MAIN_MENU_BARRELEFT); $menu_handler_top=eregi_replace('_backoffice','',$menu_handler_top); $menu_handler_top=eregi_replace('_frontoffice','',$menu_handler_top); $menu_handler_left=eregi_replace('_backoffice','',$menu_handler_left); $menu_handler_left=eregi_replace('_frontoffice','',$menu_handler_left); $menu_handler=$menu_handler_left; if ($_REQUEST["menu_handler"]) $menu_handler=$_REQUEST["menu_handler"]; /* * Actions */ if (isset($_GET["action"]) && $_GET["action"] == 'up') { $sql = "SELECT m.rowid, m.position FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.rowid = ".$_GET["menuId"]; $result = $db->query($sql); $num = $db->num_rows($result); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $precedent['rowid'] = $obj->rowid; $precedent['order'] = $obj->position; $i++; } // Menu top $sql = "SELECT m.rowid, m.position FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.position = ".($precedent['order'] - 1)." AND m.type = 'top'"; $sql.= " AND menu_handler='".$menu_handler_top."'"; $result = $db->query($sql); $num = $db->num_rows($result); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $suivant['rowid'] = $obj->rowid; $suivant['order'] = $obj->position; $i++; } $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m"; $sql.= " SET m.position = ".$suivant['order']; $sql.= " WHERE m.rowid = ".$precedent['rowid'].""; // Monte celui select $db->query($sql); $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m"; $sql.= " SET m.position = ".$precedent['order']; $sql.= " WHERE m.rowid = ".$suivant['rowid'].""; // Descend celui du dessus $db->query($sql); } if (isset($_GET["action"]) && $_GET["action"] == 'down') { $sql = "SELECT m.rowid, m.position FROM ".MAIN_DB_PREFIX."menu as m WHERE m.rowid = ".$_GET["menuId"]; $result = $db->query($sql); $num = $db->num_rows($result); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $precedent['rowid'] = $obj->rowid; $precedent['order'] = $obj->position; $i++; } $sql = "SELECT m.rowid, m.position"; $sql.= " FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.position = ".($precedent['order'] + 1)." AND type='top'"; $result = $db->query($sql); $num = $db->num_rows($result); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $suivant['rowid'] = $obj->rowid; $suivant['order'] = $obj->position; $i++; } $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m SET m.position = ".$suivant['order']." WHERE m.rowid = ".$precedent['rowid'].""; // Monte celui select $db->query($sql); $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m SET m.position = ".$precedent['order']." WHERE m.rowid = ".$suivant['rowid'].""; // Descend celui du dessus $db->query($sql); } if ($_POST["action"] == 'confirm_delete' && $_POST["confirm"] == 'yes') { $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; $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']; $resql=$db->query($sql); if ($resql) { $db->commit(); Header("Location: ".DOL_URL_ROOT.'/admin/menus/index.php?mesg='.urlencode($langs->trans("MenuDeleted"))); exit ; } else { $db->rollback(); $reload = 0; $_GET["action"]=''; } } /* * Affichage page */ $html=new Form($db); $htmladmin=new FormAdmin($db); llxHeader(); print_fiche_titre($langs->trans("Menus"),'','setup'); print $langs->trans("MenusEditorDesc")."
\n"; print "
\n"; if ($mesg) print '
'.$mesg.'.

'; $h = 0; $head[$h][0] = DOL_URL_ROOT."/admin/menus.php"; $head[$h][1] = $langs->trans("MenuHandlers"); $head[$h][2] = 'handler'; $h++; $head[$h][0] = DOL_URL_ROOT."/admin/menus/index.php"; $head[$h][1] = $langs->trans("MenuAdmin"); $head[$h][2] = 'editor'; $h++; dolibarr_fiche_head($head, 'editor', $langs->trans("Menus")); // Confirmation de la suppression menu if ($_GET["action"] == 'delete') { $sql = "SELECT m.titre FROM ".MAIN_DB_PREFIX."menu as m WHERE m.rowid = ".$_GET['menuId']; $result = $db->query($sql); $obj = $db->fetch_object($result); $html = new Form($db); $html->form_confirm("index.php?menu_handler=".$menu_handler."&menuId=".$_GET['menuId'],$langs->trans("DeleteMenu"),$langs->trans("ConfirmDeleteMenu",$obj->titre),"confirm_delete"); print "
\n"; } //print $html->textwithwarning($langs->trans("FeatureExperimental"),$langs->trans("FeatureExperimental"),-1); //print '
'; print '
'; print ''; print $langs->trans("MenuHandler").': '; print $htmladmin->select_menu_families($menu_handler,'menu_handler',$dirleft); print '   '; print '
'; print '
'; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("TreeMenuPersonalized").'
'; /************************* * ARBORESCENCE * *************************/ $rangLast = 0; $idLast = -1; if ($conf->use_javascript_ajax) { print ''; /*-------------------- MAIN ----------------------- tableau des éléments de l'arbre: c'est un tableau à 2 dimensions. Une ligne représente un élément : data[$x] chaque ligne est décomposée en 3 données: - l'index de l'élément - l'index de l'élément parent - la chaîne à afficher ie: data[]= array (index, index parent, chaine ) */ //il faut d'abord déclarer un élément racine de l'arbre $data[] = array(0,-1,"racine"); //puis tous les éléments enfants $sql = "SELECT m.rowid, m.fk_menu, m.titre, m.langs"; $sql.= " FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE menu_handler='".$menu_handler."'"; $sql.= " ORDER BY m.position, m.rowid"; $res = $db->query($sql); if ($res) { $num = $db->num_rows($res); $i = 1; while ($menu = $db->fetch_array ($res)) { $langs->load($menu['langs']); $titre = $langs->trans($menu['titre']); $data[] = array($menu['rowid'],$menu['fk_menu'],$titre); $i++; } } //appelle de la fonction récursive (ammorce) //avec recherche depuis la racine. print '
    '; recur($data,0,0); print ''; print '
'; print '
'; print ''; /* * Boutons actions */ print '
'; print ''.$langs->trans("NewMenu").''; print '
'; } else { $langs->load("errors"); print '
'.$langs->trans("ErrorFeatureNeedJavascript").'
'; } $db->close(); print '
'; llxFooter('$Date$ - $Revision$'); /* cette fonction gère le décallage des éléments suivant leur position dans l'arborescence */ function affiche($tab,$rang) { global $conf, $rangLast, $idLast, $menu_handler; if ($conf->use_javascript_ajax) { if($rang == $rangLast) { print ''; //print 'aa'; } elseif($rang > $rangLast) { print '
  • '; echo "\n"; } } } else { if($rang > $rangLast) { print '
  • '; echo "\n"; } } } print '
  • '; print ''; print ''.$tab[2].''; print ''; print ''; print ''; print ''; print '
  • '; echo "\n"; $rangLast = $rang; $idLast = $tab[0]; } /*fonction récursive d'affichage de l'arbre $tab :tableau des éléments $pere :index de l'élément courrant $rang :décallage de l'élément */ function recur($tab,$pere,$rang) { if ($rang > 10) return; // Protection contre boucle infinie //ballayage du tableau for ($x=0;$x