2022-03-25 19:26:50 +01:00
< ? php
/*
* OpenSTAManager : il software gestionale open source per l ' assistenza tecnica e la fatturazione
* Copyright ( C ) DevCode s . r . l .
*
* 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 />.
*/
include_once __DIR__ . '/../../core.php' ;
switch ( post ( 'op' )) {
case 'update' :
$nome = post ( 'nome' );
$giorni = ( array ) post ( 'giorni' );
$ora_inizio = post ( 'ora_inizio' );
$ora_fine = post ( 'ora_fine' );
$include_bank_holidays = post ( 'include_bank_holidays' );
2022-04-22 19:37:21 +02:00
$is_predefined = post ( 'is_predefined' );
2024-03-22 15:52:24 +01:00
if ( $dbo -> fetchNum ( 'SELECT * FROM `in_fasceorarie` LEFT JOIN `in_fasceorarie_lang` ON (`in_fasceorarie_lang`.`id_record` = `in_fasceorarie`.`id` AND `in_fasceorarie_lang`.`id_lang` = ' . prepare ( Models\Locale :: getDefault () -> id ) . ') WHERE `name`=' . prepare ( $nome ) . ' AND `in_fasceorarie`.`id`!=' . prepare ( $id_record )) == 0 ) {
2022-04-22 19:37:21 +02:00
if ( ! empty ( $is_predefined )) {
2024-02-28 11:39:12 +01:00
$dbo -> query ( 'UPDATE `in_fasceorarie` SET `is_predefined` = 0' );
2022-04-22 19:37:21 +02:00
}
2023-08-04 14:54:28 +02:00
2022-03-25 19:26:50 +01:00
$dbo -> update ( 'in_fasceorarie' , [
2023-08-04 14:54:28 +02:00
'giorni' => $giorni ? implode ( ',' , $giorni ) : null ,
2022-04-22 19:37:21 +02:00
'ora_inizio' => $ora_inizio ,
2022-03-25 19:26:50 +01:00
'ora_fine' => $ora_fine ,
'include_bank_holidays' => $include_bank_holidays ,
2022-04-22 19:37:21 +02:00
'is_predefined' => $is_predefined ,
2024-02-28 11:39:12 +01:00
], [ 'id' => $id_record ]);
$dbo -> update ( 'in_fasceorarie_lang' , [
2024-03-22 15:52:24 +01:00
'name' => $nome ,
], [ 'id_record' => $id_record , 'id_lang' => Models\Locale :: getDefault () -> id ]);
2022-03-25 19:26:50 +01:00
flash () -> info ( tr ( 'Salvataggio completato.' ));
} else {
flash () -> error ( tr ( " E' già presente una _TYPE_ con lo stesso nome " , [
'_TYPE_' => 'fascia oraria' ,
]));
}
break ;
case 'add' :
$nome = post ( 'nome' );
2022-06-01 15:38:36 +02:00
$ora_inizio = post ( 'ora_inizio' );
$ora_fine = post ( 'ora_fine' );
2022-03-25 19:26:50 +01:00
2024-03-22 15:52:24 +01:00
if ( $dbo -> fetchNum ( 'SELECT * FROM `in_fasceorarie` LEFT JOIN `in_fasceorarie_lang` ON (`in_fasceorarie_lang`.`id_record` = `in_fasceorarie`.`id` AND `in_fasceorarie_lang`.`id_lang` = ' . prepare ( Models\Locale :: getDefault () -> id ) . ') WHERE `name`=' . prepare ( $nome )) == 0 ) {
2022-03-25 19:26:50 +01:00
$dbo -> insert ( 'in_fasceorarie' , [
2022-06-01 15:38:36 +02:00
'ora_inizio' => $ora_inizio ,
'ora_fine' => $ora_fine ,
2022-03-25 19:26:50 +01:00
]);
$id_record = $dbo -> lastInsertedID ();
2024-02-28 11:39:12 +01:00
$dbo -> insert ( 'in_fasceorarie_lang' , [
'name' => $nome ,
'id_record' => $id_record ,
2024-03-22 15:52:24 +01:00
'id_lang' => Models\Locale :: getDefault () -> id ,
2024-02-28 11:39:12 +01:00
]);
2022-03-25 19:26:50 +01:00
2022-06-01 15:38:36 +02:00
$tipi_intervento = $dbo -> select ( 'in_tipiintervento' , '*' );
foreach ( $tipi_intervento as $tipo_intervento ) {
$dbo -> insert ( 'in_fasceorarie_tipiintervento' , [
'idfasciaoraria' => $id_record ,
2024-02-28 16:28:53 +01:00
'idtipointervento' => $tipo_intervento [ 'id' ],
2022-06-01 15:38:36 +02:00
'costo_orario' => $tipo_intervento [ 'costo_orario' ],
'costo_km' => $tipo_intervento [ 'costo_km' ],
'costo_diritto_chiamata' => $tipo_intervento [ 'costo_diritto_chiamata' ],
'costo_orario_tecnico' => $tipo_intervento [ 'costo_orario_tecnico' ],
'costo_km_tecnico' => $tipo_intervento [ 'costo_km_tecnico' ],
'costo_diritto_chiamata_tecnico' => $tipo_intervento [ 'costo_km_tecnico' ],
]);
}
2022-03-25 19:26:50 +01:00
if ( isAjaxRequest ()) {
echo json_encode ([ 'id' => $id_record , 'text' => $nome ]);
}
flash () -> info ( tr ( 'Aggiunta nuova _TYPE_' , [
'_TYPE_' => 'fascia oraria' ,
]));
} else {
flash () -> error ( tr ( " E' già presente una _TYPE_ con lo stesso nome " , [
'_TYPE_' => 'fascia oraria' ,
]));
}
break ;
case 'delete' :
2022-06-01 15:38:36 +02:00
$dbo -> update ( 'in_fasceorarie' , [
'deleted_at' => date ( 'Y-m-d H:i:s' ),
], [ 'id' => $id_record , 'can_delete' => 1 ]);
2022-03-25 19:26:50 +01:00
2022-06-01 15:38:36 +02:00
$dbo -> delete ( 'in_fasceorarie_tipiintervento' , [ 'idfasciaoraria' => $id_record ]);
2022-03-25 19:26:50 +01:00
2022-06-01 15:38:36 +02:00
flash () -> info ( tr ( '_TYPE_ eliminata con successo.' , [
'_TYPE_' => 'Fascia oraria' ,
]));
2022-03-25 19:26:50 +01:00
break ;
}