1
0
Fork 0
internet-everythings-agricu.../app/Services/Admin/RegionService.php

88 lines
2.3 KiB
PHP

<?php
namespace App\Services\Admin;
use App\Models\Region;
use App\Filters\Admin\RegionFilter;
use Illuminate\Support\Arr;
use Throwable;
use DB;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
/**
* @method Region getModel()
* @method Region|\Illuminate\Database\Query\Builder query()
*/
class RegionService extends BaseService
{
protected string $modelName = Region::class;
protected string $modelFilterName = RegionFilter::class;
protected array $withRelationships = ['category'];
public function getEditData($id): Model|\Illuminate\Database\Eloquent\Collection|Builder|array|null
{
$region = parent::getEditData($id);
$region->monitorModes = $region->monitorModes()->get()->pluck('id')->toArray();
return $region;
}
public function store($data): bool
{
$columns = $this->getTableColumns();
$model = $this->getModel();
foreach ($data as $k => $v) {
if (!in_array($k, $columns)) {
continue;
}
$model->setAttribute($k, $v);
}
try{
DB::beginTransaction();
if($model->save()){
//处理关联设备
$monitorModes = Arr::get($data, 'monitorModes');
$model->monitorModes()->sync($monitorModes ?? []);
}
DB::commit();
return true;
}catch(Throwable $th){
DB::rollBack();
report($th);
return false;
}
}
public function update($primaryKey, $data): bool
{
$columns = $this->getTableColumns();
$model = $this->query()->whereKey($primaryKey)->first();
foreach ($data as $k => $v) {
if (!in_array($k, $columns)) {
continue;
}
$model->setAttribute($k, $v);
}
try{
DB::beginTransaction();
if($model->save()){
//处理关联设备
$monitorModes = Arr::get($data, 'monitorModes');
$model->monitorModes()->sync($monitorModes ?? []);
}
DB::commit();
return true;
}catch(Throwable $th){
DB::rollBack();
report($th);
return false;
}
}
}