diff --git a/modules/fatture/row-list.php b/modules/fatture/row-list.php
index e527cf75f..28055f195 100644
--- a/modules/fatture/row-list.php
+++ b/modules/fatture/row-list.php
@@ -28,7 +28,7 @@ foreach ($righe as $row) {
// Valori assoluti
$riga['qta'] = abs($riga['qta']);
$riga['prezzo_unitario_acquisto'] = abs($riga['prezzo_unitario_acquisto']);
- $riga['totale_imponibile'] = ($fattura->isNotaDiAccredito() ? -$row->totale_imponibile : $row->totale_imponibile);
+ $riga['totale_imponibile'] = ($fattura->isNota() ? -$row->totale_imponibile : $row->totale_imponibile);
$riga['sconto_unitario'] = abs($riga['sconto_unitario']);
$riga['sconto'] = abs($riga['sconto']);
$riga['iva'] = abs($riga['iva']);
@@ -136,7 +136,7 @@ foreach ($righe as $row) {
}
// Aggiunta dei riferimenti ai documenti
- if ($fattura->isNotaDiAccredito()) {
+ if ($fattura->isNota() && !empty($record['ref_documento'])) {
$data = $dbo->fetchArray("SELECT IF(numero_esterno != '', numero_esterno, numero) AS numero, data FROM co_documenti WHERE id = ".prepare($record['ref_documento']));
$text = tr('Rif. fattura _NUM_ del _DATE_', [
@@ -256,7 +256,7 @@ foreach ($righe as $row) {
echo "
";
- if (!$fattura->isNotaDiAccredito() && $row->isArticolo() && $riga['abilita_serial'] && (empty($riga['idddt']) || empty($riga['idintervento']))) {
+ if (!$fattura->isNota() && $row->isArticolo() && $riga['abilita_serial'] && (empty($riga['idddt']) || empty($riga['idintervento']))) {
echo "
fileurl('add_serial.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$riga['id'].'&idarticolo='.$riga['idarticolo']."', 1 );\">";
}
@@ -265,7 +265,7 @@ foreach ($righe as $row) {
-
+
fileurl('row-edit.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$riga['id']."', 1 );\">
diff --git a/modules/fatture/src/Fattura.php b/modules/fatture/src/Fattura.php
index a37596321..b41ce57a8 100644
--- a/modules/fatture/src/Fattura.php
+++ b/modules/fatture/src/Fattura.php
@@ -349,8 +349,8 @@ class Fattura extends Document
$direzione = $this->tipo->dir;
foreach ($rate as $rata) {
- $importo = $direzione == 'uscita' ? -$rata['importo'] : $rata['importo'];
$scadenza = $rata['scadenza'];
+ $importo = $direzione == 'uscita' ? -$rata['importo'] : $rata['importo'];
self::registraScadenza($this, $importo, $scadenza, $is_pagato);
}
@@ -466,7 +466,7 @@ class Fattura extends Document
*
* @return bool
*/
- public function isNotaDiAccredito()
+ public function isNota()
{
return $this->tipo->reversed == 1;
}
diff --git a/plugins/exportFE/src/FatturaElettronica.php b/plugins/exportFE/src/FatturaElettronica.php
index 9fa9e8b70..01ca0561a 100644
--- a/plugins/exportFE/src/FatturaElettronica.php
+++ b/plugins/exportFE/src/FatturaElettronica.php
@@ -1042,11 +1042,9 @@ class FatturaElettronica
$aliquota = $riga->aliquota ?: $iva_descrizioni;
$percentuale = floatval($aliquota->percentuale);
- if ($documento->isNotaDiAccredito()) {
- $dettaglio['PrezzoTotale'] = -$riga->totale_imponibile ?: 0;
- } else {
- $dettaglio['PrezzoTotale'] = $riga->totale_imponibile ?: 0;
- }
+ $prezzo_totale = $documento->isNota() ? -$riga->totale_imponibile : $riga->totale_imponibile;
+ $dettaglio['PrezzoTotale'] = $prezzo_totale;
+
$dettaglio['AliquotaIVA'] = $percentuale;
if (!empty($riga['idritenutaacconto']) && empty($riga['is_descrizione'])) {
@@ -1110,16 +1108,18 @@ class FatturaElettronica
return $item->aliquota->percentuale;
});
foreach ($riepiloghi_percentuale as $riepilogo) {
- //(imponibile-sconto) + rivalsa inps
- $totale = round(($riepilogo->sum('imponibile') - $riepilogo->sum('sconto')) + $riepilogo->sum('rivalsa_inps'), 2);
+ $totale = round($riepilogo->sum('totale_imponibile') + $riepilogo->sum('rivalsa_inps'), 2);
$imposta = round($riepilogo->sum('iva') + $riepilogo->sum('iva_rivalsa_inps'), 2);
+ $totale = $documento->isNota() ? -$totale : $totale;
+ $imposta = $documento->isNota() ? -$imposta : $imposta;
+
$dati = $riepilogo->first()->aliquota;
$iva = [
'AliquotaIVA' => $dati['percentuale'],
- 'ImponibileImporto' => abs($totale),
- 'Imposta' => abs($imposta),
+ 'ImponibileImporto' => $totale,
+ 'Imposta' => $imposta,
'EsigibilitaIVA' => $dati['esigibilita'],
];
@@ -1147,17 +1147,19 @@ class FatturaElettronica
return $item->aliquota->codice_natura_fe;
});
foreach ($riepiloghi_natura as $riepilogo) {
- //(imponibile-sconto) + rivalsa inps
- $totale = round(($riepilogo->sum('imponibile') - $riepilogo->sum('sconto')) + $riepilogo->sum('rivalsa_inps'), 2);
+ $totale = round($riepilogo->sum('totale_imponibile') + $riepilogo->sum('rivalsa_inps'), 2);
$imposta = round($riepilogo->sum('iva') + $riepilogo->sum('iva_rivalsa_inps'), 2);
+ $totale = $documento->isNota() ? -$totale : $totale;
+ $imposta = $documento->isNota() ? -$imposta : $imposta;
+
$dati = $riepilogo->first()->aliquota;
$iva = [
'AliquotaIVA' => 0,
'Natura' => $dati->codice_natura_fe,
- 'ImponibileImporto' => abs($totale),
- 'Imposta' => abs($imposta),
+ 'ImponibileImporto' => $totale,
+ 'Imposta' => $imposta,
'EsigibilitaIVA' => $dati->esigibilita,
'RiferimentoNormativo' => $dati->descrizione,
];
diff --git a/plugins/importFE/src/FatturaOrdinaria.php b/plugins/importFE/src/FatturaOrdinaria.php
index 7f23da420..f4d7cb8c6 100644
--- a/plugins/importFE/src/FatturaOrdinaria.php
+++ b/plugins/importFE/src/FatturaOrdinaria.php
@@ -115,6 +115,10 @@ class FatturaOrdinaria extends FatturaElettronica
$qta = $riga['Quantita'] ?: 1;
$qta = $riga['PrezzoUnitario'] < 0 ? -$qta : $qta;
+ if ($fattura->isNota()) {
+ $qta = -$qta;
+ }
+
// Prezzo e quantitÃ
$obj->prezzo_unitario_vendita = $prezzo;
$obj->qta = $qta;
@@ -172,7 +176,7 @@ class FatturaOrdinaria extends FatturaElettronica
$dati_generali = $this->getBody()['DatiGenerali']['DatiGeneraliDocumento'];
$totale_documento = $dati_generali['ImportoTotaleDocumento'];
- $diff = $totale_documento ? floatval($totale_documento) - $fattura->totale : $totale_righe - $fattura->totale_imponibile;
+ $diff = $totale_documento ? floatval($totale_documento) - abs($fattura->totale) : $totale_righe - abs($fattura->totale_imponibile);
if (!empty($diff)) {
// Rimozione dell'IVA calcolata automaticamente dal gestionale
$iva_arrotondamento = database()->fetchOne('SELECT * FROM co_iva WHERE id='.prepare($iva[0]));
diff --git a/plugins/importFE/src/FatturaSemplificata.php b/plugins/importFE/src/FatturaSemplificata.php
index ebf1fd51c..a3158acaf 100644
--- a/plugins/importFE/src/FatturaSemplificata.php
+++ b/plugins/importFE/src/FatturaSemplificata.php
@@ -111,6 +111,10 @@ class FatturaSemplificata extends FatturaElettronica
$qta = 1;
$qta = $riga['Importo'] < 0 ? -$qta : $qta;
+ if ($fattura->isNota()) {
+ $qta = -$qta;
+ }
+
// Prezzo e quantitÃ
$obj->prezzo_unitario_vendita = $prezzo;
$obj->qta = $qta;