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['imponibile_scontato'] = ($fattura->isNotaDiAccredito() ? abs($row->imponibile_scontato) : $row->imponibile_scontato); $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 = ''; // Articoli if ($row->isArticolo()) { $riga['descrizione'] = (!empty($row->articolo) ? $row->articolo->codice.' - ' : '').$riga['descrizione']; $delete = 'unlink_articolo'; $extra = ''; $mancanti = 0; } // Intervento elseif (!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']; $delete = 'unlink_preventivo'; } // 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']; $delete = 'unlink_contratto'; } // 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']; $delete = 'unlink_riga'; } // Righe generiche else { $delete = 'unlink_riga'; } // 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 ' '; } $sconto_globale = $fattura->scontoGlobale; if (!empty($sconto_globale)) { echo ' '; } echo ' '; $imponibile = abs($fattura->imponibile); $sconto = abs($fattura->sconto); $imponibile_scontato = abs($fattura->imponibile_scontato); $iva = abs($fattura->iva); $totale = abs($fattura->totale); $netto_a_pagare = abs($fattura->netto); $guadagno = $fattura->guadagno; // IMPONIBILE echo ' '; // SCONTO if (!empty($sconto)) { echo ' '; // IMPONIBILE SCONTATO echo ' '; } // RIVALSA INPS if (!empty($fattura->rivalsa_inps)) { echo ' '; } // IVA if (!empty($iva)) { echo ' '; } // TOTALE echo ' '; // Mostra marca da bollo se c'è if (!empty($fattura->bollo)) { 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 ' '; } // GUADAGNO TOTALE if ($dir == 'entrata') { $guadagno_style = $guadagno < 0 ? 'background-color: #FFC6C6; border: 3px solid red' : ''; /* 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->isNotaDiAccredito()) { $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('Fatture di vendita', $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 ' '.Translator::numberToLocale($row->prezzo_unitario_vendita).' €'; if ($dir == 'entrata') { echo '
'.tr('Acquisto').': '.Translator::numberToLocale($row->prezzo_unitario_acquisto).' € '; } if ($row->sconto_unitario > 0) { echo '
'.tr('sconto _TOT_ _TYPE_', [ '_TOT_' => Translator::numberToLocale($row->sconto_unitario), '_TYPE_' => ($row->tipo_sconto == 'PRC' ? '%' : '€'), ]).''; } } echo '
'; if (!$row->isDescrizione()) { echo ' '.Translator::numberToLocale($riga['iva']).' €
'.$row->desc_iva.(($row->aliquota->esente) ? ' ('.$row->aliquota->codice_natura_fe.')' : null).''; } echo '
'; if (!$row->isDescrizione()) { echo ' '.Translator::numberToLocale($riga['imponibile_scontato']).' €'; /*
'.tr('Guadagno').': '.Translator::numberToLocale($row->guadagno).' € '; */ } echo '
'; if ($record['stato'] != 'Pagato' && $record['stato'] != 'Emessa') { echo "
"; if ($row->isArticolo()) { echo " "; } echo "
"; if (!$fattura->isNotaDiAccredito() && $row->isArticolo() && $riga['abilita_serial'] && (empty($riga['idddt']) || empty($riga['idintervento']))) { echo " "; } echo "
"; } echo '
'; echo '
'.$sconto_globale->descrizione.' '.Translator::numberToLocale(1, 'qta').' '.Translator::numberToLocale($sconto_globale->totale).' € '.Translator::numberToLocale($sconto_globale->iva).' € '.Translator::numberToLocale($sconto_globale->totale).' €
'.tr('Imponibile', [], ['upper' => true]).': '.Translator::numberToLocale($imponibile).' €
'.tr('Sconto', [], ['upper' => true]).': '.Translator::numberToLocale($sconto).' €
'.tr('Imponibile scontato', [], ['upper' => true]).': '.Translator::numberToLocale($imponibile_scontato).' €
'; if ($dir == 'entrata') { echo ' '; } echo ' '.tr('Rivalsa', [], ['upper' => true]).' : '.Translator::numberToLocale($fattura->rivalsa_inps).' €
'; if ($records[0]['split_payment']) { echo ''.tr('Iva a carico del destinatario', [], ['upper' => true]).':'; } else { echo ''.tr('Iva', [], ['upper' => true]).':'; } echo ' '.Translator::numberToLocale($iva).' €
'.tr('Totale', [], ['upper' => true]).': '.Translator::numberToLocale($totale).' €
'.tr('Marca da bollo', [], ['upper' => true]).': '.Translator::numberToLocale($fattura->bollo).' €
'.tr("Ritenuta d'acconto", [], ['upper' => true]).': '.Translator::numberToLocale($fattura->ritenuta_acconto).' €
'.tr('Ritenuta contributi', [], ['upper' => true]).': '.Translator::numberToLocale($fattura->totale_ritenuta_contributi).' €
'.tr('Netto a pagare', [], ['upper' => true]).': '.Translator::numberToLocale($netto_a_pagare).' €
'.tr('Guadagno', [], ['upper' => true]).': '.Translator::numberToLocale($guadagno).' €
'; echo ' ';