New-Thanasoft/thanasoft-back/app/Repositories/PurchaseOrderRepository.php
2026-01-28 14:26:20 +03:00

87 lines
2.6 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Repositories;
use App\Models\PurchaseOrder;
use App\Models\PurchaseOrderLine;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Collection;
class PurchaseOrderRepository extends BaseRepository implements PurchaseOrderRepositoryInterface
{
public function __construct(PurchaseOrder $model)
{
parent::__construct($model);
}
public function all(array $columns = ['*']): Collection
{
return $this->model->with(['fournisseur', 'lines.product'])->get($columns);
}
public function find(int|string $id, array $columns = ['*']): ?PurchaseOrder
{
return $this->model->with(['fournisseur', 'lines.product'])->find($id, $columns);
}
public function create(array $attributes): PurchaseOrder
{
return DB::transaction(function () use ($attributes) {
try {
$lines = $attributes['lines'] ?? [];
unset($attributes['lines']);
$purchaseOrder = parent::create($attributes);
foreach ($lines as $line) {
$purchaseOrder->lines()->create($line);
}
return $purchaseOrder->load('lines.product');
} catch (\Exception $e) {
Log::error('Error creating PurchaseOrder with lines: ' . $e->getMessage(), [
'attributes' => $attributes,
'exception' => $e
]);
throw $e;
}
});
}
public function update(int|string $id, array $attributes): bool
{
return DB::transaction(function () use ($id, $attributes) {
try {
$purchaseOrder = $this->find($id);
if (!$purchaseOrder) {
return false;
}
$lines = $attributes['lines'] ?? null;
unset($attributes['lines']);
$updated = parent::update($id, $attributes);
if ($lines !== null && $updated) {
$purchaseOrder->lines()->delete();
foreach ($lines as $line) {
$purchaseOrder->lines()->create($line);
}
}
return $updated;
} catch (\Exception $e) {
Log::error('Error updating PurchaseOrder with lines: ' . $e->getMessage(), [
'id' => $id,
'attributes' => $attributes,
'exception' => $e
]);
throw $e;
}
});
}
}