Fix: Pb sur les centimes dans le paiement d'une charge.
This commit is contained in:
parent
73f0a05f49
commit
be3ca9d5b4
@ -48,8 +48,9 @@ class PaiementCharge {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Creation d'un paiement de charge sociale
|
* \brief Creation d'un paiement de charge sociale
|
||||||
*
|
* \user user Utilisateur qui crée le paiement
|
||||||
|
* \return int <0 si erreur, >0 si ok
|
||||||
*/
|
*/
|
||||||
function create($user) {
|
function create($user) {
|
||||||
$sql_err = 0;
|
$sql_err = 0;
|
||||||
@ -63,14 +64,11 @@ class PaiementCharge {
|
|||||||
{
|
{
|
||||||
$facid = $key;
|
$facid = $key;
|
||||||
$value = trim($value);
|
$value = trim($value);
|
||||||
$amount = round(ereg_replace(",",".",$value), 2);
|
$amount = round(ereg_replace(",",".",$value), 2); // Un round est ok si nb avec '.'
|
||||||
|
if (is_numeric($amount)) $total += $amount;
|
||||||
if (is_numeric($amount))
|
|
||||||
{
|
|
||||||
$total += $amount;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
$total = round(ereg_replace(",",".",$total), 2);
|
$total = ereg_replace(",",".",$total);
|
||||||
|
|
||||||
if ($total > 0)
|
if ($total > 0)
|
||||||
{
|
{
|
||||||
$sql = "INSERT INTO ".MAIN_DB_PREFIX."paiementcharge (fk_charge, datec, datep, amount, fk_typepaiement, num_paiement, note, fk_user_creat)";
|
$sql = "INSERT INTO ".MAIN_DB_PREFIX."paiementcharge (fk_charge, datec, datep, amount, fk_typepaiement, num_paiement, note, fk_user_creat)";
|
||||||
@ -78,9 +76,7 @@ class PaiementCharge {
|
|||||||
|
|
||||||
if ( $this->db->query($sql) )
|
if ( $this->db->query($sql) )
|
||||||
{
|
{
|
||||||
|
|
||||||
$this->id = $this->db->last_insert_id(MAIN_DB_PREFIX."paiementcharge");
|
$this->id = $this->db->last_insert_id(MAIN_DB_PREFIX."paiementcharge");
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -90,7 +86,7 @@ class PaiementCharge {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $total > 0 && $sql_err == 0 )
|
if ($total > 0 && $sql_err == 0)
|
||||||
{
|
{
|
||||||
$this->db->commit();
|
$this->db->commit();
|
||||||
return $this->id;
|
return $this->id;
|
||||||
|
|||||||
@ -38,86 +38,92 @@ $chid=isset($_GET["id"])?$_GET["id"]:$_POST["id"];
|
|||||||
*/
|
*/
|
||||||
if ($_POST["action"] == 'add_paiement')
|
if ($_POST["action"] == 'add_paiement')
|
||||||
{
|
{
|
||||||
if ($_POST["paiementtype"] > 0)
|
if ($_POST["paiementtype"] > 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
$datepaye = $db->idate(mktime(12, 0 , 0,
|
$datepaye = $db->idate(mktime(12, 0 , 0,
|
||||||
$_POST["remonth"],
|
$_POST["remonth"],
|
||||||
$_POST["reday"],
|
$_POST["reday"],
|
||||||
$_POST["reyear"]));
|
$_POST["reyear"]));
|
||||||
|
|
||||||
$paiement_id = 0;
|
$paiement_id = 0;
|
||||||
$amounts = array();
|
$amounts = array();
|
||||||
foreach ($_POST as $key => $value)
|
foreach ($_POST as $key => $value)
|
||||||
{
|
|
||||||
if (substr($key,0,7) == 'amount_')
|
|
||||||
{
|
|
||||||
$other_chid = substr($key,7);
|
|
||||||
|
|
||||||
$amounts[$other_chid] = $_POST[$key];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO Mettre toute la chaine dans une même transaction
|
|
||||||
|
|
||||||
// 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;
|
if (substr($key,0,7) == 'amount_')
|
||||||
$value = trim($value);
|
{
|
||||||
$amount = round(ereg_replace(",",".",$value), 2);
|
$other_chid = substr($key,7);
|
||||||
if (is_numeric($amount))
|
|
||||||
{
|
$amounts[$other_chid] = $_POST[$key];
|
||||||
$total += $amount;
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Insertion dans llx_bank
|
$db->begin();
|
||||||
$label = "Règlement charge";
|
|
||||||
$acc = new Account($db, $_POST["accountid"]);
|
// Creation de la ligne paiement
|
||||||
$bank_line_id = $acc->addline($paiement->datepaye, $paiement->paiementtype, $label, -abs($total), $paiement->num_paiement, '', $user);
|
$paiement = new PaiementCharge($db);
|
||||||
|
$paiement->chid = $chid;
|
||||||
// Mise a jour fk_bank dans llx_paiementcharge. On connait ainsi le paiement qui a généré l'écriture bancaire
|
$paiement->datepaye = $datepaye;
|
||||||
if ($bank_line_id) {
|
$paiement->amounts = $amounts; // Tableau de montant
|
||||||
$paiement->update_fk_bank($bank_line_id);
|
$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(ereg_replace(",",".",$value), 2); // Un round est ok si nb avec '.'
|
||||||
|
if (is_numeric($amount)) $total += $amount;
|
||||||
|
}
|
||||||
|
$total = ereg_replace(",",".",$total);
|
||||||
|
|
||||||
|
// Insertion dans llx_bank
|
||||||
|
$label = "Règlement charge";
|
||||||
|
$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)
|
||||||
|
//{
|
||||||
|
// $chid = $key;
|
||||||
|
// $fac = new Facture($db);
|
||||||
|
// $fac->fetch($chid);
|
||||||
|
// $fac->fetch_client();
|
||||||
|
// $acc->add_url_line($bank_line_id, $paiement_id, DOL_URL_ROOT.'/compta/paiement/fiche.php?id=', "(paiement)");
|
||||||
|
// $acc->add_url_line($bank_line_id, $fac->client->id, DOL_URL_ROOT.'/compta/fiche.php?socid=', $fac->client->nom);
|
||||||
|
//}
|
||||||
|
|
||||||
|
$db->commit();
|
||||||
|
|
||||||
|
$loc = DOL_URL_ROOT.'/compta/sociales/charges.php?id='.$chid;
|
||||||
|
Header("Location: $loc");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$db->rollback();
|
||||||
|
$fiche_erreur_message = "Echec de la création entrée compte: ".$db->error();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$db->rollback();
|
||||||
|
$fiche_erreur_message = "Echec de la création du paiement: paiement_id=$paiement_id ".$db->error();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mise a jour liens (pour chaque charge concernée par le paiement)
|
|
||||||
//foreach ($paiement->amounts as $key => $value)
|
|
||||||
//{
|
|
||||||
// $chid = $key;
|
|
||||||
// $fac = new Facture($db);
|
|
||||||
// $fac->fetch($chid);
|
|
||||||
// $fac->fetch_client();
|
|
||||||
// $acc->add_url_line($bank_line_id, $paiement_id, DOL_URL_ROOT.'/compta/paiement/fiche.php?id=', "(paiement)");
|
|
||||||
// $acc->add_url_line($bank_line_id, $fac->client->id, DOL_URL_ROOT.'/compta/fiche.php?socid=', $fac->client->nom);
|
|
||||||
//}
|
|
||||||
|
|
||||||
$loc = DOL_URL_ROOT.'/compta/sociales/charges.php?id='.$chid;
|
|
||||||
Header("Location: $loc");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Il y a eu erreur
|
|
||||||
$fiche_erreur_message = "Echec de la création du paiement: ".$db->error();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$fiche_erreur_message = "Vous devez sélectionner un mode de paiement";
|
$fiche_erreur_message = "Vous devez sélectionner un mode de paiement";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user