. */ use Carbon\CarbonInterval; include_once __DIR__.'/../../core.php'; $prezzi_ivati = setting('Utilizza prezzi di vendita comprensivi di IVA'); // Creazione righe fantasma $autofill = new Util\Autofill($options['pricing'] ? 4 : 2); $autofill->setRows(20, 10); echo '


'.tr('Contratto num. _NUM_ del _DATE_', [ '_NUM_' => $documento['numero'], '_DATE_' => Translator::dateToLocale($documento['data_bozza']), ], ['upper' => true]).'
'; // Elenco impianti $impianti = $dbo->fetchArray('SELECT nome, matricola FROM my_impianti WHERE id IN (SELECT my_impianti_contratti.idimpianto FROM my_impianti_contratti WHERE idcontratto = '.prepare($documento['id']).')'); if (!empty($impianti)) { $list = []; foreach ($impianti as $impianto) { $list[] = $impianto['nome']." (".$impianto['matricola'].')'; } echo '

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

'.implode(', ', $list).'

'; } echo '
'; if (!empty($destinazione)) { echo ' '; } echo '

'.tr('Spett.le', [], ['upper' => true]).'

$c_ragionesociale$

$c_indirizzo$

$c_citta_full$

'.tr('Partita IVA', [], ['upper' => true]).'

$c_piva$

'.tr('Codice fiscale', [], ['upper' => true]).'

$c_codicefiscale$

'.tr('Destinazione diversa', [], ['upper' => true]).'

'.$destinazione.'
'; // Descrizione if (!empty($documento['descrizione'])) { echo '

'.nl2br($documento['descrizione']).'


'; } // Intestazione tabella per righe echo " '; if ($options['pricing']) { echo " '; } echo ' '; // 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; } } } } foreach ($righe as $riga) { $r = $riga->toArray(); $autofill->count($r['descrizione']); echo ' '; } $text = $text.''; if (!$riga->isDescrizione()) { echo ' '; if ($options['pricing']) { // Prezzo unitario echo ' '; // Imponibile 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; // 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('Descrizione', [], ['upper' => true])." ".tr('Q.tà', [], ['upper' => true]).'".tr('Prezzo unitario', [], ['upper' => true])." ".tr('Imponibile', [], ['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']).'
'; } $text = ''.$key.'
'; if ($options['pricing']) { $text = $text.'
'; echo nl2br($text); } } $r['descrizione'] = str_replace('Rif. '.strtolower($key), '', $r['descrizione']); } $source_type = get_class($riga); if (!setting('Visualizza riferimento su ogni riga in stampa')) { echo $r['descrizione']; } else { echo nl2br($r['descrizione']); } if ($riga->isArticolo()) { echo nl2br('
'.$riga->codice.''); } else { echo '-'; } if ($riga->isArticolo()) { // Seriali $seriali = $riga->serials; if (!empty($seriali)) { $text = tr('SN').': '.implode(', ', $seriali); echo ' '.$text.''; $autofill->count($text, true); } } echo '
'.Translator::numberToLocale(abs($riga->qta), $d_qta).' '.$r['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).'
'.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).'
'; // CONDIZIONI GENERALI DI FORNITURA $pagamento = $dbo->fetchOne('SELECT * FROM co_pagamenti WHERE id = '.$documento['idpagamento']); echo '
'.tr('Condizioni generali di fornitura', [], ['upper' => true]).'
'.tr('Pagamento', [], ['upper' => true]).' '.$pagamento['descrizione'].'
'.tr('Validità offerta', [], ['upper' => true]).' '; if (!empty($documento->validita) && !empty($documento->tipo_validita)) { $intervallo = CarbonInterval::make($documento->validita.' '.$documento->tipo_validita); echo $intervallo->forHumans(); } elseif (!empty($documento->validita)) { echo tr('_TOT_ giorni', [ '_TOT_' => $documento->validita, ]); } else { echo '-'; } echo '
'.tr('Validità contratto', [], ['upper' => true]).' '; if (!empty($documento['data_accettazione']) && !empty($documento['data_conclusione'])) { echo ' '.tr('dal _START_ al _END_', [ '_START_' => Translator::dateToLocale($documento['data_accettazione']), '_END_' => Translator::dateToLocale($documento['data_conclusione']), ]); } else { echo '-'; } echo '
'.tr('Esclusioni', [], ['upper' => true]).' '.nl2br($documento['esclusioni']).'
'; // Conclusione if (empty($documento->stato->fatturabile)) { echo '

'.tr('Il tutto S.E. & O.').'

'.tr("In attesa di un Vostro Cortese riscontro, colgo l'occasione per porgere Cordiali Saluti").'

'; } if (!empty($documento->condizioni_fornitura)) { echo ''.$documento->condizioni_fornitura; }