Dbut ajout modles commande et facture fournisseur
This commit is contained in:
parent
6fc44f0b86
commit
0237545f52
209
htdocs/fourn/commande/modules/modules_commandefournisseur.php
Normal file
209
htdocs/fourn/commande/modules/modules_commandefournisseur.php
Normal file
@ -0,0 +1,209 @@
|
|||||||
|
<?php
|
||||||
|
/* Copyright (C) 2003-2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
||||||
|
* Copyright (C) 2004-2005 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||||
|
* Copyright (C) 2004 Eric Seigne <eric.seigne@ryxeo.com>
|
||||||
|
* Copyright (C) 2006 Andre Cianfarani <acianfa@free.fr>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
* or see http://www.gnu.org/
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
* $Source$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
\file htdocs/includes/modules/commande/modules_commandefournisseur.php
|
||||||
|
\ingroup commande
|
||||||
|
\brief Fichier contenant la classe mère de generation des commandes fournisseurs en PDF
|
||||||
|
et la classe mère de numérotation des commandes fournisseurs
|
||||||
|
\version $Revision$
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once(FPDF_PATH.'fpdf.php');
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class ModelePDFCommandesSuppliers
|
||||||
|
\brief Classe mère des modèles de commandes
|
||||||
|
*/
|
||||||
|
|
||||||
|
class ModelePDFCommandesSuppliers extends FPDF
|
||||||
|
{
|
||||||
|
var $error='';
|
||||||
|
|
||||||
|
/**
|
||||||
|
\brief Renvoi le dernier message d'erreur de création de PDF de commande
|
||||||
|
*/
|
||||||
|
function pdferror()
|
||||||
|
{
|
||||||
|
return $this->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Renvoi la liste des modèles actifs
|
||||||
|
*/
|
||||||
|
function liste_modeles($db)
|
||||||
|
{
|
||||||
|
$liste=array();
|
||||||
|
$sql ="SELECT nom as id, nom as lib";
|
||||||
|
$sql.=" FROM ".MAIN_DB_PREFIX."commande_fournisseur_model_pdf";
|
||||||
|
|
||||||
|
$resql = $db->query($sql);
|
||||||
|
if ($resql)
|
||||||
|
{
|
||||||
|
$num = $db->num_rows($resql);
|
||||||
|
$i = 0;
|
||||||
|
while ($i < $num)
|
||||||
|
{
|
||||||
|
$row = $db->fetch_row($resql);
|
||||||
|
$liste[$row[0]]=$row[1];
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$this->error=$db->error();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return $liste;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class ModeleNumRefCommandesSuppliers
|
||||||
|
\brief Classe mère des modèles de numérotation des références de commandes fournisseurs
|
||||||
|
*/
|
||||||
|
|
||||||
|
class ModeleNumRefCommandesSuppliers
|
||||||
|
{
|
||||||
|
var $error='';
|
||||||
|
|
||||||
|
/** \brief Renvoi la description par defaut du modele de numérotation
|
||||||
|
* \return string Texte descripif
|
||||||
|
*/
|
||||||
|
function info()
|
||||||
|
{
|
||||||
|
global $langs;
|
||||||
|
$langs->load("orders");
|
||||||
|
return $langs->trans("NoDescription");
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Renvoi un exemple de numérotation
|
||||||
|
* \return string Example
|
||||||
|
*/
|
||||||
|
function getExample()
|
||||||
|
{
|
||||||
|
global $langs;
|
||||||
|
$langs->load("orders");
|
||||||
|
return $langs->trans("NoExample");
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Test si les numéros déjà en vigueur dans la base ne provoquent pas de
|
||||||
|
* de conflits qui empechera cette numérotation de fonctionner.
|
||||||
|
* \return boolean false si conflit, true si ok
|
||||||
|
*/
|
||||||
|
function canBeActivated()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Renvoi prochaine valeur attribuée
|
||||||
|
* \return string Valeur
|
||||||
|
*/
|
||||||
|
function getNextValue()
|
||||||
|
{
|
||||||
|
global $langs;
|
||||||
|
return $langs->trans("NotAvailable");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
function commande_supplier_pdf_create($db, $comid, $modele='')
|
||||||
|
{
|
||||||
|
global $langs;
|
||||||
|
$langs->load("suppliers");
|
||||||
|
|
||||||
|
$dir = DOL_DOCUMENT_ROOT."/fourn/commande/modules/";
|
||||||
|
|
||||||
|
// Positionne modele sur le nom du modele de commande fournisseur à utiliser
|
||||||
|
if (! strlen($modele))
|
||||||
|
{
|
||||||
|
if (defined("COMMANDE_SUPPLIER_ADDON_PDF") && COMMANDE_SUPPLIER_ADDON_PDF)
|
||||||
|
{
|
||||||
|
$modele = COMMANDE_SUPPLIER_ADDON_PDF;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
print $langs->trans("Error")." ".$langs->trans("Error_COMMANDE_SUPPLIER_ADDON_PDF_NotDefined");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Charge le modele
|
||||||
|
$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($comid) > 0)
|
||||||
|
{
|
||||||
|
// on supprime l'image correspondant au preview
|
||||||
|
commande_delete_preview($db, $comid);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dolibarr_syslog("Erreur dans commande_supplier_pdf_create");
|
||||||
|
dolibarr_print_error($db,$obj->pdferror());
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
print $langs->trans("Error")." ".$langs->trans("ErrorFileDoesNotExists",$dir.$file);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function commande_supplier_delete_preview($db, $propalid)
|
||||||
|
{
|
||||||
|
global $langs,$conf;
|
||||||
|
|
||||||
|
$comfourn = new Commande($db,"",$propalid);
|
||||||
|
$comfourn->fetch($propalid);
|
||||||
|
$client = new Societe($db);
|
||||||
|
$client->fetch($comfourn->soc_id);
|
||||||
|
|
||||||
|
if ($conf->fournisseur->commande->dir_output)
|
||||||
|
{
|
||||||
|
$comfournref = sanitize_string($comfourn->ref);
|
||||||
|
$dir = $conf->commande->dir_output . "/" . $comfournref ;
|
||||||
|
$file = $dir . "/" . $comfournref . ".pdf.png";
|
||||||
|
|
||||||
|
if ( file_exists( $file ) && is_writable( $file ) )
|
||||||
|
{
|
||||||
|
if ( ! unlink($file) )
|
||||||
|
{
|
||||||
|
$this->error=$langs->trans("ErrorFailedToOpenFile",$file);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
@ -252,6 +252,10 @@ $conf->don->dir_images=DOL_DATA_ROOT."/dons/images";
|
|||||||
$conf->syslog->enabled=defined("MAIN_MODULE_SYSLOG")?MAIN_MODULE_SYSLOG:0;
|
$conf->syslog->enabled=defined("MAIN_MODULE_SYSLOG")?MAIN_MODULE_SYSLOG:0;
|
||||||
// Module fournisseur
|
// Module fournisseur
|
||||||
$conf->fournisseur->enabled=defined("MAIN_MODULE_FOURNISSEUR")?MAIN_MODULE_FOURNISSEUR:0;
|
$conf->fournisseur->enabled=defined("MAIN_MODULE_FOURNISSEUR")?MAIN_MODULE_FOURNISSEUR:0;
|
||||||
|
$conf->fournisseur->commande->dir_output=DOL_DATA_ROOT."/fournisseur/commande";
|
||||||
|
$conf->fournisseur->commande->dir_images=DOL_DATA_ROOT."/fournisseur/commande/images";
|
||||||
|
$conf->fournisseur->facture->dir_output=DOL_DATA_ROOT."/fournisseur/facture";
|
||||||
|
$conf->fournisseur->facture->dir_images=DOL_DATA_ROOT."/fournisseur/facture/images";
|
||||||
// Module ficheinter
|
// Module ficheinter
|
||||||
$conf->fichinter->enabled=defined("MAIN_MODULE_FICHEINTER")?MAIN_MODULE_FICHEINTER:0;
|
$conf->fichinter->enabled=defined("MAIN_MODULE_FICHEINTER")?MAIN_MODULE_FICHEINTER:0;
|
||||||
$conf->fichinter->dir_output=DOL_DATA_ROOT."/ficheinter";
|
$conf->fichinter->dir_output=DOL_DATA_ROOT."/ficheinter";
|
||||||
|
|||||||
@ -42,3 +42,11 @@ create table llx_comfourn_facfourn
|
|||||||
key(fk_commande),
|
key(fk_commande),
|
||||||
key(fk_facture)
|
key(fk_facture)
|
||||||
)type=innodb;
|
)type=innodb;
|
||||||
|
|
||||||
|
|
||||||
|
create table llx_commande_fournisseur_model_pdf
|
||||||
|
(
|
||||||
|
nom varchar(50) PRIMARY KEY,
|
||||||
|
libelle varchar(255),
|
||||||
|
description text
|
||||||
|
)type=innodb;
|
||||||
30
mysql/tables/llx_commande_fournisseur_model_pdf.sql
Normal file
30
mysql/tables/llx_commande_fournisseur_model_pdf.sql
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
-- ===================================================================
|
||||||
|
-- Copyright (C) 2001-2003 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
||||||
|
--
|
||||||
|
-- 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$
|
||||||
|
--
|
||||||
|
-- Liste des modeles de commande fournisseur pdf disponibles
|
||||||
|
--
|
||||||
|
-- ===================================================================
|
||||||
|
|
||||||
|
create table llx_commande_fournisseur_model_pdf
|
||||||
|
(
|
||||||
|
nom varchar(50) PRIMARY KEY,
|
||||||
|
libelle varchar(255),
|
||||||
|
description text
|
||||||
|
)type=innodb;
|
||||||
Loading…
Reference in New Issue
Block a user