diff --git a/htdocs/includes/modules/rapport/pdf_paiement.class.php b/htdocs/includes/modules/rapport/pdf_paiement.class.php new file mode 100644 index 00000000000..eabe3983e61 --- /dev/null +++ b/htdocs/includes/modules/rapport/pdf_paiement.class.php @@ -0,0 +1,187 @@ + + * + * 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$ + * + */ + +Class pdf_paiement { + + Function pdf_paiement($db=0) + { + $this->db = $db; + $this->description = "Liste des paiements"; + + $this->dir = $GLOBALS["DOCUMENT_ROOT"]."/document/rapport/"; + + $this->file = $this->dir . "paiements" . ".pdf"; + + $this->url = "/document/rapport/" . "paiements" . ".pdf"; + + $this->tab_top = 30; + + $this->line_height = 8; + $this->line_per_page = 25; + $this->tab_height = $this->line_height * $this->line_per_page; + + } + + Function print_link() + { + if (file_exists($this->file)) + { + print 'paiements.pdf'; + print ''; + print ''; + print ''; + print '
'.filesize($this->file). ' bytes'.strftime("%d %b %Y %H:%M:%S",filemtime($this->file)).'
'; + } + } + + function Header(&$pdf, $page, $pages) + { + $pdf->SetFont('Arial','B',12); + $pdf->Text(10, 10, FAC_PDF_INTITULE); + + $pdf->SetFont('Arial','B',12); + $pdf->Text(90, 10, "Liste des paiements encaissés"); + + $pdf->SetFont('Arial','B',12); + $pdf->Text(11, 16, "Date : " . strftime("%d %b %Y", time())); + + $pdf->SetFont('Arial','B',12); + $pdf->Text(11, 22, "Page " . $page . " sur " . $pages); + + $pdf->SetFont('Arial','',12); + + $pdf->Text(11,$this->tab_top + 6,'Facture'); + + $pdf->line(50, $this->tab_top, 50, $this->tab_top + $this->tab_height + 10); + $pdf->Text(52, $this->tab_top + 6,'Date'); + $pdf->line(80, $this->tab_top, 80, $this->tab_top + $this->tab_height + 10); + $pdf->Text(82, $this->tab_top + 6,'Type paiement'); + + $pdf->line(120, $this->tab_top, 120, $this->tab_top + $this->tab_height + 10); + $pdf->Text(122, $this->tab_top + 6,'Numéro'); + + $pdf->line(160, $this->tab_top, 160, $this->tab_top + $this->tab_height + 10); + + $pdf->SetXY (160, $this->tab_top); + $pdf->MultiCell(40, 10, "Montant", 0, 'R'); + + $pdf->Rect(10, $this->tab_top, 190, $this->tab_height + 10); + $pdf->line(10, $this->tab_top + 10, 200, $this->tab_top + 10 ); + + } + + Function Body(&$pdf, $page, $lines) + { + $pdf->SetFont('Arial','', 10); + for ($i = 0 ; $i < $this->line_per_page ; $i++) + { + $j = $i + (($page - 1) * $this->line_per_page ); + $pdf->SetFillColor(220,220,220); + + $pdf->SetXY (10, $this->tab_top + 10 + ($i * $this->line_height) ); + $pdf->MultiCell(40, $this->line_height, $lines[$j][0], 0, 'J', 0); + + $pdf->SetXY (50, $this->tab_top + 10 + ($i * $this->line_height) ); + $pdf->MultiCell(30, $this->line_height, $lines[$j][1], 0, 'J', 0); + + $pdf->SetXY (80, $this->tab_top + 10 + ($i * $this->line_height) ); + $pdf->MultiCell(40, $this->line_height, $lines[$j][2], 0, 'J', 0); + + $pdf->SetXY (120, $this->tab_top + 10 + ($i * $this->line_height) ); + $pdf->MultiCell(40, $this->line_height, $lines[$j][3], 0, 'J', 0); + + $pdf->SetXY (160, $this->tab_top + 10 + ($i * $this->line_height) ); + $pdf->MultiCell(40, $this->line_height, $lines[$j][4], 0, 'R', 0); + + if ($i < $this->line_per_page - 1) + { + $pdf->line(10, $this->tab_top + 10 + (($i+1) * $this->line_height), 200, $this->tab_top + 10 + (($i+1) * $this->line_height)); + } + } + } + + Function write_pdf_file() + { + global $conf; + + if (! file_exists($this->dir)) + { + mkdir($this->dir, 755); + } + + $pdf = new FPDF('P','mm','A4'); + $pdf->Open(); + + /* + * + */ + + $sql = "SELECT ".$this->db->pdate("p.datep")." as dp, p.amount, f.amount as fa_amount, f.facnumber"; + $sql .=", f.rowid as facid, c.libelle as paiement_type, p.num_paiement"; + $sql .= " FROM llx_paiement as p, llx_facture as f, c_paiement as c"; + $sql .= " WHERE p.fk_facture = f.rowid AND p.fk_paiement = c.id ORDER BY p.rowid DESC"; + $result = $this->db->query($sql); + + if ($result) + { + $lignes = $this->db->num_rows(); + $i = 0; + $var=True; + + while ($i < $lignes) + { + $objp = $this->db->fetch_object( $i); + $var=!$var; + + $lines[$i][0] = $objp->facnumber; + $lines[$i][1] = strftime("%d %B %Y",$objp->dp); + $lines[$i][2] = $objp->paiement_type ; + $lines[$i][3] = $objp->num_paiement; + $lines[$i][4] = price($objp->amount); + $i++; + } + } + + $pages = intval($lignes / $this->line_per_page); + + if (($lignes % $this->line_per_page)>0) + { + $pages++; + } + + for ($i = 0 ; $i < $pages ; $i++) + { + $pdf->AddPage(); + $this->Header($pdf, $i+1, $pages); + $this->Body($pdf, $i+1, $lines); + } + /* + * + */ + + $pdf->Output($this->file); + } + +} + +?>