Aggiunta azione di gruppo unisci rdo

This commit is contained in:
MatteoPistorello 2022-02-14 10:51:36 +01:00
parent dba45f7264
commit 69b67fd1de
1 changed files with 69 additions and 3 deletions

View File

@ -19,11 +19,13 @@
include_once __DIR__.'/../../core.php'; include_once __DIR__.'/../../core.php';
use Modules\Anagrafiche\Anagrafica;
use Modules\Articoli\Articolo as ArticoloOriginale; use Modules\Articoli\Articolo as ArticoloOriginale;
use Modules\Fatture\Fattura; use Modules\Fatture\Fattura;
use Modules\Fatture\Stato; use Modules\Fatture\Stato;
use Modules\Fatture\Tipo; use Modules\Fatture\Tipo as TipoFattura;
use Modules\Ordini\Ordine; use Modules\Ordini\Ordine;
use Modules\Ordini\Tipo;
$module_fatture = 'Fatture di vendita'; $module_fatture = 'Fatture di vendita';
@ -45,7 +47,7 @@ switch (post('op')) {
$documenti = collect(); $documenti = collect();
$numero_totale = 0; $numero_totale = 0;
$tipo_documento = Tipo::where('id', post('idtipodocumento'))->first(); $tipo_documento = TipoFattura::where('id', post('idtipodocumento'))->first();
$stato_documenti_accodabili = Stato::where('descrizione', 'Bozza')->first(); $stato_documenti_accodabili = Stato::where('descrizione', 'Bozza')->first();
$accodare = post('accodare'); $accodare = post('accodare');
@ -141,6 +143,55 @@ switch (post('op')) {
} }
break; break;
case 'unisci_rdo':
$id_stato = post('id_stato');
$data = post('data') ?: null;
$tipo = Tipo::where('dir', 'uscita')->first();
$numero_ordini = [];
$fornitori = [];
$new_ordini = [];
foreach ($id_records as $id) {
$ordine = Ordine::find($id);
if (in_array($ordine->stato->descrizione, ['Bozza', 'In attesa di conferma', 'Accettato'])) {
// Controllo se è già stato creato un nuovo ordine per l'anagrafica
if (in_array($ordine->idanagrafica, array_keys($new_ordini))) {
$new_ordine = Ordine::find($new_ordini[$ordine->idanagrafica]);
} else {
$anagrafica = Anagrafica::find($ordine->idanagrafica);
$new_ordine = Ordine::build($anagrafica, $tipo, $data);
$new_ordine->idstatoordine = $id_stato;
$new_ordine->data = $data;
$new_ordine->save();
$new_ordini[$ordine->idanagrafica] = $new_ordine->id;
$numero_ordini[] = $new_ordine->numero;
}
$righe = $ordine->getRighe();
foreach ($righe as $riga) {
$new_riga = $riga->replicate();
$new_riga->setDocument($new_ordine);
$new_riga->save();
}
$ordine->delete();
}
}
if (sizeof($numero_ordini) > 0) {
flash()->info(tr('Sono stati creati i seguenti ordini: ', [
'_NUM_' => implode(',', $numero_ordini),
]));
} else {
flash()->warning(tr('Nessun ordine creato!'));
}
break;
} }
if ($module['name'] == 'Ordini cliente') { if ($module['name'] == 'Ordini cliente') {
$operations['crea_fattura'] = [ $operations['crea_fattura'] = [
@ -155,6 +206,21 @@ if ($module['name'] == 'Ordini cliente') {
'blank' => false, 'blank' => false,
], ],
]; ];
} else {
if (App::debug()) {
$operations['unisci_rdo'] = [
'text' => '<span><i class="fa fa-refresh"></i> '.tr('Unisci rdo'),
'data' => [
'title' => tr('Unire gli ordini selezionati?'),
'msg' => tr('Gli ordini saranno processati solo se in uno dei seguenti stati: Bozza, In attesa di conferma, Accettato.<br>Tutti gli ordini processati verranno eliminati e verrà creato un nuovo ordine unificato per fornitore.').'<br>
<br>{[ "type": "select", "label": "'.tr('Stato').'", "name": "id_stato", "required": 1, "values": "query=SELECT id, descrizione FROM or_statiordine" ]}<br>
<br>{[ "type": "date", "label": "'.tr('Data').'", "name": "data", "required": 1]}',
'button' => tr('Procedi'),
'class' => 'btn btn-lg btn-warning',
'blank' => false,
],
];
}
} }
$operations['cambia_stato'] = [ $operations['cambia_stato'] = [
@ -169,4 +235,4 @@ $operations['cambia_stato'] = [
], ],
]; ];
return $operations; return $operations;