1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-06 12:56:56 +01:00
openstamanager/include/src/Components/Article.php

173 lines
5.3 KiB
PHP
Raw Normal View History

2018-09-25 16:47:44 +02:00
<?php
2018-12-25 11:32:19 +01:00
namespace Common\Components;
2018-09-25 16:47:44 +02:00
2018-12-29 12:03:22 +01:00
use Common\Document;
2018-09-25 17:13:23 +02:00
use Illuminate\Database\Eloquent\Builder;
2018-12-29 12:03:22 +01:00
use Modules\Articoli\Articolo as Original;
use UnexpectedValueException;
2018-09-25 16:47:44 +02:00
abstract class Article extends Row
{
2018-09-25 17:13:23 +02:00
protected $serialRowID = 'documento';
2018-09-25 16:47:44 +02:00
2018-12-25 11:32:19 +01:00
public static function make(Document $document, Original $articolo)
2018-09-25 16:47:44 +02:00
{
2018-12-25 11:33:15 +01:00
$model = parent::make($document, true);
2018-09-25 16:47:44 +02:00
$model->articolo()->associate($articolo);
$model->descrizione = $articolo->descrizione;
$model->abilita_serial = $articolo->abilita_serial;
$model->um = $articolo->um;
return $model;
}
2018-09-26 12:20:06 +02:00
abstract public function movimenta($qta);
2018-10-04 17:41:31 +02:00
abstract public function getDirection();
2018-09-26 12:20:06 +02:00
2018-09-26 15:37:46 +02:00
/**
* Imposta i seriali collegati all'articolo del documento.
*
* @param array $serials
*/
public function setSerialsAttribute($serials)
2018-09-25 16:47:44 +02:00
{
database()->sync('mg_prodotti', [
2018-09-25 17:13:23 +02:00
'id_riga_'.$this->serialRowID => $this->id,
'dir' => $this->getDirection(),
2018-09-25 16:47:44 +02:00
'id_articolo' => $this->idarticolo,
], [
2018-09-28 16:43:40 +02:00
'serial' => array_clean($serials),
2018-09-25 16:47:44 +02:00
]);
}
2018-09-26 15:37:46 +02:00
/**
* Restituisce l'elenco dei seriali collegati all'articolo del documento.
*
* @return array
*/
2018-09-25 17:13:23 +02:00
public function getSerialsAttribute()
{
if (empty($this->abilita_serial)) {
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));
2018-09-26 10:49:38 +02:00
return array_column($results, 'serial');
}
2018-09-26 15:37:46 +02:00
/**
* Modifica la quantità dell'articolo e movimenta automaticamente il magazzino.
*
2018-10-04 17:41:31 +02:00
* @param float $value
2018-09-26 15:37:46 +02:00
*/
2018-09-25 16:47:44 +02:00
public function setQtaAttribute($value)
{
if (!$this->cleanupSerials($value)) {
throw new UnexpectedValueException();
}
2018-09-25 16:47:44 +02:00
$previous = $this->qta;
$diff = $value - $previous;
2018-09-25 16:47:44 +02:00
2018-12-29 11:42:53 +01:00
$this->attributes['qta'] = $value;
2018-09-25 16:47:44 +02:00
$this->movimenta($diff);
$database = database();
// Se c'è un collegamento ad un ddt, aggiorno la quantità evasa
if (!empty($this->idddt)) {
$database->query('UPDATE dt_righe_ddt SET qta_evasa = qta_evasa + '.$diff.' WHERE descrizione = '.prepare($this->descrizione).' AND idarticolo = '.prepare($this->idarticolo).' AND idddt = '.prepare($this->idddt).' AND idiva = '.prepare($this->idiva));
}
// Se c'è un collegamento ad un ordine, aggiorno la quantità evasa
if (!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));
}
}
public function articolo()
{
return $this->belongsTo(Original::class, 'idarticolo');
}
public function copiaIn(Document $document)
{
$class = get_class($document);
$namespace = implode('\\', explode('\\', $class, -1));
$current = get_class($this);
$pieces = explode('\\', $current);
$type = end($pieces);
$object = $namespace.'\\Components\\'.$type;
$attributes = $this->getAttributes();
unset($attributes['id']);
$model = $object::make($document, $this->articolo);
$model->save();
$model = $object::find($model->id);
$accepted = $model->getAttributes();
$attributes = array_intersect_key($attributes, $accepted);
$model->fill($attributes);
return $model;
}
2018-12-29 12:03:22 +01:00
protected static function boot()
{
parent::boot(true);
static::addGlobalScope('articles', function (Builder $builder) {
$builder->whereNotNull('idarticolo')->where('idarticolo', '<>', 0);
});
}
protected function usedSerials()
{
if ($this->getDirection() == 'uscita') {
$results = database()->fetchArray("SELECT serial FROM mg_prodotti WHERE serial IN (SELECT DISTINCT serial FROM mg_prodotti WHERE dir = 'entrata') AND serial IS NOT NULL AND id_riga_".$this->serialRowID.' = '.prepare($this->id));
return array_column($results, 'serial');
}
return [];
}
protected function cleanupSerials($new_qta)
{
// Se la nuova quantità è minore della precedente
if ($this->qta > $new_qta) {
$seriali_usati = $this->usedSerials();
$count_seriali_usati = count($seriali_usati);
// Controllo sulla possibilità di rimuovere i seriali (se non utilizzati da documenti di vendita)
if ($this->getDirection() == 'uscita' && $new_qta < $count_seriali_usati) {
return false;
} else {
// Controllo sul numero di seriali effettivi da rimuovere
$seriali = $this->serials;
if ($new_qta < count($seriali)) {
$rimovibili = array_diff($seriali, $seriali_usati);
// Rimozione dei seriali aggiuntivi
$serials = array_slice($rimovibili, 0, $new_qta - $count_seriali_usati);
$this->serials = array_merge($seriali_usati, $serials);
}
}
}
return true;
}
2018-09-25 16:47:44 +02:00
}