Fix: Pb sur les centimes dans le paiement d'une charge.

This commit is contained in:
Laurent Destailleur 2005-07-02 16:33:39 +00:00
parent 73f0a05f49
commit be3ca9d5b4
2 changed files with 86 additions and 84 deletions

View File

@ -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;

View File

@ -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";
} }
} }