* * 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$ * $Source$ */ /** \file htdocs/admin/menus/index.php \ingroup core,menudb \brief Gestion des menus \version $Revision$ */ require("./pre.inc.php"); if (!$user->rights->menudb->creer && ! $user->admin) accessforbidden(); $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; /* * Actions */ if (isset($_GET["action"]) && $_GET["action"] == 'up') { $sql = "SELECT m.rowid, m.order FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.rowid = ".$_GET["menuId"]; $result = $db->query($sql); $num = $db->num_rows(); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $precedent['rowid'] = $obj->rowid; $precedent['order'] = $obj->order; $i++; } // Menu top $sql = "SELECT m.rowid, m.order FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.order = ".($precedent['order'] - 1)." AND m.type = 'top'"; $sql.= " AND menu_handler='".$menu_handler_top."'"; $result = $db->query($sql); $num = $db->num_rows(); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $suivant['rowid'] = $obj->rowid; $suivant['order'] = $obj->order; $i++; } $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m"; $sql.= " SET m.order = ".$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.order = ".$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.order FROM ".MAIN_DB_PREFIX."menu as m WHERE m.rowid = ".$_GET["menuId"]; $result = $db->query($sql); $num = $db->num_rows(); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $precedent['rowid'] = $obj->rowid; $precedent['order'] = $obj->order; $i++; } $sql = "SELECT m.rowid, m.order"; $sql.= " FROM ".MAIN_DB_PREFIX."menu as m"; $sql.= " WHERE m.order = ".($precedent['order'] + 1)." AND type='top'"; $result = $db->query($sql); $num = $db->num_rows(); $i = 0; while($i < $num) { $obj = $db->fetch_object($result); $suivant['rowid'] = $obj->rowid; $suivant['order'] = $obj->order; $i++; } $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m SET m.order = ".$suivant['order']." WHERE m.rowid = ".$precedent['rowid'].""; // Monte celui select $db->query($sql); $sql = "UPDATE ".MAIN_DB_PREFIX."menu as m SET m.order = ".$precedent['order']." WHERE m.rowid = ".$suivant['rowid'].""; // Descend celui du dessus $db->query($sql); } /* * Affichage page */ llxHeader(); print_fiche_titre($langs->trans("Menus"),'','setup'); print $langs->trans("MenusEditorDesc")."
\n"; print "
\n"; $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")); if ($_POST["action"] == 'confirm_delete' && $_POST["confirm"] == 'yes') { $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']; $db->query($sql); if ($result == 0) { llxHeader(); print '
'.$langs->trans("MenuDeleted").'
'; llxFooter(); exit ; } else { $reload = 0; $_GET["action"]=''; } } // Confirmation de la suppression de la facture 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?menuId=".$_GET['menuId'],$langs->trans("DeleteMenu"),$langs->trans("ConfirmDeleteMenu")." ".$obj->titre,"confirm_delete"); print "
\n"; } print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("MenuHandler").': '.$menu_handler.'
'.$langs->trans("TreeMenu").'
'; /************************* * ARBORESCENCE * *************************/ $rangLast = 0; $idLast = -1; if ($conf->use_javascript) { print ''; } /* cette fonction gère le décallage des éléments suivant leur position dans l'arborescence */ function affiche($tab,$rang) { global $rangLast, $idLast; if ($conf->use_javascript) { if($rang == $rangLast) { print ''; } elseif($rang > $rangLast) { print '
    • '; } elseif($rang < $rangLast) { print ''; for($i=$rang; $i < $rangLast; $i++) { print '
  • '; echo "\n"; } } } else { if($rang > $rangLast) { print '
    • '; } elseif($rang < $rangLast) { for($i=$rang; $i < $rangLast; $i++) { print '
  • '; echo "\n"; } } } 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) { //ballayage du tableau for ($x=0;$xquery($sql); if ($res) { $num = $db->num_rows(); $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 ''; print '
    '; print ''.$langs->trans("NewMenu").''; print '
    '; $db->close(); llxFooter('$Date$ - $Revision$'); ?>