. */ use Models\Module; use Models\Plugin; include_once __DIR__.'/../../core.php'; // Lettura dei parametri di interesse $id_anagrafica = filter('idanagrafica'); $id_sede = filter('idsede'); $richiesta = filter('richiesta'); $descrizione = filter('descrizione'); $id_tipo = filter('id_tipo'); $origine_dashboard = get('ref') == 'dashboard' ? true : false; $id_modulo_anagrafiche = (new Module())->getByField('name', 'Anagrafiche', Models\Locale::getPredefined()->id); $id_plugin_sedi = (new Plugin())->getByField('name', 'Sedi', Models\Locale::getPredefined()->id); // 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').':00:00'; } // Un utente del gruppo Tecnici può aprire attività solo a proprio nome $id_tecnico = filter('id_tecnico'); $id_cliente = null; if ($user['gruppo'] == 'Tecnici' && !empty($user['idanagrafica'])) { $id_tecnico = $user['idanagrafica']; } elseif ($user['gruppo'] == 'Clienti' && !empty($user['idanagrafica'])) { $id_cliente = $user['idanagrafica']; } // 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 `id` = `co_promemoria`.`idtipointervento`) AS tempo_standard FROM `co_promemoria` WHERE `idcontratto`='.prepare($id_contratto).' AND `co_promemoria`.`id` = '.prepare($id_promemoria_contratto)); $id_tipo = $promemoria['idtipointervento']; $data = filter('data') ?? $promemoria['data_richiesta']; $richiesta = $promemoria['richiesta']; $descrizione = $promemoria['descrizione']; $id_sede = $promemoria['idsede']; $impianti_collegati = $promemoria['idimpianti']; $tecnici_assegnati = $promemoria['idtecnici']; $data_scadenza = $promemoria['data_scadenza']; // 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 `id` = `in_interventi`.`idtipointervento`) AS tempo_standard FROM `in_interventi` WHERE `id` = '.prepare($id_intervento)); $id_tipo = $intervento['idtipointervento']; $data = filter('data') ?? $intervento['data_richiesta']; $data_richiesta = $intervento['data_richiesta']; $data_scadenza = $intervento['data_scadenza']; $richiesta = $intervento['richiesta']; $descrizione = $intervento['descrizione']; $id_sede = $intervento['idsede_destinazione']; $id_anagrafica = $intervento['idanagrafica']; $id_cliente_finale = $intervento['idclientefinale']; $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')); $rs = $dbo->fetchArray('SELECT id_tecnico FROM in_interventi_tecnici_assegnati WHERE id_intervento = '.prepare($id_intervento)); $tecnici_assegnati = implode(',', array_column($rs, 'id_tecnico')); } // Selezione dei tecnici predefiniti per gli 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 $data = (!empty(filter('data')) ? filter('data') : date('Y-m-d')); // Impostazione della data di fine da Dashboard $data_fine = (!empty(filter('data')) ? filter('data') : $data); $inizio_sessione = $data.' '.$orario_inizio; $fine_sessione = $data_fine.' '.$orario_fine; echo '
'; if (!empty($id_promemoria_contratto)) { echo ''; } if (!empty($id_intervento)) { echo ''; } echo '
{[ "type": "select", "label": "'.tr('Cliente').'", "name": "idanagrafica", "required": 1, "value": "'.(!$id_cliente ? $id_anagrafica : $id_cliente).'", "ajax-source": "clienti", "icon-after": "add|'.$id_modulo_anagrafiche.'|tipoanagrafica=Cliente&readonly_tipo=1", "readonly": "'.((empty($id_anagrafica) && empty($id_cliente)) ? 0 : 1).'" ]}
{[ "type": "select", "label": "'.tr('Sede destinazione').'", "name": "idsede_destinazione", "value": "'.$id_sede.'", "ajax-source": "sedi", "select-options": '.json_encode(['idanagrafica' => $id_anagrafica]).', "icon-after": "add|'.$id_modulo_anagrafiche.'|id_plugin='.$id_plugin_sedi.'&id_parent='.$id_anagrafica.'" ]}
{[ "type": "select", "label": "'.tr('Per conto di').'", "name": "idclientefinale", "value": "'.$id_cliente_finale.'", "ajax-source": "clienti" ]}
{[ "type": "select", "label": "'.tr('Impianto').'", "multiple": 1, "name": "idimpianti[]", "value": "'.$impianti_collegati.'", "ajax-source": "impianti-cliente", "select-options": {"idanagrafica": '.($id_anagrafica ?: '""').', "idsede_destinazione": '.($id_sede ?: '""').'}, "icon-after": "add|'.(new Module())->getByField('name', 'Impianti', Models\Locale::getPredefined()->id).'|id_anagrafica='.$id_anagrafica.'" ]}
{[ "type": "select", "label": "'.tr('Componenti').'", "multiple": 1, "name": "componenti[]", "placeholder": "'.tr('Seleziona prima un impianto').'", "ajax-source": "componenti" ]}
{[ "type": "select", "label": "'.tr('Sezionale').'", "name": "id_segment", "required": 1, "ajax-source": "segmenti", "select-options": '.json_encode(['id_module' => $id_module, 'is_sezionale' => 1]).', "value": "'.$_SESSION['module_'.$id_module]['id_segment'].'" ]}
{[ "type": "select", "label": "'.tr('Preventivo').'", "name": "idpreventivo", "value": "'.$id_preventivo.'", "ajax-source": "preventivi", "readonly": "'.(empty($id_preventivo) ? 0 : 1).'", "select-options": '.json_encode(['idanagrafica' => $id_anagrafica]).' ]}
{[ "type": "select", "label": "'.tr('Contratto').'", "name": "idcontratto", "value": "'.$id_contratto.'", "ajax-source": "contratti", "readonly": "'.(empty($id_contratto) ? 0 : 1).'", "select-options": '.json_encode(['idanagrafica' => $id_anagrafica]).', "icon-after": "add|'.(new Module())->getByField('name', 'Contratti', Models\Locale::getPredefined()->id).'|pianificabile=1&idanagrafica='.$id_anagrafica.'" ]}
{[ "type": "select", "label": "'.tr('Ordine').'", "name": "idordine", "ajax-source": "ordini-cliente", "value": "'.$id_ordine.'", "select-options": '.json_encode(['idanagrafica' => $id_anagrafica]).' ]}
{[ "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, "value": "'.$id_tipo.'", "ajax-source": "tipiintervento" ]}
{[ "type": "select", "label": "'.tr('Stato').'", "name": "id", "required": 1, "values": "query=SELECT `in_statiintervento`.`id`, `in_statiintervento_lang`.`name` as descrizione, `colore` AS _bgcolor_ FROM `in_statiintervento` LEFT JOIN `in_statiintervento_lang` ON (`in_statiintervento`.`id` = `in_statiintervento_lang`.`id_record` AND `in_statiintervento_lang`.`id_lang` = '.prepare(Models\Locale::getDefault()->id).') WHERE `deleted_at` IS NULL ORDER BY `name`", "value": "'.($origine_dashboard ? setting('Stato predefinito dell\'attività da Dashboard') : setting('Stato predefinito dell\'attività')).'" ]}
'; echo input([ 'type' => 'ckeditor', 'label' => tr('Richiesta'), 'name' => 'richiesta', 'id' => 'richiesta_add', 'required' => 1, 'value' => htmlentities($richiesta), 'extra' => 'style=\'max-height:80px;\'', ]); echo '
'; echo input([ 'type' => 'ckeditor', 'label' => tr('Descrizione'), 'name' => 'descrizione', 'id' => 'descrizione_add', 'value' => htmlentities($descrizione), 'extra' => 'style=\'max-height:80px;\'', ]); echo '

