* Copyright (C) 2004-2006 Laurent Destailleur * Copyright (C) 2004 Eric Seigne * Copyright (C) 2005 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. * or see http://www.gnu.org/ * * $Id$ * $Source$ */ /** \file htdocs/includes/modules/facture/modules_facture.php \ingroup facture \brief Fichier contenant la classe mère de generation des factures en PDF et la classe mère de numérotation des factures \version $Revision$ */ require_once(FPDF_PATH.'fpdi_protection.php'); require_once(DOL_DOCUMENT_ROOT."/product.class.php"); require_once(DOL_DOCUMENT_ROOT."/compta/bank/account.class.php"); // Requis car utilisé dans les classes qui héritent /** \class ModelePDFFactures \brief Classe mère des modèles de facture */ class ModelePDFFactures extends FPDF { var $error=''; /** * \brief Renvoi le dernier message d'erreur de création de facture */ function pdferror() { return $this->error; } /** * \brief Renvoi la liste des modèles actifs * \param db Handler de base */ function liste_modeles($db) { $type='invoice'; $liste=array(); $sql ="SELECT nom as id, nom as lib"; $sql.=" FROM ".MAIN_DB_PREFIX."document_model"; $sql.=" WHERE type = '".$type."'"; $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 { dolibarr_print_error($db); return -1; } return $liste; } } /** \class ModeleNumRefFactures \brief Classe mère des modèles de numérotation des références de facture */ class ModeleNumRefFactures { var $error=''; /** \brief Renvoi la description par defaut du modele de numérotation * \return string Texte descripif */ function info() { global $langs; $langs->load("bills"); return $langs->trans("NoDescription"); } /** \brief Renvoi un exemple de numérotation * \return string Example */ function getExample() { global $langs; $langs->load("bills"); 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 * \param objsoc Objet societe * \param facture Objet facture * \return string Valeur */ function getNextValue($objsoc,$facture) { global $langs; return $langs->trans("NotAvailable"); } } /** \brief Crée un facture sur disque en fonction du modèle de FACTURE_ADDON_PDF \param db objet base de donnée \param id id de la facture à créer \param message message \param modele force le modele à utiliser ('' par defaut) \param outputlangs objet lang a utiliser pour traduction \return int <0 si KO, >0 si OK */ function facture_pdf_create($db, $id, $message='', $modele='', $outputlangs='') { global $conf,$langs; $langs->load("bills"); $dir = DOL_DOCUMENT_ROOT . "/includes/modules/facture/"; // Positionne modele sur le nom du modele à utiliser if (! strlen($modele)) { if ($conf->global->FACTURE_ADDON_PDF) { $modele = $conf->global->FACTURE_ADDON_PDF; } else { print $langs->trans("Error")." ".$langs->trans("Error_FACTURE_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); $obj->message = $message; if ($obj->write_pdf_file($id, $outputlangs) > 0) { // Succès de la création de la facture. On génère le fichier meta facture_meta_create($db, $id); // et on supprime l'image correspondant au preview facture_delete_preview($db, $id); return 1; } else { dolibarr_print_error('',"facture_pdf_create Error: ".$obj->error); $this->error=$langs->trans("Error")." ".$obj->error; return -1; } } else { dolibarr_print_error('',$langs->trans("Error")." ".$langs->trans("ErrorFileDoesNotExists",$dir.$file)); return -1; } } /** \brief Créé un meta fichier à côté de la facture sur le disque pour faciliter les recherches en texte plein. Pourquoi ? tout simplement parcequ'en fin d'exercice quand je suis avec mon comptable je n'ai pas de connexion internet "rapide" pour retrouver en 2 secondes une facture non payée ou compliquée à gérer ... avec un rgrep c'est vite fait bien fait [eric seigne] \param db Objet base de donnée \param facid Id de la facture à créer \param message Message */ function facture_meta_create($db, $facid, $message="") { global $langs,$conf; $fac = new Facture($db,"",$facid); $fac->fetch($facid); $fac->fetch_client(); if ($conf->facture->dir_output) { $facref = sanitize_string($fac->ref); $dir = $conf->facture->dir_output . "/" . $facref ; $file = $dir . "/" . $facref . ".meta"; if (! is_dir($dir)) { create_exdir($dir); } if (is_dir($dir)) { $nblignes = sizeof($fac->lignes); $client = $fac->client->nom . " " . $fac->client->adresse . " " . $fac->client->cp . " " . $fac->client->ville; $meta = "REFERENCE=\"" . $fac->ref . "\" DATE=\"" . strftime("%d/%m/%Y",$fac->date) . "\" NB_ITEMS=\"" . $nblignes . "\" CLIENT=\"" . $client . "\" TOTAL_HT=\"" . $fac->total_ht . "\" TOTAL_TTC=\"" . $fac->total_ttc . "\"\n"; for ($i = 0 ; $i < $nblignes ; $i++) { //Pour les articles $meta .= "ITEM_" . $i . "_QUANTITY=\"" . $fac->lignes[$i]->qty . "\" ITEM_" . $i . "_UNIT_PRICE=\"" . $fac->lignes[$i]->price . "\" ITEM_" . $i . "_TVA=\"" .$fac->lignes[$i]->tva_tx . "\" ITEM_" . $i . "_DESCRIPTION=\"" . str_replace("\r\n","",nl2br($fac->lignes[$i]->desc)) . "\" "; } } $fp = fopen ($file,"w"); fputs($fp,$meta); fclose($fp); } } /** \brief Supprime l'image de prévisualitation, pour le cas de régénération de facture \param db objet base de donnée \param facid id de la facture à créer */ function facture_delete_preview($db, $facid) { global $langs,$conf; $fac = new Facture($db,"",$facid); $fac->fetch($facid); if ($conf->facture->dir_output) { $facref = sanitize_string($fac->ref); $dir = $conf->facture->dir_output . "/" . $facref ; $file = $dir . "/" . $facref . ".pdf.png"; if ( file_exists( $file ) && is_writable( $file ) ) { if ( ! unlink($file) ) { $this->error=$langs->trans("ErrorFailedToOpenFile",$file); return 0; } } } } ?>