From 801ed47ef8f74a83fd242e868de21b9096d5b191 Mon Sep 17 00:00:00 2001 From: loviuz Date: Fri, 9 Feb 2024 17:12:47 +0100 Subject: [PATCH] Correzione problemi di sbilanciamento contabile --- modules/fatture/src/Gestori/Movimenti.php | 26 ++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/modules/fatture/src/Gestori/Movimenti.php b/modules/fatture/src/Gestori/Movimenti.php index 2e309c389..85041546f 100644 --- a/modules/fatture/src/Gestori/Movimenti.php +++ b/modules/fatture/src/Gestori/Movimenti.php @@ -220,10 +220,34 @@ class Movimenti } // Registrazione dei singoli Movimenti nel relativo Mastrino + $i = 0; + + $totale_dare = 0; + $totale_avere = 0; + $mastrino = $this->generateMastrino(); + foreach ($movimenti as $element) { + $dare = round($element['dare'], 2); + $avere = round($element['avere'], 2); + + $totale_dare += $dare; + $totale_avere += $avere; + + // Nell'ultimo conto del mastrino inserisco l'eventuale differenza per evitare sbilanci nel totale + $aggiustamento_dare = 0; + $aggiustamento_avere = 0; + + if ($i++ == count($movimenti) -1) { + if ($element['dare']) { + $aggiustamento_dare -= round( $totale_dare - $totale_avere, 6 ); + } elseif ($element['avere']) { + $aggiustamento_avere -= round( $totale_avere - $totale_dare, 6 ); + } + } + $movimento = Movimento::build($mastrino, $element['id_conto'], $this->fattura); - $movimento->setTotale($element['avere'] ?: 0, $element['dare'] ?: 0); + $movimento->setTotale((float)$avere + $aggiustamento_avere, (float)$dare + $aggiustamento_dare); $movimento->save(); } }