Miglioramento seriali articolo

This commit is contained in:
Thomas Zilio 2019-05-04 08:47:53 -07:00
parent c69091fa0a
commit ef8ad6f01e
2 changed files with 27 additions and 7 deletions

View File

@ -11,6 +11,7 @@ abstract class Article extends Row
{ {
protected $serialRowID = null; protected $serialRowID = null;
protected $abilita_movimentazione = true; protected $abilita_movimentazione = true;
protected $serialsList = null;
protected $qta_movimentazione = 0; protected $qta_movimentazione = 0;
@ -38,13 +39,17 @@ abstract class Article extends Row
*/ */
public function setSerialsAttribute($serials) public function setSerialsAttribute($serials)
{ {
$serials = array_clean($serials);
database()->sync('mg_prodotti', [ database()->sync('mg_prodotti', [
'id_riga_'.$this->serialRowID => $this->id, 'id_riga_'.$this->serialRowID => $this->id,
'dir' => $this->getDirection(), 'dir' => $this->getDirection(),
'id_articolo' => $this->idarticolo, 'id_articolo' => $this->idarticolo,
], [ ], [
'serial' => array_clean($serials), 'serial' => $serials,
]); ]);
$this->serialsList = $serials;
} }
/** /**
@ -61,6 +66,8 @@ abstract class Article extends Row
], [ ], [
'serial' => array_clean($serials), 'serial' => array_clean($serials),
]); ]);
$this->serialsList = null;
} }
/** /**
@ -74,10 +81,24 @@ abstract class Article extends Row
return []; return [];
} }
// Individuazione dei seriali if (!isset($this->serialsList)) {
$results = database()->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_'.$this->serialRowID.' = '.prepare($this->id)); // Individuazione dei seriali
$results = database()->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_'.$this->serialRowID.' = '.prepare($this->id));
return array_column($results, 'serial'); $this->serialsList = array_column($results, 'serial');
}
return $this->serialsList;
}
/**
* Restituisce il numero di seriali mancanti per il completamento dell'articolo.
*
* @return float
*/
public function getMissingSerialsAttribute()
{
return $this->qta - count($this->serials);
} }
/** /**

View File

@ -170,16 +170,15 @@ trait RelationTrait
elseif (!empty($this->idordine)) { elseif (!empty($this->idordine)) {
$database->query('UPDATE or_righe_ordini SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idordine = '.prepare($this->idordine).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1'); $database->query('UPDATE or_righe_ordini SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idordine = '.prepare($this->idordine).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1');
} }
// Se c'è un collegamento ad un preventivo, aggiorno la quantità evasa // Se c'è un collegamento ad un preventivo, aggiorno la quantità evasa
elseif (!empty($this->idpreventivo)) { elseif (!empty($this->idpreventivo)) {
$database->query('UPDATE co_righe_preventivi SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idpreventivo = '.prepare($this->idpreventivo).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1'); $database->query('UPDATE co_righe_preventivi SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idpreventivo = '.prepare($this->idpreventivo).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1');
} }
// Se c'è un collegamento ad un contratto, aggiorno la quantità evasa // Se c'è un collegamento ad un contratto, aggiorno la quantità evasa
elseif (!empty($this->idcontratto)) { elseif (!empty($this->idcontratto)) {
$database->query('UPDATE co_righe_contratti SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idcontratto = '.prepare($this->idcontratto).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1'); $database->query('UPDATE co_righe_contratti SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idcontratto = '.prepare($this->idcontratto).' AND idiva = '.prepare($this->idiva).' AND qta_evasa < qta LIMIT 1');
} }
} }
} }