Miglioramento seriali articolo
This commit is contained in:
parent
c69091fa0a
commit
ef8ad6f01e
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue