mirror of
https://github.com/YunoHost-Apps/noalyss_ynh.git
synced 2024-09-03 19:46:20 +02:00
242 lines
8.3 KiB
PHP
242 lines
8.3 KiB
PHP
|
<?php
|
||
|
|
||
|
/*
|
||
|
* This file is part of NOALYSS.
|
||
|
*
|
||
|
* NOALYSS 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.
|
||
|
*
|
||
|
* NOALYSS 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 NOALYSS; if not, write to the Free Software
|
||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||
|
*/
|
||
|
|
||
|
// Copyright Author Dany De Bontridder danydb@aevalys.eu
|
||
|
/*! \file
|
||
|
* \brief send the account list in PDF
|
||
|
*/
|
||
|
if ( ! defined ('ALLOWED') ) die('Appel direct ne sont pas permis');
|
||
|
require_once NOALYSS_INCLUDE.'/class_acc_account_ledger.php';
|
||
|
require_once NOALYSS_INCLUDE.'/ac_common.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class_database.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class_impress.php';
|
||
|
require_once NOALYSS_INCLUDE.'/header_print.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class_dossier.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class_user.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class_pdf.php';
|
||
|
|
||
|
$gDossier=dossier::id();
|
||
|
|
||
|
/* Security */
|
||
|
$cn=new Database($gDossier);
|
||
|
extract($_GET);
|
||
|
|
||
|
if ( isset ( $poste_fille) )
|
||
|
{ //choisit de voir tous les postes
|
||
|
$a_poste=$cn->get_array("select pcm_val from tmp_pcmn where pcm_val::text like '$poste_id%' order by pcm_val");
|
||
|
}
|
||
|
else
|
||
|
$a_poste=$cn->get_array("select pcm_val from tmp_pcmn where pcm_val::text = '$poste_id'");
|
||
|
|
||
|
|
||
|
$ret="";
|
||
|
|
||
|
$pdf=new PDF($cn);
|
||
|
$pdf->setDossierInfo(" Periode : ".$_GET['from_periode']." - ".$_GET['to_periode']);
|
||
|
$pdf->AliasNbPages();
|
||
|
$pdf->AddPage();
|
||
|
$pdf->SetAuthor('NOALYSS');
|
||
|
$pdf->setTitle("Détail poste comptable",true);
|
||
|
|
||
|
|
||
|
if ( count($a_poste) == 0 )
|
||
|
{
|
||
|
$pdf->Output('poste.pdf','D');
|
||
|
exit;
|
||
|
}
|
||
|
$size=array(13,25,13,65,12,20,20,20);
|
||
|
$align=array('L','C','C','L','R','R','R','R');
|
||
|
|
||
|
foreach ($a_poste as $poste)
|
||
|
{
|
||
|
$Poste=new Acc_Account_Ledger($cn,$poste['pcm_val']);
|
||
|
list($array,$tot_deb,$tot_cred)=$Poste->get_row_date($from_periode,$to_periode,$_GET['ople']);
|
||
|
// don't print empty account
|
||
|
if ( count($array) == 0 )
|
||
|
{
|
||
|
continue;
|
||
|
}
|
||
|
$Libelle=sprintf("(%s) %s ",$Poste->id,$Poste->get_name());
|
||
|
$pdf->SetFont('DejaVuCond','',10);
|
||
|
$pdf->Cell(0,8,$Libelle,1,0,'C');
|
||
|
$pdf->Ln();
|
||
|
|
||
|
$pdf->SetFont('DejaVuCond','',8);
|
||
|
$l=0;
|
||
|
$pdf->Cell($size[$l],6,'Date',0,0,'L');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Ref',0,0,'C');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Journal',0,0,'C');
|
||
|
$l++;
|
||
|
$pdf->LongLine($size[$l],6,'Libellé',0,'L');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Let',0,0,'R');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Debit',0,0,'R');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Credit',0,0,'R');
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,'Prog',0,0,'R');
|
||
|
$l++;
|
||
|
$pdf->ln();
|
||
|
$tot_deb=0;
|
||
|
$tot_cred=0;
|
||
|
$prog=0;
|
||
|
$current_exercice="";
|
||
|
bcscale(2);
|
||
|
for ($e=0;$e<count($array);$e++)
|
||
|
{
|
||
|
$row=$array[$e];
|
||
|
/*
|
||
|
* separation per exercice
|
||
|
*/
|
||
|
if ( $current_exercice == "") $current_exercice=$row['p_exercice'];
|
||
|
|
||
|
if ( $current_exercice != $row['p_exercice']) {
|
||
|
$str_debit=sprintf("% 12.2f €",$tot_deb);
|
||
|
$str_credit=sprintf("% 12.2f €",$tot_cred);
|
||
|
$diff_solde=bcsub($tot_deb,$tot_cred);
|
||
|
if ( $diff_solde < 0 )
|
||
|
{
|
||
|
$solde=" créditeur ";
|
||
|
$diff_solde=bcmul($diff_solde,-1);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$solde=" débiteur ";
|
||
|
}
|
||
|
$str_diff_solde=sprintf("%12.2f €",$diff_solde);
|
||
|
|
||
|
$pdf->SetFont('DejaVu','B',8);
|
||
|
$pdf->Cell(15,6,_('totaux'),0,0,'L');
|
||
|
$pdf->Cell(15,6,$current_exercice,0,0,'L');
|
||
|
$pdf->Cell(40,6,$solde,0,'L');
|
||
|
$pdf->Cell(40,6,$str_debit,0,0,'R');
|
||
|
$pdf->Cell(40,6,$str_credit,0,0,'R');
|
||
|
$pdf->Cell(40,6,$str_diff_solde,0,0,'R');
|
||
|
$pdf->Ln();
|
||
|
/*
|
||
|
* reset total and current_exercice
|
||
|
*/
|
||
|
$prog=0;
|
||
|
$current_exercice=$row['p_exercice'];
|
||
|
$tot_deb=0;$tot_cred=0;
|
||
|
$pdf->SetFont('DejaVuCond','',8);
|
||
|
}
|
||
|
$l=0;
|
||
|
$diff=bcsub($row['deb_montant'],$row['cred_montant']);
|
||
|
$prog=bcadd($row['deb_montant'],$row['cred_montant']);
|
||
|
|
||
|
$date=shrink_date($row['j_date_fmt']);
|
||
|
$pdf->Cell($size[$l],6,$date,0,0,$align[$l]);
|
||
|
$l++;
|
||
|
if ( $row['jr_pj_number'] == '')
|
||
|
$pdf->Cell($size[$l],6,$row['jr_internal'],0,0,$align[$l]);
|
||
|
else
|
||
|
$pdf->Cell($size[$l],6,$row['jr_pj_number'],0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,mb_substr($row['jrn_def_code'],0,14),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->LongLine($size[$l],6, $row['description'],0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(($row['letter']!=-1)?$row['letter']:''),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(sprintf('% 12.2f',$row['deb_montant'])),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(sprintf('% 12.2f',$row['cred_montant'])),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(sprintf('% 12.2f',abs($prog))),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->ln();
|
||
|
$tot_deb=bcadd($tot_deb,$row['deb_montant']);
|
||
|
$tot_cred=bcadd($tot_deb,$row['cred_montant']);
|
||
|
/* -------------------------------------- */
|
||
|
/* if details are asked we show them here */
|
||
|
/* -------------------------------------- */
|
||
|
if ( isset($_GET['oper_detail']))
|
||
|
{
|
||
|
$detail=new Acc_Operation($cn);
|
||
|
$detail->jr_id=$row['jr_id'];
|
||
|
$a_detail=$detail->get_jrnx_detail();
|
||
|
for ($f=0;$f<count($a_detail);$f++)
|
||
|
{
|
||
|
$l=0;
|
||
|
$pdf->Cell($size[$l],6,'',0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,$a_detail[$f]['j_qcode'],0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,$a_detail[$f]['j_poste'],0,0,$align[$l]);
|
||
|
$l++;
|
||
|
if ( $a_detail[$f]['j_qcode']=='')
|
||
|
$lib=$a_detail[$f]['pcm_lib'];
|
||
|
else
|
||
|
{
|
||
|
$f_id=$cn->get_value('select f_id from vw_poste_qcode where j_qcode=$1',array($a_detail[$f]['j_qcode'])) ;
|
||
|
$lib=$cn->get_value('select ad_value from fiche_detail where ad_id=$1 and f_id=$2',
|
||
|
array(ATTR_DEF_NAME,$f_id));
|
||
|
}
|
||
|
$pdf->Cell($size[$l],6,$lib,0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(($a_detail[$f]['letter']!=-1)?$a_detail[$f]['letter']:''),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
|
||
|
$deb=($a_detail[$f]['debit']=='D')?$a_detail[$f]['j_montant']:'';
|
||
|
$cred=($a_detail[$f]['debit']=='C')?$a_detail[$f]['j_montant']:'';
|
||
|
|
||
|
$pdf->Cell($size[$l],6,(sprintf('% 12.2f',$deb)),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->Cell($size[$l],6,(sprintf('% 12.2f',$cred)),0,0,$align[$l]);
|
||
|
$l++;
|
||
|
$pdf->ln();
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$str_debit=sprintf("% 12.2f €",$tot_deb);
|
||
|
$str_credit=sprintf("% 12.2f €",$tot_cred);
|
||
|
$diff_solde=$tot_deb-$tot_cred;
|
||
|
if ( $diff_solde < 0 )
|
||
|
{
|
||
|
$solde=" créditeur ";
|
||
|
$diff_solde=bcmul($diff_solde,-1);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$solde=" débiteur ";
|
||
|
}
|
||
|
$str_diff_solde=sprintf("%12.2f €",$diff_solde);
|
||
|
|
||
|
$pdf->SetFont('DejaVu','B',8);
|
||
|
|
||
|
$pdf->Cell(160,5,'Débit',0,0,'R');
|
||
|
$pdf->Cell(30,5,$str_debit,0,0,'R');
|
||
|
$pdf->Ln();
|
||
|
$pdf->Cell(160,5,'Crédit',0,0,'R');
|
||
|
$pdf->Cell(30,5,$str_credit,0,0,'R');
|
||
|
$pdf->Ln();
|
||
|
$pdf->Cell(160,5,'Solde '.$solde,0,0,'R');
|
||
|
$pdf->Cell(30,5,$str_diff_solde,0,0,'R');
|
||
|
$pdf->Ln();
|
||
|
|
||
|
}
|
||
|
$fDate=date('dmy-Hi');
|
||
|
$pdf->Output('poste-'.$fDate.'-'.$poste_id.'.pdf','D');
|
||
|
?>
|