* Copyright (C) 2004-2007 Laurent Destailleur * Copyright (C) 2004 Sebastien Di Cintio * Copyright (C) 2004 Benoit Mortier * Copyright (C) 2004 Andre Cianfarani * * 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/commande.php \ingroup commande \brief Page d'administration-configuration du module Commande \version $Revision$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT.'/commande/commande.class.php'); $langs->load("admin"); $langs->load("bills"); $langs->load("other"); $langs->load("orders"); if (!$user->admin) accessforbidden(); /* * Actions */ if ($_GET["action"] == 'specimen') { $modele=$_GET["module"]; $commande = new Commande($db); $commande->initAsSpecimen(); // Charge le modele $dir = DOL_DOCUMENT_ROOT . "/includes/modules/commande/"; $file = "pdf_".$modele.".modules.php"; if (file_exists($dir.$file)) { $classname = "pdf_".$modele; require_once($dir.$file); $obj = new $classname($db); if ($obj->write_pdf_file($commande) > 0) { header("Location: ".DOL_URL_ROOT."/document.php?modulepart=commande&file=SPECIMEN.pdf"); return; } } } if ($_GET["action"] == 'set') { $type='order'; $sql = "INSERT INTO ".MAIN_DB_PREFIX."document_model (nom, type) VALUES ('".$_GET["value"]."','".$type."')"; if ($db->query($sql)) { } } if ($_GET["action"] == 'del') { $type='order'; $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, "COMMANDE_ADDON_PDF",$_GET["value"])) { $conf->global->COMMANDE_ADDON_PDF = $_GET["value"]; } // On active le modele $type='order'; $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, "COMMANDE_ADDON",$_GET["value"]); } if ($_POST["action"] == 'setvalidorder') { dolibarr_set_const($db, "COMMANDE_VALID_AFTER_CLOSE_PROPAL",$_POST["validorder"]); } if ($_POST["action"] == 'deliverycostline') { dolibarr_set_const($db, "COMMANDE_ADD_DELIVERY_COST_LINE",$_POST["addline"]); } // défini les constantes du modèle saphir if ($_POST["action"] == 'updateMatrice') dolibarr_set_const($db, "COMMANDE_NUM_MATRICE",$_POST["matrice"]); if ($_POST["action"] == 'updatePrefix') dolibarr_set_const($db, "COMMANDE_NUM_PREFIX",$_POST["prefix"]); if ($_POST["action"] == 'setOffset') dolibarr_set_const($db, "COMMANDE_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, "COMMANDE_NUM_RESTART_BEGIN_YEAR",$_POST["numrestart"]); /* * Affichage page */ llxHeader(); $dir = "../includes/modules/commande/"; $html=new Form($db); print_fiche_titre($langs->trans("OrdersSetup"),'','setup'); print "
"; print_titre($langs->trans("OrdersNumberingModules")); print ''; print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; clearstatcache(); $dir = "../includes/modules/commande/"; $handle = opendir($dir); if ($handle) { $var=true; while (($file = readdir($handle))!==false) { if (substr($file, 0, 13) == 'mod_commande_' && substr($file, strlen($file)-3, 3) == 'php') { $file = substr($file, 0, strlen($file)-4); require_once(DOL_DOCUMENT_ROOT ."/includes/modules/commande/".$file.".php"); $module = new $file; $var=!$var; print ''; // Examples print '\n"; print ''; $commande=new Commande($db); // Info $htmltooltip=''; $nextval=$module->getNextValue($mysoc,$commande); 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->COMMANDE_ADDON == "$file") { print img_tick($langs->trans("Activated")); } else { print ''.$langs->trans("Activate").''; } print ''; print $html->textwithhelp('',$htmltooltip,1,0); print '

'; /* * Modeles de documents */ print_titre($langs->trans("OrdersModelModule")); // Defini tableau def de modele $type='order'; $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); } $dir = "../includes/modules/commande/"; print "\n"; print "\n"; print ' \n"; print " \n"; print '\n"; print '\n"; print ''; print "\n"; clearstatcache(); $handle=opendir($dir); $var=true; while (($file = readdir($handle))!==false) { if (eregi('\.modules\.php$',$file) && substr($file,0,4) == 'pdf_') { $name = substr($file, 4, strlen($file) -16); $classname = substr($file, 0, strlen($file) -12); $var=!$var; print "\n \n \n"; // Activé if (in_array($name, $def)) { print ""; } else { print ""; } // Defaut print "'; // Info $htmltooltip = ''.$langs->trans("Name").': '.$module->name; $htmltooltip.='
'.$langs->trans("Type").': '.($module->type?$module->type:$langs->trans("Unknown")); $htmltooltip.='
'.$langs->trans("Height").'/'.$langs->trans("Width").': '.$module->page_hauteur.'/'.$module->page_largeur; $htmltooltip.='

'.$langs->trans("FeaturesSupported").':'; $htmltooltip.='
'.$langs->trans("Logo").': '.yn($module->option_logo); $htmltooltip.='
'.$langs->trans("PaymentMode").': '.yn($module->option_modereg); $htmltooltip.='
'.$langs->trans("PaymentConditions").': '.yn($module->option_condreg); $htmltooltip.='
'.$langs->trans("MultiLanguage").': '.yn($module->option_multilang); print ''; print ''; print "\n"; } } closedir($handle); print '
'.$langs->trans("Name")."".$langs->trans("Description")."'.$langs->trans("Activated")."'.$langs->trans("Default")."'.$langs->trans("Infos").'
"; print "$name"; print "\n"; require_once($dir.$file); $module = new $classname($db); print $module->description; print "\n"; if ($conf->global->COMMANDE_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->COMMANDE_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"),'order').''; print '
'; //Autres Options print "
"; print_titre($langs->trans("OtherOptions")); print ''; print ''; print ''; print ''; print "\n"; $var=true; // Valider la commande après cloture de la propale // permet de na pas passer par l'option commande provisoire $var=! $var; print '\n"; // Ajouter une ligne de frais port indiquant le poids de la commande $var=! $var; print '\n"; print '
'.$langs->trans("Parameter").''.$langs->trans("Value").'
'; print $langs->trans("ValidOrderAfterPropalClosed"); print ''; print '
'; print ''; print $html->selectyesno("validorder",$conf->global->COMMANDE_VALID_AFTER_CLOSE_PROPAL,1); print ''; print "
\n"; print "
'; print $langs->trans("AddDeliveryCostLine"); print ''; print '
'; print ''; print $html->selectyesno("addline",$conf->global->COMMANDE_ADD_DELIVERY_COST_LINE,1); print ''; print '
'; print "
'; llxFooter('$Date$ - $Revision$'); ?>