. */ 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']; } // 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'); // 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 = date('Y-m-d'); } } $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_promemoria_contratto)) { echo ''; } if (!empty($id_intervento)) { echo ''; } echo '
{[ "type": "select", "label": "'.tr('Cliente').'", "name": "idanagrafica", "required": 1, "value": "'.$id_anagrafica.'", "ajax-source": "clienti", "icon-after": "add|'.$module_anagrafiche['id'].'|tipoanagrafica=Cliente&readonly_tipo=1", "readonly": "'.(empty($id_anagrafica) ? 0 : 1).'" ]}
{[ "type": "select", "label": "'.tr('Preventivo').'", "name": "idpreventivo", "value": "'.$id_preventivo.'", "ajax-source": "preventivi", "readonly": "'.(empty($id_preventivo) ? 0 : 1).'" ]}
{[ "type": "select", "label": "'.tr('Contratto').'", "name": "idcontratto", "value": "'.$id_contratto.'", "ajax-source": "contratti", "readonly": "'.(empty($id_contratto) ? 0 : 1).'" ]}
{[ "type": "timestamp", "label": "'.tr('Data/ora richiesta').'", "name": "data_richiesta", "required": 1, "value": "'.($data_richiesta ?: '-now-').'" ]}
{[ "type": "select", "label": "'.tr('Tipo').'", "name": "idtipointervento", "required": 1, "values": "query=SELECT idtipointervento AS id, descrizione FROM in_tipiintervento ORDER BY descrizione ASC", "value": "'.$id_tipo.'", "ajax-source": "tipiintervento" ]}
{[ "type": "select", "label": "'.tr('Stato').'", "name": "idstatointervento", "required": 1, "values": "query=SELECT idstatointervento AS id, descrizione, colore AS _bgcolor_ FROM in_statiintervento WHERE deleted_at IS NULL", "value": "'.$id_stato.'" ]}
{[ "type": "textarea", "label": "'.tr('Richiesta').'", "name": "richiesta", "required": 1, "value": "'.$richiesta.'", "extra": "style=\'max-height:80px;\'" ]}
'; $espandi_dettagli = setting('Espandi automaticamente la sezione "Dettagli aggiuntivi"'); echo '

'.tr('Dettagli aggiuntivi').'

{[ "type": "select", "label": "'.tr('Zona').'", "name": "idzona", "values": "query=SELECT id, CONCAT_WS(\' - \', nome, descrizione) AS descrizione FROM an_zone ORDER BY nome", "placeholder": "'.tr('Nessuna zona').'", "help":"'.tr('La zona viene definita automaticamente in base al cliente selezionato').'.", "readonly": "0", "value": "'.$id_zona.'" ]}
{[ "type": "select", "label": "'.tr('Sede destinazione').'", "name": "idsede_destinazione", "value": "'.$id_sede.'", "ajax-source": "sedi" ]}
{[ "type": "select", "label": "'.tr('Per conto di').'", "name": "idclientefinale", "value": "'.$id_cliente_finale.'", "ajax-source": "clienti" ]}
{[ "type": "timestamp", "label": "'.tr('Data/ora scadenza').'", "name": "data_scadenza", "required": 0, "value": "'.$data_scadenza.'" ]}
{[ "type": "select", "label": "'.tr('Impianto').'", "multiple": 1, "name": "idimpianti[]", "value": "'.$impianti_collegati.'", "ajax-source": "impianti-cliente", "select-options": {"idanagrafica": '.($id_anagrafica ?: '""').'}, "icon-after": "add|'.Modules::get('Impianti')['id'].'|id_anagrafica='.$id_anagrafica.'" ]}
{[ "type": "select", "label": "'.tr('Componenti').'", "multiple": 1, "name": "componenti[]", "placeholder": "'.tr('Seleziona prima un impianto').'", "ajax-source": "componenti" ]}
'; if (empty($id_intervento)) { echo '

'.tr('Assegnazione tecnici').'

{[ "type": "select", "label": "'.tr('Tecnici assegnati').'", "multiple": "1", "name": "tecnici_assegnati[]", "ajax-source": "tecnici", "value": "", "icon-after": "add|'.$module_anagrafiche['id'].'|tipoanagrafica=Tecnico" ]}
'; } echo '

'.tr('Ore di lavoro').'

{[ "type": "timestamp", "label": "'.tr('Inizio attività').'", "name": "orario_inizio", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$inizio_sessione.'" ]}
{[ "type": "timestamp", "label": "'.tr('Fine attività').'", "name": "orario_fine", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$fine_sessione.'" ]}
{[ "type": "select", "label": "'.tr('Tecnici').'", "multiple": "1", "name": "idtecnico[]", "required": '.($origine_dashboard ? 1 : 0).', "ajax-source": "tecnici", "value": "'.$id_tecnico.'", "icon-after": "add|'.$module_anagrafiche['id'].'|tipoanagrafica=Tecnico||'.(empty($id_tecnico) ? '' : 'disabled').'" ]}
'; 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 ' ';