. */ include_once __DIR__.'/../../core.php'; $prezzi_ivati = setting('Utilizza prezzi di vendita comprensivi di IVA'); // Righe documento $righe = $documento->getRighe(); if (!setting('Visualizza riferimento su ogni riga in stampa')) { $riferimenti = []; $id_rif = []; foreach ($righe as $riga) { $riferimento = ($riga->getOriginalComponent() ? $riga->getOriginalComponent()->getDocument()->getReference() : null); if (!empty($riferimento)) { if (!array_key_exists($riferimento, $riferimenti)) { $riferimenti[$riferimento] = []; } if (!in_array($riga->id, $riferimenti[$riferimento])) { $id_rif[] = $riga->id; $riferimenti[$riferimento][] = $riga->id; } } } } $columns = 7; $has_image = $righe->search(fn ($item) => !empty($item->articolo->immagine)) !== false && $options['images'] == true; if ($has_image) { ++$columns; } if ($documento->direzione == 'uscita') { $columns += 2; } $columns = $options['pricing'] ? $columns : $columns - 3; // Creazione righe fantasma $autofill = new Util\Autofill($columns); $autofill->setRows(27, 0, 31); // Informazioni aggiuntive echo '
'.tr('Porto', [], ['upper' => true]).' '.tr('Tipo di spedizione', [], ['upper' => true]).' '.tr('Vettore', [], ['upper' => true]).'
$porto$   $spedizione$   $vettore$  
'; // Intestazione tabella per righe echo " '; if ($has_image) { echo " '; } echo " '; if ($documento->direzione == 'uscita') { echo " '; } echo " '; if ($options['pricing']) { echo " '; } echo " '; $num = 0; foreach ($righe as $riga) { ++$num; $r = $riga->toArray(); echo ' '; if ($options['pricing']) { $text .= ' '; } $text .= ''; if ($has_image) { echo ' '; } echo ' '; if ($has_image) { if ($riga->isArticolo() && !empty($riga->articolo->image)) { echo ' '; } else { echo ' '; } } echo ' '; if ($has_image) { if ($riga->isArticolo() && !empty($riga->articolo->image)) { echo ' '; } else { echo ' '; } } echo ' '; } if ($riga->isArticolo()) { if ($documento->direzione == 'entrata' && !$options['hide-item-number']) { // Codice articolo $text = tr('COD. _COD_', [ '_COD_' => $riga->codice, ]); echo '
'.$text.''; $autofill->count($text, true); } // Seriali $seriali = $riga->serials; if (!empty($seriali)) { $text = tr('SN').': '.implode(', ', $seriali); echo '
'.$text.''; $autofill->count($text, true); } } echo ' '; if (!$riga->isDescrizione()) { $qta = $riga->qta; $um = $r['um']; if ($riga->isArticolo() && $documento->direzione == 'uscita' && !empty($riga->articolo->um_secondaria)) { $um = $riga->articolo->um_secondaria; $qta *= $riga->articolo->fattore_um_secondaria; } echo ' '; if ($options['pricing']) { // Prezzo unitario echo ' '; // Imponibile echo ' '; // Iva echo ' '; } echo ' '; } else { echo ' '; if ($options['pricing']) { echo ' '; } } echo ' '; $autofill->next(); } echo ' |autofill| '; // Calcoli $imponibile = $documento->imponibile; $sconto = $documento->sconto; $totale_imponibile = $documento->totale_imponibile; $totale_iva = $documento->iva; $totale = $documento->totale; $sconto_finale = $documento->getScontoFinale(); $netto_a_pagare = $documento->netto; $show_sconto = $sconto > 0; $colspan = 5; $documento->direzione == 'uscita' ? $colspan += 2 : $colspan; $has_image ? $colspan++ : $colspan; // TOTALE COSTI FINALI if ($options['pricing']) { // Totale imponibile echo ' '; // Eventuale sconto incondizionato if ($show_sconto) { echo ' '; // Totale imponibile echo ' '; } // IVA echo ' '; // TOTALE echo ' '; if ($sconto_finale) { // SCONTO IN FATTURA echo ' '; // NETTO A PAGARE echo ' '; } } echo '
".tr('#', [], ['upper' => true]).'".tr('Immagine', [], ['upper' => true]).'".tr('Descrizione', [], ['upper' => true]).'".tr('Codice', [], ['upper' => true])." ".tr('Codice fornitore', [], ['upper' => true]).'".tr('Q.tà', [], ['upper' => true]).'".tr('Prezzo unitario', [], ['upper' => true])." ".tr('Imponibile', [], ['upper' => true])." ".tr('IVA', [], ['upper' => true]).' (%)".tr('Data evasione', [], ['upper' => true]).'
'; $text = ''; foreach ($riferimenti as $key => $riferimento) { if (in_array($riga->id, $riferimento)) { if ($riga->id === $riferimento[0]) { $riga_ordine = $database->fetchOne('SELECT numero_cliente, data_cliente FROM or_ordini WHERE id = '.prepare($riga->idordine)); if (!empty($riga_ordine['numero_cliente']) && !empty($riga_ordine['data_cliente'])) { $text = $text.'Ordine n. '.$riga_ordine['numero_cliente'].' del '.Translator::dateToLocale($riga_ordine['data_cliente']).'
'; } $r['descrizione'] = str_replace("\nRif. ".strtolower((string) $key), '', $r['descrizione']); if (preg_match("/Rif\.(.*)/s", $r['descrizione'], $rif2)) { $r['descrizione'] = str_replace('\nRif.'.strtolower($rif2[1] ?: ''), '', $r['descrizione']); $text .= ''.$rif2[0].'
'; } $text .= ''.$key.'
'; echo ' '.nl2br($text); } } $r['descrizione'] = preg_replace("/(\r\n|\r|\n)Rif\.(.*)/s", '', (string) $r['descrizione']); $autofill->count($r['descrizione']); } $source_type = $riga::class; if (!setting('Visualizza riferimento su ogni riga in stampa')) { echo $num.' '.$r['descrizione']; } else { $autofill->count($r['descrizione']); echo $num.' '.nl2br((string) $r['descrizione']); } if ($documento->direzione == 'uscita') { echo ' '.$riga->articolo->codice.' '.($riga->articolo ? $riga->articolo->dettaglioFornitore($documento->idanagrafica)->codice_fornitore : '').' '.Translator::numberToLocale(abs($qta), $d_qta).' '.$um.' '.moneyFormat($prezzi_ivati ? $riga->prezzo_unitario_ivato : $riga->prezzo_unitario, $d_importi); if ($riga->sconto > 0) { $text = discountInfo($riga, false); echo '
'.$text.''; $autofill->count($text, true); } echo '
'.moneyFormat($prezzi_ivati ? $riga->totale : $riga->totale_imponibile, $d_importi).' '.Translator::numberToLocale($riga->aliquota->percentuale, 0).' '.Translator::dateToLocale($riga->data_evasione).($riga->ora_evasione ? '
'.Translator::timeToLocale($riga->ora_evasione).'' : '').'
'.tr('Imponibile', [], ['upper' => true]).': '.moneyFormat($show_sconto ? $imponibile : $totale_imponibile, $d_totali).'
'.tr('Sconto', [], ['upper' => true]).': '.moneyFormat($sconto, $d_totali).'
'.tr('Totale imponibile', [], ['upper' => true]).': '.moneyFormat($totale_imponibile, $d_totali).'
'.tr('Totale IVA', [], ['upper' => true]).': '.moneyFormat($totale_iva, $d_totali).'
'.tr('Totale documento', [], ['upper' => true]).': '.moneyFormat($totale, $d_totali).'
'.tr('Sconto in fattura', [], ['upper' => true]).': '.moneyFormat($sconto_finale, $d_totali).'
'.tr('Netto a pagare', [], ['upper' => true]).': '.moneyFormat($netto_a_pagare, $d_totali).'
'; if (!empty($documento->condizioni_fornitura)) { echo ''.$documento->condizioni_fornitura; } if (!empty($documento['note'])) { echo '

'.tr('Note', [], ['upper' => true]).':

'.nl2br((string) $documento['note']).'

'; }