2017-08-04 16:28:16 +02:00
< ? php
include_once __DIR__ . '/../../../core.php' ;
2018-06-26 10:25:50 +02:00
$matricole = ( array ) post ( 'matricole' );
2017-08-04 16:28:16 +02:00
// Salvo gli impianti selezionati
if ( filter ( 'op' ) == 'link_myimpianti' ) {
$matricole_old = $dbo -> fetchArray ( 'SELECT * FROM my_impianti_interventi WHERE idintervento=' . prepare ( $id_record ));
$matricole_old = array_column ( $matricole_old , 'idimpianto' );
// Individuazione delle matricole mancanti
foreach ( $matricole_old as $matricola ) {
if ( ! in_array ( $matricola , $matricole )) {
$dbo -> query ( 'DELETE FROM my_impianti_interventi WHERE idintervento=' . prepare ( $id_record ) . ' AND idimpianto = ' . prepare ( $matricola ));
$components = $dbo -> fetchArray ( 'SELECT * FROM my_impianto_componenti WHERE idimpianto = ' . prepare ( $matricola ));
if ( ! empty ( $components )) {
foreach ( $components as $component ) {
$dbo -> query ( 'DELETE FROM my_componenti_interventi WHERE id_componente = ' . prepare ( $component [ 'id' ]) . ' AND id_intervento = ' . prepare ( $id_record ));
}
}
}
}
foreach ( $matricole as $matricola ) {
if ( ! in_array ( $matricola , $matricole_old )) {
$dbo -> query ( 'INSERT INTO my_impianti_interventi(idimpianto, idintervento) VALUES(' . prepare ( $matricola ) . ', ' . prepare ( $id_record ) . ')' );
}
}
2018-07-07 13:56:22 +02:00
App :: flash () -> info ( tr ( 'Informazioni impianti salvate!' ));
2017-08-04 16:28:16 +02:00
} elseif ( filter ( 'op' ) == 'link_componenti' ) {
$components = ( array ) $post [ 'componenti' ];
$list = ( ! empty ( $post [ 'list' ])) ? explode ( ',' , $post [ 'list' ]) : [];
foreach ( $list as $delete ) {
if ( ! in_array ( $delete , $components )) {
$dbo -> query ( 'DELETE FROM my_componenti_interventi WHERE id_componente = ' . prepare ( $delete ) . ' AND id_intervento = ' . prepare ( $id_record ));
}
}
foreach ( $components as $component ) {
if ( ! in_array ( $component , $list )) {
$dbo -> query ( 'INSERT INTO my_componenti_interventi(id_componente, id_intervento) VALUES(' . prepare ( $component ) . ', ' . prepare ( $id_record ) . ')' );
}
}
2018-07-07 13:56:22 +02:00
App :: flash () -> info ( tr ( 'Informazioni componenti salvate!' ));
2017-08-04 16:28:16 +02:00
}
2018-02-16 15:45:15 +01:00
//Blocco della modifica impianti se l'intervento è completato
$rss = $dbo -> fetchArray ( 'SELECT in_statiintervento.completato FROM in_statiintervento INNER JOIN in_interventi ON in_statiintervento.idstatointervento=in_interventi.idstatointervento WHERE in_interventi.id=' . prepare ( $id_record ));
$flg_completato = $rss [ 0 ][ 'completato' ];
2018-02-18 19:53:23 +01:00
if ( $flg_completato ) {
2018-02-16 15:45:15 +01:00
$readonly = 'readonly' ;
$disabled = 'disabled' ;
} else {
$readonly = '' ;
$disabled = '' ;
}
2017-08-04 16:28:16 +02:00
// IMPIANTI
echo '
< div class = " box " >
< div class = " box-header with-border " >
2017-09-04 12:02:29 +02:00
< h3 class = " box-title " > '.tr("Impianti dell' intervento " ).'</h3>
2017-08-04 16:28:16 +02:00
</ div >
< div class = " box-body " >
2017-09-04 12:02:29 +02:00
< p > '.tr("Impianti su cui è stato effettuato l' intervento " ).'</p>';
2017-08-04 16:28:16 +02:00
$query = 'SELECT * FROM my_impianti_interventi INNER JOIN my_impianti ON my_impianti_interventi.idimpianto=my_impianti.id WHERE idintervento=' . prepare ( $id_record );
$rs = $dbo -> fetchArray ( $query );
echo '
< div class = " row " > ' ;
foreach ( $rs as $r ) {
echo '
< div class = " col-md-3 " >
< table class = " table table-hover table-condensed table-striped " > ' ;
// MATRICOLA
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td align = " right " > '.tr(' Matricola ').' :</ td >
2017-08-04 16:28:16 +02:00
< td valign = " top " > '.$r[' matricola '].' </ td >
</ tr > ' ;
// NOME
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td align = " right " > '.tr(' Nome ').' :</ td >
2017-08-04 16:28:16 +02:00
< td valign = " top " >
'.Modules::link(' MyImpianti ', $r[' id '], $r[' nome ']).'
</ td >
</ tr > ' ;
// DATA
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td align = " right " > '.tr(' Data ').' :</ td >
2017-08-04 16:28:16 +02:00
< td valign = " top " > '.Translator::dateToLocale($r[' data ']).' </ td >
</ tr > ' ;
// DESCRIZIONE
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td align = " right " > '.tr(' Descrizione ').' :</ td >
2017-08-04 16:28:16 +02:00
< td valign = " top " > '.$r[' descrizione '].' </ td >
</ tr > ' ;
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td valign = " top " align = " right " > '.tr("Componenti soggetti all' intervento " ).'</td>
2017-08-04 16:28:16 +02:00
< td valign = " top " >
< form action = " '. $rootdir .'/editor.php?id_module='. $id_module .'&id_record='. $id_record .'&op=link_componenti&matricola='. $r['id'] .' " method = " post " >
< input type = " hidden " name = " backto " value = " record-edit " >
2018-02-16 15:45:15 +01:00
< select class = " superselect " name = " componenti[] " multiple '.$readonly.' '.$disabled.' > ' ;
2017-08-04 16:28:16 +02:00
$inseriti = $dbo -> fetchArray ( 'SELECT * FROM my_componenti_interventi WHERE id_intervento=' . prepare ( $id_record ));
$inseriti = ! empty ( $inseriti ) ? array_column ( $inseriti , 'id_componente' ) : [];
$list = [];
$componenti = $dbo -> fetchArray ( 'SELECT * FROM my_impianto_componenti WHERE idimpianto=' . prepare ( $r [ 'id' ]) . ' ORDER BY id' );
if ( ! empty ( $componenti )) {
foreach ( $componenti as $componente ) {
$nome = '' ;
echo '
< option value = " '. $componente['id'] .' " ' ;
if ( in_array ( $componente [ 'id' ], $inseriti )) {
echo ' selected="selected"' ;
$list [] = $componente [ 'id' ];
}
2017-08-28 15:29:03 +02:00
if ( str_contains ( $componente [ 'contenuto' ], '[Matricola]' )) {
2017-08-04 16:28:16 +02:00
$ini_array = parse_ini_string ( $componente [ 'contenuto' ], true );
foreach ( $ini_array as $sezione => $array_impostazioni ) {
if ( $sezione == 'Matricola' ) {
$nome .= $ini_array [ $sezione ][ 'valore' ] . ' - ' ;
}
}
}
$nome .= $componente [ 'nome' ];
echo ' title="' . addslashes ( $componente [ 'nome' ]) . '">' . $nome . '</option>' ;
}
}
echo '
</ select >< br >< br >
< input type = " hidden " name = " list " value = " '.implode(',', $list ).' " >
2018-02-16 15:45:15 +01:00
< button type = " submit " class = " btn btn-success " '.$disabled.' >< i class = " fa fa-check " ></ i > '.tr(' Salva componenti ').' </ button >
2017-08-04 16:28:16 +02:00
</ form >
</ td >
</ tr >
</ table >
</ div > ' ;
}
echo '
</ div > ' ;
/*
Aggiunta impianti all ' intervento
*/
// Elenco impianti collegati all'intervento
2017-09-18 18:11:19 +02:00
$impianti = $dbo -> fetchArray ( 'SELECT idimpianto FROM my_impianti_interventi WHERE idintervento=' . prepare ( $id_record ));
$impianti = ! empty ( $impianti ) ? array_column ( $impianti , 'idimpianto' ) : [];
2017-08-04 16:28:16 +02:00
// Elenco sedi
2018-07-18 15:20:10 +02:00
$sedi = $dbo -> fetchArray ( 'SELECT id, nomesede, citta FROM an_sedi WHERE idanagrafica=' . prepare ( $record [ 'idanagrafica' ]) . " UNION SELECT 0, 'Sede legale', '' ORDER BY id " );
2017-08-04 16:28:16 +02:00
echo '
2017-09-04 12:02:29 +02:00
< p >< strong > '.tr(' Impianti disponibili ').' </ strong ></ p >
2017-08-04 16:28:16 +02:00
< form action = " '. $rootdir .'/editor.php?id_module='. $id_module .'&id_record='. $id_record .'&op=link_myimpianti " method = " post " >
< input type = " hidden " name = " backto " value = " record-edit " >
< div class = " row " >
< div class = " col-xs-12 col-md-6 " >
2018-07-18 15:20:10 +02:00
{[ " type " : " select " , " name " : " matricole[] " , " multiple " : 1 , " value " : " '.implode(',', $impianti ).' " , " values " : " query=SELECT my_impianti.id, CONCAT(matricola, \ ' - \ ', nome) AS descrizione, CONCAT(nomesede, IF(citta IS NULL OR citta = \ ' \ ', \ ' \ ', CONCAT( \ ' ( \ ', citta, \ ') \ '))) AS optgroup FROM my_impianti JOIN (SELECT id, nomesede, citta FROM an_sedi UNION SELECT 0 AS id, \ 'Sede legale \ ' AS nomesede, \ ' \ ' AS citta) AS t ON t.id = my_impianti.idsede WHERE idanagrafica='.prepare( $record['idanagrafica'] ).' ORDER BY idsede ASC, matricola ASC " , " extra " : " '. $readonly .' " ]}
2017-08-04 16:28:16 +02:00
</ div >
</ div >
< br >< br >
2018-02-16 15:45:15 +01:00
< button type = " submit " class = " btn btn-success " '.$disabled.' >< i class = " fa fa-check " ></ i > '.tr(' Salva impianti ').' </ button ></ a >
2017-08-04 16:28:16 +02:00
</ form > ' ;
echo '
</ div >
</ div > ' ;