netgescon-master/app/Models/VoceSpesa.php
2025-06-29 23:39:33 +02:00

73 lines
1.5 KiB
PHP

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class VoceSpesa extends Model
{
use HasFactory;
protected $table = 'voci_spesa';
protected $fillable = [
'stabile_id',
'codice',
'descrizione',
'tipo_gestione',
'categoria',
'tabella_millesimale_default_id',
'ritenuta_acconto_default',
'attiva',
'ordinamento',
];
protected $casts = [
'ritenuta_acconto_default' => 'decimal:2',
'attiva' => 'boolean',
'ordinamento' => 'integer',
'created_at' => 'datetime',
'updated_at' => 'datetime',
];
/**
* Relazione con Stabile
*/
public function stabile()
{
return $this->belongsTo(Stabile::class, 'stabile_id', 'id_stabile');
}
/**
* Relazione con Tabella Millesimale Default
*/
public function tabellaMillesimaleDefault()
{
return $this->belongsTo(TabellaMillesimale::class, 'tabella_millesimale_default_id');
}
/**
* Scope per voci attive
*/
public function scopeAttive($query)
{
return $query->where('attiva', true);
}
/**
* Scope per tipo gestione
*/
public function scopeTipoGestione($query, $tipo)
{
return $query->where('tipo_gestione', $tipo);
}
/**
* Scope ordinato
*/
public function scopeOrdinato($query)
{
return $query->orderBy('ordinamento')->orderBy('descrizione');
}
}