This commit is contained in:
Thomas Zilio 2019-11-12 16:48:06 +01:00
parent e6e502e23c
commit 99d1a475cf
3 changed files with 86 additions and 81 deletions

View File

@ -105,7 +105,7 @@ if (!API\Response::isAPIRequest()) {
// Disabilita i messaggi nativi di PHP
ini_set('display_errors', 0);
// Ignora gli avvertimenti e le informazioni relative alla deprecazione di componenti
error_reporting(E_ALL & ~E_WARNING & ~E_NOTICE & ~E_USER_DEPRECATED & ~E_STRICT);
error_reporting(E_ALL & ~E_WARNING & ~E_CORE_WARNING & ~E_NOTICE & ~E_USER_DEPRECATED & ~E_STRICT);
$pattern = '[%datetime%] %channel%.%level_name%: %message% %context%'.PHP_EOL.'%extra% '.PHP_EOL;
$monologFormatter = new Monolog\Formatter\LineFormatter($pattern);

View File

@ -273,36 +273,35 @@ switch (post('op')) {
// Rinnovo contratto
case 'renew':
$rs = $dbo->fetchArray('SELECT *, DATEDIFF(data_conclusione, data_accettazione) AS giorni FROM co_contratti WHERE id='.prepare($id_record));
$giorni = $contratto->data_conclusione->diffInDays($contratto->data_accettazione);
if (sizeof($rs) == 1) {
// Verifico se il rinnovo contratto è un numero accettabile con la differenza di data inizio e data fine
if ($rs[0]['giorni'] > 0 && $rs[0]['giorni'] < 365 * 10) {
$giorni_add = $rs[0]['giorni'];
} else {
$giorni_add = 0;
if ($giorni < 0 || $giorni > 365 * 10) {
$giorni = 0;
}
// Calcolo numero successivo contratti
$rs2 = $dbo->fetchArray('SELECT MAX(CAST(numero AS UNSIGNED)) AS maxn FROM co_contratti');
$numero = $rs2[0]['maxn'] + 1;
$new_contratto = $contratto->replicate();
$new_contratto->numero = Contratto::getNextNumero();
if ($dbo->query('INSERT INTO co_contratti(numero, nome, idagente, data_bozza, data_accettazione, data_rifiuto, data_conclusione, rinnovabile, giorni_preavviso_rinnovo, budget, descrizione, idstato, idreferente, validita, esclusioni, idanagrafica, idpagamento, costo_diritto_chiamata, ore_lavoro, costo_orario, costo_km, idcontratto_prev) VALUES('.prepare($numero).', '.prepare($rs[0]['nome']).', '.prepare($rs[0]['idagente']).', NOW(), '.prepare(date('Y-m-d', strtotime($rs[0]['data_conclusione'].' +1 day'))).', "", '.prepare(date('Y-m-d', strtotime($rs[0]['data_conclusione'].' +'.$giorni_add.' day'))).', '.prepare($rs[0]['rinnovabile']).', '.prepare($rs[0]['giorni_preavviso_rinnovo']).', '.prepare($rs[0]['budget']).', '.prepare($rs[0]['descrizione']).', '.prepare($rs[0]['idstato']).', '.prepare($rs[0]['idreferente']).', '.prepare($rs[0]['validita']).', '.prepare($rs[0]['esclusioni']).', '.prepare($rs[0]['idanagrafica']).', '.prepare($rs[0]['idpagamento']).', '.prepare($rs[0]['costo_diritto_chiamata']).', '.prepare($rs[0]['ore_lavoro']).', '.prepare($rs[0]['costo_orario']).', '.prepare($rs[0]['costo_km']).', '.prepare($id_record).')')) {
$new_idcontratto = $dbo->lastInsertedID();
$new_contratto->idcontratto_prev = $contratto->id;
$new_contratto->data_accettazione = $contratto->data_conclusione->addDays(1);
$new_contratto->data_conclusione = $new_contratto->data_accettazione->addDays($giorni);
$new_contratto->save();
$new_idcontratto = $new_contratto->id;
// Correzioni dei prezzi per gli interventi
$dbo->query('DELETE FROM co_contratti_tipiintervento WHERE idcontratto='.prepare($new_idcontratto));
$dbo->query('INSERT INTO co_contratti_tipiintervento(idcontratto, idtipointervento, costo_ore, costo_km, costo_dirittochiamata, costo_ore_tecnico, costo_km_tecnico, costo_dirittochiamata_tecnico) SELECT '.prepare($new_idcontratto).', idtipointervento, costo_ore, costo_km, costo_dirittochiamata, costo_ore_tecnico, costo_km_tecnico, costo_dirittochiamata_tecnico FROM co_contratti_tipiintervento AS z WHERE idcontratto='.prepare($id_record));
$new_contratto->save();
// Replico le righe del contratto
$rs = $dbo->fetchArray('SELECT * FROM co_righe_contratti WHERE idcontratto='.prepare($id_record));
$righe = $contratto->getRighe();
foreach ($righe as $riga) {
$new_riga = $riga->replicate();
$new_riga->qta_evasa = 0;
$new_riga->idcontratto = $new_contratto->id;
for ($i = 0; $i < sizeof($rs); ++$i) {
unset($rs[$i]['id']);
unset($rs[$i]['created_at']);
unset($rs[$i]['updated_at']);
unset($rs[$i]['qta_evasa']);
$rs[$i]['idcontratto'] = $new_idcontratto;
$dbo->insert('co_righe_contratti', $rs);
$new_riga->save();
}
// Replicazione degli impianti
@ -314,7 +313,7 @@ switch (post('op')) {
foreach ($promemoria as $p) {
$dbo->insert('co_promemoria', [
'idcontratto' => $new_idcontratto,
'data_richiesta' => date('Y-m-d', strtotime($p['data_richiesta'].' +'.$giorni_add.' day')),
'data_richiesta' => date('Y-m-d', strtotime($p['data_richiesta'].' +'.$giorni.' day')),
'idtipointervento' => $p['idtipointervento'],
'richiesta' => $p['richiesta'],
'idimpianti' => $p['idimpianti'],
@ -351,10 +350,6 @@ switch (post('op')) {
flash()->info(tr('Contratto rinnovato!'));
$id_record = $new_idcontratto;
} else {
flash()->error(tr('Errore durante il rinnovo del contratto!'));
}
}
break;

View File

@ -17,6 +17,16 @@ class Contratto extends Document
protected $table = 'co_contratti';
/**
* The attributes that should be mutated to dates.
*
* @var array
*/
protected $dates = [
'data_conclusione',
'data_accettazione',
];
/**
* Crea un nuovo contratto.
*