2018-09-25 16:47:44 +02:00
|
|
|
<?php
|
|
|
|
|
2018-10-05 11:22:32 +02:00
|
|
|
namespace Common;
|
2018-09-25 16:47:44 +02:00
|
|
|
|
2018-09-25 17:13:23 +02:00
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
|
|
|
2018-09-26 12:06:24 +02:00
|
|
|
abstract class Row extends Description
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
2018-11-23 17:50:05 +01:00
|
|
|
protected $prezzo_unitario_vendita_riga;
|
2018-09-26 15:37:46 +02:00
|
|
|
|
2018-09-26 12:20:06 +02:00
|
|
|
protected static function boot($bypass = false)
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
2018-11-16 16:14:46 +01:00
|
|
|
parent::boot(true);
|
2018-09-25 16:47:44 +02:00
|
|
|
|
2018-09-26 12:06:24 +02:00
|
|
|
if (!$bypass) {
|
|
|
|
static::addGlobalScope('rows', function (Builder $builder) {
|
2018-10-04 17:25:42 +02:00
|
|
|
$builder->whereNull('idarticolo')->orWhere('idarticolo', '=', 0);
|
2018-09-26 12:06:24 +02:00
|
|
|
});
|
|
|
|
}
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-10-02 18:25:52 +02:00
|
|
|
public static function make($bypass = false)
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
2018-10-02 18:25:52 +02:00
|
|
|
return parent::make(true);
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-11-23 17:50:05 +01:00
|
|
|
public function getSubtotaleAttribute()
|
|
|
|
{
|
|
|
|
return $this->prezzo_unitario_vendita * $this->qta;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getImponibileAttribute()
|
|
|
|
{
|
|
|
|
return $this->subtotale;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getImponibileScontatoAttribute()
|
|
|
|
{
|
|
|
|
return $this->imponibile - $this->sconto;
|
|
|
|
}
|
|
|
|
|
2018-09-25 16:47:44 +02:00
|
|
|
public function getTotaleAttribute()
|
|
|
|
{
|
2018-11-23 17:50:05 +01:00
|
|
|
return $this->imponibile_scontato + $this->iva + $this->rivalsa_inps;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getNettoAttribute()
|
|
|
|
{
|
|
|
|
return $this->totale - $this->ritenuta_acconto;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRivalsaINPSAttribute()
|
|
|
|
{
|
|
|
|
return $this->attributes['rivalsainps'];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRitenutaAccontoAttribute()
|
|
|
|
{
|
|
|
|
return $this->attributes['ritenutaacconto'];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIvaIndetraibileAttribute()
|
|
|
|
{
|
|
|
|
return $this->attributes['iva_indetraibile'];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIvaAttribute()
|
|
|
|
{
|
|
|
|
$percentuale = database()->fetchOne('SELECT percentuale FROM co_iva WHERE id = :id', [
|
|
|
|
':id' => $this->idiva,
|
|
|
|
])['percentuale'];
|
|
|
|
|
|
|
|
return ($this->imponibile_scontato + $this->rivalsa_inps) * $percentuale /100;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIvaDetraibileAttribute()
|
|
|
|
{
|
|
|
|
return $this->iva - $this->iva_indetraibile;
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Restituisce lo sconto della riga corrente in euro.
|
|
|
|
*
|
|
|
|
* @return float
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function getScontoAttribute()
|
|
|
|
{
|
|
|
|
return calcola_sconto([
|
|
|
|
'sconto' => $this->sconto_unitario,
|
2018-11-21 17:45:06 +01:00
|
|
|
'prezzo' => $this->prezzo_unitario_vendita,
|
2018-09-25 16:47:44 +02:00
|
|
|
'tipo' => $this->tipo_sconto,
|
|
|
|
'qta' => $this->qta,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta l'identificatore della Rivalsa INPS, effettuando di conseguenza i conti.
|
|
|
|
*
|
|
|
|
* @param int $value
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function setIdRivalsaINPSAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['idrivalsainps'] = $value;
|
|
|
|
|
2018-10-05 10:49:46 +02:00
|
|
|
$this->fixRivalsaINPS();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Effettua i conti per la Rivalsa INPS.
|
|
|
|
*/
|
|
|
|
protected function fixRivalsaINPS()
|
|
|
|
{
|
|
|
|
$rivalsa = database()->fetchOne('SELECT * FROM co_rivalsainps WHERE id = '.prepare($this->idrivalsainps));
|
|
|
|
$this->attributes['rivalsainps'] = ($this->subtotale - $this->sconto) / 100 * $rivalsa['percentuale'];
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Restituisce il metodo di calcolo per la Ritenuta d'Acconto.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function getCalcoloRitenutaAccontoAttribute()
|
|
|
|
{
|
2018-09-26 15:37:46 +02:00
|
|
|
return $this->calcolo_ritenutaacconto ?: setting("Metodologia calcolo ritenuta d'acconto predefinito");
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta il metodo di calcolo per la Ritenuta d'Acconto.
|
|
|
|
*
|
|
|
|
* @param string $value
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function setCalcoloRitenutaAccontoAttribute($value)
|
|
|
|
{
|
|
|
|
return $this->attributes['calcolo_ritenutaacconto'] = $value;
|
2018-09-26 15:37:46 +02:00
|
|
|
|
|
|
|
$this->fixRitenutaAcconto();
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta l'identificatore della Ritenuta d'Acconto, effettuando di conseguenza i conti in base al valore del campo calcolo_ritenuta_acconto.
|
|
|
|
*
|
|
|
|
* @param int $value
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function setIdRitenutaAccontoAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['idritenutaacconto'] = $value;
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->fixRitenutaAcconto();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Effettua i conti per la Ritenuta d'Acconto.
|
|
|
|
*/
|
|
|
|
protected function fixRitenutaAcconto()
|
|
|
|
{
|
2018-09-25 16:47:44 +02:00
|
|
|
// Calcolo ritenuta d'acconto
|
2018-09-26 15:37:46 +02:00
|
|
|
$ritenuta = database()->fetchOne('SELECT * FROM co_ritenutaacconto WHERE id = '.prepare($this->idritenutaacconto));
|
2018-09-25 16:47:44 +02:00
|
|
|
$conto = ($this->subtotale - $this->sconto);
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
if ($this->calcolo_ritenuta_acconto == 'Imponibile + rivalsa inps') {
|
2018-09-25 16:47:44 +02:00
|
|
|
$conto += $this->rivalsainps;
|
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->attributes['ritenutaacconto'] = $conto / 100 * $ritenuta['percentuale'];
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta il valore dello sconto.
|
|
|
|
*
|
|
|
|
* @param float $value
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function setScontoUnitarioAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['sconto_unitario'] = $value;
|
|
|
|
|
|
|
|
$this->fixSconto();
|
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta il tipo dello sconto.
|
|
|
|
*
|
|
|
|
* @param string $value
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
public function setTipoScontoAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['tipo_sconto'] = $value;
|
|
|
|
|
|
|
|
$this->fixSconto();
|
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Effettua i conti per lo sconto totale.
|
|
|
|
*/
|
2018-09-25 16:47:44 +02:00
|
|
|
protected function fixSconto()
|
|
|
|
{
|
|
|
|
$this->attributes['sconto'] = $this->sconto;
|
2018-09-28 09:30:46 +02:00
|
|
|
|
|
|
|
$this->fixIva();
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta l'identificatore dell'IVA, effettuando di conseguenza i conti.
|
|
|
|
*
|
|
|
|
* @param int $value
|
|
|
|
*/
|
|
|
|
public function setIdIvaAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['idiva'] = $value;
|
|
|
|
|
|
|
|
$this->fixIva();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Effettua i conti per l'IVA.
|
|
|
|
*/
|
2018-09-26 12:06:24 +02:00
|
|
|
protected function fixIva()
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
|
|
|
$iva = database()->fetchOne('SELECT * FROM co_iva WHERE id = :id_iva', [
|
2018-09-26 12:06:24 +02:00
|
|
|
':id_iva' => $this->idiva,
|
2018-09-25 16:47:44 +02:00
|
|
|
]);
|
|
|
|
$descrizione = $iva['descrizione'];
|
|
|
|
|
|
|
|
$valore = ($this->subtotale - $this->sconto) * $iva['percentuale'] / 100;
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->attributes['desc_iva'] = $descrizione;
|
|
|
|
$this->attributes['iva'] = $valore;
|
2018-09-25 16:47:44 +02:00
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->fixIvaIndetraibile();
|
|
|
|
}
|
2018-09-26 12:06:24 +02:00
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Effettua i conti per l'IVA indetraibile.
|
|
|
|
*/
|
|
|
|
protected function fixIvaIndetraibile()
|
|
|
|
{
|
|
|
|
$iva = database()->fetchOne('SELECT * FROM co_iva WHERE id = :id_iva', [
|
|
|
|
':id_iva' => $this->idiva,
|
|
|
|
]);
|
|
|
|
|
|
|
|
$this->attributes['iva_indetraibile'] = $this->iva / 100 * $iva['indetraibile'];
|
2018-09-26 12:06:24 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta la quantità della riga.
|
|
|
|
*
|
|
|
|
* @param float $value
|
|
|
|
*/
|
|
|
|
public function setQtaAttribute($value)
|
2018-09-26 12:06:24 +02:00
|
|
|
{
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->attributes['qta'] = $value;
|
2018-09-26 12:06:24 +02:00
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
$this->fixSubtotale();
|
2018-09-28 09:30:46 +02:00
|
|
|
$this->fixSconto();
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Imposta il costo unitario della riga.
|
|
|
|
*
|
|
|
|
* @param float $value
|
|
|
|
*/
|
2018-11-21 17:45:06 +01:00
|
|
|
public function setPrezzoUnitarioVenditaAttribute($value)
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
2018-11-23 17:50:05 +01:00
|
|
|
$this->prezzo_unitario_vendita_riga = $value;
|
2018-09-26 15:37:46 +02:00
|
|
|
|
|
|
|
$this->fixSubtotale();
|
2018-09-28 09:30:46 +02:00
|
|
|
$this->fixSconto();
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
|
2018-09-26 15:37:46 +02:00
|
|
|
/**
|
|
|
|
* Restituisce il costo unitario della riga.
|
|
|
|
*/
|
2018-11-21 17:45:06 +01:00
|
|
|
public function getPrezzoUnitarioVenditaAttribute()
|
2018-09-25 16:47:44 +02:00
|
|
|
{
|
2018-11-23 17:50:05 +01:00
|
|
|
if (empty($this->prezzo_unitario_vendita_riga)) {
|
|
|
|
$this->prezzo_unitario_vendita_riga = $this->attributes['subtotale'] / $this->qta;
|
2018-09-26 15:37:46 +02:00
|
|
|
}
|
2018-09-25 16:47:44 +02:00
|
|
|
|
2018-11-23 17:50:05 +01:00
|
|
|
return $this->prezzo_unitario_vendita_riga;
|
2018-09-26 15:37:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Effettua i conti per il subtotale della riga.
|
|
|
|
*/
|
|
|
|
protected function fixSubtotale()
|
|
|
|
{
|
2018-11-21 17:45:06 +01:00
|
|
|
$this->attributes['subtotale'] = $this->prezzo_unitario_vendita * $this->qta;
|
2018-09-26 12:06:24 +02:00
|
|
|
|
|
|
|
$this->fixIva();
|
2018-10-05 10:49:46 +02:00
|
|
|
$this->fixRitenutaAcconto();
|
|
|
|
$this->fixRivalsaINPS();
|
2018-09-25 16:47:44 +02:00
|
|
|
}
|
|
|
|
}
|