dealhub/app/Models/Report.php

44 lines
1.1 KiB
PHP

<?php
namespace App\Models;
use App\Enums\ReportStatus;
use App\Enums\ReportType;
use Illuminate\Database\Eloquent\Attributes\Scope;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
class Report extends Model
{
public function user(): BelongsTo
{
return $this->belongsTo(User::class);
}
public function deals(): BelongsToMany
{
return $this->belongsToMany(Deal::class);
}
protected function casts(): array
{
return [
'type' => ReportType::class,
'status' => ReportStatus::class,
];
}
#[Scope]
public function orderByStatus(Builder $query, array $statusOrder): Builder
{
$values = array_map(fn ($enum) => $enum->value, $statusOrder);
// Create placeholders for each value: FIELD(status, ?, ?, ?)
$placeholders = implode(',', array_fill(0, count($values), '?'));
return $query->orderByRaw("FIELD(status, $placeholders)", $values);
}
}