Correzioni #673
This commit is contained in:
parent
e6e502e23c
commit
99d1a475cf
2
core.php
2
core.php
|
@ -105,7 +105,7 @@ if (!API\Response::isAPIRequest()) {
|
||||||
// Disabilita i messaggi nativi di PHP
|
// Disabilita i messaggi nativi di PHP
|
||||||
ini_set('display_errors', 0);
|
ini_set('display_errors', 0);
|
||||||
// Ignora gli avvertimenti e le informazioni relative alla deprecazione di componenti
|
// 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;
|
$pattern = '[%datetime%] %channel%.%level_name%: %message% %context%'.PHP_EOL.'%extra% '.PHP_EOL;
|
||||||
$monologFormatter = new Monolog\Formatter\LineFormatter($pattern);
|
$monologFormatter = new Monolog\Formatter\LineFormatter($pattern);
|
||||||
|
|
|
@ -273,89 +273,84 @@ switch (post('op')) {
|
||||||
|
|
||||||
// Rinnovo contratto
|
// Rinnovo contratto
|
||||||
case 'renew':
|
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
|
||||||
// Verifico se il rinnovo contratto è un numero accettabile con la differenza di data inizio e data fine
|
if ($giorni < 0 || $giorni > 365 * 10) {
|
||||||
if ($rs[0]['giorni'] > 0 && $rs[0]['giorni'] < 365 * 10) {
|
$giorni = 0;
|
||||||
$giorni_add = $rs[0]['giorni'];
|
|
||||||
} else {
|
|
||||||
$giorni_add = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Calcolo numero successivo contratti
|
|
||||||
$rs2 = $dbo->fetchArray('SELECT MAX(CAST(numero AS UNSIGNED)) AS maxn FROM co_contratti');
|
|
||||||
$numero = $rs2[0]['maxn'] + 1;
|
|
||||||
|
|
||||||
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();
|
|
||||||
|
|
||||||
$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));
|
|
||||||
|
|
||||||
// Replico le righe del contratto
|
|
||||||
$rs = $dbo->fetchArray('SELECT * FROM co_righe_contratti WHERE idcontratto='.prepare($id_record));
|
|
||||||
|
|
||||||
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);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Replicazione degli impianti
|
|
||||||
$impianti = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto='.prepare($id_record));
|
|
||||||
$dbo->sync('my_impianti_contratti', ['idcontratto' => $new_idcontratto], ['idimpianto' => array_column($impianti, 'idimpianto')]);
|
|
||||||
|
|
||||||
// Replicazione dei promemoria
|
|
||||||
$promemoria = $dbo->fetchArray('SELECT * FROM co_promemoria WHERE idcontratto='.prepare($id_record));
|
|
||||||
foreach ($promemoria as $p) {
|
|
||||||
$dbo->insert('co_promemoria', [
|
|
||||||
'idcontratto' => $new_idcontratto,
|
|
||||||
'data_richiesta' => date('Y-m-d', strtotime($p['data_richiesta'].' +'.$giorni_add.' day')),
|
|
||||||
'idtipointervento' => $p['idtipointervento'],
|
|
||||||
'richiesta' => $p['richiesta'],
|
|
||||||
'idimpianti' => $p['idimpianti'],
|
|
||||||
]);
|
|
||||||
$id_promemoria = $dbo->lastInsertedID();
|
|
||||||
|
|
||||||
// Copia degli articoli
|
|
||||||
$dbo->query('INSERT INTO co_promemoria_articoli(idarticolo, id_promemoria, idimpianto, descrizione, prezzo_vendita, prezzo_acquisto, sconto, sconto_unitario, tipo_sconto, idiva, desc_iva, iva, qta, um, abilita_serial) SELECT idarticolo, :id_new, idimpianto, descrizione, prezzo_vendita, prezzo_acquisto, sconto, sconto_unitario, tipo_sconto, idiva, desc_iva, iva, qta, um, abilita_serial FROM co_promemoria_articoli AS z WHERE id_promemoria = :id_old', [
|
|
||||||
':id_new' => $id_promemoria,
|
|
||||||
':id_old' => $p['id'],
|
|
||||||
]);
|
|
||||||
|
|
||||||
// Copia delle righe
|
|
||||||
$dbo->query('INSERT INTO co_promemoria_righe(id_promemoria, descrizione, qta, um, prezzo_vendita, prezzo_acquisto, idiva, desc_iva, iva, sconto, sconto_unitario, tipo_sconto) SELECT :id_new, descrizione, qta, um, prezzo_vendita, prezzo_acquisto, idiva, desc_iva, iva, sconto, sconto_unitario, tipo_sconto FROM co_promemoria_righe AS z WHERE id_promemoria = :id_old', [
|
|
||||||
':id_new' => $id_promemoria,
|
|
||||||
':id_old' => $p['id'],
|
|
||||||
]);
|
|
||||||
|
|
||||||
// Copia degli allegati
|
|
||||||
Uploads::copy([
|
|
||||||
'id_module' => $id_module,
|
|
||||||
'id_plugin' => Plugins::get('Pianificazione interventi')['id'],
|
|
||||||
'id_record' => $p['id'],
|
|
||||||
], [
|
|
||||||
'id_module' => $id_module,
|
|
||||||
'id_plugin' => Plugins::get('Pianificazione interventi')['id'],
|
|
||||||
'id_record' => $id_promemoria,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Cambio stato precedente contratto in concluso (non più pianificabile)
|
|
||||||
$dbo->query('UPDATE `co_contratti` SET `rinnovabile`= 0, `idstato`= (SELECT id FROM co_staticontratti WHERE is_pianificabile = 0 AND is_fatturabile = 1 AND descrizione = \'Concluso\') WHERE `id` = '.prepare($id_record));
|
|
||||||
|
|
||||||
flash()->info(tr('Contratto rinnovato!'));
|
|
||||||
|
|
||||||
$id_record = $new_idcontratto;
|
|
||||||
} else {
|
|
||||||
flash()->error(tr('Errore durante il rinnovo del contratto!'));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$new_contratto = $contratto->replicate();
|
||||||
|
$new_contratto->numero = Contratto::getNextNumero();
|
||||||
|
|
||||||
|
$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
|
||||||
|
$righe = $contratto->getRighe();
|
||||||
|
foreach ($righe as $riga) {
|
||||||
|
$new_riga = $riga->replicate();
|
||||||
|
$new_riga->qta_evasa = 0;
|
||||||
|
$new_riga->idcontratto = $new_contratto->id;
|
||||||
|
|
||||||
|
$new_riga->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Replicazione degli impianti
|
||||||
|
$impianti = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto='.prepare($id_record));
|
||||||
|
$dbo->sync('my_impianti_contratti', ['idcontratto' => $new_idcontratto], ['idimpianto' => array_column($impianti, 'idimpianto')]);
|
||||||
|
|
||||||
|
// Replicazione dei promemoria
|
||||||
|
$promemoria = $dbo->fetchArray('SELECT * FROM co_promemoria WHERE idcontratto='.prepare($id_record));
|
||||||
|
foreach ($promemoria as $p) {
|
||||||
|
$dbo->insert('co_promemoria', [
|
||||||
|
'idcontratto' => $new_idcontratto,
|
||||||
|
'data_richiesta' => date('Y-m-d', strtotime($p['data_richiesta'].' +'.$giorni.' day')),
|
||||||
|
'idtipointervento' => $p['idtipointervento'],
|
||||||
|
'richiesta' => $p['richiesta'],
|
||||||
|
'idimpianti' => $p['idimpianti'],
|
||||||
|
]);
|
||||||
|
$id_promemoria = $dbo->lastInsertedID();
|
||||||
|
|
||||||
|
// Copia degli articoli
|
||||||
|
$dbo->query('INSERT INTO co_promemoria_articoli(idarticolo, id_promemoria, idimpianto, descrizione, prezzo_vendita, prezzo_acquisto, sconto, sconto_unitario, tipo_sconto, idiva, desc_iva, iva, qta, um, abilita_serial) SELECT idarticolo, :id_new, idimpianto, descrizione, prezzo_vendita, prezzo_acquisto, sconto, sconto_unitario, tipo_sconto, idiva, desc_iva, iva, qta, um, abilita_serial FROM co_promemoria_articoli AS z WHERE id_promemoria = :id_old', [
|
||||||
|
':id_new' => $id_promemoria,
|
||||||
|
':id_old' => $p['id'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Copia delle righe
|
||||||
|
$dbo->query('INSERT INTO co_promemoria_righe(id_promemoria, descrizione, qta, um, prezzo_vendita, prezzo_acquisto, idiva, desc_iva, iva, sconto, sconto_unitario, tipo_sconto) SELECT :id_new, descrizione, qta, um, prezzo_vendita, prezzo_acquisto, idiva, desc_iva, iva, sconto, sconto_unitario, tipo_sconto FROM co_promemoria_righe AS z WHERE id_promemoria = :id_old', [
|
||||||
|
':id_new' => $id_promemoria,
|
||||||
|
':id_old' => $p['id'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Copia degli allegati
|
||||||
|
Uploads::copy([
|
||||||
|
'id_module' => $id_module,
|
||||||
|
'id_plugin' => Plugins::get('Pianificazione interventi')['id'],
|
||||||
|
'id_record' => $p['id'],
|
||||||
|
], [
|
||||||
|
'id_module' => $id_module,
|
||||||
|
'id_plugin' => Plugins::get('Pianificazione interventi')['id'],
|
||||||
|
'id_record' => $id_promemoria,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cambio stato precedente contratto in concluso (non più pianificabile)
|
||||||
|
$dbo->query('UPDATE `co_contratti` SET `rinnovabile`= 0, `idstato`= (SELECT id FROM co_staticontratti WHERE is_pianificabile = 0 AND is_fatturabile = 1 AND descrizione = \'Concluso\') WHERE `id` = '.prepare($id_record));
|
||||||
|
|
||||||
|
flash()->info(tr('Contratto rinnovato!'));
|
||||||
|
|
||||||
|
$id_record = $new_idcontratto;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'import':
|
case 'import':
|
||||||
|
|
|
@ -17,6 +17,16 @@ class Contratto extends Document
|
||||||
|
|
||||||
protected $table = 'co_contratti';
|
protected $table = 'co_contratti';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The attributes that should be mutated to dates.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $dates = [
|
||||||
|
'data_conclusione',
|
||||||
|
'data_accettazione',
|
||||||
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Crea un nuovo contratto.
|
* Crea un nuovo contratto.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue