getRighe(); echo ' '; foreach ($righe as $row) { $riga = $row->toArray(); // Valori assoluti $riga['qta'] = abs($riga['qta']); $riga['prezzo_unitario_acquisto'] = abs($riga['prezzo_unitario_acquisto']); $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']); if (empty($riga['is_descrizione'])) { $riga['descrizione_conto'] = $dbo->fetchOne('SELECT descrizione FROM co_pianodeiconti3 WHERE id = '.prepare($riga['idconto']))['descrizione']; } $extra = ''; $delete = 'unlink_riga'; // Articoli if ($row->isArticolo()) { $riga['descrizione'] = (!empty($row->articolo) ? $row->articolo->codice.' - ' : '').$riga['descrizione']; $extra = ''; $mancanti = 0; } // Intervento if (!empty($riga['idintervento'])) { $intervento = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM in_interventi WHERE id = '.prepare($riga['idintervento'])); $riga['num_item'] = $intervento['num_item']; $riga['codice_cig'] = $intervento['codice_cig']; $riga['codice_cup'] = $intervento['codice_cup']; $riga['id_documento_fe'] = $intervento['id_documento_fe']; $delete = 'unlink_intervento'; } // Preventivi elseif (!empty($riga['idpreventivo'])) { $preventivo = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_preventivi WHERE id = '.prepare($riga['idpreventivo'])); $riga['num_item'] = $preventivo['num_item']; $riga['codice_cig'] = $preventivo['codice_cig']; $riga['codice_cup'] = $preventivo['codice_cup']; $riga['id_documento_fe'] = $preventivo['id_documento_fe']; } // Contratti elseif (!empty($riga['idcontratto'])) { $contratto = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_contratti WHERE id = '.prepare($riga['idcontratto'])); $riga['num_item'] = $contratto['num_item']; $riga['codice_cig'] = $contratto['codice_cig']; $riga['codice_cup'] = $contratto['codice_cup']; $riga['id_documento_fe'] = $contratto['id_documento_fe']; } // Ordini (IDDOCUMENTO,CIG,CUP) elseif (!empty($riga['idordine'])) { $ordine = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM or_ordini WHERE id = '.prepare($riga['idordine'])); $riga['num_item'] = $ordine['num_item']; $riga['codice_cig'] = $ordine['codice_cig']; $riga['codice_cup'] = $ordine['codice_cup']; $riga['id_documento_fe'] = $ordine['id_documento_fe']; } // Individuazione dei seriali if (!empty($riga['abilita_serial'])) { $serials = $row->serials; $mancanti = $riga['qta'] - count($serials); if ($mancanti > 0) { $extra = 'class="warning"'; } else { $mancanti = 0; } } $extra_riga = ''; if (!$riga['is_descrizione']) { $extra_riga = tr('_DESCRIZIONE_CONTO__ID_DOCUMENTO__NUMERO_RIGA__CODICE_CIG__CODICE_CUP_', [ '_DESCRIZIONE_CONTO_' => $riga['descrizione_conto'] ?: null, '_ID_DOCUMENTO_' => $riga['id_documento_fe'] ? ' - DOC: '.$riga['id_documento_fe'] : null, '_NUMERO_RIGA_' => $riga['num_item'] ? ', NRI: '.$riga['num_item'] : null, '_CODICE_CIG_' => $riga['codice_cig'] ? ', CIG: '.$riga['codice_cig'] : null, '_CODICE_CUP_' => $riga['codice_cup'] ? ', CUP: '.$riga['codice_cup'] : null, ]); } echo ' '; echo ' '; // Unità di misura echo ' '; // Prezzi unitari echo ' '; // Iva echo ' '; // Importo echo ' '; // Possibilità di rimuovere una riga solo se la fattura non è pagata echo ' '; } echo ' '; $imponibile = abs($fattura->imponibile); $sconto = $fattura->sconto; $totale_imponibile = abs($fattura->totale_imponibile); $iva = abs($fattura->iva); $totale = abs($fattura->totale); $netto_a_pagare = abs($fattura->netto); // IMPONIBILE echo ' '; // SCONTO if (!empty($sconto)) { echo ' '; // TOTALE IMPONIBILE echo ' '; } // RIVALSA INPS if (!empty($fattura->rivalsa_inps)) { echo ' '; } // IVA if (!empty($iva)) { echo ' '; } // TOTALE echo ' '; // RITENUTA D'ACCONTO if (!empty($fattura->ritenuta_acconto)) { echo ' '; } // RITENUTA CONTRIBUTI if (!empty($fattura->totale_ritenuta_contributi)) { echo ' '; } // NETTO A PAGARE if ($totale != $netto_a_pagare) { echo ' '; } echo '
'.tr('Descrizione').' '.tr('Q.tà').' '.tr('U.m.').' '.tr('Prezzo unitario').' '.tr('Iva').' '.tr('Importo').'
'.Modules::link($row->isArticolo() ? Modules::get('Articoli')['id'] : null, $row->isArticolo() ? $riga['idarticolo'] : null, $riga['descrizione']).' '.$extra_riga.''; if (!empty($riga['abilita_serial'])) { if (!empty($mancanti)) { echo '
'.tr('_NUM_ serial mancanti', [ '_NUM_' => $mancanti, ]).''; } if (!empty($serials)) { echo '
'.tr('SN').': '.implode(', ', $serials); } } // Aggiunta dei riferimenti ai documenti 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_', [ '_NUM_' => $data[0]['numero'], '_DATE_' => Translator::dateToLocale($data[0]['data']), ]); echo '
'.Modules::link($id_module, $record['ref_documento'], $text, $text); } $ref = doc_references($riga, $dir, ['iddocumento']); if (!empty($ref)) { echo '
'.Modules::link($ref['module'], $ref['id'], $ref['description'], $ref['description']); } echo '
'; if (!$row->isDescrizione()) { echo ' '.Translator::numberToLocale($riga['qta'], 'qta'); } echo ' '; if (!$row->isDescrizione()) { echo ' '.$riga['um']; } echo ' '; if (!$row->isDescrizione()) { echo ' '.moneyFormat($row->prezzo_unitario_vendita); if ($dir == 'entrata' && $row->prezzo_unitario_acquisto != 0) { echo '
'.tr('Acquisto').': '.moneyFormat($row->prezzo_unitario_acquisto).' '; } if (abs($row->sconto_unitario) > 0) { $text = $row->sconto_unitario > 0 ? tr('sconto _TOT_ _TYPE_') : tr('maggiorazione _TOT_ _TYPE_'); echo '
'.replace($text, [ '_TOT_' => Translator::numberToLocale(abs($row->sconto_unitario)), '_TYPE_' => ($row->tipo_sconto == 'PRC' ? '%' : currency()), ]).''; } } echo '
'; if (!$row->isDescrizione()) { echo ' '.moneyFormat($riga['iva']).'
'.$row->aliquota->descrizione.(($row->aliquota->esente) ? ' ('.$row->aliquota->codice_natura_fe.')' : null).''; } echo '
'; if (!$row->isDescrizione()) { echo ' '.moneyFormat($riga['totale_imponibile']); } echo ' '; if ($record['stato'] != 'Pagato' && $record['stato'] != 'Emessa' && $riga['id'] != $fattura->rigaBollo->id) { echo "
"; if ($row->isArticolo()) { echo " "; } echo "
"; } echo '
'; echo '
'.tr('Imponibile', [], ['upper' => true]).': '.moneyFormat($imponibile, 2).'
'.tr('Sconto/maggiorazione', [], ['upper' => true]).': '.moneyFormat($sconto, 2).'
'.tr('Totale imponibile', [], ['upper' => true]).': '.moneyFormat($totale_imponibile, 2).'
'; if ($dir == 'entrata') { echo ' '; } echo ' '.tr('Rivalsa', [], ['upper' => true]).' : '.moneyFormat($fattura->rivalsa_inps, 2).'
'; if ($records[0]['split_payment']) { echo ''.tr('Iva a carico del destinatario', [], ['upper' => true]).':'; } else { echo ''.tr('Iva', [], ['upper' => true]).':'; } echo ' '.moneyFormat($iva, 2).'
'.tr('Totale', [], ['upper' => true]).': '.moneyFormat($totale, 2).'
'.tr("Ritenuta d'acconto", [], ['upper' => true]).': '.moneyFormat(abs($fattura->ritenuta_acconto), 2).'
'.tr('Ritenuta contributi', [], ['upper' => true]).': '.moneyFormat($fattura->totale_ritenuta_contributi).'
'.tr('Netto a pagare', [], ['upper' => true]).': '.moneyFormat($netto_a_pagare, 2).'
'; echo ' ';