all(); $list = VisitAudit::with('visit')->where(function ($query) use ($all) { if (isset($all['myself_audit']) && !empty($all['myself_audit'])) { $query->where('audit_admin_id', $this->getUserId()); } $query->whereHas('visit', function ($q) use ($all) { if (isset($all['audit_status'])) { $q->where('audit_status', $all['audit_status']); } if (isset($all['type'])) { $q->where('type', $all['type']); } if (isset($all['myself_accept']) && !empty($all['myself_accept'])) { $q->where('accept_admin_id', $this->getUserId()); } }); })->orderBy($all['sort_name'] ?? 'id', $all['sort_type'] ?? 'desc') ->paginate($all['page_size'] ?? 20); return $this->success($list); } /** * @OA\Get( * path="/api/admin/visit_audit/show", * tags={"拜访审核"}, * summary="详情", * description="", * @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"), * @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"), * @OA\Response( * response="200", * description="暂无" * ) * ) */ public function show() { $all = \request()->all(); $messages = [ 'id.required' => 'Id必填', ]; $validator = Validator::make($all, [ 'id' => 'required' ], $messages); if ($validator->fails()) { return $this->fail([ResponseCode::ERROR_PARAMETER, implode(',', $validator->errors()->all())]); } $detail = VisitAudit::find($all['id']); return $this->success($detail); } /** * @OA\Post( * path="/api/admin/visit_audit/save", * tags={"拜访审核"}, * summary="更新", * description="", * @OA\Parameter(name="id", in="query", @OA\Schema(type="int"), required=true, description="Id(存在更新,不存在新增)"), * @OA\Parameter(name="admin_id", in="query", @OA\Schema(type="string"), required=false, description="不用填"), * @OA\Parameter(name="department_id", in="query", @OA\Schema(type="string"), required=false, description="不用填"), * @OA\Parameter(name="visit_id", in="query", @OA\Schema(type="string"), required=true, description="参观id"), * @OA\Parameter(name="audit_admin_id", in="query", @OA\Schema(type="string"), required=true, description="审核人员id"), * @OA\Parameter(name="status", in="query", @OA\Schema(type="string"), required=false, description="状态0待审核1通过2驳回"), * @OA\Parameter(name="reason", in="query", @OA\Schema(type="string"), required=false, description="原因"), * @OA\Parameter(name="level", in="query", @OA\Schema(type="string"), required=false, description="审核次序"), * @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"), * @OA\Response( * response="200", * description="暂无" * ) * ) */ public function save() { $all = \request()->all(); $messages = [ 'visit_id.required' => '参观id必填' ]; $validator = Validator::make($all, [ 'visit_id' => 'required' ], $messages); if ($validator->fails()) { return $this->fail([ResponseCode::ERROR_PARAMETER, implode(',', $validator->errors()->all())]); } DB::beginTransaction(); try { if (isset($all['id'])) { $model = VisitAudit::find($all['id']); } else { $model = new VisitAudit(); $all['admin_id'] = $this->getUserId(); $all['department_id'] = $this->getUser()->department_id; } $model->fill($all); $model->save(); // 如果全部审核通过则拜访通过 $waitCount = VisitAudit::where('visit_id', $all['visit_id'])->whereIn('status', [0])->count(); $noPassCount = VisitAudit::where('visit_id', $all['visit_id'])->whereIn('status', [2])->count(); if ($noPassCount || (empty($noPassCount) && empty($waitCount))) { $auditResult = ''; if ($noPassCount) { // 不通过 $auditResult = '驳回'; // 修改状态 Visit::where('id', $all['visit_id'])->update(['audit_status' => 2]); } if (empty($noPassCount) && empty($waitCount)) { // 通过 $auditResult = '通过'; Visit::where('id', $all['visit_id'])->update(['audit_status' => 2]); } // 发通知 $visit = Visit::find($all['visit_id']); $user = User::find($visit->user_id); $visitTime = VisitTime::find($visit->visit_time_id); $acceptAdmin = Admin::find($visit->accept_admin_id); $templateData = [ 'date1' => [ 'value' => $visit->date . '-' . $visitTime->start_time . '-' . $visitTime->end_time ], 'name3' => [ 'value' => $acceptAdmin->name, ], 'thing4' => [ 'value' => $visit->name ], 'thing13' => [ 'value' => $auditResult, ], 'thing9' => [ 'value' => $visit->company_name ], ]; Visit::subMsg('IczaKkCmwf55tAAzCcxb_fbbf5L25SWrSKvaBrkIyk4', $user->openid, $templateData); } // 审核记录 $auditAdmin = Admin::find($model->audit_admin_id); VisitLog::add($this->getUser(), '', $all['visit_id'], $auditAdmin->name . '审核' . $all['status'] == 1 ? '通过' : '驳回'); DB::commit(); return $this->success('更新成功'); } catch (\Exception $exception) { DB::rollBack(); return $this->fail([$exception->getCode(), $exception->getMessage()]); } } /** * @OA\Get( * path="/api/admin/visit_audit/destroy", * tags={"拜访审核"}, * summary="删除", * description="", * @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"), * @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"), * @OA\Response( * response="200", * description="暂无" * ) * ) */ public function destroy() { $all = \request()->all(); $messages = [ 'id.required' => 'Id必填', ]; $validator = Validator::make($all, [ 'id' => 'required' ], $messages); if ($validator->fails()) { return $this->fail([ResponseCode::ERROR_PARAMETER, implode(',', $validator->errors()->all())]); } VisitAudit::where('id', $all['id'])->delete(); return $this->success('删除成功'); } }