'.tr('Dettagli cliente').'

'.tr('Seleziona prima un cliente').'...

'.tr('Posizione').'

'; $espandi_dettagli = setting('Espandi automaticamente la sezione "Dettagli aggiuntivi"'); echo '

'.tr('Dettagli aggiuntivi').'

{[ "type": "timestamp", "label": "'.tr('Data/ora scadenza').'", "name": "data_scadenza", "required": 0, "value": "'.$data_scadenza.'" ]}
{[ "type": "select", "label": "'.tr('Referente').'", "name": "idreferente", "ajax-source": "referenti", "select-options": '.json_encode(['idanagrafica' => $id_anagrafica, 'idclientefinale' => $id_cliente_finale]).', "icon-after": "add|'.(new Module())->getByField('name', 'Anagrafiche', Models\Locale::getPredefined()->id)->id_record.'|id_plugin='.(new Plugin())->getByField('name', 'Referenti', Models\Locale::getPredefined()->id).'&id_parent='.$id_anagrafica.'" ]}
'; // if (empty($id_intervento)) { echo '

'.tr('Assegnazione tecnici').'

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

'.tr('Sessioni 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('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": "1", "value": "'.$id_zona.'" ]}
{[ "type": "select", "label": "'.tr('Tecnici').'", "multiple": "1", "name": "idtecnico[]", "required": '.($origine_dashboard ? 1 : 0).', "ajax-source": "tecnici", "value": "'.$id_tecnico.'", "icon-after": "add|'.$id_modulo_anagrafiche.'|tipoanagrafica=Tecnico&readonly_tipo=1||'.(empty($id_tecnico) ? '' : 'disabled').'" ]}

'.tr('Ricorrenza').'

{[ "type": "checkbox", "label": "'.tr('Attività ricorrente').'", "name": "ricorsiva", "value": "" ]}
{[ "type": "timestamp", "label": "'.tr('Data/ora inizio').'", "name": "data_inizio_ricorrenza", "value": "'.($data_richiesta ?: '-now-').'" ]}
{[ "type": "number", "label": "'.tr('Periodicità').'", "name": "periodicita", "decimals": "0", "icon-after": "choice|period|months", "value": "1" ]}
{[ "type": "select", "label": "'.tr('Metodo fine ricorrenza').'", "name": "metodo_ricorrenza", "values": "list=\"data\":\"Data fine\",\"numero\":\"Numero ricorrenze\"" ]}
{[ "type": "timestamp", "label": "'.tr('Data/ora fine').'", "name": "data_fine_ricorrenza" ]}
{[ "type": "number", "label": "'.tr('Numero ricorrenze').'", "name": "numero_ricorrenze", "decimals": "0" ]}
{[ "type": "select", "label": "'.tr('Stato ricorrenze').'", "name": "idstatoricorrenze", "values": "query=SELECT `in_statiintervento`.`id`,`in_statiintervento_lang`.`name` as descrizione, `colore` AS _bgcolor_ FROM `in_statiintervento` LEFT JOIN `in_statiintervento_lang` ON (`in_statiintervento`.`id` = `in_statiintervento_lang`.`id_record` AND `in_statiintervento_lang`.`id_lang` = '.prepare(Models\Locale::getDefault()->id).') WHERE `deleted_at` IS NULL AND `is_completato`=0 ORDER BY `name`" ]}
{[ "type": "checkbox", "label": "'.tr('Riporta sessioni di lavoro').'", "name": "riporta_sessioni", "value": "" ]}
'; 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 ' ';