. */ include_once __DIR__.'/../../core.php'; use Carbon\Carbon; use Models\Module; use Models\Upload; use Modules\Anagrafiche\Anagrafica; use Modules\Anagrafiche\Sede; use Modules\Contratti\Contratto; use Modules\Interventi\Intervento; use Modules\Preventivi\Preventivo; use Modules\Scadenzario\Scadenza; // Anagrafica $anagrafica = $ordine->anagrafica; // Sede if ($ordine->idsede_destinazione) { $sede = $dbo->selectOne('an_sedi', '*', ['id' => $ordine->idsede_destinazione]); } else { $sede = $anagrafica->toArray(); } // Referente $referente = null; if ($ordine->idreferente) { $referente = $dbo->selectOne('an_referenti', '*', ['id' => $ordine->idreferente]); } // Contratto $contratto = null; $ore_erogate = 0; $ore_previste = 0; $perc_ore = 0; $color = 'danger'; if ($ordine->id_contratto) { $contratto = Contratto::find($ordine->id_contratto); $ore_erogate = $contratto->interventi->sum('ore_totali'); $ore_previste = $contratto->getRighe()->where('um', 'ore')->sum('qta'); $perc_ore = $ore_previste != 0 ? ($ore_erogate * 100) / $ore_previste : 0; if ($perc_ore < 75) { $color = 'success'; } elseif ($perc_ore <= 100) { $color = 'warning'; } } // Preventivo $preventivo = null; if ($ordine->id_preventivo) { $preventivo = Preventivo::find($ordine->id_preventivo); } // Altre attività $interventi_programmati = Intervento::select('in_interventi.*') ->join('in_statiintervento', 'in_interventi.idstatointervento', '=', 'in_statiintervento.id') ->where('idanagrafica', $intervento->idanagrafica) ->where('idsede_destinazione', $intervento->idsede_destinazione) ->where('is_completato', '!=', 1) ->where('in_interventi.id', '!=', $id_record) ->get(); // Insoluti $insoluti = Scadenza::where('idanagrafica', $ordine->idanagrafica) ->whereRaw('co_scadenziario.da_pagare > co_scadenziario.pagato') ->whereRaw('co_scadenziario.scadenza < NOW()') ->count(); // Logo $logo = Upload::where('id_module', Module::where('name', 'Anagrafiche')->first()->id)->where('id_record', $ordine->idanagrafica)->where('name', 'Logo azienda')->first()->filename; $logo = $logo ? base_path().'/files/anagrafiche/'.$logo : App::getPaths()['img'].'/logo_header.png'; echo '
'; // Cliente echo '

'.$anagrafica->ragione_sociale.'

'.($sede['nomesede'] ? $sede['nomesede'].'
' : '').' '.$sede['indirizzo'].'
'.$sede['cap'].' - '.$sede['citta'].' ('.$sede['provincia'].')

'.($sede['telefono'] ? ' '.$sede['telefono'].'' : '').' '.($sede['email'] ? ' '.$sede['email'].'' : '').' '.($referente['nome'] ? '

'.$referente['nome'].'
' : '').' '.($referente['telefono'] ? ' '.$referente['telefono'].'' : '').' '.($referente['email'] ? ' '.$referente['email'].'' : '').'

'; // Panoramica echo '

'.tr('Panoramica ordine num. ').$ordine->numero.'

'.($insoluti ? tr('Sono presenti insoluti') : tr('Non sono presenti insoluti')).'

'.(count($interventi_programmati) == 0 ? tr('Non sono presenti attività programmate') : 'Attività aperte:'); if (count($interventi_programmati) != 0) { foreach ($interventi_programmati as $intervento_programmato) { echo ' '.$intervento_programmato->codice.' ('.(new Carbon($intervento_programmato->data_richiesta))->diffForHumans().')'; } } echo '

'; // Contratto if ($contratto) { echo '

'.Modules::link('Contratti', $contratto->id, tr('Contratto num. _NUM_ del _DATA_', ['_NUM_' => $contratto->numero, '_DATA_' => Translator::dateToLocale($contratto->data_bozza)])); if ($ore_previste > 0) { echo ' - '.$ore_erogate.'/'.$ore_previste.' '.tr('ore').'

'; } echo '

'; } // Preventivo if ($preventivo) { echo '

'.Modules::link('Preventivi', $preventivo->id, tr('Preventivo num. _NUM_ del _DATA_', ['_NUM_' => $preventivo->numero, '_DATA_' => Translator::dateToLocale($preventivo->data_bozza)])).'

'; } echo '
';