fetchArray($queryc); for ($i = 0; $i < sizeof($rsc); ++$i) { $colori[$rsc[$i]['idstatointervento']] = $rsc[$i]['colore']; $stati[$rsc[$i]['idstatointervento']] = $rsc[$i]['descrizione']; } $budget = get_imponibile_preventivo($id_record); $totale_costo = 0; $totale_addebito = 0; $totale_scontato = 0; $totale_stato = []; // Tabella con riepilogo interventi $rsi = $dbo->fetchArray('SELECT *, in_interventi.id, vw_activity_subtotal.*, (manodopera_scontato + viaggio_scontato + ricambi_scontato + altro_scontato - vw_activity_subtotal.sconto_globale) AS subtotale, (SELECT MIN(orario_inizio) FROM in_interventi_tecnici WHERE idintervento=in_interventi.id) AS inizio, (SELECT SUM(ore) FROM in_interventi_tecnici WHERE idintervento=in_interventi.id) AS ore, (SELECT MIN(km) FROM in_interventi_tecnici WHERE idintervento=in_interventi.id) AS km FROM co_preventivi_interventi INNER JOIN in_interventi ON co_preventivi_interventi.idintervento=in_interventi.id JOIN vw_activity_subtotal ON vw_activity_subtotal.id = in_interventi.id WHERE co_preventivi_interventi.idpreventivo='.prepare($id_record).' ORDER BY co_preventivi_interventi.idintervento DESC'); if (!empty($rsi)) { echo ' '; // Tabella con i dati foreach ($rsi as $int) { $totale_stato[$int['idstatointervento']] = sum($totale_stato[$int['idstatointervento']], $int['subtotale']); // Riga intervento singolo echo ' '; // Riga con dettagli echo ' '; $totale_ore += $int['ore']; $totale_km += $int['km']; $totale_costo += $int['manodopera_costo']; $totale_addebito += $int['manodopera_addebito']; $totale_scontato += $int['manodopera_scontato']; } // Totali echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; // Totali per stato echo ' '; foreach ($totale_stato as $stato => $tot) { echo ' '; } echo '
'.tr('Attività').' '.tr('Ore').' '.tr('Km').' '.tr('Costo').' '.tr('Addebito').' '.tr('Tot. scontato').'
'.Modules::link('Interventi', $int['id'], str_replace(['_NUM_', '_DATE_'], [$int['id'], Translator::dateToLocale($int['inizio'])], 'Intervento _NUM_ del _DATE_')).' '.Translator::numberToLocale($int['ore']).' '.Translator::numberToLocale($int['km']).' '.Translator::numberToLocale($int['manodopera_costo']).' '.Translator::numberToLocale($int['manodopera_addebito']).' '.Translator::numberToLocale($int['manodopera_scontato']).'
'; /** * Lettura sessioni di lavoro. */ $rst = $dbo->fetchArray('SELECT in_interventi_tecnici.*, ragione_sociale FROM in_interventi_tecnici LEFT OUTER JOIN an_anagrafiche ON in_interventi_tecnici.idtecnico=an_anagrafiche.idanagrafica WHERE idintervento='.prepare($int['id'])); if (!empty($rst)) { echo ' '; foreach ($rst as $r) { // Visualizzo lo sconto su ore o km se c'è $sconto_ore = ($r['sconto'] != 0) ? '
'.Translator::numberToLocale(-$r['sconto']).'' : ''; $sconto_km = ($r['scontokm'] != 0) ? '
'.Translator::numberToLocale(-$r['scontokm']).'' : ''; echo ' '; } echo '
'.tr('Tecnico').' '.tr('Tipo attività').' '.tr('Ore').' '.tr('Km').' '.tr('Costo orario').' '.tr('Costo km').' '.tr('Diritto ch.').' '.tr('Prezzo orario').' '.tr('Prezzo km').' '.tr('Diritto ch.').'
'.$r['ragione_sociale'].' '.$r['idtipointervento'].' '.Translator::numberToLocale($r['ore']).' '.Translator::numberToLocale($r['km']).' '.Translator::numberToLocale($r['prezzo_ore_consuntivo_tecnico']).' '.Translator::numberToLocale($r['prezzo_km_consuntivo_tecnico']).' '.Translator::numberToLocale($r['prezzo_dirittochiamata_tecnico']).' '.Translator::numberToLocale($r['prezzo_ore_consuntivo']).$sconto_ore.' '.Translator::numberToLocale($r['prezzo_km_consuntivo']).$sconto_km.' '.Translator::numberToLocale($r['prezzo_dirittochiamata']).'
'; } /** * Lettura articoli utilizzati. */ $rst = $dbo->fetchArray('SELECT * FROM mg_articoli_interventi WHERE idintervento='.prepare($int['id'])); if (!empty($rst)) { echo ' '; foreach ($rst as $r) { // Visualizzo lo sconto su ore o km se c'è $sconto = ($r['sconto'] != 0) ? '
'.Translator::numberToLocale(-$r['sconto'] * $r['qta']).'' : ''; // Info extra (lotto, serial, altro) $extra = []; if (!empty($r['lotto'])) { $extra[] = ''.tr('Lotto').': '.$r['lotto']; } if (!empty($r['serial'])) { $extra[] = ''.tr('Serial').': '.$r['serial']; } if (!empty($r['altro'])) { $extra[] = ''.tr('Altro').': '.$r['altro']; } echo ' '; } echo '
'.tr('Materiale').' '.tr('Q.tà').' '.tr('Prezzo di acquisto').' '.tr('Prezzo di vendita').'
'.Modules::link('Articoli', $r['idarticolo'], $r['descrizione']).(!empty($extra) ? ''.implode(', ', $extra).'' : '').' '.Translator::numberToLocale($r['qta']).' '.Translator::numberToLocale($r['prezzo_acquisto'] * $r['qta']).' '.Translator::numberToLocale($r['prezzo_vendita'] * $r['qta']).$sconto.'
'; } /** * Lettura spese aggiuntive. */ $rst = $dbo->fetchArray('SELECT * FROM in_righe_interventi WHERE idintervento='.prepare($int['id'])); if (!empty($rst)) { echo ' '; foreach ($rst as $r) { // Visualizzo lo sconto su ore o km se c'è $sconto = ($r['sconto'] != 0) ? '
'.Translator::numberToLocale(-$r['sconto'] * $r['qta']).'' : ''; echo ' '; } echo '
'.tr('Altre spese').' '.tr('Q.tà').' '.tr('Prezzo di acquisto').' '.tr('Prezzo di vendita').'
'.$r['descrizione'].' '.Translator::numberToLocale($r['qta']).' '.Translator::numberToLocale($r['prezzo_acquisto'] * $r['qta']).' '.Translator::numberToLocale($r['prezzo_vendita'] * $r['qta']).$sconto.'
'; } echo '
'.tr('Totale').' '.Translator::numberToLocale($totale_ore).' '.Translator::numberToLocale($totale_km).' '.Translator::numberToLocale($totale_costo).' '.Translator::numberToLocale($totale_addebito).' '.Translator::numberToLocale($totale_scontato).'

