AddServiceWorkJob.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?php
  2. namespace app\job;
  3. use think\facade\Db;
  4. use think\queue\Job;
  5. use think\facade\Log;
  6. use app\common\enum\WorkEnum;
  7. use app\common\model\equity\UserEquity;
  8. use app\common\model\works\ServiceWork;
  9. use app\common\model\recharge\OrderGoods;
  10. use app\common\model\equity\UserEquityLog;
  11. use app\common\model\orders\RechargeOrder;
  12. use app\common\model\group_activity\GroupOrder;
  13. use app\common\model\group_activity\GroupUserOrder;
  14. class AddServiceWorkJob
  15. {
  16. public function fire(Job $job, $data)
  17. {
  18. $group_order_id = $data['id'];//拼团订单ID
  19. $goods = [];
  20. $category = GroupOrder::alias('a')
  21. ->leftJoin('group_activity_category b','a.group_category_id=b.id')
  22. ->where('a.id', $group_order_id)
  23. ->field('b.service_time,b.master_worker_id')
  24. ->findOrEmpty()
  25. ->toArray();
  26. try {
  27. //查询拼团用户订单
  28. $userOrder = GroupUserOrder::alias('a')
  29. ->leftJoin('user b','a.user_id=b.id')
  30. ->where('group_order_id', $group_order_id)
  31. ->where('pay_status', 1)
  32. ->where('refund_status', 0)
  33. ->field('a.*,b.mobile')
  34. ->select()
  35. ->toArray();
  36. if (empty($userOrder)) {
  37. return true;
  38. }
  39. Db::startTrans();
  40. foreach ($userOrder as $k => $item) {
  41. if (empty($goods)) {
  42. $goods = UserEquity::alias('a')->leftJoin('goods b','a.goods_id=b.id')
  43. ->where('a.id', $item['user_equity_id'])
  44. ->field('a.number,a.goods_id,b.*')
  45. ->findOrEmpty()
  46. ->toArray();
  47. }
  48. //生成服务工单
  49. $work_data = [
  50. 'work_sn' => generate_sn(ServiceWork::class, 'work_sn'),
  51. 'real_name' => '',
  52. 'mobile' => $item['mobile'],
  53. 'address' => $item['area'].$item['address'],
  54. 'province' => 0,
  55. 'city' => 0,
  56. 'area_name' => '',
  57. 'title' => $goods['goods_name'],
  58. 'category_type' => $goods['category_type'],
  59. 'goods_category_ids' => $goods['goods_category_ids'],
  60. 'goods_category_id' => $goods['goods_category_id'],
  61. 'base_service_fee' => $goods['base_service_fee'],
  62. 'service_fee' => $item['paid_amount'],
  63. 'work_pay_status'=>WorkEnum::IS_PAY_STATUS,
  64. 'master_worker_id' => $category['master_worker_id'],
  65. 'appointment_time' => $category['service_time'],
  66. 'dispatch_time' => time(),
  67. 'receive_time' => time(),
  68. 'user_id'=>$item['user_id'],
  69. 'lon'=>'',
  70. 'lat'=>'',
  71. 'property_activity_id'=>0,
  72. 'user_equity_id'=>0,
  73. 'third_type'=>1,
  74. 'work_total'=>$item['paid_amount'],
  75. 'work_status' => 5,
  76. 'user_confirm_status' => 3,
  77. 'service_status' => 1,
  78. 'remark' => '拼团单:'.$item['id'],
  79. 'user_equity_id' => $item['user_equity_id'],
  80. 'group_order_id' => $item['id'],
  81. 'third_type' => 0,
  82. ];
  83. $service_work = ServiceWork::create($work_data);
  84. //生成客户订单
  85. $data = [
  86. 'work_id'=> $service_work['id'],
  87. 'sn' => generate_sn(RechargeOrder::class, 'sn'),
  88. 'order_type'=>0,//服务订单
  89. 'order_terminal' => $item['order_terminal'],
  90. 'user_id' => $item['user_id'],
  91. 'pay_status' => $item['pay_status'],
  92. 'pay_way' => $item['pay_way'],
  93. 'pay_time' => time(),
  94. 'order_total' => 0,
  95. 'order_amount' => 0,
  96. ];
  97. $order = RechargeOrder::create($data);
  98. //生成订单服务详情
  99. OrderGoods::create([
  100. 'sn' => $order['sn'],
  101. 'goods_id' => $goods['goods_id'],
  102. 'category_type' => $goods['category_type'],
  103. 'goods_category_ids' => $goods['goods_category_ids'],
  104. 'goods_category_id' => $goods['goods_category_id'],
  105. 'goods_name' => $goods['goods_name'],
  106. 'goods_image' => $goods['goods_image'],
  107. 'goods_video' => $goods['goods_video'],
  108. 'goods_number' => $goods['goods_number'],
  109. 'good_unit' => $goods['good_unit'],
  110. 'goods_size' => $goods['goods_size'],
  111. 'goods_type' => $goods['goods_type'],
  112. 'goods_brand' => $goods['goods_brand'],
  113. 'install_guide' => $goods['install_guide'],
  114. 'goods_payment_type'=>$goods['goods_payment_type'],
  115. 'base_service_fee' => $goods['base_service_fee'],
  116. 'service_total' => $goods['service_total'],
  117. 'service_fee' => $goods['service_fee'],
  118. 'service_image' => $goods['service_image'],
  119. 'warranty_period'=>$goods['warranty_period'],
  120. 'fee_schedule' => $goods['fee_schedule'],
  121. 'goods_status' => $goods['goods_status'],
  122. ]);
  123. //更新用户的权益卡剩余次数
  124. UserEquity::where('id', $item['user_equity_id'])->update(['number' => 0, 'update_time' => time()]);
  125. //记录用户的权益卡使用记录
  126. UserEquityLog::create([
  127. 'user_id' => $item['user_id'],
  128. 'number' => $goods['number'],
  129. 'user_equity_id' => $item['user_equity_id'],
  130. 'create_time' => time(),
  131. ]);
  132. }
  133. GroupOrder::where('id', $group_order_id)->update(['work_status' => 2]);
  134. Db::commit();
  135. // 任务执行完毕后删除任务
  136. $job->delete();
  137. return true;
  138. } catch (\Exception $e) {
  139. Db::rollback();
  140. Log::write("拼团订单批量生成服务工单异常:".$e->getMessage());
  141. // 任务执行失败,重试任务
  142. if ($job->attempts() > 3) {
  143. // 超过最大重试次数,删除任务
  144. $job->delete();
  145. } else {
  146. $job->release(10); // 10 秒后重试
  147. }
  148. return false;
  149. }
  150. }
  151. }