2017-08-04 16:28:16 +02:00
< ? php
2020-09-07 15:04:06 +02:00
/*
* OpenSTAManager : il software gestionale open source per l ' assistenza tecnica e la fatturazione
2021-01-20 15:08:51 +01:00
* Copyright ( C ) DevCode s . r . l .
2020-09-07 15:04:06 +02:00
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < https :// www . gnu . org / licenses />.
*/
2017-08-04 16:28:16 +02:00
2018-06-25 20:50:40 +02:00
include_once __DIR__ . '/../../core.php' ;
2023-02-03 18:05:51 +01:00
use Carbon\CarbonPeriod ;
2019-01-11 08:32:08 +01:00
use Modules\Anagrafiche\Anagrafica ;
2018-09-25 16:47:44 +02:00
use Modules\Articoli\Articolo as ArticoloOriginale ;
2019-08-29 10:25:14 +02:00
use Modules\Emails\Mail ;
use Modules\Emails\Template ;
2021-08-05 18:17:26 +02:00
use Modules\Impianti\Impianto ;
2018-12-25 11:32:19 +01:00
use Modules\Interventi\Components\Articolo ;
2019-03-29 12:46:17 +01:00
use Modules\Interventi\Components\Riga ;
2019-05-16 04:52:16 +02:00
use Modules\Interventi\Components\Sconto ;
2019-07-15 12:27:12 +02:00
use Modules\Interventi\Components\Sessione ;
2018-12-29 12:03:22 +01:00
use Modules\Interventi\Intervento ;
2019-01-11 08:32:08 +01:00
use Modules\Interventi\Stato ;
2019-07-08 12:24:59 +02:00
use Modules\TipiIntervento\Tipo as TipoSessione ;
2021-08-05 18:17:26 +02:00
use Plugins\ComponentiImpianti\Componente ;
2022-09-02 17:24:12 +02:00
use Plugins\ListinoClienti\DettaglioPrezzo ;
2020-02-17 15:09:07 +01:00
use Plugins\PianificazioneInterventi\Promemoria ;
2018-08-29 18:06:51 +02:00
2017-08-04 16:28:16 +02:00
switch ( post ( 'op' )) {
case 'update' :
$idcontratto = post ( 'idcontratto' );
2020-02-17 15:09:07 +01:00
$id_promemoria = post ( 'idcontratto_riga' );
2017-08-04 16:28:16 +02:00
2019-02-14 09:52:42 +01:00
// Rimozione del collegamento al promemoria
2020-02-17 15:09:07 +01:00
if ( ! empty ( $id_promemoria ) && $intervento -> id_contratto != $idcontratto ) {
2018-08-31 11:39:38 +02:00
$dbo -> update ( 'co_promemoria' , [ 'idintervento' => null ], [ 'idintervento' => $id_record ]);
2017-08-04 16:28:16 +02:00
}
// Salvataggio modifiche intervento
2021-02-25 15:16:05 +01:00
$intervento -> codice = post ( 'codice' );
2019-02-14 09:52:42 +01:00
$intervento -> data_richiesta = post ( 'data_richiesta' );
2019-12-09 16:44:07 +01:00
$intervento -> data_scadenza = post ( 'data_scadenza' ) ? : null ;
2019-02-14 09:52:42 +01:00
$intervento -> richiesta = post ( 'richiesta' );
$intervento -> descrizione = post ( 'descrizione' );
$intervento -> informazioniaggiuntive = post ( 'informazioniaggiuntive' );
$intervento -> idanagrafica = post ( 'idanagrafica' );
$intervento -> idclientefinale = post ( 'idclientefinale' );
$intervento -> idreferente = post ( 'idreferente' );
2022-05-19 17:42:41 +02:00
$intervento -> idagente = post ( 'idagente' );
2019-02-14 09:52:42 +01:00
$intervento -> idtipointervento = post ( 'idtipointervento' );
$intervento -> idstatointervento = post ( 'idstatointervento' );
2019-05-29 19:17:57 +02:00
$intervento -> idsede_partenza = post ( 'idsede_partenza' );
$intervento -> idsede_destinazione = post ( 'idsede_destinazione' );
2019-02-14 09:52:42 +01:00
$intervento -> id_preventivo = post ( 'idpreventivo' );
$intervento -> id_contratto = $idcontratto ;
2021-03-01 15:01:02 +01:00
$intervento -> id_ordine = post ( 'idordine' );
2019-02-14 09:52:42 +01:00
$intervento -> id_documento_fe = post ( 'id_documento_fe' );
2019-02-26 21:38:26 +01:00
$intervento -> num_item = post ( 'num_item' );
2019-02-14 09:52:42 +01:00
$intervento -> codice_cup = post ( 'codice_cup' );
$intervento -> codice_cig = post ( 'codice_cig' );
$intervento -> save ();
2017-08-04 16:28:16 +02:00
2020-08-04 18:33:28 +02:00
$tecnici_assegnati = ( array ) post ( 'tecnici_assegnati' );
2021-11-23 12:04:44 +01:00
2023-09-15 18:06:15 +02:00
$tecnici_presenti_array = $dbo -> select ( 'in_interventi_tecnici_assegnati' , 'id_tecnico' , [], [ 'id_intervento' => $intervento -> id ]);
2021-11-23 12:04:44 +01:00
2023-08-04 14:54:28 +02:00
foreach ( $tecnici_presenti_array as $tecnico_presente ) {
2021-11-23 12:04:44 +01:00
$tecnici_presenti [] = $tecnico_presente [ 'id_tecnico' ];
// Notifica rimozione tecnico assegnato
if ( setting ( 'Notifica al tecnico la rimozione dell\'assegnazione dall\'attività' )) {
2023-08-04 14:54:28 +02:00
if ( ! in_array ( $tecnico_presente [ 'id_tecnico' ], $tecnici_assegnati )) {
2021-11-23 12:04:44 +01:00
$tecnico = Anagrafica :: find ( $tecnico_presente [ 'id_tecnico' ]);
if ( ! empty ( $tecnico [ 'email' ])) {
$template = Template :: pool ( 'Notifica rimozione intervento' );
if ( ! empty ( $template )) {
$mail = Mail :: build ( auth () -> getUser (), $template , $intervento -> id );
$mail -> addReceiver ( $tecnico [ 'email' ]);
$mail -> save ();
}
}
}
}
}
2023-08-04 14:54:28 +02:00
foreach ( $tecnici_assegnati as $tecnico_assegnato ) {
2021-11-23 12:04:44 +01:00
// Notifica aggiunta tecnico assegnato
if ( setting ( 'Notifica al tecnico l\'assegnazione all\'attività' )) {
2023-08-04 14:54:28 +02:00
if ( ! in_array ( $tecnico_assegnato , $tecnici_presenti )) {
2021-11-23 12:04:44 +01:00
$tecnico = Anagrafica :: find ( $tecnico_assegnato );
if ( ! empty ( $tecnico [ 'email' ])) {
$template = Template :: pool ( 'Notifica intervento' );
if ( ! empty ( $template )) {
$mail = Mail :: build ( auth () -> getUser (), $template , $intervento -> id );
$mail -> addReceiver ( $tecnico [ 'email' ]);
$mail -> save ();
}
}
}
}
}
// Assegnazione dei tecnici all'intervento
2020-08-04 18:33:28 +02:00
$dbo -> sync ( 'in_interventi_tecnici_assegnati' , [
'id_intervento' => $id_record ,
], [
'id_tecnico' => $tecnici_assegnati ,
]);
2021-11-23 12:04:44 +01:00
// Notifica cambio stato intervento
2019-02-14 09:52:42 +01:00
$stato = $dbo -> selectOne ( 'in_statiintervento' , '*' , [ 'idstatointervento' => post ( 'idstatointervento' )]);
2021-02-02 13:01:27 +01:00
if ( ! empty ( $stato [ 'notifica' ]) && $stato [ 'idstatointervento' ] != $record [ 'idstatointervento' ]) {
2019-08-29 10:25:14 +02:00
$template = Template :: find ( $stato [ 'id_email' ]);
2018-09-20 11:39:03 +02:00
2021-02-18 18:48:44 +01:00
if ( ! empty ( $stato [ 'destinatari' ])) {
2021-02-02 13:01:27 +01:00
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $stato [ 'destinatari' ]);
$mail -> save ();
}
2021-02-18 18:48:44 +01:00
if ( ! empty ( $stato [ 'notifica_cliente' ])) {
2022-12-07 16:21:38 +01:00
if ( ! empty ( $intervento -> anagrafica -> email )) {
2021-02-02 13:01:27 +01:00
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
2022-12-07 16:21:38 +01:00
$mail -> addReceiver ( $intervento -> anagrafica -> email );
2021-02-02 13:01:27 +01:00
$mail -> save ();
}
}
2022-08-02 13:12:56 +02:00
$tecnici_intervento = [];
2021-11-23 12:04:44 +01:00
if ( ! empty ( $stato [ 'notifica_tecnico_sessione' ])) {
2023-09-15 18:06:15 +02:00
$tecnici_intervento = $dbo -> select ( 'in_interventi_tecnici' , 'idtecnico' , [], [ 'idintervento' => $id_record ]);
2021-11-23 12:04:44 +01:00
}
2022-08-02 13:12:56 +02:00
$tecnici_assegnati = [];
2021-11-23 12:04:44 +01:00
if ( ! empty ( $stato [ 'notifica_tecnico_assegnato' ])) {
2023-09-15 18:06:15 +02:00
$tecnici_assegnati = $dbo -> select ( 'in_interventi_tecnici_assegnati' , 'id_tecnico AS idtecnico' , [], [ 'id_intervento' => $id_record ]);
2021-11-23 12:04:44 +01:00
}
2023-08-04 14:54:28 +02:00
2021-11-23 12:04:44 +01:00
$tecnici = array_unique ( array_merge ( $tecnici_intervento , $tecnici_assegnati ), SORT_REGULAR );
2021-02-02 13:01:27 +01:00
2021-11-23 12:04:44 +01:00
foreach ( $tecnici as $tecnico ) {
$mail_tecnico = $dbo -> selectOne ( 'an_anagrafiche' , '*' , [ 'idanagrafica' => $tecnico ]);
if ( ! empty ( $mail_tecnico [ 'email' ])) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $mail_tecnico [ 'email' ]);
$mail -> save ();
2021-02-02 13:01:27 +01:00
}
}
2018-09-20 11:39:03 +02:00
}
2021-06-16 18:54:09 +02:00
2023-06-26 12:41:34 +02:00
aggiorna_sedi_movimenti ( 'interventi' , $id_record );
2020-08-03 12:43:30 +02:00
flash () -> info ( tr ( 'Attività modificata correttamente!' ));
2017-08-04 16:28:16 +02:00
break ;
case 'add' :
2018-09-20 09:21:34 +02:00
if ( post ( 'id_intervento' ) == null ) {
2019-01-11 08:32:08 +01:00
$idanagrafica = post ( 'idanagrafica' );
$idtipointervento = post ( 'idtipointervento' );
$idstatointervento = post ( 'idstatointervento' );
$data_richiesta = post ( 'data_richiesta' );
2019-12-09 17:47:07 +01:00
$data_scadenza = post ( 'data_scadenza' ) ? : null ;
2022-11-28 09:27:25 +01:00
$id_segment = post ( 'id_segment' );
2017-08-04 16:28:16 +02:00
2019-01-11 08:32:08 +01:00
$anagrafica = Anagrafica :: find ( $idanagrafica );
$tipo = TipoSessione :: find ( $idtipointervento );
$stato = Stato :: find ( $idstatointervento );
2017-08-04 16:28:16 +02:00
2022-11-28 09:27:25 +01:00
$intervento = Intervento :: build ( $anagrafica , $tipo , $stato , $data_richiesta , $id_segment );
2019-01-11 08:32:08 +01:00
$id_record = $intervento -> id ;
flash () -> info ( tr ( 'Aggiunto nuovo intervento!' ));
2018-01-08 17:14:59 +01:00
2018-09-20 09:21:34 +02:00
// Informazioni di base
$idpreventivo = post ( 'idpreventivo' );
$idcontratto = post ( 'idcontratto' );
2020-02-17 15:09:07 +01:00
$id_promemoria = post ( 'idcontratto_riga' );
2018-09-20 09:21:34 +02:00
$idtipointervento = post ( 'idtipointervento' );
2019-05-29 19:17:57 +02:00
$idsede_partenza = post ( 'idsede_partenza' );
2022-01-28 12:33:29 +01:00
$idsede_destinazione = post ( 'idsede_destinazione' ) ? : 0 ;
2018-09-20 09:21:34 +02:00
2019-01-11 08:32:08 +01:00
if ( post ( 'idclientefinale' )) {
$intervento -> idclientefinale = post ( 'idclientefinale' );
}
2019-02-14 09:52:42 +01:00
$intervento -> id_preventivo = post ( 'idpreventivo' );
$intervento -> id_contratto = post ( 'idcontratto' );
2021-03-01 15:01:02 +01:00
$intervento -> id_ordine = post ( 'idordine' );
2022-02-16 17:47:19 +01:00
$intervento -> idreferente = post ( 'idreferente' );
2021-03-29 18:31:23 +02:00
$intervento -> richiesta = post ( 'richiesta' );
2023-03-31 14:15:09 +02:00
$intervento -> descrizione = post ( 'descrizione' );
2019-10-29 17:23:52 +01:00
$intervento -> idsede_destinazione = $idsede_destinazione ;
2019-02-27 13:17:47 +01:00
$intervento -> data_scadenza = $data_scadenza ;
2019-01-16 16:26:19 +01:00
$intervento -> save ();
2019-01-11 08:32:08 +01:00
2020-02-17 15:09:07 +01:00
// Sincronizzazione con il promemoria indicato
if ( ! empty ( $id_promemoria )) {
$promemoria = Promemoria :: find ( $id_promemoria );
2020-09-25 11:40:52 +02:00
$promemoria -> pianifica ( $intervento , false );
2017-08-04 16:28:16 +02:00
}
2018-09-20 09:21:34 +02:00
// Collegamenti intervento/impianti
$impianti = ( array ) post ( 'idimpianti' );
if ( ! empty ( $impianti )) {
2020-09-25 11:40:52 +02:00
$impianti = array_unique ( $impianti );
2018-09-20 09:21:34 +02:00
foreach ( $impianti as $impianto ) {
$dbo -> insert ( 'my_impianti_interventi' , [
'idintervento' => $id_record ,
'idimpianto' => $impianto ,
]);
}
// Collegamenti intervento/componenti
$componenti = ( array ) post ( 'componenti' );
foreach ( $componenti as $componente ) {
$dbo -> insert ( 'my_componenti_interventi' , [
'id_intervento' => $id_record ,
'id_componente' => $componente ,
]);
}
}
} else {
$id_record = post ( 'id_intervento' );
2021-05-17 17:31:03 +02:00
$intervento = Intervento :: find ( $id_record );
$intervento -> richiesta = post ( 'richiesta' );
2023-03-31 14:15:09 +02:00
$intervento -> descrizione = post ( 'descrizione' );
2021-05-17 17:31:03 +02:00
$intervento -> save ();
2018-09-20 09:21:34 +02:00
$idcontratto = $dbo -> fetchOne ( 'SELECT idcontratto FROM co_promemoria WHERE idintervento = :id' , [
2018-09-25 16:47:44 +02:00
':id' => $id_record ,
2018-09-20 09:21:34 +02:00
])[ 'idcontratto' ];
2017-08-04 16:28:16 +02:00
}
// Collegamenti tecnici/interventi
2020-02-14 12:23:50 +01:00
if ( ! empty ( post ( 'orario_inizio' )) && ! empty ( post ( 'orario_fine' ))) {
2020-09-25 11:14:50 +02:00
$idtecnici = post ( 'idtecnico' );
2020-02-12 10:35:07 +01:00
foreach ( $idtecnici as $idtecnico ) {
add_tecnico ( $id_record , $idtecnico , post ( 'orario_inizio' ), post ( 'orario_fine' ), $idcontratto );
}
2017-08-04 16:28:16 +02:00
}
2020-08-04 18:33:28 +02:00
// Assegnazione dei tecnici all'intervento
$tecnici_assegnati = ( array ) post ( 'tecnici_assegnati' );
$dbo -> sync ( 'in_interventi_tecnici_assegnati' , [
'id_intervento' => $id_record ,
], [
'id_tecnico' => $tecnici_assegnati ,
]);
2023-08-04 14:54:28 +02:00
foreach ( $tecnici_assegnati as $tecnico_assegnato ) {
2021-11-23 12:04:44 +01:00
$tecnico = Anagrafica :: find ( $tecnico_assegnato );
// Notifica al tecnico
if ( setting ( 'Notifica al tecnico l\'assegnazione all\'attività' )) {
if ( ! empty ( $tecnico [ 'email' ])) {
$template = Template :: pool ( 'Notifica intervento' );
if ( ! empty ( $template )) {
$mail = Mail :: build ( auth () -> getUser (), $template , $intervento -> id );
$mail -> addReceiver ( $tecnico [ 'email' ]);
$mail -> save ();
}
}
}
}
2021-09-23 10:04:44 +02:00
if ( ! empty ( post ( 'ricorsiva' ))) {
2021-09-22 11:22:03 +02:00
$periodicita = post ( 'periodicita' );
$data = post ( 'data_inizio_ricorrenza' );
2021-09-23 10:04:44 +02:00
$interval = post ( 'tipo_periodicita' ) != 'manual' ? post ( 'tipo_periodicita' ) : 'days' ;
2021-09-22 11:22:03 +02:00
$stato = Stato :: find ( post ( 'idstatoricorrenze' ));
// Estraggo le date delle ricorrenze
2021-09-23 10:04:44 +02:00
if ( post ( 'metodo_ricorrenza' ) == 'data' ) {
2021-09-22 11:22:03 +02:00
$data_fine = post ( 'data_fine_ricorrenza' );
2021-09-23 10:04:44 +02:00
while ( strtotime ( $data ) <= strtotime ( $data_fine )) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+' . $periodicita . ' ' . $interval . '' , strtotime ( $data )));
$w = date ( 'w' , strtotime ( $data ));
//Escludo sabato e domenica
2021-09-23 10:04:44 +02:00
if ( $w == '6' ) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+2 day' , strtotime ( $data )));
2021-09-23 10:04:44 +02:00
} elseif ( $w == '0' ) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+1 day' , strtotime ( $data )));
}
2021-09-23 10:04:44 +02:00
if ( $data <= $data_fine ) {
2021-09-22 11:22:03 +02:00
$date_ricorrenze [] = $data ;
}
}
} else {
$ricorrenze = post ( 'numero_ricorrenze' );
2021-09-23 10:04:44 +02:00
for ( $i = 0 ; $i < $ricorrenze ; ++ $i ) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+' . $periodicita . ' ' . $interval . '' , strtotime ( $data )));
$w = date ( 'w' , strtotime ( $data ));
//Escludo sabato e domenica
2021-09-23 10:04:44 +02:00
if ( $w == '6' ) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+2 day' , strtotime ( $data )));
2021-09-23 10:04:44 +02:00
} elseif ( $w == '0' ) {
2021-09-22 11:22:03 +02:00
$data = date ( 'Y-m-d' , strtotime ( '+1 day' , strtotime ( $data )));
}
$date_ricorrenze [] = $data ;
}
}
2021-09-23 10:04:44 +02:00
foreach ( $date_ricorrenze as $data_ricorrenza ) {
2021-09-22 11:22:03 +02:00
$intervento = Intervento :: find ( $id_record );
$new = $intervento -> replicate ();
// Calcolo il nuovo codice
2022-11-28 09:27:25 +01:00
$new -> codice = Intervento :: getNextCodice ( $data_ricorrenza , $new -> id_segment );
2021-09-22 11:22:03 +02:00
$new -> data_richiesta = $data_ricorrenza ;
$new -> idstatointervento = $stato -> idstatointervento ;
$new -> save ();
$idintervento = $new -> id ;
// Inserimento sessioni
if ( ! empty ( post ( 'riporta_sessioni' ))) {
$numero_sessione = 0 ;
$sessioni = $intervento -> sessioni ;
foreach ( $sessioni as $sessione ) {
// Se è la prima sessione che copio importo la data con quella della richiesta
if ( $numero_sessione == 0 ) {
$orario_inizio = date ( 'Y-m-d' , strtotime ( $data_ricorrenza )) . ' ' . date ( 'H:i:s' , strtotime ( $sessione -> orario_inizio ));
} else {
$diff = strtotime ( $sessione -> orario_inizio ) - strtotime ( $inizio_old );
2021-11-09 11:40:07 +01:00
$orario_inizio = date ( 'Y-m-d H:i:s' , ( strtotime ( $new_sessione -> orario_inizio ) + $diff ));
2021-09-22 11:22:03 +02:00
}
2021-09-23 10:04:44 +02:00
2021-09-22 11:22:03 +02:00
$diff_fine = strtotime ( $sessione -> orario_fine ) - strtotime ( $sessione -> orario_inizio );
$orario_fine = date ( 'Y-m-d H:i:s' , ( strtotime ( $orario_inizio ) + $diff_fine ));
2021-09-23 10:04:44 +02:00
2021-09-22 11:22:03 +02:00
$new_sessione = $sessione -> replicate ();
$new_sessione -> idintervento = $new -> id ;
$new_sessione -> orario_inizio = $orario_inizio ;
$new_sessione -> orario_fine = $orario_fine ;
$new_sessione -> save ();
2021-09-23 10:04:44 +02:00
2021-09-22 11:22:03 +02:00
++ $numero_sessione ;
$inizio_old = $sessione -> orario_inizio ;
}
}
// Assegnazione dei tecnici all'intervento
$tecnici_assegnati = ( array ) post ( 'tecnici_assegnati' );
$dbo -> sync ( 'in_interventi_tecnici_assegnati' , [
'id_intervento' => $new -> id ,
], [
'id_tecnico' => $tecnici_assegnati ,
]);
2021-09-23 10:04:44 +02:00
++ $n_ricorrenze ;
2021-09-22 11:22:03 +02:00
}
flash () -> info ( tr ( 'Aggiunte _NUM_ nuove ricorrenze!' , [
2021-09-23 10:04:44 +02:00
'_NUM_' => $n_ricorrenze ,
2021-09-22 11:22:03 +02:00
]));
}
2017-08-04 16:28:16 +02:00
if ( post ( 'ref' ) == 'dashboard' ) {
2018-07-19 17:29:21 +02:00
flash () -> clearMessage ( 'info' );
flash () -> clearMessage ( 'warning' );
2017-08-04 16:28:16 +02:00
}
2019-10-01 18:01:00 +02:00
2017-08-04 16:28:16 +02:00
break ;
// Eliminazione intervento
case 'delete' :
2019-10-01 18:32:06 +02:00
try {
// Eliminazione associazioni tra interventi e contratti
$dbo -> query ( 'UPDATE co_promemoria SET idintervento = NULL WHERE idintervento=' . prepare ( $id_record ));
2017-08-04 16:28:16 +02:00
2020-09-25 11:40:52 +02:00
$intervento -> delete ();
2019-10-01 18:32:06 +02:00
// Elimino il collegamento al componente
2021-08-06 14:48:51 +02:00
$dbo -> query ( 'DELETE FROM my_componenti WHERE id_intervento=' . prepare ( $id_record ));
2017-08-04 16:28:16 +02:00
2019-10-01 18:32:06 +02:00
// Eliminazione associazione tecnici collegati all'intervento
$dbo -> query ( 'DELETE FROM in_interventi_tecnici WHERE idintervento=' . prepare ( $id_record ));
2017-08-04 16:28:16 +02:00
2019-10-01 18:32:06 +02:00
// Eliminazione associazione interventi e my_impianti
$dbo -> query ( 'DELETE FROM my_impianti_interventi WHERE idintervento=' . prepare ( $id_record ));
2017-08-04 16:28:16 +02:00
2019-10-01 18:32:06 +02:00
flash () -> info ( tr ( 'Intervento eliminato!' ));
} catch ( InvalidArgumentException $e ) {
flash () -> error ( tr ( 'Sono stati utilizzati alcuni serial number nel documento: impossibile procedere!' ));
}
2017-08-04 16:28:16 +02:00
break ;
2019-10-01 18:32:06 +02:00
case 'delete_riga' :
2023-08-04 14:54:28 +02:00
$id_righe = ( array ) post ( 'righe' );
2022-04-01 09:58:53 +02:00
foreach ( $id_righe as $id_riga ) {
$riga = Articolo :: find ( $id_riga ) ? : Riga :: find ( $id_riga );
$riga = $riga ? : Sconto :: find ( $id_riga );
2019-10-01 18:01:00 +02:00
try {
$riga -> delete ();
} catch ( InvalidArgumentException $e ) {
flash () -> error ( tr ( 'Alcuni serial number sono già stati utilizzati!' ));
}
2022-04-01 09:58:53 +02:00
$riga = null ;
2019-10-01 18:01:00 +02:00
}
2022-04-01 09:58:53 +02:00
flash () -> info ( tr ( 'Righe eliminate!' ));
break ;
// Duplicazione riga
case 'copy_riga' :
2023-08-04 14:54:28 +02:00
$id_righe = ( array ) post ( 'righe' );
2022-04-01 09:58:53 +02:00
foreach ( $id_righe as $id_riga ) {
$riga = Articolo :: find ( $id_riga ) ? : Riga :: find ( $id_riga );
$riga = $riga ? : Sconto :: find ( $id_riga );
$new_riga = $riga -> replicate ();
$new_riga -> setDocument ( $intervento );
$new_riga -> qta_evasa = 0 ;
$new_riga -> save ();
if ( $new_riga -> isArticolo ()) {
$new_riga -> movimenta ( $new_riga -> qta );
}
$riga = null ;
}
flash () -> info ( tr ( 'Righe duplicate!' ));
2017-08-04 16:28:16 +02:00
break ;
2020-02-14 17:02:16 +01:00
case 'manage_articolo' :
if ( post ( 'idriga' ) != null ) {
$articolo = Articolo :: find ( post ( 'idriga' ));
} else {
$originale = ArticoloOriginale :: find ( post ( 'idarticolo' ));
$articolo = Articolo :: build ( $intervento , $originale );
2020-07-06 13:32:43 +02:00
$articolo -> id_dettaglio_fornitore = post ( 'id_dettaglio_fornitore' ) ? : null ;
2020-02-14 17:02:16 +01:00
}
$qta = post ( 'qta' );
2021-07-07 07:57:10 +02:00
2021-06-16 18:54:09 +02:00
$articolo -> idsede_partenza = post ( 'idsede_partenza' );
2020-02-14 17:02:16 +01:00
$articolo -> descrizione = post ( 'descrizione' );
2022-07-20 17:41:14 +02:00
$articolo -> note = post ( 'note' );
2020-02-14 17:02:16 +01:00
$articolo -> um = post ( 'um' ) ? : null ;
2022-01-21 13:30:24 +01:00
$articolo -> idimpianto = post ( 'id_impianto' ) ? : null ;
2020-02-14 17:02:16 +01:00
2020-02-14 18:31:07 +01:00
$articolo -> costo_unitario = post ( 'costo_unitario' ) ? : 0 ;
2020-02-17 19:11:40 +01:00
$articolo -> setPrezzoUnitario ( post ( 'prezzo_unitario' ), post ( 'idiva' ));
2020-02-14 18:31:07 +01:00
$articolo -> setSconto ( post ( 'sconto' ), post ( 'tipo_sconto' ));
2022-05-19 17:42:41 +02:00
$articolo -> setProvvigione ( post ( 'provvigione' ), post ( 'tipo_provvigione' ));
2020-02-14 17:02:16 +01:00
try {
$articolo -> qta = $qta ;
} catch ( UnexpectedValueException $e ) {
flash () -> error ( tr ( 'Alcuni serial number sono già stati utilizzati!' ));
}
$articolo -> save ();
if ( post ( 'idriga' ) != null ) {
flash () -> info ( tr ( 'Articolo modificato!' ));
} else {
flash () -> info ( tr ( 'Articolo aggiunto!' ));
}
2021-08-05 18:17:26 +02:00
// Collegamento all'Impianto tramite generazione Componente
$id_impianto = post ( 'id_impianto' );
$impianto = Impianto :: find ( $id_impianto );
2021-08-06 11:06:47 +02:00
if ( ! empty ( $impianto )) {
2021-08-05 18:17:26 +02:00
// Data di inizio dell'intervento (data_richiesta in caso di assenza di sessioni)
$data_registrazione = $intervento -> inizio ? : $intervento -> data_richiesta ;
// Creazione in base alla quantità
for ( $q = 0 ; $q < $articolo -> qta ; ++ $q ) {
$componente = Componente :: build ( $impianto , $articolo -> articolo , $data_registrazione );
}
}
2020-02-14 17:02:16 +01:00
break ;
2019-03-29 12:46:17 +01:00
case 'manage_sconto' :
if ( post ( 'idriga' ) != null ) {
2019-05-12 04:37:14 +02:00
$sconto = Sconto :: find ( post ( 'idriga' ));
2019-03-29 12:46:17 +01:00
} else {
2019-05-12 04:37:14 +02:00
$sconto = Sconto :: build ( $intervento );
2019-03-29 12:46:17 +01:00
}
$sconto -> descrizione = post ( 'descrizione' );
2020-09-29 15:27:00 +02:00
$sconto -> setScontoUnitario ( post ( 'sconto_unitario' ), post ( 'idiva' ));
2022-07-20 17:41:14 +02:00
$sconto -> note = post ( 'note' );
2019-03-29 12:46:17 +01:00
$sconto -> save ();
if ( post ( 'idriga' ) != null ) {
flash () -> info ( tr ( 'Sconto/maggiorazione modificato!' ));
} else {
2019-07-11 17:20:58 +02:00
flash () -> info ( tr ( 'Sconto/maggiorazione aggiunto!' ));
2019-03-29 12:46:17 +01:00
}
break ;
2020-02-14 17:02:16 +01:00
case 'manage_riga' :
if ( post ( 'idriga' ) != null ) {
$riga = Riga :: find ( post ( 'idriga' ));
} else {
$riga = Riga :: build ( $intervento );
}
2019-06-04 20:45:40 +02:00
2020-02-14 17:02:16 +01:00
$qta = post ( 'qta' );
2018-09-25 16:47:44 +02:00
2020-02-14 17:02:16 +01:00
$riga -> descrizione = post ( 'descrizione' );
2022-07-20 17:41:14 +02:00
$riga -> note = post ( 'note' );
2020-02-14 17:02:16 +01:00
$riga -> um = post ( 'um' ) ? : null ;
2018-09-25 16:47:44 +02:00
2020-02-14 18:31:07 +01:00
$riga -> costo_unitario = post ( 'costo_unitario' ) ? : 0 ;
2020-02-17 19:11:40 +01:00
$riga -> setPrezzoUnitario ( post ( 'prezzo_unitario' ), post ( 'idiva' ));
2020-02-14 18:31:07 +01:00
$riga -> setSconto ( post ( 'sconto' ), post ( 'tipo_sconto' ));
2022-05-19 17:42:41 +02:00
$riga -> setProvvigione ( post ( 'provvigione' ), post ( 'tipo_provvigione' ));
2018-09-25 11:55:52 +02:00
2020-02-14 17:02:16 +01:00
$riga -> qta = $qta ;
2019-06-04 20:45:40 +02:00
2020-02-14 17:02:16 +01:00
$riga -> save ();
2017-09-05 18:20:02 +02:00
2020-02-14 17:02:16 +01:00
if ( post ( 'idriga' ) != null ) {
flash () -> info ( tr ( 'Riga modificata!' ));
} else {
flash () -> info ( tr ( 'Riga aggiunta!' ));
2017-08-04 16:28:16 +02:00
}
break ;
case 'add_serial' :
2020-07-06 17:01:43 +02:00
$articolo = Articolo :: find ( post ( 'idriga' ));
2017-08-04 16:28:16 +02:00
2020-08-10 09:54:01 +02:00
$serials = ( array ) post ( 'serial' );
$articolo -> serials = $serials ;
2017-08-04 16:28:16 +02:00
break ;
2020-07-31 10:30:38 +02:00
// Aggiunta di un documento in ordine
2021-05-11 11:50:44 +02:00
case 'add_intervento' :
2020-07-31 10:30:38 +02:00
case 'add_documento' :
$class = post ( 'class' );
$id_documento = post ( 'id_documento' );
// Individuazione del documento originale
if ( ! is_subclass_of ( $class , \Common\Document :: class )) {
return ;
}
$documento = $class :: find ( $id_documento );
// Individuazione sede
$id_sede = ( $documento -> direzione == 'entrata' ) ? $documento -> idsede_destinazione : $documento -> idsede_partenza ;
$id_sede = $id_sede ? : $documento -> idsede ;
$id_sede = $id_sede ? : 0 ;
// Creazione dell' ordine al volo
if ( post ( 'create_document' ) == 'on' ) {
$stato = Stato :: find ( post ( 'id_stato_intervento' ));
$tipo = TipoSessione :: find ( post ( 'id_tipo_intervento' ));
2021-07-07 07:57:10 +02:00
2021-05-11 11:50:44 +02:00
$anagrafica = post ( 'idanagrafica' ) ? Anagrafica :: find ( post ( 'idanagrafica' )) : $documento -> anagrafica ;
2020-07-31 10:30:38 +02:00
2022-11-28 09:27:25 +01:00
$intervento = Intervento :: build ( $anagrafica , $tipo , $stato , post ( 'data' ), post ( 'id_segment' ));
2020-07-31 10:30:38 +02:00
$intervento -> idsede_destinazione = $id_sede ;
$intervento -> id_documento_fe = $documento -> id_documento_fe ;
$intervento -> codice_cup = $documento -> codice_cup ;
$intervento -> codice_cig = $documento -> codice_cig ;
$intervento -> num_item = $documento -> num_item ;
2021-04-20 17:12:04 +02:00
$intervento -> idreferente = $documento -> idreferente ;
2022-05-19 17:42:41 +02:00
$intervento -> idagente = $documento -> idagente ;
2020-07-31 10:30:38 +02:00
$intervento -> save ();
$id_record = $intervento -> id ;
}
2022-09-02 17:24:12 +02:00
// Evado le righe solo se il documento originale non è un Ordine fornitore
$evadi_qta_parent = true ;
if ( post ( 'op' ) == 'add_intervento' ) {
$evadi_qta_parent = false ;
}
2020-07-31 10:30:38 +02:00
$righe = $documento -> getRighe ();
foreach ( $righe as $riga ) {
if ( post ( 'evadere' )[ $riga -> id ] == 'on' and ! empty ( post ( 'qta_da_evadere' )[ $riga -> id ])) {
$qta = post ( 'qta_da_evadere' )[ $riga -> id ];
2022-09-02 17:24:12 +02:00
$copia = $riga -> copiaIn ( $intervento , $qta , $evadi_qta_parent );
2021-06-10 15:21:49 +02:00
2021-07-07 07:57:10 +02:00
if ( $copia -> isArticolo ()) {
2022-09-02 17:24:12 +02:00
// Aggiornamento seriali
2021-07-07 07:57:10 +02:00
$serials = is_array ( post ( 'serial' )[ $riga -> id ]) ? post ( 'serial' )[ $riga -> id ] : [];
$copia -> serials = $serials ;
2022-09-02 17:24:12 +02:00
// Aggiornamento prezzi se il documento originale è un Ordine fornitore
if ( post ( 'op' ) == 'add_intervento' ) {
$articolo = $copia -> articolo ;
$cliente = DettaglioPrezzo :: dettagli ( $riga -> idarticolo , $anagrafica -> id , 'entrata' , $qta ) -> first ();
if ( empty ( $cliente )) {
$cliente = DettaglioPrezzo :: dettaglioPredefinito ( $riga -> idarticolo , $anagrafica -> id , 'entrata' ) -> first ();
}
$prezzo_unitario = $cliente -> prezzo_unitario - ( $cliente -> prezzo_unitario * $cliente -> percentuale / 100 );
$copia -> setPrezzoUnitario ( $cliente ? $prezzo_unitario : $cliente -> prezzo_vendita , $copia -> aliquota -> id );
$copia -> setSconto ( $cliente -> sconto_percentuale ? : 0 , 'PRC' );
$copia -> costo_unitario = $riga -> prezzo_unitario ? : 0 ;
}
2021-07-07 07:57:10 +02:00
}
2021-06-10 15:21:49 +02:00
2020-07-31 10:30:38 +02:00
$copia -> save ();
}
}
2020-09-25 11:14:50 +02:00
// Modifica finale dello stato
/*
if ( post ( 'create_document' ) == 'on' ) {
$intervento -> idstatointervento = post ( 'id_stato_intervento' );
$intervento -> save ();
} */
2020-07-31 10:30:38 +02:00
// Messaggio informativo
$message = tr ( '_DOC_ aggiunto!' , [
'_DOC_' => $documento -> getReference (),
]);
flash () -> info ( $message );
break ;
2017-08-04 16:28:16 +02:00
case 'firma' :
2020-09-23 13:36:37 +02:00
if ( directory ( base_dir () . '/files/interventi' )) {
2017-08-04 16:28:16 +02:00
if ( post ( 'firma_base64' ) != '' ) {
// Salvataggio firma
2018-02-10 11:16:35 +01:00
$firma_file = 'firma_' . time () . '.jpg' ;
2017-08-04 16:28:16 +02:00
$firma_nome = post ( 'firma_nome' );
$data = explode ( ',' , post ( 'firma_base64' ));
2019-01-12 13:09:10 +01:00
$img = Intervention\Image\ImageManagerStatic :: make ( base64_decode ( $data [ 1 ]));
2017-08-04 16:28:16 +02:00
$img -> resize ( 680 , 202 , function ( $constraint ) {
$constraint -> aspectRatio ();
});
2023-08-04 14:54:28 +02:00
if ( setting ( 'Sistema di firma' ) == 'Tavoletta Wacom' ) {
2023-07-28 14:17:04 +02:00
$img -> brightness ( setting ( 'Luminosità firma Wacom' ));
$img -> contrast ( setting ( 'Contrasto firma Wacom' ));
}
2020-09-23 13:36:37 +02:00
if ( ! $img -> save ( base_dir () . '/files/interventi/' . $firma_file )) {
2018-07-19 17:29:21 +02:00
flash () -> error ( tr ( 'Impossibile creare il file!' ));
2021-01-21 13:08:31 +01:00
} elseif ( $dbo -> query ( 'UPDATE in_interventi SET firma_file=' . prepare ( $firma_file ) . ', firma_data=NOW(), firma_nome = ' . prepare ( $firma_nome ) . ' WHERE id=' . prepare ( $id_record ))) {
2018-07-19 17:29:21 +02:00
flash () -> info ( tr ( 'Firma salvata correttamente!' ));
2018-09-20 11:39:03 +02:00
2020-08-04 09:44:37 +02:00
$id_stato = setting ( " Stato dell'attività dopo la firma " );
$stato = $dbo -> selectOne ( 'in_statiintervento' , '*' , [ 'idstatointervento' => $id_stato ]);
2021-01-20 10:58:00 +01:00
$intervento = Intervento :: find ( $id_record );
2022-08-01 17:45:19 +02:00
if ( ! empty ( $stato )) {
$intervento = Intervento :: find ( $id_record );
$intervento -> idstatointervento = $stato [ 'idstatointervento' ];
$intervento -> save ();
}
2022-12-07 16:21:38 +01:00
2018-09-20 11:39:03 +02:00
// Notifica chiusura intervento
2022-12-07 16:21:38 +01:00
if ( ! empty ( $stato [ 'notifica' ])) {
2019-08-29 10:25:14 +02:00
$template = Template :: find ( $stato [ 'id_email' ]);
2018-09-20 11:39:03 +02:00
2022-12-07 16:21:38 +01:00
if ( ! empty ( $stato [ 'destinatari' ])) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $stato [ 'destinatari' ]);
$mail -> save ();
}
if ( ! empty ( $stato [ 'notifica_cliente' ])) {
if ( ! empty ( $intervento -> anagrafica -> email )) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $intervento -> anagrafica -> email );
$mail -> save ();
}
}
if ( ! empty ( $stato [ 'notifica_tecnici' ])) {
2023-09-15 18:06:15 +02:00
$tecnici_intervento = $dbo -> select ( 'in_interventi_tecnici' , 'idtecnico' , [], [ 'idintervento' => $id_record ]);
$tecnici_assegnati = $dbo -> select ( 'in_interventi_tecnici_assegnati' , 'id_tecnico AS idtecnico' , [], [ 'id_intervento' => $id_record ]);
2022-12-07 16:21:38 +01:00
$tecnici = array_unique ( array_merge ( $tecnici_intervento , $tecnici_assegnati ), SORT_REGULAR );
foreach ( $tecnici as $tecnico ) {
$mail_tecnico = $dbo -> selectOne ( 'an_anagrafiche' , '*' , [ 'idanagrafica' => $tecnico ]);
if ( ! empty ( $mail_tecnico [ 'email' ])) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $mail_tecnico [ 'email' ]);
$mail -> save ();
}
}
}
2018-09-20 11:39:03 +02:00
}
2017-08-04 16:28:16 +02:00
} else {
2018-07-19 17:29:21 +02:00
flash () -> error ( tr ( 'Errore durante il salvataggio della firma nel database!' ));
2017-08-04 16:28:16 +02:00
}
} else {
2018-07-19 17:29:21 +02:00
flash () -> error ( tr ( 'Errore durante il salvataggio della firma!' ) . tr ( 'La firma risulta vuota' ) . '...' );
2017-08-04 16:28:16 +02:00
}
} else {
2018-07-19 17:29:21 +02:00
flash () -> error ( tr ( " Non è stato possibile creare la cartella _DIRECTORY_ per salvare l'immagine della firma! " , [
2017-09-10 14:35:41 +02:00
'_DIRECTORY_' => '<b>/files/interventi</b>' ,
2018-07-07 13:56:22 +02:00
]));
2017-08-04 16:28:16 +02:00
}
2018-10-30 11:39:45 +01:00
break ;
2018-11-01 12:39:54 +01:00
2023-03-31 17:24:59 +02:00
case 'firma_bulk' :
if ( directory ( base_dir () . '/files/interventi' )) {
$firmati = 0 ;
$non_firmati = 0 ;
2023-08-04 14:54:28 +02:00
$id_records = filter ( 'records' ) ? explode ( ';' , filter ( 'records' )) : null ;
2023-03-31 17:24:59 +02:00
if ( post ( 'firma_base64' ) != '' ) {
foreach ( $id_records as $id_record ) {
// Salvataggio firma
$firma_file = 'firma_' . time () . '.jpg' ;
$firma_nome = post ( 'firma_nome' );
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
$data = explode ( ',' , post ( 'firma_base64' ));
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
$img = Intervention\Image\ImageManagerStatic :: make ( base64_decode ( $data [ 1 ]));
$img -> resize ( 680 , 202 , function ( $constraint ) {
$constraint -> aspectRatio ();
});
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! $img -> save ( base_dir () . '/files/interventi/' . $firma_file )) {
flash () -> error ( tr ( 'Impossibile creare il file!' ));
} elseif ( $dbo -> query ( 'UPDATE in_interventi SET firma_file=' . prepare ( $firma_file ) . ', firma_data=NOW(), firma_nome = ' . prepare ( $firma_nome ) . ' WHERE id=' . prepare ( $id_record ))) {
++ $firmati ;
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
$id_stato = setting ( " Stato dell'attività dopo la firma " );
$stato = $dbo -> selectOne ( 'in_statiintervento' , '*' , [ 'idstatointervento' => $id_stato ]);
$intervento = Intervento :: find ( $id_record );
if ( ! empty ( $stato )) {
$intervento = Intervento :: find ( $id_record );
$intervento -> idstatointervento = $stato [ 'idstatointervento' ];
$intervento -> save ();
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
// Notifica chiusura intervento
if ( ! empty ( $stato [ 'notifica' ])) {
$template = Template :: find ( $stato [ 'id_email' ]);
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! empty ( $stato [ 'destinatari' ])) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $stato [ 'destinatari' ]);
$mail -> save ();
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! empty ( $stato [ 'notifica_cliente' ])) {
if ( ! empty ( $intervento -> anagrafica -> email )) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $intervento -> anagrafica -> email );
$mail -> save ();
}
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! empty ( $stato [ 'notifica_tecnici' ])) {
2023-09-15 18:06:15 +02:00
$tecnici_intervento = $dbo -> select ( 'in_interventi_tecnici' , 'idtecnico' , [], [ 'idintervento' => $id_record ]);
$tecnici_assegnati = $dbo -> select ( 'in_interventi_tecnici_assegnati' , 'id_tecnico AS idtecnico' , [], [ 'id_intervento' => $id_record ]);
2023-03-31 17:24:59 +02:00
$tecnici = array_unique ( array_merge ( $tecnici_intervento , $tecnici_assegnati ), SORT_REGULAR );
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
foreach ( $tecnici as $tecnico ) {
$mail_tecnico = $dbo -> selectOne ( 'an_anagrafiche' , '*' , [ 'idanagrafica' => $tecnico ]);
if ( ! empty ( $mail_tecnico [ 'email' ])) {
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $mail_tecnico [ 'email' ]);
$mail -> save ();
}
}
}
}
} else {
++ $non_firmati ;
}
}
} else {
flash () -> error ( tr ( 'Errore durante il salvataggio della firma!' ) . tr ( 'La firma risulta vuota' ) . '...' );
}
} else {
flash () -> error ( tr ( " Non è stato possibile creare la cartella _DIRECTORY_ per salvare l'immagine della firma! " , [
'_DIRECTORY_' => '<b>/files/interventi</b>' ,
]));
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! empty ( $firmati )) {
flash () -> info ( tr ( '_NUM_ interventi firmati correttamente!' , [
'_NUM_' => $firmati ,
]));
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
if ( ! empty ( $non_firmati )) {
flash () -> info ( tr ( '_NUM_ interventi non sono stati firmati correttamente!' , [
'_NUM_' => $non_firmati ,
]));
}
2023-08-04 14:54:28 +02:00
2023-03-31 17:24:59 +02:00
break ;
2023-08-04 14:54:28 +02:00
2018-11-01 12:39:54 +01:00
// OPERAZIONI PER AGGIUNTA NUOVA SESSIONE DI LAVORO
case 'add_sessione' :
$id_tecnico = post ( 'id_tecnico' );
2019-05-17 19:24:04 +02:00
$idcontratto = $intervento [ 'id_contratto' ];
2018-11-01 12:39:54 +01:00
2021-04-07 17:47:48 +02:00
$inizio = post ( 'orario_inizio' ) ? : date ( 'Y-m-d H:\0\0' );
2022-05-05 17:08:16 +02:00
$fine = post ( 'orario_fine' ) ? : null ;
2018-11-01 12:39:54 +01:00
add_tecnico ( $id_record , $id_tecnico , $inizio , $fine , $idcontratto );
break ;
2023-02-03 18:05:51 +01:00
// OPERAZIONI PER AGGIUNTA SESSIONi DI LAVORO MULTIPLE
case 'add_sessioni' :
$idcontratto = $intervento [ 'id_contratto' ];
$orario_inizio = post ( 'orario_inizio' );
$orario_fine = post ( 'orario_fine' );
$data_inizio = post ( 'data_inizio' );
$data_fine = post ( 'data_fine' );
2023-08-04 14:54:28 +02:00
$giorni = ( array ) post ( 'giorni' );
$id_tecnici = ( array ) post ( 'id_tecnici' );
2023-02-03 18:05:51 +01:00
$period = CarbonPeriod :: create ( $data_inizio , $data_fine );
// Iterate over the period
foreach ( $period as $date ) {
$data = $date -> format ( 'Y-m-d' );
$giorno = $date -> locale ( 'IT' ) -> dayName ;
if ( in_array ( $giorno , $giorni )) {
$inizio = $data . ' ' . $orario_inizio ;
$fine = $data . ' ' . $orario_fine ;
2023-08-04 14:54:28 +02:00
2023-02-03 18:05:51 +01:00
foreach ( $id_tecnici as $id_tecnico ) {
add_tecnico ( $id_record , $id_tecnico , $inizio , $fine , $idcontratto );
}
}
}
break ;
2018-11-01 12:39:54 +01:00
// RIMOZIONE SESSIONE DI LAVORO
case 'delete_sessione' :
$id_sessione = post ( 'id_sessione' );
$tecnico = $dbo -> fetchOne ( 'SELECT an_anagrafiche.email FROM an_anagrafiche INNER JOIN in_interventi_tecnici ON in_interventi_tecnici.idtecnico = an_anagrafiche.idanagrafica WHERE in_interventi_tecnici.id = ' . prepare ( $id_sessione ));
$dbo -> query ( 'DELETE FROM in_interventi_tecnici WHERE id=' . prepare ( $id_sessione ));
2019-02-07 18:27:15 +01:00
// Notifica rimozione dell' intervento al tecnico
2021-11-23 12:04:44 +01:00
if ( setting ( 'Notifica al tecnico la rimozione della sessione dall\'attività' )) {
2020-06-22 17:45:10 +02:00
if ( ! empty ( $tecnico [ 'email' ])) {
2020-09-23 13:36:37 +02:00
$template = Template :: pool ( 'Notifica rimozione intervento' );
2020-06-22 17:45:10 +02:00
2020-06-30 13:26:15 +02:00
if ( ! empty ( $template )) {
2020-06-22 17:45:10 +02:00
$mail = Mail :: build ( auth () -> getUser (), $template , $id_record );
$mail -> addReceiver ( $tecnico [ 'email' ]);
$mail -> save ();
}
}
2018-11-01 12:39:54 +01:00
}
break ;
2018-10-30 11:39:45 +01:00
case 'edit_sessione' :
$id_sessione = post ( 'id_sessione' );
2019-07-15 12:27:12 +02:00
$sessione = Sessione :: find ( $id_sessione );
2018-11-01 12:39:54 +01:00
2019-07-15 12:27:12 +02:00
$sessione -> orario_inizio = post ( 'orario_inizio' );
$sessione -> orario_fine = post ( 'orario_fine' );
$sessione -> km = post ( 'km' );
2018-10-30 11:39:45 +01:00
2019-07-15 12:27:12 +02:00
$id_tipo = post ( 'idtipointerventot' );
$sessione -> setTipo ( $id_tipo );
2018-10-30 11:39:45 +01:00
2019-07-15 12:27:12 +02:00
// Prezzi
$sessione -> prezzo_ore_unitario = post ( 'prezzo_ore_unitario' );
$sessione -> prezzo_km_unitario = post ( 'prezzo_km_unitario' );
$sessione -> prezzo_dirittochiamata = post ( 'prezzo_dirittochiamata' );
2018-10-30 11:39:45 +01:00
2019-07-15 12:27:12 +02:00
// Sconto orario
$sessione -> sconto_unitario = post ( 'sconto' );
$sessione -> tipo_sconto = post ( 'tipo_sconto' );
2018-10-30 11:39:45 +01:00
2019-07-15 12:27:12 +02:00
// Sconto chilometrico
$sessione -> scontokm_unitario = post ( 'sconto_km' );
$sessione -> tipo_scontokm = post ( 'tipo_sconto_km' );
2018-10-30 11:39:45 +01:00
2019-07-15 12:27:12 +02:00
$sessione -> save ();
2018-11-01 12:39:54 +01:00
2017-08-04 16:28:16 +02:00
break ;
2020-06-08 11:59:40 +02:00
// Duplica intervento
case 'copy' :
2020-09-22 13:59:50 +02:00
$id_stato = post ( 'id_stato' );
2023-06-16 16:07:19 +02:00
$ora_richiesta = post ( 'ora_richiesta' );
2020-09-22 13:59:50 +02:00
$copia_sessioni = post ( 'copia_sessioni' );
$copia_righe = post ( 'copia_righe' );
2022-09-29 15:22:24 +02:00
$copia_impianti = post ( 'copia_impianti' );
2022-10-05 17:20:35 +02:00
$copia_allegati = post ( 'copia_allegati' );
2023-06-16 16:07:19 +02:00
$data_inizio = post ( 'data_inizio' );
$data_fine = post ( 'data_fine' );
2023-08-04 14:54:28 +02:00
$giorni = ( array ) post ( 'giorni' );
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
$period = CarbonPeriod :: create ( $data_inizio , $data_fine );
2020-06-09 16:59:26 +02:00
2023-06-16 16:07:19 +02:00
// Iterate over the period
foreach ( $period as $date ) {
$data_richiesta = $date -> format ( 'Y-m-d' ) . ' ' . $ora_richiesta ;
$giorno = $date -> locale ( 'IT' ) -> dayName ;
if ( in_array ( $giorno , $giorni )) {
$new = $intervento -> replicate ();
$new -> idstatointervento = $id_stato ;
2020-06-09 16:59:26 +02:00
2023-06-16 16:07:19 +02:00
// Calcolo del nuovo codice sulla base della data di richiesta
$new -> codice = Intervento :: getNextCodice ( $data_richiesta , $new -> id_segment );
$new -> data_richiesta = $data_richiesta ;
$new -> data_scadenza = post ( 'ora_scadenza' ) ? $date -> format ( 'Y-m-d' ) . ' ' . post ( 'ora_scadenza' ) : null ;
$new -> firma_file = '' ;
$new -> firma_data = null ;
$new -> firma_nome = '' ;
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
$new -> save ();
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
$id_record = $new -> id ;
2020-09-22 13:59:50 +02:00
2023-06-16 16:07:19 +02:00
// Copio le righe
if ( ! empty ( $copia_righe )) {
$righe = $intervento -> getRighe ();
foreach ( $righe as $riga ) {
$new_riga = $riga -> replicate ();
$new_riga -> setDocument ( $new );
2022-04-01 09:58:53 +02:00
2023-06-16 16:07:19 +02:00
$new_riga -> qta_evasa = 0 ;
$new_riga -> save ();
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
if ( $new_riga -> isArticolo ()) {
$new_riga -> movimenta ( $new_riga -> qta );
}
}
2020-06-08 11:59:40 +02:00
}
2023-06-16 16:07:19 +02:00
// Copia delle sessioni
$numero_sessione = 0 ;
if ( ! empty ( $copia_sessioni )) {
$sessioni = $intervento -> sessioni ;
foreach ( $sessioni as $sessione ) {
// Se è la prima sessione che copio importo la data con quella della richiesta
if ( $numero_sessione == 0 ) {
$orario_inizio = date ( 'Y-m-d' , strtotime ( $data_richiesta )) . ' ' . date ( 'H:i:s' , strtotime ( $sessione -> orario_inizio ));
} else {
$diff = strtotime ( $sessione -> orario_inizio ) - strtotime ( $inizio_old );
$orario_inizio = date ( 'Y-m-d H:i:s' , ( strtotime ( $new_sessione -> orario_inizio ) + $diff ));
}
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
$diff_fine = strtotime ( $sessione -> orario_fine ) - strtotime ( $sessione -> orario_inizio );
$orario_fine = date ( 'Y-m-d H:i:s' , ( strtotime ( $orario_inizio ) + $diff_fine ));
2020-06-09 16:59:26 +02:00
2023-06-16 16:07:19 +02:00
$new_sessione = $sessione -> replicate ();
$new_sessione -> idintervento = $new -> id ;
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
$new_sessione -> orario_inizio = $orario_inizio ;
$new_sessione -> orario_fine = $orario_fine ;
$new_sessione -> save ();
2020-06-08 11:59:40 +02:00
2023-06-16 16:07:19 +02:00
++ $numero_sessione ;
$inizio_old = $sessione -> orario_inizio ;
}
}
2022-09-29 15:22:24 +02:00
2023-06-16 16:07:19 +02:00
// Copia degli impianti
if ( ! empty ( $copia_impianti )) {
2023-09-15 18:06:15 +02:00
$impianti = $dbo -> select ( 'my_impianti_interventi' , '*' , [], [ 'idintervento' => $intervento -> id ]);
2023-06-16 16:07:19 +02:00
foreach ( $impianti as $impianto ) {
$dbo -> insert ( 'my_impianti_interventi' , [
'idintervento' => $id_record ,
2023-08-04 14:54:28 +02:00
'idimpianto' => $impianto [ 'idimpianto' ],
2023-06-16 16:07:19 +02:00
]);
}
2022-09-29 15:22:24 +02:00
2023-09-15 18:06:15 +02:00
$componenti = $dbo -> select ( 'my_componenti_interventi' , '*' , [], [ 'id_intervento' => $intervento -> id ]);
2023-06-16 16:07:19 +02:00
foreach ( $componenti as $componente ) {
$dbo -> insert ( 'my_componenti_interventi' , [
'id_intervento' => $id_record ,
2023-08-04 14:54:28 +02:00
'id_componente' => $componente [ 'id_componente' ],
2023-06-16 16:07:19 +02:00
]);
}
}
//copia allegati
if ( ! empty ( $copia_allegati )) {
$allegati = $intervento -> uploads ();
foreach ( $allegati as $allegato ) {
$allegato -> copia ([
'id_module' => $new -> getModule () -> id ,
'id_record' => $new -> id ,
]);
}
}
2022-10-05 17:20:35 +02:00
}
}
2023-06-16 16:07:19 +02:00
flash () -> info ( tr ( 'Attività duplicate correttamente!' ));
2020-06-08 11:59:40 +02:00
2021-10-04 11:27:05 +02:00
break ;
case 'update_position' :
$order = explode ( ',' , post ( 'order' , true ));
foreach ( $order as $i => $id_riga ) {
$dbo -> query ( 'UPDATE `in_righe_interventi` SET `order` = ' . prepare ( $i + 1 ) . ' WHERE id=' . prepare ( $id_riga ));
}
2023-02-17 12:33:45 +01:00
break ;
case 'add_articolo' :
$id_articolo = post ( 'id_articolo' );
$barcode = post ( 'barcode' );
$dir = 'entrata' ;
if ( ! empty ( $barcode )) {
2023-08-04 14:54:28 +02:00
$id_articolo = $dbo -> selectOne ( 'mg_articoli' , 'id' , [ 'deleted_at' => null , 'attivo' => 1 , 'barcode' => $barcode ])[ 'id' ];
2023-02-17 12:33:45 +01:00
}
if ( ! empty ( $id_articolo )) {
$permetti_movimenti_sotto_zero = setting ( 'Permetti selezione articoli con quantità minore o uguale a zero in Documenti di Vendita' );
$qta_articolo = $dbo -> selectOne ( 'mg_articoli' , 'qta' , [ 'id' => $id_articolo ])[ 'qta' ];
$originale = ArticoloOriginale :: find ( $id_articolo );
if ( $qta_articolo <= 0 && ! $permetti_movimenti_sotto_zero && ! $originale -> servizio && $dir == 'entrata' ) {
$response [ 'error' ] = tr ( 'Quantità a magazzino non sufficiente' );
echo json_encode ( $response );
} else {
$articolo = Articolo :: build ( $intervento , $originale );
$qta = 1 ;
$articolo -> descrizione = $originale -> descrizione ;
$articolo -> um = $originale -> um ;
$articolo -> qta = 1 ;
$articolo -> costo_unitario = $originale -> prezzo_acquisto ;
2023-04-12 17:56:15 +02:00
$id_iva = ( $intervento -> anagrafica -> idiva_vendite ? : $originale -> idiva_vendita ) ? : setting ( 'Iva predefinita' );
2023-02-17 12:33:45 +01:00
$id_anagrafica = $intervento -> idanagrafica ;
$prezzi_ivati = setting ( 'Utilizza prezzi di vendita comprensivi di IVA' );
2023-08-04 14:54:28 +02:00
2023-02-17 12:33:45 +01:00
// CALCOLO PREZZO UNITARIO
$prezzo_unitario = 0 ;
$sconto = 0 ;
// Prezzi netti clienti / listino fornitore
$prezzi = $dbo -> fetchArray ( 'SELECT minimo, massimo, sconto_percentuale, ' . ( $prezzi_ivati ? 'prezzo_unitario_ivato' : 'prezzo_unitario' ) . ' AS prezzo_unitario
FROM mg_prezzi_articoli
WHERE id_articolo = '.prepare($id_articolo).' AND dir = '.prepare($dir).' AND id_anagrafica = ' . prepare ( $id_anagrafica ));
if ( $prezzi ) {
foreach ( $prezzi as $prezzo ) {
if ( $qta >= $prezzo [ 'minimo' ] && $qta <= $prezzo [ 'massimo' ]) {
$prezzo_unitario = $prezzo [ 'prezzo_unitario' ];
$sconto = $prezzo [ 'sconto_percentuale' ];
continue ;
}
if ( $prezzo [ 'minimo' ] == null && $prezzo [ 'massimo' ] == null && $prezzo [ 'prezzo_unitario' ] != null ) {
$prezzo_unitario = $prezzo [ 'prezzo_unitario' ];
$sconto = $prezzo [ 'sconto_percentuale' ];
continue ;
}
}
2023-08-04 14:54:28 +02:00
}
2023-02-17 12:33:45 +01:00
if ( empty ( $prezzo_unitario )) {
// Prezzi listini clienti
$listino = $dbo -> fetchOne ( 'SELECT sconto_percentuale AS sconto_percentuale_listino, ' . ( $prezzi_ivati ? 'prezzo_unitario_ivato' : 'prezzo_unitario' ) . ' AS prezzo_unitario_listino
FROM mg_listini
LEFT JOIN mg_listini_articoli ON mg_listini . id = mg_listini_articoli . id_listino
LEFT JOIN an_anagrafiche ON mg_listini . id = an_anagrafiche . id_listino
WHERE mg_listini . data_attivazione <= NOW () AND mg_listini_articoli . data_scadenza >= NOW () AND mg_listini . attivo = 1 AND id_articolo = '.prepare($id_articolo).' AND dir = '.prepare($dir).' AND idanagrafica = ' . prepare ( $id_anagrafica ));
if ( $listino ) {
$prezzo_unitario = $listino [ 'prezzo_unitario_listino' ];
$sconto = $listino [ 'sconto_percentuale_listino' ];
}
}
$prezzo_unitario = $prezzo_unitario ? : ( $prezzi_ivati ? $originale -> prezzo_vendita_ivato : $originale -> prezzo_vendita );
2023-02-27 17:56:13 +01:00
$provvigione = $dbo -> selectOne ( 'an_anagrafiche' , 'provvigione_default' , [ 'idanagrafica' => $intervento -> idagente ])[ 'provvigione_default' ];
2023-02-17 12:33:45 +01:00
2023-07-31 17:26:06 +02:00
// Aggiunta sconto combinato se è presente un piano di sconto nell'anagrafica
$piano_sconto = $dbo -> fetchOne ( 'SELECT prc_guadagno FROM an_anagrafiche INNER JOIN mg_piani_sconto ON an_anagrafiche.id_piano_sconto_vendite=mg_piani_sconto.id WHERE idanagrafica=' . prepare ( $id_anagrafica ));
if ( ! empty ( $piano_sconto )) {
$sconto = parseScontoCombinato ( $piano_sconto [ 'prc_guadagno' ] . '+' . $sconto );
}
2023-02-17 12:33:45 +01:00
$articolo -> setPrezzoUnitario ( $prezzo_unitario , $id_iva );
$articolo -> setSconto ( $sconto , 'PRC' );
2023-02-27 17:56:13 +01:00
$articolo -> setProvvigione ( $provvigione ? : 0 , 'PRC' );
2023-03-10 17:39:00 +01:00
$articolo -> idsede_partenza = $intervento -> idsede_partenza ;
2023-02-17 12:33:45 +01:00
$articolo -> save ();
flash () -> info ( tr ( 'Nuovo articolo aggiunto!' ));
}
} else {
$response [ 'error' ] = tr ( 'Nessun articolo corrispondente a magazzino' );
echo json_encode ( $response );
}
break ;
case 'update_inline' :
$id_riga = post ( 'riga_id' );
$riga = $riga ? : Riga :: find ( $id_riga );
$riga = $riga ? : Articolo :: find ( $id_riga );
if ( ! empty ( $riga )) {
$riga -> qta = post ( 'qta' );
$riga -> setSconto ( post ( 'sconto' ), post ( 'tipo_sconto' ));
$riga -> save ();
flash () -> info ( tr ( 'Quantità aggiornata!' ));
}
2023-04-27 14:35:02 +02:00
break ;
case 'edit-price' :
$righe = $post [ 'righe' ];
2023-05-04 09:57:01 +02:00
$numero_totale = 0 ;
2023-04-27 14:35:02 +02:00
foreach ( $righe as $riga ) {
2023-04-28 14:44:35 +02:00
if (( $riga [ 'id' ]) != null ) {
$articolo = Articolo :: find ( $riga [ 'id' ]);
} else {
$originale = ArticoloOriginale :: find ( post ( 'idarticolo' ));
$articolo = Articolo :: build ( $fattura , $originale );
$articolo -> id_dettaglio_fornitore = post ( 'id_dettaglio_fornitore' ) ? : null ;
}
2023-08-04 14:54:28 +02:00
2023-05-04 09:57:01 +02:00
if ( $articolo [ 'prezzo_unitario' ] != $riga [ 'price' ]) {
$articolo -> setPrezzoUnitario ( $riga [ 'price' ], $articolo -> idiva );
$articolo -> save ();
++ $numero_totale ;
}
}
if ( $numero_totale > 1 ) {
flash () -> info ( tr ( '_NUM_ prezzi modificati!' , [
'_NUM_' => $numero_totale ,
]));
2023-08-04 14:54:28 +02:00
} elseif ( $numero_totale == 1 ) {
2023-05-04 09:57:01 +02:00
flash () -> info ( tr ( '_NUM_ prezzo modificato!' , [
'_NUM_' => $numero_totale ,
]));
} else {
flash () -> warning ( tr ( 'Nessun prezzo modificato!' ));
2023-04-28 14:44:35 +02:00
}
2023-05-04 09:07:34 +02:00
2020-06-08 11:59:40 +02:00
break ;
2017-08-04 16:28:16 +02:00
}