'.strtoupper(tr('Totale interventi per stato')).'
'.$stati[$stato].': '.Translator::numberToLocale($tot).'
'; } /* Bilancio del preventivo */ $diff = sum($budget, -$totale_scontato); echo '

'.tr('Rapporto budget/spesa').':
'; if ($budget > $totale_scontato) { echo ' +'.Translator::numberToLocale($diff).' €'; } elseif ($diff < 0) { echo ' '.$diff.' €'; } else { echo ' '.$diff.' €'; } echo '


'; /* Stampa consuntivo */ echo '

Stampa consuntivo
'; /* Aggiunta interventi se il preventivo é aperto o in attesa o pagato (non si possono inserire interventi collegati ad altri preventivi) */ if ($stato == 'Accettato' || $stato == 'In lavorazione' || $stato = 'Pagato') { echo '
{[ "type": "select", "label": "'.tr('Aggiungi un altro intervento a questo preventivo').'", "name": "idintervento", "values": "query=SELECT id, CONCAT(\'Intervento \', codice, \' del \', DATE_FORMAT(IFNULL((SELECT MIN(orario_inizio) FROM in_interventi_tecnici WHERE in_interventi_tecnici.idintervento=in_interventi.id), data_richiesta), \'%d/%m/%Y\')) AS descrizione FROM in_interventi WHERE id NOT IN( SELECT idintervento FROM co_preventivi_interventi WHERE idintervento IS NOT NULL) AND id NOT IN( SELECT idintervento FROM co_righe_documenti WHERE idintervento IS NOT NULL) AND id NOT IN( SELECT idintervento FROM co_righe_contratti WHERE idintervento IS NOT NULL) AND idanagrafica='.prepare($records[0]['idanagrafica']).'" ]}
'; }