openstamanager/modules/primanota/src/Movimento.php

121 lines
3.4 KiB
PHP
Executable File

<?php
/*
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
* Copyright (C) DevCode s.r.l.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
namespace Modules\PrimaNota;
use Common\SimpleModelTrait;
use Illuminate\Database\Eloquent\Model;
use Modules\Fatture\Fattura;
use Modules\Scadenzario\Scadenza;
class Movimento extends Model
{
use SimpleModelTrait;
protected $table = 'co_movimenti';
protected $appends = [
'id_conto',
'avere',
'dare',
];
public static function build(Mastrino $mastrino, $id_conto, Fattura $documento = null, Scadenza $scadenza = null)
{
$model = new static();
// Informazioni dipendenti dal mastrino
$model->idmastrino = $mastrino->idmastrino;
$model->data = $mastrino->data;
$model->descrizione = $mastrino->descrizione;
$model->note = $mastrino->note;
$model->primanota = $mastrino->primanota;
$model->is_insoluto = $mastrino->is_insoluto;
$model->id_anagrafica = $mastrino->id_anagrafica;
// Conto associato
$model->idconto = $id_conto;
// Associazione al documento indicato
$documento_scadenza = $scadenza ? $scadenza->documento : null;
$documento = $documento ?: $documento_scadenza;
if (!empty($documento)) {
$model->id_anagrafica = $documento->idanagrafica;
$model->iddocumento = $documento->id;
}
// Associazione alla scadenza indicata
$model->id_scadenza = $scadenza ? $scadenza->id : null;
$model->save();
return $model;
}
public function setTotale($avere, $dare)
{
if (!empty($avere)) {
$totale = -$avere;
} else {
$totale = $dare;
}
$this->totale = $totale;
}
public function save(array $options = [])
{
// Aggiornamento automatico di totale_reddito
$conto = database()->fetchOne('SELECT * FROM co_pianodeiconti3 WHERE id = '.prepare($this->id_conto));
$percentuale = floatval($conto['percentuale_deducibile']);
$this->totale_reddito = $this->totale * $percentuale / 100;
return parent::save($options);
}
// Attributi
public function getIdContoAttribute()
{
return $this->attributes['idconto'];
}
public function getAvereAttribute()
{
return $this->totale < 0 ? abs($this->totale) : 0;
}
public function getDareAttribute()
{
return $this->totale > 0 ? abs($this->totale) : 0;
}
// Relazioni Eloquent
public function scadenza()
{
return $this->belongsTo(Scadenza::class, 'id_scadenza');
}
public function documento()
{
return $this->belongsTo(Fattura::class, 'iddocumento');
}
}