Order.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. namespace app\api\controller\company;
  3. use app\common\controller\Apic;
  4. use app\common\service\SmsService;
  5. use app\common\service\UserService;
  6. use think\Db;
  7. use alipaysdkphpallmaster\aop\AopClient;
  8. use alipaysdkphpallmaster\aop\request\AlipayTradePayRequest;
  9. use think\Log;
  10. /**
  11. * 订单管理
  12. */
  13. class Order extends Apic
  14. {
  15. protected $noNeedLogin = [];
  16. protected $noNeedRight = '*';
  17. private function status_text($status){
  18. $arr = [
  19. 1 => '待支付',
  20. 2 => '待处理',
  21. 3 => '已完成',
  22. 4 => '已取消',
  23. ];
  24. return isset($arr[$status]) ? $arr[$status] : '';
  25. }
  26. //
  27. public function lists(){
  28. $keyword = input('keyword','');
  29. $starttime = input('starttime',0);
  30. $endtime = input('endtime',0);
  31. $servicetype_id = intval(input('servicetype_id',0));
  32. $status = intval(input('status',0));
  33. $o = 'order';
  34. $p = 'package';
  35. $order = $o.'.id desc';
  36. $where = [
  37. $o.'.company_id' => $this->auth->company_id,
  38. ];
  39. //员工
  40. if($this->auth->type == 2){
  41. $where[$o.'.staff_id'] = $this->auth->id;
  42. }//员工
  43. if($starttime || $endtime){
  44. $where[$o.'.createtime'] = ['between',$starttime,$endtime];
  45. }
  46. if($servicetype_id){
  47. $where[$o.'.servicetype_id'] = $servicetype_id;
  48. }
  49. if($status){
  50. $where[$o.'.status'] = $status; //状态:2=待处理,3=已核销(完成),4=已取消
  51. if($status > 2){
  52. $order = $o.'.finish_time desc';
  53. }
  54. }
  55. if(!empty($keyword))
  56. {
  57. $where['user_car_number|user_mobile'] = ['LIKE','%'.$keyword.'%'];
  58. }
  59. $list = Db::name('order')->alias($o)
  60. ->join('servicetype',$o.'.servicetype_id = servicetype.id','LEFT')
  61. ->join($p,$p.'.id = '.$o.'.package_id','LEFT')
  62. ->field($o.'.id,orderno,ordertype,user_name,user_mobile,user_car_number,'.
  63. $o.'.createtime,'.$o.'.servicetype_id,server_info,server_time,'.$o.'.status,finish_time,cancel_reason,hexiao_time,cancel_time,servicetype.title as servicetype_title,servicetype.baoyang_switch,'.$p.'.title as `package_title`')->where($where)->order($order)->autopage()->select();
  64. foreach($list as $key => &$val){
  65. $val['status_text'] = $this->status_text($val['status']);
  66. $val['server_info'] = $val['package_title'];
  67. }
  68. $this->success(1,$list);
  69. }
  70. //详情
  71. public function info(){
  72. $id = input('id',0);
  73. $o = 'order';
  74. $p = 'package';
  75. $info = Db::name('order')->alias($o)
  76. ->join('servicetype',$o.'.servicetype_id = servicetype.id','LEFT')
  77. ->join($p,$p.'.id = '.$o.'.package_id','LEFT')
  78. ->field($o.'.*,servicetype.title as servicetype_title,servicetype.baoyang_switch,'.$p.'.title as package_title')
  79. ->where($o.'.id',$id)->find();
  80. $info = info_domain_image($info,['server_images']);
  81. $info['status_text'] = $this->status_text($info['status']);
  82. $info['total_fee'] = bcadd($info['pay_fee'],$info['appen_fee'],2);
  83. $info['server_info'] = $info['package_title'];
  84. $info['appen_list'] = Db::name('order_appen')->where('order_id',$id)->select();
  85. $this->success(1,$info);
  86. }
  87. //取消
  88. public function cancel(){
  89. $id = input('id',0);
  90. $reason = input('reason','');
  91. $info = Db::name('order')->where('id',$id)->where('company_id',$this->auth->company_id)->find();
  92. if($info['status'] == 4){
  93. $this->error('当前订单已经取消');
  94. }
  95. if($info['status'] != 2){
  96. $this->error('当前订单状态不能取消');
  97. }
  98. if($info['ordertype'] == 3){
  99. $this->error('套餐订单不能取消');
  100. }
  101. $time = time();
  102. //同步到预约单,这一步不该有
  103. if (!empty($info['pre_order_id'])) {
  104. $preOrderWhere['id'] = $info['pre_order_id'];
  105. $preOrder = Db::name('pre_order')->where($preOrderWhere)->find();
  106. if (!empty($preOrder) && $preOrder['pre_order_status'] != 0) {
  107. $preOrderData = ['pre_order_status'=>0,'cancel_time'=>$time,'cancel_reason'=>$reason];
  108. $preOrderRes = Db::name('pre_order')->where($preOrderWhere)->update($preOrderData);
  109. if (!$preOrderRes) {
  110. $this->error('预约单取消失败');
  111. }
  112. }
  113. }
  114. //取消
  115. $rs = Db::name('order')->where('id',$id)->update(['status'=>4,'cancel_time'=>time(),'finish_time'=>time(),'cancel_reason'=>$reason]);
  116. if($rs === false){
  117. $this->error('取消失败');
  118. }
  119. //订单取消发送消息
  120. $userService = new UserService();
  121. $params['order_id'] = $id;
  122. $userService->msgOrder($params);
  123. $this->success('取消成功');
  124. }
  125. //完成
  126. public function finish(){
  127. $id = input('id',0);
  128. Db::startTrans();
  129. $info = Db::name('order')->where('id',$id)->where('company_id',$this->auth->company_id)->lock(true)->find();
  130. if($info['status'] != 2){
  131. Db::rollback();
  132. $this->error('当前订单不能完成');
  133. }
  134. //完成
  135. $time = time();
  136. $updateData = ['status'=>3,'finish_time'=>time()];
  137. $rs = Db::name('order')->where('id',$id)->update($updateData);
  138. if($rs === false){
  139. Db::rollback();
  140. $this->error('操作失败');
  141. }
  142. //给门店加钱
  143. if($info['ordertype'] == 3 && $info['paytype'] == 3 && $info['pay_fee'] > 0){
  144. $wallet_rs = model('walletcompany')->lockChangeAccountRemain($this->auth->company_id,'money',$info['pay_fee'],203,$remark='套餐订单完成服务','order',$id);
  145. if($wallet_rs['status'] === false){
  146. Db::rollback();
  147. $this->error($wallet_rs['msg']);
  148. }
  149. }
  150. Db::commit();
  151. //订单取消发送消息
  152. $userService = new UserService();
  153. $params['order_id'] = $id;
  154. $userService->msgOrder($params);
  155. //是否弹出保养
  156. $baoyang_switch = Db::name('servicetype')->where('id',$info['servicetype_id'])->value('baoyang_switch');
  157. $this->success('操作成功',$baoyang_switch);
  158. }
  159. //设置保养时间提醒
  160. public function baoyang(){
  161. $id = input('id',0);
  162. $info = Db::name('order')->where('id',$id)->where('company_id',$this->auth->company_id)->find();
  163. if(!$info){
  164. $this->error('不存在的订单');
  165. }
  166. //更新
  167. $next_date = input('next_date','');
  168. $next_carlicheng = input('next_carlicheng','');
  169. $data = [
  170. 'next_date' => $next_date,
  171. 'next_carlicheng' => $next_carlicheng,
  172. ];
  173. Db::name('order')->where('id',$id)->update($data);
  174. //记录保养时间(后续提醒客户保养)
  175. $smsService = new SmsService();
  176. $nextDate = !empty($next_date) ? strtotime($next_date) : 0;
  177. $params = [
  178. 'order_id' => $info['id'],
  179. 'company_id' => $info['company_id'],
  180. 'user_id' => $info['user_id'],
  181. 'car_id' => $info['user_car_id'],
  182. 'car_number' => $info['user_car_number'],
  183. 'upkeep_time' => $nextDate,
  184. ];
  185. $orderRes = $smsService->carRemindSave($params);
  186. if (!$orderRes['status']) {
  187. Log::error('记录保养短信提醒失败:params:'.json_encode($params));
  188. }
  189. $this->success('操作成功');
  190. }
  191. //追加列表
  192. public function appen_lists(){
  193. $id = input('id',0);
  194. $info = Db::name('order')->field('id,orderno,pay_fee,appen_fee')->where('id',$id)->where('company_id',$this->auth->company_id)->find();
  195. if(!$info){
  196. $this->error('不存在的订单');
  197. }
  198. $info['appen_list'] = Db::name('order_appen')->where('order_id',$id)->select();
  199. $this->success(1,$info);
  200. }
  201. //追加新费用
  202. public function appen_newone(){
  203. $id = input('id',0);
  204. Db::startTrans();
  205. $info = Db::name('order')->field('id,orderno,pay_fee,appen_fee')->where('id',$id)->where('company_id',$this->auth->company_id)->lock(true)->find();
  206. if(!$info){
  207. $this->error('不存在的订单');
  208. }
  209. //加入新的一条
  210. $name = input('name','');
  211. $price = intval(input('price',0));
  212. if($price <= 0){
  213. Db::rollback();
  214. $this->error('请填写正确的金额');
  215. }
  216. $data = [
  217. 'company_id' => $this->auth->company_id,
  218. 'order_id' => $id,
  219. 'name' => $name,
  220. 'price' => $price,
  221. 'createtime' => time(),
  222. ];
  223. $log_id = Db::name('order_appen')->insertGetId($data);
  224. if(!$log_id){
  225. Db::rollback();
  226. $this->error('操作失败');
  227. }
  228. //计算追加总额做冗余
  229. $sum_price = Db::name('order_appen')->where('order_id',$id)->sum('price');
  230. $update = [
  231. 'appen_fee'=>$sum_price,
  232. 'total_fee'=>bcadd($sum_price,$info['pay_fee'],2),
  233. ];
  234. $rs = Db::name('order')->where('id',$id)->update($update);
  235. if($rs === false){
  236. Db::rollback();
  237. $this->error('操作失败');
  238. }
  239. //结束
  240. Db::commit();
  241. $this->success();
  242. }
  243. }