1
0
Fork 0
party-rank-server/app/Models/UserScore.php

73 lines
1.7 KiB
PHP

<?php
namespace App\Models;
use App\Casts\StorageFile;
use App\Enums\CheckStatus;
use App\Traits\HasDateTimeFormatter;
use EloquentFilter\Filterable;
use Illuminate\Database\Eloquent\Casts\Attribute;
use Illuminate\Database\Eloquent\Model;
use Slowlyo\OwlAdmin\Models\AdminUser;
use Illuminate\Database\Eloquent\Factories\HasFactory;
/**
* 党员审核记录
*/
class UserScore extends Model
{
use HasDateTimeFormatter, Filterable, HasFactory;
protected $fillable = ['type_id', 'cate_id', 'user_id', 'title', 'content', 'images', 'file', 'check_status', 'check_user_id', 'check_remarks', 'check_at', 'score'];
protected $casts = [
'images' => 'array',
'file' => StorageFile::class,
'check_status' => CheckStatus::class,
'check_at' => 'datetime',
];
protected $attributes = [
'check_status' => CheckStatus::None,
];
protected $appends = ['check_status_text'];
public static function getTypeList()
{
return Keyword::where('key', 'like', 'score_cate_%')->get();
}
public function type()
{
return $this->belongsTo(Keyword::class, 'type_id');
}
public function cate()
{
return $this->belongsTo(PartyCate::class, 'cate_id');
}
public function user()
{
return $this->belongsTo(PartyUser::class, 'user_id');
}
public function checkUser()
{
return $this->belongsTo(AdminUser::class, 'check_user_id');
}
protected function checkStatusText(): Attribute
{
return new Attribute(
get: fn () => $this->check_status ? $this->check_status->text() : '',
);
}
public function scopeSort($q)
{
$this->orderBy('check_status')->latest('created_at');
}
}