* Copyright (C) 2004-2007 Laurent Destailleur * Copyright (C) 2004 Sebastien Di Cintio * Copyright (C) 2004 Benoit Mortier * Copyright (C) 2004 Eric Seigne * Copyright (C) 2005-2007 Regis Houssin * * 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/livraison.php \ingroup livraison \brief Page d'administration/configuration du module Livraison \version $Revision$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/livraison/livraison.class.php"); $langs->load("admin"); $langs->load("bills"); $langs->load("other"); $langs->load("sendings"); $langs->load("deliveries"); if (!$user->admin) accessforbidden(); /* * Actions */ if ($_GET["action"] == 'set') { $type='delivery'; $sql = "INSERT INTO ".MAIN_DB_PREFIX."document_model (nom, type) VALUES ('".$_GET["value"]."','".$type."')"; if ($db->query($sql)) { } } if ($_GET["action"] == 'del') { $type='delivery'; $sql = "DELETE FROM ".MAIN_DB_PREFIX."document_model"; $sql .= " WHERE nom = '".$_GET["value"]."' AND type = '".$type."'"; if ($db->query($sql)) { } } if ($_GET["action"] == 'setdoc') { $db->begin(); if (dolibarr_set_const($db, "LIVRAISON_ADDON_PDF",$_GET["value"])) { $conf->global->LIVRAISON_ADDON_PDF = $_GET["value"]; } // On active le modele $type='delivery'; $sql_del = "DELETE FROM ".MAIN_DB_PREFIX."document_model"; $sql_del .= " WHERE nom = '".$_GET["value"]."' AND type = '".$type."'"; $result1=$db->query($sql_del); $sql = "INSERT INTO ".MAIN_DB_PREFIX."document_model (nom,type) VALUES ('".$_GET["value"]."','".$type."')"; $result2=$db->query($sql); if ($result1 && $result2) { $db->commit(); } else { $db->rollback(); } } if ($_GET["action"] == 'setmod') { // \todo Verifier si module numerotation choisi peut etre activé // par appel methode canBeActivated dolibarr_set_const($db, "LIVRAISON_ADDON",$_GET["value"]); } // défini les constantes du modèle saphir if ($_POST["action"] == 'updateMatrice') dolibarr_set_const($db, "LIVRAISON_NUM_MATRICE",$_POST["matrice"]); if ($_POST["action"] == 'updatePrefix') dolibarr_set_const($db, "LIVRAISON_NUM_PREFIX",$_POST["prefix"]); if ($_POST["action"] == 'setOffset') dolibarr_set_const($db, "LIVRAISON_NUM_DELTA",$_POST["offset"]); if ($_POST["action"] == 'setFiscalMonth') dolibarr_set_const($db, "SOCIETE_FISCAL_MONTH_START",$_POST["fiscalmonth"]); if ($_POST["action"] == 'setNumRestart') dolibarr_set_const($db, "LIVRAISON_NUM_RESTART_BEGIN_YEAR",$_POST["numrestart"]); /* * Affiche page */ llxHeader("",""); $dir = DOL_DOCUMENT_ROOT."/livraison/mods/"; $html=new Form($db); $h = 0; $head[$h][0] = DOL_URL_ROOT."/admin/confexped.php"; $head[$h][1] = $langs->trans("Setup"); $h++; if ($conf->global->MAIN_SUBMODULE_EXPEDITION) { $head[$h][0] = DOL_URL_ROOT."/admin/expedition.php"; $head[$h][1] = $langs->trans("Sending"); $h++; } $head[$h][0] = DOL_URL_ROOT."/admin/livraison.php"; $head[$h][1] = $langs->trans("Delivery"); $hselected=$h; $h++; dolibarr_fiche_head($head, $hselected, $langs->trans("ModuleSetup")); /* * Module numérotation */ print_fiche_titre($langs->trans("DeliveryOrderNumberingModules"),'','setup'); print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''."\n"; clearstatcache(); $handle = opendir($dir); $var=true; if ($handle) { $var=true; while (($file = readdir($handle))!==false) { if (substr($file, 0, 14) == 'mod_livraison_' && substr($file, strlen($file)-3, 3) == 'php') { $file = substr($file, 0, strlen($file)-4); require_once(DOL_DOCUMENT_ROOT ."/livraison/mods/".$file.".php"); $module = new $file; $var=!$var; print ''; // Affiche example print ''; print ''; $livraison=new Livraison($db); // Info $htmltooltip=''; $nextval=$module->getNextValue($mysoc,$livraison); if ($nextval != $langs->trans("NotAvailable")) { $htmltooltip=''.$langs->trans("NextValue").': '.$nextval; } print ''; print ''; } } closedir($handle); } print '
'.$langs->trans("Name").''.$langs->trans("Description").''.$langs->trans("Example").''.$langs->trans("Activated").''.$langs->trans("Infos").'
'.$module->nom."\n"; print $module->info(); print ''.$module->getExample().''; if ($conf->global->LIVRAISON_ADDON == "$file") { print img_tick($langs->trans("Activated")); } else { print ''.$langs->trans("Default").''; } print ''; print $html->textwithhelp('',$htmltooltip,1,0); print '
'; /* * Modeles de documents */ print '
'; print_titre($langs->trans("DeliveryOrderModel")); // Defini tableau def de modele invoice $type="delivery"; $def = array(); $sql = "SELECT nom"; $sql.= " FROM ".MAIN_DB_PREFIX."document_model"; $sql.= " WHERE type = '".$type."'"; $resql=$db->query($sql); if ($resql) { $i = 0; $num_rows=$db->num_rows($resql); while ($i < $num_rows) { $array = $db->fetch_array($resql); array_push($def, $array[0]); $i++; } } else { dolibarr_print_error($db); } print ''; print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; clearstatcache(); $dir = DOL_DOCUMENT_ROOT."/livraison/mods/pdf/"; if(is_dir($dir)) { $handle=opendir($dir); $var=true; while (($file = readdir($handle))!==false) { if (substr($file, strlen($file) -12) == '.modules.php' && substr($file,0,4) == 'pdf_') { $name = substr($file, 4, strlen($file) - 16); $classname = substr($file, 0, strlen($file) - 12); $var=!$var; print "'; // Activ if (in_array($name, $def)) { print ""; } else { print ""; } // Defaut print "'; // Info $htmltooltip = ''.$langs->trans("Type").': '.($module->type?$module->type:$langs->trans("Unknown")); $htmltooltip.='
'.$langs->trans("Width").': '.$module->page_largeur; $htmltooltip.='
'.$langs->trans("Height").': '.$module->page_hauteur; $htmltooltip.='

'.$langs->trans("FeaturesSupported").':'; $htmltooltip.='
'.$langs->trans("Logo").': '.yn($module->option_logo); print ''; print ''; print ''; } } closedir($handle); } else { print "\n"; } print '
'.$langs->trans("Name").''.$langs->trans("Description").''.$langs->trans("Action").''.$langs->trans("Default").''.$langs->trans("Infos").'
"; print $name; print "\n"; require_once($dir.$file); $obj = new $classname($db); print $obj->description; print '\n"; if ($conf->global->LIVRAISON_ADDON_PDF != "$name") { print ''; print img_tick($langs->trans("Disable")); print ''; } else { print img_tick($langs->trans("Enabled")); } print "\n"; print ''.$langs->trans("Activate").''; print ""; if ($conf->global->LIVRAISON_ADDON_PDF == "$name") { print img_tick($langs->trans("Default")); } else { print ''.$langs->trans("Default").''; } print ''; print $html->textwithhelp('',$htmltooltip,1,0); print ''; print ''.img_object($langs->trans("Preview"),'sending').''; print '
ERROR: $dir is not a directory !
'; /* * * */ $db->close(); llxFooter(); ?>