* * 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. * * $Id$ * $Source$ */ /** \file htdocs/compta/paiement_charge.php \ingroup compta \brief Page de création d'un paiement d'une charge \version $Revision$ */ include_once("./pre.inc.php"); include_once("../chargesociales.class.php"); include_once(DOL_DOCUMENT_ROOT."/compta/bank/account.class.php"); $langs->load("bills"); $chid=isset($_GET["id"])?$_GET["id"]:$_POST["id"]; // Sécurité accés client if ($user->societe_id > 0) { $action = ''; $socid = $user->societe_id; } /* * Actions ajoute paiement */ if ($_POST["action"] == 'add_paiement') { if ($_POST["cancel"]) { $loc = DOL_URL_ROOT.'/compta/sociales/charges.php?id='.$chid; Header("Location: $loc"); exit; } if ($_POST["paiementtype"] > 0) { $datepaye = $db->idate(dolibarr_mktime(12, 0 , 0, $_POST["remonth"], $_POST["reday"], $_POST["reyear"])); $paiement_id = 0; $amounts = array(); foreach ($_POST as $key => $value) { if (substr($key,0,7) == 'amount_') { $other_chid = substr($key,7); $amounts[$other_chid] = $_POST[$key]; } } $db->begin(); // Creation de la ligne paiement $paiement = new PaiementCharge($db); $paiement->chid = $chid; $paiement->datepaye = $datepaye; $paiement->amounts = $amounts; // Tableau de montant $paiement->paiementtype = $_POST["paiementtype"]; $paiement->num_paiement = $_POST["num_paiement"]; $paiement->note = $_POST["note"]; $paiement_id = $paiement->create($user); if ($paiement_id > 0) { // On determine le montant total du paiement $total=0; foreach ($paiement->amounts as $key => $value) { $chid = $key; $value = trim($value); $amount = round(price2num($value), 2); // Un round est ok si nb avec '.' if (is_numeric($amount)) $total += $amount; } $total = price2num($total); // Insertion dans llx_bank $langs->load("banks"); $label = $langs->trans("SocialContributionPayment"); $acc = new Account($db, $_POST["accountid"]); $bank_line_id = $acc->addline($paiement->datepaye, $paiement->paiementtype, $label, -abs($total), $paiement->num_paiement, '', $user); // Mise a jour fk_bank dans llx_paiementcharge. On connait ainsi le paiement qui a généré l'écriture bancaire if ($bank_line_id > 0) { $paiement->update_fk_bank($bank_line_id); // Mise a jour liens (pour chaque charge concernée par le paiement) foreach ($paiement->amounts as $key => $value) { $acc->add_url_line($bank_line_id, $chid, DOL_URL_ROOT.'/compta/sociales/charges.php?id=', '(socialcontribution)','sc'); } $db->commit(); $loc = DOL_URL_ROOT.'/compta/sociales/charges.php?id='.$chid; Header("Location: $loc"); exit; } else { $db->rollback(); $mesg = "Echec de la création entrée compte: ".$db->error(); } } else { $db->rollback(); $mesg = "Echec de la création du paiement: paiement_id=$paiement_id ".$db->error(); } } else { $mesg = $langs->trans("ErrorFieldRequired",$langs->transnoentities("PaymentMode")); } $_GET["action"]='create'; } /* * Affichage */ llxHeader(); $html=new Form($db); /* * Formulaire de creation d'un paiement de charge */ if ($_GET["action"] == 'create') { $charge = new ChargeSociales($db); $charge->fetch($chid); $total = $charge->amount; print_titre($langs->trans("DoPayment")); print "
\n"; if ($mesg) { print "
$mesg
"; } print '
'; print "id\">"; print ''; print ''; print ""; print ''; print '\n"; print '\n"; print '\n"; print '\n"; print ''; $sql = "SELECT sum(p.amount) as total"; $sql.= " FROM ".MAIN_DB_PREFIX."paiementcharge as p"; $sql.= " WHERE p.fk_charge = ".$chid; $resql = $db->query($sql); if ($resql) { $obj=$db->fetch_object($resql); $sumpayed = $obj->total; $db->free(); } print ''; print "'; print "'; print ""; print '"; print ''; print '\n"; print ''; print ''; print ''; print ''; print '\n"; /* * Autres charges impayées */ $num = 1; $i = 0; print '\n"; // } // $db->free(); // } // else // { // print $sql ."
".$db->error(); // } /* * */ print ''; print "
Charge
'.$langs->trans("Ref").''; print ''.$chid.'
'.$langs->trans("Type")."$charge->type_libelle
'.$langs->trans("Period")."$charge->periode
'.$langs->trans("Label").''.$charge->lib."
'.$langs->trans("DateDue")."".dolibarr_print_date($charge->date_ech)."
'.$langs->trans("AmountTTC")."".price($charge->amount).' '.$langs->trans("Currency".$conf->monnaie).'
'.$langs->trans("AlreadyPayed").''.price($sumpayed).' '.$langs->trans("Currency".$conf->monnaie).'
".$langs->trans("RemainderToPay")."".price($total - $sumpayed).' '.$langs->trans("Currency".$conf->monnaie).'
".$langs->trans("Payment").'
'.$langs->trans("Date").''; $html->select_date('','','','','',"add_paiement"); print "'.$langs->trans("Comments").'
'.$langs->trans("PaymentMode").''; $html->select_types_paiements($charge->paiementtype, "paiementtype"); print "
'.$langs->trans('AccountToCredit').''; $html->select_comptes($charge->accountid, "accountid", 0, "courant=1"); // Affiche liste des comptes courant print '
'.$langs->trans('Numero'); print ' (Numéro chèque ou virement)'; // \todo a traduire print "
'; print ''; print ''; //print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; $var=True; $total=0; $totalrecu=0; while ($i < $num) { //$objp = $db->fetch_object($result); $objp = $charge; $var=!$var; print ""; //print '\n"; if ($objp->date_ech > 0) { print "\n"; } else { print "\n"; } print '"; print '"; print '"; print '"; print "\n"; $total+=$objp->total; $total_ttc+=$objp->total_ttc; $totalrecu+=$objp->am; $i++; } if ($i > 1) { // Print total print ""; print ''; print ""; print ""; print ""; print ''; print "\n"; } print "
'.$langs->trans("SocialContribution").''.$langs->trans("DateDue").''.$langs->trans("AmountTTC").''.$langs->trans("AlreadyPayed").''.$langs->trans("RemainderToPay").''.$langs->trans("Amount").'
'.$charge->getNomUrl(1)."".dolibarr_print_date($objp->date_ech,'day')."!!!'.price($objp->amount)."'.price($sumpayed)."'.price($objp->amount-$sumpayed)."'; if ($sumpayed < $objp->amount) { $namef = "amount_".$objp->id; print ''; } else { print '-'; } print "
'.$langs->trans("TotalTTC").':".price($total_ttc)."".price($totalrecu)."".price($total_ttc - $totalrecu)." 
'; print ''; print '   '; print ''; print '
"; print "
\n"; // } } $db->close(); llxFooter('$Date$ - $Revision$'); ?>