diff --git a/include/src/Components/Article.php b/include/src/Components/Article.php index 29c490a36..e0e63f72f 100644 --- a/include/src/Components/Article.php +++ b/include/src/Components/Article.php @@ -11,6 +11,7 @@ abstract class Article extends Row { protected $serialRowID = null; protected $abilita_movimentazione = true; + protected $serialsList = null; protected $qta_movimentazione = 0; @@ -38,13 +39,17 @@ abstract class Article extends Row */ public function setSerialsAttribute($serials) { + $serials = array_clean($serials); + database()->sync('mg_prodotti', [ 'id_riga_'.$this->serialRowID => $this->id, 'dir' => $this->getDirection(), '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), ]); + + $this->serialsList = null; } /** @@ -74,10 +81,24 @@ abstract class Article extends Row return []; } - // Individuazione dei seriali - $results = database()->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_'.$this->serialRowID.' = '.prepare($this->id)); + if (!isset($this->serialsList)) { + // 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); } /** diff --git a/modules/fatture/src/Components/RelationTrait.php b/modules/fatture/src/Components/RelationTrait.php index a54010ac0..10814a2cb 100644 --- a/modules/fatture/src/Components/RelationTrait.php +++ b/modules/fatture/src/Components/RelationTrait.php @@ -170,16 +170,15 @@ trait RelationTrait 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'); } - + // Se c'è un collegamento ad un preventivo, aggiorno la quantità evasa 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'); } - + // Se c'è un collegamento ad un contratto, aggiorno la quantità evasa 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'); } - } }