'.tr('Rapporto operazioni e interventi', [], ['upper' => true]).' '.tr('Intervento num.').': '.$documento['codice'].' '.tr('Data').': '.Translator::dateToLocale($documento['data_richiesta']).' '.tr('Preventivo num.').': '.(!empty($preventivo) ? $preventivo['numero'] : '').' '.tr('Contratto num.').': '.(!empty($contratto) ? $contratto['numero'] : '').' '; // Dati cliente echo ' '.tr('Cliente').': '.$c_ragionesociale.' '; // Codice fiscale o P.Iva if (!empty($c_piva)) { echo ' '.tr('P.Iva').': '.strtoupper($c_piva).' '; } else { echo ' '.tr('C.F.').': '.strtoupper($c_codicefiscale).' '; } echo ''; //Indirizzo if (!empty($c_indirizzo) or !empty($c_cap) or !empty($c_citta) or !empty($c_provincia)) { echo ' '.((!empty($c_indirizzo)) ? tr('Via').': '.$c_indirizzo.'' : '').' '.((!empty($c_cap)) ? tr('CAP').': '.$c_cap.'' : '').' '.((!empty($c_citta)) ? tr('Città').': '.$c_citta.'' : '').' '.((!empty($c_provincia)) ? tr('Provincia').': '.strtoupper($c_provincia).'' : '').' '; } echo ' '.tr('Telefono').': '.$c_telefono.''; if (!empty($c_cellulare)) { echo' - '.tr('Cellulare').': '.$c_cellulare.''; } echo ' '; // riga 3 // Elenco impianti su cui è stato fatto l'intervento $rs2 = $dbo->fetchArray('SELECT *, (SELECT nome FROM my_impianti WHERE id=my_impianti_interventi.idimpianto) AS nome, (SELECT matricola FROM my_impianti WHERE id=my_impianti_interventi.idimpianto) AS matricola FROM my_impianti_interventi WHERE idintervento='.prepare($id_record)); $impianti = []; for ($j = 0; $j < count($rs2); ++$j) { $impianti[] = ''.$rs2[$j]['nome']." (".$rs2[$j]['matricola'].')'; } echo ' '.tr('Impianti').': '.implode(', ', $impianti).' '; // Tipo intervento echo ' '.tr('Tipo intervento').': '.$documento['tipointervento'].' '; // Richiesta echo ' '.tr('Richiesta').':

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

'; // Descrizione echo ' '.tr('Descrizione').':

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

'; echo ' '; $righe = $documento->getRighe(); if (!$righe->isEmpty()) { echo ' '; foreach ($righe as $riga) { $r = $riga->toArray(); // Articolo echo ' '; // Quantità echo ' '; // Prezzo unitario echo ' '; // Prezzo totale echo ' '; } echo ' '; if ($options['pricing']) { // Totale spese aggiuntive echo ' '; } echo '
'.tr('Materiale utilizzato e spese aggiuntive', [], ['upper' => true]).'
'.tr('Descrizione').' '.tr('Q.tà').' '.tr('Prezzo unitario').' '.tr('Imponibile').'
'.nl2br($r['descrizione']); if ($riga->isArticolo()) { // Codice articolo $text = tr('COD. _COD_', [ '_COD_' => $riga->articolo->codice, ]); echo '
'.$text.''; // Seriali $seriali = $riga->serials; if (!empty($seriali)) { $text = tr('SN').': '.implode(', ', $seriali); echo '
'.$text.''; } } echo '
'.Translator::numberToLocale($r['qta'], 'qta').' '.$r['um'].' '.($options['pricing'] ? moneyFormat($riga->prezzo_unitario_vendita) : '-'); if ($options['pricing'] && $r['sconto'] > 0) { echo "
".tr('sconto _TOT_ _TYPE_', [ '_TOT_' => Translator::numberToLocale($r['sconto_unitario']), '_TYPE_' => ($r['tipo_sconto'] == 'PRC' ? '%' : currency()), ]).''; } echo '
'.($options['pricing'] ? Translator::numberToLocale($riga->totale_imponibile) : '-').'
'.tr('Totale', [], ['upper' => true]).': '.moneyFormat($righe->sum('totale_imponibile'), 2).'
'; } // INTESTAZIONE ELENCO TECNICI echo ' '; // Sessioni di lavoro dei tecnici $sessioni = $documento->sessioni; foreach ($sessioni as $i => $sessione) { echo ' '; // Nome tecnico echo ' '; // Data echo ' '; // Ora inizio echo ' '; // Ora fine echo ' '; // Spazio aggiuntivo if ($i == 0) { echo ' '; } else { echo ' '; } echo ' '; } // Ore lavorate $ore = $documento->ore_totali; echo ' '; // Costo totale manodopera if ($options['pricing']) { echo ' '; } else { echo ' '; } // Timbro e firma $firma = !empty($documento['firma_file']) ? '' : ''; echo ' '; // Totale km echo ' '; // Costo trasferta if ($options['pricing']) { echo ' '; } else { echo ' '; } // Diritto di chiamata if ($options['pricing']) { echo ' '; } else { echo ' '; } // Calcoli $imponibile = abs($documento->imponibile); $sconto = $documento->sconto; $totale_imponibile = abs($documento->totale_imponibile); $totale_iva = abs($documento->iva); $totale = abs($documento->totale); $netto_a_pagare = abs($documento->netto); $show_sconto = $sconto > 0; // TOTALE COSTI FINALI if ($options['pricing']) { // Totale imponibile echo ' '; // Eventuale sconto totale if ($show_sconto) { echo ' '; // Totale imponibile echo ' '; } // IVA // Totale intervento echo ' '; // TOTALE INTERVENTO echo ' '; } echo '
'.tr('Ore tecnici', [], ['upper' => true]).'
'.tr('Tecnico').' '.tr('Data').' '.tr('Dalle').' '.tr('Alle').' '.tr('I dati del ricevente verrano trattati in base alla normativa europea UE 2016/679 del 27 aprile 2016 (GDPR)').'
'.$sessione->anagrafica->ragione_sociale.' '.Translator::dateToLocale($sessione['orario_inizio'], '-').' '.Translator::timeToLocale($sessione['orario_inizio'], '-').' '.Translator::timeToLocale($sessione['orario_fine'], '-').' '.tr('Si dichiara che i lavori sono stati eseguiti ed i materiali installati').'
'.tr('Ore lavorate').':
'.Translator::numberToLocale($ore, 2).'
'.tr('Totale manodopera').':
'.moneyFormat($sessioni->sum('prezzo_manodopera'), 2).'
- '.$firma.'
('.tr('Timbro e firma leggibile').'.)
'.tr('Km percorsi').':
'.Translator::numberToLocale($sessioni->sum('km'), 2).'
'.tr('Costi di trasferta').':
'.moneyFormat($sessioni->sum('prezzo_viaggio'), 2).'
- '.tr('Diritto di chiamata').':
'.moneyFormat($sessioni->sum('prezzo_diritto_chiamata'), 2).'
-
'.tr('Imponibile', [], ['upper' => true]).': '.moneyFormat($show_sconto ? $imponibile : $totale_imponibile, 2).'
'.tr('Sconto', [], ['upper' => true]).': '.moneyFormat($sconto, 2).'
'.tr('Totale imponibile', [], ['upper' => true]).': '.moneyFormat($totale_imponibile, 2).'
'.tr('Iva', [], ['upper' => true]).': '.moneyFormat($totale_iva, 2).'
'.tr('Totale intervento', [], ['upper' => true]).': '.moneyFormat($totale, 2).'
';