ledger=$p_jrn; $this->a_Tva=$this->ledger->existing_vat(); foreach($this->a_Tva as $line_tva) { //initialize Amount TVA $tmp1=$line_tva['tva_id']; $this->rap_tva[$tmp1]=0; } $this->jrn_type=$p_jrn->get_type(); //---------------------------------------------------------------------- /* report * * get rappel to initialize amount rap_xx *the easiest way is to compute sum from quant_ */ $this->previous=$this->ledger->previous_amount($_GET['from_periode']); /* initialize the amount to report */ foreach($this->previous['tva'] as $line_tva) { //initialize Amount TVA $tmp1=$line_tva['tva_id']; $this->rap_tva[$tmp1]=$line_tva['sum_vat']; } $this->rap_htva=$this->previous['price']; $this->rap_tvac=$this->previous['price']+$this->previous['vat']; $this->rap_priv=$this->previous['priv']; $this->rap_nd=$this->previous['tva_nd']; $this->rap_tva_np=$this->previous['tva_np']; } function setDossierInfo($dossier = "n/a") { $this->dossier = dossier::name()." ".$dossier; } /** *@brief write the header of each page */ function Header() { //Arial bold 12 $this->SetFont('DejaVu', 'B', 12); //Title $this->Cell(0,10,$this->dossier, 'B', 0, 'C'); //Line break $this->Ln(20); $this->SetFont('DejaVu', 'B', 8); /* column header */ //---------------------------------------------------------------------- // Show column header, if $flag_tva is false then display vat as column foreach($this->a_Tva as $line_tva) { //initialize Amount TVA $tmp1=$line_tva['tva_id']; $this->rap_tva[$tmp1]=(isset($this->rap_tva[$tmp1]))?$this->rap_tva[$tmp1]:0; } $this->Cell(15,6,'Pièce'); $this->Cell(10,6,'Date'); $this->Cell(13,6,'ref'); if ( $this->jrn_type=='ACH') $this->Cell(40,6,'Client'); else $this->Cell(40,6,'Fournisseur'); $flag_tva=(count($this->a_Tva) > 4)?true:false; if ( !$flag_tva ) $this->Cell(65,6,'Description'); $this->Cell(15,6,'HTVA',0,0,'R'); if ( $this->jrn_type=='ACH') { $this->Cell(15,6,'Priv/DNA',0,0,'R'); $this->Cell(15,6,'TVA ND',0,0,'R'); } $this->Cell(15,6,'TVA NP',0,0,'R'); // Unpaid TVA --> autoliquidation, NPR foreach($this->a_Tva as $line_tva) { $this->Cell(15,6,$line_tva['tva_label'],0,0,'R'); } $this->Cell(15,6,'TVAC',0,0,'R'); $this->Ln(5); $this->SetFont('DejaVu','',6); // page Header $this->Cell(143,6,'report',0,0,'R'); $this->Cell(15,6,nbm($this->rap_htva),0,0,'R'); /* HTVA */ if ( $this->jrn_type != 'VEN') { $this->Cell(15,6,nbm($this->rap_priv),0,0,'R'); /* prive */ $this->Cell(15,6,nbm($this->rap_nd),0,0,'R'); /* Tva ND */ } $this->Cell(15,6,nbm($this->rap_tva_np),0,0,'R'); /* Tva ND */ foreach($this->rap_tva as $line_tva) $this->Cell(15,6,nbm($line_tva),0,0,'R'); $this->Cell(15,6,nbm($this->rap_tvac),0,0,'R'); /* Tvac */ $this->Ln(6); //total page $this->tp_htva=0.0; $this->tp_tvac=0.0; $this->tp_priv=0; $this->tp_nd=0; $this->tp_tva_np=0; foreach($this->a_Tva as $line_tva) { //initialize Amount TVA $tmp1=$line_tva['tva_id']; $this->tp_tva[$tmp1]=0.0; } } /** *@brief write the Footer */ function Footer() { //Position at 3 cm from bottom $this->SetY(-20); /* write reporting */ $this->Cell(143,6,'Total page ','T',0,'R'); /* HTVA */ $this->Cell(15,6,nbm($this->tp_htva),'T',0,'R'); /* HTVA */ if ( $this->jrn_type !='VEN') { $this->Cell(15,6,nbm($this->tp_priv),'T',0,'R'); /* prive */ $this->Cell(15,6,nbm($this->tp_nd),'T',0,'R'); /* Tva ND */ } $this->Cell(15,6,nbm($this->tp_tva_np),'T',0,'R'); /* Tva Unpaid */ foreach($this->a_Tva as $line_tva) { $l=$line_tva['tva_id']; $this->Cell(15,6,nbm($this->tp_tva[$l]),'T',0,'R'); } $this->Cell(15,6,nbm($this->tp_tvac),'T',0,'R'); /* Tvac */ $this->Ln(2); $this->Cell(143,6,'report',0,0,'R'); /* HTVA */ $this->Cell(15,6,nbm($this->rap_htva),0,0,'R'); /* HTVA */ if ( $this->jrn_type !='VEN') { $this->Cell(15,6,nbm($this->rap_priv),0,0,'R'); /* prive */ $this->Cell(15,6,nbm($this->rap_nd),0,0,'R'); /* Tva ND */ } $this->Cell(15,6,nbm($this->rap_tva_np),0,0,'R'); /* Tva ND */ foreach($this->a_Tva as $line_tva) { $l=$line_tva['tva_id']; $this->Cell(15,6,nbm($this->rap_tva[$l]),0,0,'R'); } $this->Cell(15,6,nbm($this->rap_tvac),0,0,'R'); /* Tvac */ $this->Ln(2); //Arial italic 8 $this->SetFont('Arial', 'I', 8); //Page number $this->Cell(0,8,'Date '.$this->date." - Page ".$this->PageNo().'/{nb}',0,0,'L'); // Created by NOALYSS $this->Cell(0,8,'Created by NOALYSS, online on http://www.aevalys.eu',0,0,'R',false,'http://www.aevalys.eu'); } function Cell ($w, $h=0, $txt='', $border=0, $ln=0, $align='', $fill=false, $link='') { $txt = str_replace("\\", "", $txt); return parent::Cell($w, $h, $txt, $border, $ln, $align, $fill, $link); } /** *@brief export the ledger in PDF */ function export() { bcscale(2); $a_jrn=$this->ledger->get_operation($_GET['from_periode'], $_GET['to_periode']); if ( $a_jrn == null ) return; for ( $i=0;$ia_Tva);$f++) { $l=$this->a_Tva[$f]['tva_id']; $atva_amount[$l]=0; } // retrieve info from ledger $aAmountVat=$this->ledger->vat_operation($a_jrn[$i]['jr_grpt_id']); // put vat into array for ($f=0;$ftp_tva[$l]=bcadd($this->tp_tva[$l],$aAmountVat[$f]['sum_vat']); $this->rap_tva[$l]=bcadd($this->rap_tva[$l],$aAmountVat[$f]['sum_vat']); } $row=$a_jrn[$i]; $this->LongLine(15,5,($row['pj']),0); $this->Cell(10,5,$row['date_fmt'],0,0); $this->Cell(13,5,$row['internal'],0,0); list($qc,$name)=$this->get_tiers($row['id'],$this->jrn_type); $this->LongLine(40,5,"[".$qc."]".$name,0,'L'); $this->LongLine(65,5,mb_substr($row['comment'],0,150),0,'L'); /* get other amount (without vat, total vat included, private, ND */ $other=$this->ledger->get_other_amount($a_jrn[$i]['jr_grpt_id']); $this->tp_htva=bcadd($this->tp_htva,$other['price']); $this->tp_tvac=bcadd($this->tp_tvac,$other['price']+$other['vat']); $this->tp_tva_np=bcadd($this->tp_tva_np,$other['tva_np']); $this->tp_priv=bcadd($this->tp_priv,$other['priv']); $this->tp_nd=bcadd($this->tp_nd,$other['tva_nd']); $this->rap_htva=bcadd($this->rap_htva,$other['price']); $this->rap_tvac=bcadd($this->rap_tvac,bcadd($other['price'], bcsub($other['vat'],$other['tva_np']))); $this->rap_priv=bcadd($this->rap_priv,$other['priv']); $this->rap_nd=bcadd($this->rap_nd,$other['tva_nd']); $this->rap_tva_np=bcadd($this->rap_tva_np,$other['tva_np']); $this->Cell(15,5,nbm($other['price']),0,0,'R'); if ( $this->jrn_type !='VEN') { $this->Cell(15,5,nbm($other['priv']),0,0,'R'); $this->Cell(15,5,nbm($other['tva_nd']),0,0,'R'); } $this->Cell(15,5,nbm($other['tva_np']),0,0,'R'); foreach ($atva_amount as $row_atva_amount) { $this->Cell(15, 5, nbm($row_atva_amount), 0, 0, 'R'); } $l_tvac=bcadd($other['price'], bcsub($other['vat'],$other['tva_np'])); $l_tvac=bcadd($l_tvac,$other['tva_nd']); $this->Cell(15,5,nbm($l_tvac),0,0,'R'); $this->Ln(5); } } }