generated from liutk/owl-admin-base
56 lines
1.7 KiB
PHP
56 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace App\Admin\Services;
|
|
|
|
use App\Admin\Filters\OvertimeApplyFilter;
|
|
use App\Models\Employee;
|
|
use App\Models\OvertimeApply;
|
|
use Carbon\Carbon;
|
|
use Illuminate\Support\Facades\Validator;
|
|
|
|
class OvertimeApplyService extends BaseService
|
|
{
|
|
protected array $withRelationships = ['store', 'employee', 'workflow'];
|
|
|
|
protected string $modelName = OvertimeApply::class;
|
|
|
|
protected string $modelFilterName = OvertimeApplyFilter::class;
|
|
|
|
public function resloveData($data, $model = null)
|
|
{
|
|
// 获取员工所在的门店
|
|
if (! isset($data['store_id']) && isset($data['employee_id'])) {
|
|
$data['store_id'] = Employee::where('id', $data['employee_id'])->value('store_id');
|
|
}
|
|
if (isset($data['datetime_range'])) {
|
|
$time = explode(',', $data['datetime_range']);
|
|
$start = Carbon::createFromTimestamp(data_get($time, 0));
|
|
$end = Carbon::createFromTimestamp(data_get($time, 1));
|
|
$data['start_at'] = $start;
|
|
$data['end_at'] = $end;
|
|
$data['date'] = $start->format('Y-m-d');
|
|
$data['hours'] = $start->diffInHours($end);
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function validate($data, $model = null)
|
|
{
|
|
// 验证申请时间是否重叠
|
|
// todo
|
|
$createRules = [
|
|
'employee_id' => ['required'],
|
|
'start_at' => ['required'],
|
|
'end_at' => ['required'],
|
|
];
|
|
$updateRules = [];
|
|
$validator = Validator::make($data, $model ? $updateRules : $createRules, []);
|
|
if ($validator->fails()) {
|
|
return $validator->errors()->first();
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|