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 '| '.filesize($this->file). ' bytes | ';
+ print ''.strftime("%d %b %Y %H:%M:%S",filemtime($this->file)).' | ';
+ print '
';
+ }
+ }
+
+ 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);
+ }
+
+}
+
+?>