$data['user_id']])->value('join_time'); $evaluateExist = ServiceEvaluate::where(['user_id' => $data['user_id']])->exists(); $data['is_new_user'] = 0; if ( !$evaluateExist && $data['user_created_at']>=strtotime(date('Y-m-d 00:00:00')) && $data['user_created_at']<=strtotime(date('Y-m-d 23:59:59')) ) { $data['is_new_user'] = 1; } // 计算评分平均分 $score = $data['c_attitude'] + $data['c_service'] + $data['c_quality']; $data['c_average'] = round($score/3, 1); return ServiceEvaluate::create($data); } public function isPersonnel($user_id) { $res = Db::table('lanzu_service_personnel') ->where([ ['user_id','=',$user_id], ]) ->select('id') ->first(); return $res; } public function getPersonnelInfo($service_personnel_id) { $res = Db::table('lanzu_service_personnel') ->where([ ['id','=',$service_personnel_id], ['status','=',1] ]) ->first(); //如果存在服务专员则计算评价平均分 if(!empty($res)) { $personnel_average = Db::table('lanzu_service_evaluate')->where(['service_personnel_id' => $service_personnel_id])->avg('c_average'); $res->personnel_average = sprintf("%.1f", $personnel_average); } return $res; } public function getEvaluateList($data) { //踩坑 paginate 只能接收int型参数 $per_page = isset($data['per_page']) && $data['per_page'] > 0 ? intval($data['per_page']) : 6; //查询评论列表 按照创建时间降序排序 $res = ServiceEvaluate::join('ims_cjdc_user as u','u.id','=','lanzu_service_evaluate.user_id') ->where(['lanzu_service_evaluate.service_personnel_id'=>$data['service_personnel_id']]) ->select('lanzu_service_evaluate.*','u.name','u.img') ->orderBy('lanzu_service_evaluate.created_at','desc') ->paginate($per_page); return $res; } public function getQuickEvaluate() { $data = (object)null; //获取快速评论标题 $obj1 = (object)null; $obj1->title1 = '服务态度超好'; $obj1->title2 = '服务态度一般般'; $data->quick_evaluate_title = $obj1; //获取快速评论内容 $obj2 = (object)null; $obj2->content1 = '超级细心'; $obj2->content2 = '马马虎虎'; $data->quick_evaluate_content = $obj2; //获取评论长度限制参数 $obj3 = (object)null; $obj3->min_length = 15; $obj3->max_length = 150; $data->length = $obj3; return $data; } }