44 lines
1.1 KiB
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);
|
|
}
|
|
}
|