ReturnWorkLogic.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. namespace app\api\logic;
  3. use app\common\enum\worker\WorkerAccountLogEnum;
  4. use app\common\logic\BaseLogic;
  5. use app\common\logic\WorkerAccountLogLogic;
  6. use app\common\model\master_worker\MasterWorker;
  7. use app\common\model\master_worker\MasterWorkerAccountLog;
  8. use app\common\model\master_worker\MasterWorkerRetentionMoneyLog;
  9. use app\common\model\works\IssueWork;
  10. use app\common\model\works\ReturnWork;
  11. use app\common\model\works\ServiceWork;
  12. use think\db\Query;
  13. use think\facade\Db;
  14. /**
  15. * @author 林海涛
  16. * @date 2024/7/29 下午4:26
  17. */
  18. class ReturnWorkLogic extends BaseLogic
  19. {
  20. public static function lists($params)
  21. {
  22. return ReturnWork::with(['serviceWork'=>function(Query $query){
  23. $query->field('id,address,title');
  24. }])
  25. ->where('user_id',$params['user_id'])
  26. ->field(['id', 'work_sn','service_work_id','return_work_status','dispatch_time','create_time','appointment_time'])
  27. ->append(['return_work_status_text'])
  28. ->order(['id' => 'desc'])
  29. ->select()
  30. ->toArray();
  31. }
  32. public static function detail($params)
  33. {
  34. $issue_work = ReturnWork::with(['serviceWork'=>function(Query $query){
  35. $query->field('id,address,title,real_name,mobile');
  36. },'worker'=>function(Query $query){
  37. $query->field('id,avatar,real_name,worker_number,mobile');
  38. }])
  39. ->where(['id'=>$params['id'],'user_id'=>$params['user_id']])
  40. ->where(['id'=>$params['id']])
  41. ->field('id,work_sn,service_work_id,return_work_status,dispatch_time,master_worker_id,create_time,appointment_time')
  42. ->append(['return_work_status_text'])
  43. ->findOrEmpty()->toArray();
  44. return $issue_work;
  45. }
  46. public static function confirmFinish($params):bool
  47. {
  48. Db::startTrans();
  49. try{
  50. $work = ReturnWork::where('work_sn',$params['work_sn'])->findOrEmpty();
  51. if($work->isEmpty()){
  52. throw new \Exception('返修工单不存在');
  53. }
  54. if($work->user_id != $params['user_id']){
  55. throw new \Exception('用户不正确');
  56. }
  57. if($work->return_work_status != 3){
  58. throw new \Exception('等待工程师确认服务完成');
  59. }
  60. $work->return_work_status = 4;
  61. $work->save();
  62. MasterWorker::setWorktotal('inc',$work->master_worker_id);
  63. //更新投诉状态
  64. $issue = IssueWork::where('service_work_id',$work->service_work_id)->findOrEmpty();
  65. if(!$issue->isEmpty()){
  66. // 返修完成-工程师的账号余额、质保金可用金额 对应原工单 增加
  67. if($issue->is_refunded_payment == 1 && $issue->issue_approval != 4){
  68. $serviceWork = ServiceWork::where('id',$work->service_work_id)->findOrEmpty();
  69. if(!$serviceWork->isEmpty()){
  70. // 加余额
  71. $change_amount = MasterWorkerAccountLog::where([
  72. 'change_object'=>WorkerAccountLogEnum::UM,'change_type'=>WorkerAccountLogEnum::UM_INC_ADMIN,
  73. 'action'=>WorkerAccountLogEnum::INC,'worker_id'=>$issue->master_worker_id,
  74. 'work_sn'=>$issue->work_sn])->value('change_amount');
  75. // 加质保金
  76. $retentionAmount = MasterWorkerRetentionMoneyLog::where(['action'=>WorkerAccountLogEnum::INC,
  77. 'worker_id'=>$issue->master_worker_id,'work_id'=>$issue->service_work_id])
  78. ->value('amount');
  79. $settlement_amount = $change_amount + $retentionAmount;
  80. // 返修单-新工程师 缴纳质保金 $work->id $work->master_worker_id
  81. $masterWorkerInfo = MasterWorker::where('id', $work->master_worker_id)->findOrEmpty()->toArray();
  82. if(!empty($masterWorkerInfo) && $masterWorkerInfo['retention_pay_status'] == 2 && ($masterWorkerInfo['earnest_money'] > $masterWorkerInfo['earnest_money_usable'])){
  83. $retentionData['action'] = WorkerAccountLogEnum::INC;
  84. $retentionData['worker_id'] = $work->master_worker_id;
  85. $retentionData['work_id'] = $issue->service_work_id;
  86. $retentionData['return_work_id'] = $work->id;
  87. $amount = bcmul($settlement_amount, bcdiv($masterWorkerInfo['installment_ratio'], 100, 4),2);
  88. $retentionData['amount'] = $amount;
  89. $retentionData['remark'] = "返修单-分期缴纳质保金:该单实提成--{$settlement_amount},分期每单缴纳比例--{$masterWorkerInfo['installment_ratio']}%,缴纳金额--{$amount}";
  90. $settlement_amount -= (float)$amount;
  91. $surplusMoney = RetentionMoneyLogic::add($retentionData);
  92. if($surplusMoney === false){
  93. Log::info('返修单-分期缴纳质保金支付失败-'.RetentionMoneyLogic::getError(),$retentionData);
  94. $settlement_amount += (float)$amount;
  95. }else{
  96. $settlement_amount += (float)$surplusMoney;
  97. }
  98. }
  99. $extra['ReturnWorkInfo'] = ['id'=>$work->id,'master_worker_id'=>$work->master_worker_id,'service_work_id'=>$work->service_work_id,'issue_work_id'=>$work->issue_work_id];
  100. $remark = '工单号:'.$issue->work_sn.',返修单号:'.$work->work_sn.',收益金额:'.$settlement_amount.',原因:返修工单新工程师收益';
  101. WorkerAccountLogLogic::addAccountLog($serviceWork,$settlement_amount,WorkerAccountLogEnum::UM_INC_ADMIN,WorkerAccountLogEnum::INC,$remark,$extra);
  102. }
  103. }
  104. $issue->issue_approval = 4;
  105. $issue->complaint_status = 2;
  106. $issue->responsible = 2;
  107. $issue->finished_time = time();
  108. $issue->save();
  109. }
  110. Db::commit();
  111. return true;
  112. }catch(\Exception $e){
  113. Db::rollback();
  114. self::setError($e->getMessage());
  115. return false;
  116. }
  117. }
  118. }