. */ use Modules\Interventi\Intervento; include_once __DIR__.'/../../core.php'; // Lettura dei parametri di interesse $id_anagrafica = filter('idanagrafica'); $id_sede = filter('idsede'); $richiesta = filter('richiesta'); $origine_dashboard = get('ref') !== null; $module_anagrafiche = Modules::get('Anagrafiche'); // Calcolo dell'orario di inizio e di fine sulla base delle informazioni fornite $orario_inizio = filter('orario_inizio'); $orario_fine = filter('orario_fine'); if (null == $orario_inizio || '00:00:00' == $orario_inizio) { $orario_inizio = date('H').':00:00'; $orario_fine = date('H', time() + 60 * 60).':00:00'; } // Un utente del gruppo Tecnici può aprire attività solo a proprio nome $id_tecnico = filter('id_tecnico'); if ($user['gruppo'] == 'Tecnici' && !empty($user['idanagrafica'])) { $id_tecnico = $user['idanagrafica']; } elseif ($user['gruppo'] == 'Clienti' && !empty($user['idanagrafica'])) { $id_cliente = $user['idanagrafica']; } // Stato di default associato all'attivitò $stato = $dbo->fetchArray("SELECT * FROM in_statiintervento WHERE descrizione = 'In programmazione'"); $id_stato = $stato['idstatointervento']; // Se è indicata un'anagrafica relativa, si carica il tipo di intervento di default impostato if (!empty($id_anagrafica)) { $anagrafica = $dbo->fetchOne('SELECT idtipointervento_default, idzona FROM an_anagrafiche WHERE idanagrafica='.prepare($id_anagrafica)); $id_tipo = $anagrafica['idtipointervento_default']; $id_zona = $anagrafica['idzona']; } // Gestione dell'impostazione dei Contratti $id_intervento = filter('id_intervento'); $id_contratto = filter('idcontratto'); $id_promemoria_contratto = filter('idcontratto_riga'); $id_ordine = null; // Trasformazione di un Promemoria dei Contratti in Intervento if (!empty($id_contratto) && !empty($id_promemoria_contratto)) { $contratto = $dbo->fetchOne('SELECT *, (SELECT idzona FROM an_anagrafiche WHERE idanagrafica = co_contratti.idanagrafica) AS idzona FROM co_contratti WHERE id = '.prepare($id_contratto)); $id_anagrafica = $contratto['idanagrafica']; $id_zona = $contratto['idzona']; // Informazioni del Promemoria $promemoria = $dbo->fetchOne('SELECT *, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = co_promemoria.idtipointervento) AS tempo_standard FROM co_promemoria WHERE idcontratto='.prepare($id_contratto).' AND id = '.prepare($id_promemoria_contratto)); $id_tipo = $promemoria['idtipointervento']; $data = (null !== filter('data')) ? filter('data') : $promemoria['data_richiesta']; $richiesta = $promemoria['richiesta']; $id_sede = $promemoria['idsede']; $impianti_collegati = $promemoria['idimpianti']; // Generazione dell'orario di fine sulla base del tempo standard definito dal Promemoria if (!empty($promemoria['tempo_standard'])) { $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $promemoria['tempo_standard'])); } // Caricamento degli impianti a Contratto se non definiti in Promemoria if (empty($impianti_collegati)) { $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto = '.prepare($id_contratto)); $impianti_collegati = implode(',', array_column($rs, 'idimpianto')); } } // Gestione dell'aggiunta di una sessione a un Intervento senza sessioni (Promemoria intervento) da Dashboard elseif (!empty($id_intervento)) { $intervento = $dbo->fetchOne('SELECT *, (SELECT idcontratto FROM co_promemoria WHERE idintervento = in_interventi.id LIMIT 0,1) AS idcontratto, in_interventi.id_preventivo as idpreventivo, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = in_interventi.idtipointervento) AS tempo_standard FROM in_interventi WHERE id = '.prepare($id_intervento)); $id_tipo = $intervento['idtipointervento']; $data = (null !== filter('data')) ? filter('data') : $intervento['data_richiesta']; $data_richiesta = $intervento['data_richiesta']; $data_scadenza = $intervento['data_scadenza']; $richiesta = $intervento['richiesta']; $id_sede = $intervento['idsede']; $id_anagrafica = $intervento['idanagrafica']; $id_cliente_finale = $intervento['idclientefinale']; $id_stato = $intervento['idstatointervento']; $id_contratto = $intervento['idcontratto']; $id_preventivo = $intervento['idpreventivo']; $id_zona = $intervento['idzona']; // Generazione dell'orario di fine sulla base del tempo standard definito dall'Intervento if (!empty($intervento['tempo_standard'])) { $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $intervento['tempo_standard'])); } $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_interventi WHERE idintervento = '.prepare($id_intervento)); $impianti_collegati = implode(',', array_column($rs, 'idimpianto')); } // Selezione dei tecnici assegnati agli impianti selezionati if (!empty($impianti_collegati)) { $tecnici_impianti = $dbo->fetchArray('SELECT idtecnico FROM my_impianti WHERE id IN ('.prepare($impianti_collegati).')'); $id_tecnico = array_unique(array_column($tecnici_impianti, 'idtecnico')); } // Impostazione della data se mancante if (empty($data)) { $data = filter('data'); if (null == $data) { $data = date('Y-m-d'); } } // Impostazione della data di fine da Dashboard if (empty($data_fine)) { $data_fine = filter('data_fine'); if (null == $data_fine) { $data_fine = $data; } } $data_fine = $data_fine ?: $data; $inizio_sessione = $data.' '.$orario_inizio; $fine_sessione = $data_fine.' '.$orario_fine; // Calcolo del nuovo codice $new_codice = Intervento::getNextCodice($data); echo '
'; if (!empty($id_intervento)) { echo ' '; } // Disabilito i campi che non devono essere modificati per poter collegare l'Intervento al Promemoria del Contratto if (!empty($id_contratto) && !empty($id_promemoria_contratto)) { echo ' '; } echo ' ';