You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

98 lines
3.1 KiB

  1. <?php
  2. namespace App\Service;
  3. use App\Model\ServiceEvaluate;
  4. use App\Model\Users;
  5. use Hyperf\DbConnection\Db;
  6. use Hyperf\HttpServer\Contract\RequestInterface;
  7. use Hyperf\Di\Annotation\Inject;
  8. use Hyperf\Paginator\Paginator;
  9. class ServiceEvaluateService implements ServiceEvaluateServiceInterface
  10. {
  11. public function evaluate($data)
  12. {
  13. // 当前用户是否今日新注册并第一次提交评论
  14. $data['user_created_at'] = Users::where(['id' => $data['user_id']])->value('join_time');
  15. $evaluateExist = ServiceEvaluate::where(['user_id' => $data['user_id']])->exists();
  16. $data['is_new_user'] = 0;
  17. if (
  18. !$evaluateExist
  19. && $data['user_created_at']>=strtotime(date('Y-m-d 00:00:00'))
  20. && $data['user_created_at']<=strtotime(date('Y-m-d 23:59:59'))
  21. ) {
  22. $data['is_new_user'] = 1;
  23. }
  24. // 计算评分平均分
  25. $score = $data['c_attitude'] + $data['c_service'] + $data['c_quality'];
  26. $data['c_average'] = round($score/3, 1);
  27. return ServiceEvaluate::create($data);
  28. }
  29. public function isPersonnel($user_id)
  30. {
  31. $res = Db::table('lanzu_service_personnel')
  32. ->where([
  33. ['user_id','=',$user_id],
  34. ['status','=',1]
  35. ])
  36. ->select('id')
  37. ->first();
  38. return $res;
  39. }
  40. public function getPersonnelInfo($service_personnel_id)
  41. {
  42. $res = Db::table('lanzu_service_personnel')
  43. ->where([
  44. ['id','=',$service_personnel_id],
  45. ['status','=',1]
  46. ])
  47. ->first();
  48. //如果存在服务专员则计算评价平均分
  49. if(!empty($res)) {
  50. $personnel_average = Db::table('lanzu_service_evaluate')->where(['service_personnel_id' => $service_personnel_id])->avg('c_average');
  51. $res->personnel_average = sprintf("%.1f", $personnel_average);
  52. }
  53. return $res;
  54. }
  55. public function getEvaluateList($service_personnel_id)
  56. {
  57. //查询评论列表 按照创建时间降序排序
  58. $res = Db::table('lanzu_service_evaluate as e')
  59. ->join('ims_cjdc_user as u','u.id','=','e.user_id')
  60. ->where(['e.service_personnel_id'=>$service_personnel_id])
  61. ->select('e.*','u.name','u.img')
  62. ->orderBy('created_at','desc')
  63. ->paginate(4);
  64. return $res;
  65. }
  66. public function getQuickEvaluate()
  67. {
  68. $data = (object)null;
  69. //获取快速评论标题
  70. $obj1 = (object)null;
  71. $obj1->title1 = '服务态度超好';
  72. $obj1->title2 = '服务态度一般般';
  73. $data->quick_evaluate_title = $obj1;
  74. //获取快速评论内容
  75. $obj2 = (object)null;
  76. $obj2->content1 = '超级细心';
  77. $obj2->content2 = '马马虎虎';
  78. $data->quick_evaluate_content = $obj2;
  79. //获取评论长度限制参数
  80. $obj3 = (object)null;
  81. $obj3->min_length = 15;
  82. $obj3->max_length = 150;
  83. $data->length = $obj3;
  84. return $data;
  85. }
  86. }