Akaunting/app/Models/Common/Report.php

100 lines
2.5 KiB
PHP
Raw Normal View History

2019-11-16 07:21:14 +00:00
<?php
namespace App\Models\Common;
use App\Abstracts\Model;
2020-01-25 23:21:34 +00:00
use Bkwld\Cloner\Cloneable;
use Illuminate\Support\Str;
2025-04-29 17:50:09 +00:00
use Illuminate\Database\Eloquent\Builder;
2019-11-16 07:21:14 +00:00
class Report extends Model
{
2020-01-25 23:21:34 +00:00
use Cloneable;
2019-11-16 07:21:14 +00:00
protected $table = 'reports';
/**
* Attributes that should be mass-assignable.
*
* @var array
*/
2021-09-07 07:33:34 +00:00
protected $fillable = ['company_id', 'class', 'name', 'description', 'settings', 'created_from', 'created_by'];
2020-01-16 12:39:37 +00:00
/**
2020-11-13 12:15:27 +00:00
* The attributes that should be cast.
2020-01-16 12:39:37 +00:00
*
* @var array
*/
protected $casts = [
2023-03-16 13:36:13 +00:00
'settings' => 'object',
'deleted_at' => 'datetime',
2020-01-16 12:39:37 +00:00
];
/**
* Scope to only include reports of a given alias.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param string $alias
* @return \Illuminate\Database\Eloquent\Builder
*/
public function scopeAlias($query, $alias)
{
$class = ($alias == 'core') ? 'App\\\\' : 'Modules\\\\' . Str::studly($alias) . '\\\\';
return $query->where('class', 'like', $class . '%');
}
2025-04-29 17:50:09 +00:00
/**
* Scope to only include reports of a given class.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param string $class
* @return \Illuminate\Database\Eloquent\Builder
*/
public function scopeClass($query, $class)
{
return $query->where('class', '=', $class);
}
public function scopeExpenseSummary(Builder $query): Builder
{
return $query->where($this->qualifyColumn('class'), '=', 'App\\Reports\\ExpenseSummary');
}
public function scopeIncomeSummary(Builder $query): Builder
{
return $query->where($this->qualifyColumn('class'), '=', 'App\\Reports\\IncomeSummary');
}
public function scopeIncomeExpenseSummary(Builder $query): Builder
{
return $query->where($this->qualifyColumn('class'), '=', 'App\\Reports\\IncomeExpenseSummary');
}
public function scopeProfitLoss(Builder $query): Builder
{
return $query->where($this->qualifyColumn('class'), '=', 'App\\Reports\\ProfitLoss');
}
public function scopeTaxSummary(Builder $query): Builder
{
return $query->where($this->qualifyColumn('class'), '=', 'App\\Reports\\TaxSummary');
}
/**
* Get the alias based on class.
*
* @return string
*/
public function getAliasAttribute()
{
if (Str::startsWith($this->class, 'App\\')) {
return 'core';
}
$arr = explode('\\', $this->class);
return Str::kebab($arr[1]);
}
2019-11-16 07:21:14 +00:00
}