mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-22 20:09:58 +01:00
Gestione duplicazione multipla intervento
This commit is contained in:
parent
92f4e62c2d
commit
b9184eac0a
@ -949,102 +949,114 @@ switch (post('op')) {
|
||||
// Duplica intervento
|
||||
case 'copy':
|
||||
$id_stato = post('id_stato');
|
||||
$data_richiesta = post('data_richiesta');
|
||||
$ora_richiesta = post('ora_richiesta');
|
||||
$copia_sessioni = post('copia_sessioni');
|
||||
$copia_righe = post('copia_righe');
|
||||
$copia_impianti = post('copia_impianti');
|
||||
$copia_allegati = post('copia_allegati');
|
||||
$data_inizio = post('data_inizio');
|
||||
$data_fine = post('data_fine');
|
||||
$giorni = (array)post('giorni');
|
||||
|
||||
$new = $intervento->replicate();
|
||||
$new->idstatointervento = $id_stato;
|
||||
$period = CarbonPeriod::create($data_inizio, $data_fine);
|
||||
|
||||
// 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('data_scadenza');
|
||||
$new->firma_file = '';
|
||||
$new->firma_data = null;
|
||||
$new->firma_nome = '';
|
||||
// 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;
|
||||
|
||||
$new->save();
|
||||
// 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 = '';
|
||||
|
||||
$id_record = $new->id;
|
||||
$new->save();
|
||||
|
||||
// Copio le righe
|
||||
if (!empty($copia_righe)) {
|
||||
$righe = $intervento->getRighe();
|
||||
foreach ($righe as $riga) {
|
||||
$new_riga = $riga->replicate();
|
||||
$new_riga->setDocument($new);
|
||||
$id_record = $new->id;
|
||||
|
||||
$new_riga->qta_evasa = 0;
|
||||
$new_riga->save();
|
||||
// Copio le righe
|
||||
if (!empty($copia_righe)) {
|
||||
$righe = $intervento->getRighe();
|
||||
foreach ($righe as $riga) {
|
||||
$new_riga = $riga->replicate();
|
||||
$new_riga->setDocument($new);
|
||||
|
||||
if ($new_riga->isArticolo()) {
|
||||
$new_riga->movimenta($new_riga->qta);
|
||||
$new_riga->qta_evasa = 0;
|
||||
$new_riga->save();
|
||||
|
||||
if ($new_riga->isArticolo()) {
|
||||
$new_riga->movimenta($new_riga->qta);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 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));
|
||||
}
|
||||
|
||||
$diff_fine = strtotime($sessione->orario_fine) - strtotime($sessione->orario_inizio);
|
||||
$orario_fine = date('Y-m-d H:i:s', (strtotime($orario_inizio) + $diff_fine));
|
||||
|
||||
$new_sessione = $sessione->replicate();
|
||||
$new_sessione->idintervento = $new->id;
|
||||
|
||||
$new_sessione->orario_inizio = $orario_inizio;
|
||||
$new_sessione->orario_fine = $orario_fine;
|
||||
$new_sessione->save();
|
||||
|
||||
++$numero_sessione;
|
||||
$inizio_old = $sessione->orario_inizio;
|
||||
}
|
||||
}
|
||||
|
||||
// Copia degli impianti
|
||||
if (!empty($copia_impianti)) {
|
||||
$impianti = $dbo->select('my_impianti_interventi', '*', ['idintervento' => $intervento->id]);
|
||||
foreach ($impianti as $impianto) {
|
||||
$dbo->insert('my_impianti_interventi', [
|
||||
'idintervento' => $id_record,
|
||||
'idimpianto' => $impianto['idimpianto']
|
||||
]);
|
||||
}
|
||||
|
||||
$componenti = $dbo->select('my_componenti_interventi', '*', ['id_intervento' => $intervento->id]);
|
||||
foreach ($componenti as $componente) {
|
||||
$dbo->insert('my_componenti_interventi', [
|
||||
'id_intervento' => $id_record,
|
||||
'id_componente' => $componente['id_componente']
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
//copia allegati
|
||||
if (!empty($copia_allegati)) {
|
||||
$allegati = $intervento->uploads();
|
||||
foreach ($allegati as $allegato) {
|
||||
$allegato->copia([
|
||||
'id_module' => $new->getModule()->id,
|
||||
'id_record' => $new->id,
|
||||
]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 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));
|
||||
}
|
||||
|
||||
$diff_fine = strtotime($sessione->orario_fine) - strtotime($sessione->orario_inizio);
|
||||
$orario_fine = date('Y-m-d H:i:s', (strtotime($orario_inizio) + $diff_fine));
|
||||
|
||||
$new_sessione = $sessione->replicate();
|
||||
$new_sessione->idintervento = $new->id;
|
||||
|
||||
$new_sessione->orario_inizio = $orario_inizio;
|
||||
$new_sessione->orario_fine = $orario_fine;
|
||||
$new_sessione->save();
|
||||
|
||||
++$numero_sessione;
|
||||
$inizio_old = $sessione->orario_inizio;
|
||||
}
|
||||
}
|
||||
|
||||
// Copia degli impianti
|
||||
if (!empty($copia_impianti)) {
|
||||
$impianti = $dbo->select('my_impianti_interventi', '*', ['idintervento' => $intervento->id]);
|
||||
foreach ($impianti as $impianto) {
|
||||
$dbo->insert('my_impianti_interventi', [
|
||||
'idintervento' => $id_record,
|
||||
'idimpianto' => $impianto['idimpianto']
|
||||
]);
|
||||
}
|
||||
|
||||
$componenti = $dbo->select('my_componenti_interventi', '*', ['id_intervento' => $intervento->id]);
|
||||
foreach ($componenti as $componente) {
|
||||
$dbo->insert('my_componenti_interventi', [
|
||||
'id_intervento' => $id_record,
|
||||
'id_componente' => $componente['id_componente']
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
//copia allegati
|
||||
if (!empty($copia_allegati)) {
|
||||
$allegati = $intervento->uploads();
|
||||
foreach ($allegati as $allegato) {
|
||||
$allegato->copia([
|
||||
'id_module' => $new->getModule()->id,
|
||||
'id_record' => $new->id,
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
flash()->info(tr('Attività duplicata correttamente!'));
|
||||
flash()->info(tr('Attività duplicate correttamente!'));
|
||||
|
||||
break;
|
||||
|
||||
|
@ -25,20 +25,34 @@ echo '
|
||||
<input type="hidden" name="op" value="copy">
|
||||
|
||||
<div class="row">
|
||||
<div class="col-md-6">
|
||||
{[ "type": "timestamp", "label": "'.tr('Data/ora richiesta').'", "name": "data_richiesta", "value": "-now-", "required":1 ]}
|
||||
<div class="col-md-3">
|
||||
{[ "type": "date", "label": "'.tr('Data inizio').'", "name": "data_inizio", "value": "-now-", "required":1 ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-6">
|
||||
{[ "type": "timestamp", "label": "'.tr('Data/ora scadenza').'", "name": "data_scadenza" ]}
|
||||
<div class="col-md-3">
|
||||
{[ "type": "date", "label": "'.tr('Data fine').'", "name": "data_fine", "value": "-now-", "required":1 ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-3">
|
||||
{[ "type": "time", "label": "'.tr('Ora richiesta').'", "name": "ora_richiesta", "value": "-now-", "required":1 ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-3">
|
||||
{[ "type": "time", "label": "'.tr('Ora scadenza').'", "name": "ora_scadenza" ]}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="col-md-6">
|
||||
{[ "type": "select", "label": "'.tr('Stato').'", "name": "id_stato", "required": 1, "values": "query=SELECT idstatointervento AS id, descrizione, colore AS _bgcolor_ FROM in_statiintervento WHERE deleted_at IS NULL ORDER BY descrizione", "value": "" ]}
|
||||
{[ "type": "select", "multiple":"1", "label": "'.tr('Giorni').'", "name": "giorni[]", "required": 0, "value": "'.strtolower(setting('Giorni lavorativi')).'", "values": "list=\"lunedì\":\"'.tr('Lunedì').'\", \"martedì\":\"'.tr('Martedì').'\", \"mercoledì\":\"'.tr('Mercoledì').'\", \"giovedì\":\"'.tr('Giovedì').'\", \"venerdì\":\"'.tr('Venerdì').'\", \"sabato\":\"'.tr('Sabato').'\", \"domenica\":\"'.tr('Domenica').'\"", "required":1 ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-6">
|
||||
{[ "type": "select", "label": "'.tr('Stato').'", "name": "id_stato", "required": 1, "values": "query=SELECT idstatointervento AS id, descrizione, colore AS _bgcolor_ FROM in_statiintervento WHERE deleted_at IS NULL ORDER BY descrizione", "value": "" ]}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="col-md-3">
|
||||
{["type": "checkbox", "label": "'.tr('Duplica righe').'", "name": "copia_righe", "help": "'.tr('Selezione per riportare anche le righe nella nuova attività').'" ]}
|
||||
</div>
|
||||
@ -54,7 +68,6 @@ echo '
|
||||
<div class="col-md-3">
|
||||
{["type": "checkbox", "label": "'.tr('Duplica allegati').'", "name": "copia_allegati", "help": "'.tr('Selezione per riportare anche gli allegati nella nuova attività').'", "value": 1 ]}
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- PULSANTI -->
|
||||
|
Loading…
Reference in New Issue
Block a user