UserCar.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <?php
  2. namespace app\api\controller;
  3. use AlibabaCloud\SDK\Dingtalk\Vyida_1_0\Models\GetFormDataByIDResponseBody\originator\name;
  4. use app\common\model\CarApprove;
  5. use app\common\model\CarFlow;
  6. use app\common\model\CarInfo;
  7. use think\Db;
  8. /**
  9. * @title 用车管理
  10. * @controller UserCar
  11. * @group base
  12. */
  13. class UserCar extends Base
  14. {
  15. public function initialize()
  16. {
  17. parent::initialize();
  18. parent::checkLogin();
  19. }
  20. /**
  21. * @title 获取审批流程
  22. * @desc 获取审批流程
  23. * @author qc
  24. * @url /api/User_car/getApproveFlow
  25. * @method GET
  26. * @tag 个人信息
  27. * @header name:Authorization require:1 desc:Token
  28. * @return name:user_name type:string default:-- desc:会员名称
  29. * @return name:headimg type:string default:-- desc:会员头像
  30. */
  31. public function getApproveFlow()
  32. {
  33. $check_flow = CarFlow::where('user_id',$this->user_id)->where('type',1)->find();
  34. $where = [];
  35. $where[] = ['l.type','=',1];
  36. if($check_flow)$where[] = ['l.sort','>',$check_flow->sort];
  37. $list = CarFlow::field('l.user_id,u.name user_name,u.headimg')
  38. ->alias('l')
  39. ->where($where)
  40. ->order('l.sort asc')
  41. ->leftJoin('StoreMember u','u.id = l.user_id')
  42. ->select()->toArray();
  43. $this->success('ok',['list'=>$list]);
  44. }
  45. /**
  46. * @title 获取抄送人流程
  47. * @desc 获取抄送人流程
  48. * @author qc
  49. * @url /api/User_car/getCopyFlow
  50. * @method GET
  51. * @tag 个人信息
  52. * @header name:Authorization require:1 desc:Token
  53. * @return name:user_name type:string default:-- desc:会员名称
  54. * @return name:headimg type:string default:-- desc:会员头像
  55. */
  56. public function getCopyFlow()
  57. {
  58. $check_flow = CarFlow::where('user_id',$this->user_id)->where('type',2)->find();
  59. $where = [];
  60. $where[] = ['l.type','=',2];
  61. if($check_flow)$where[] = ['l.sort','>',$check_flow->sort];
  62. $list = CarFlow::field('l.user_id,u.name user_name,u.headimg')
  63. ->alias('l')
  64. ->where($where)
  65. ->order('l.sort asc')
  66. ->leftJoin('StoreMember u','u.id = l.user_id')
  67. ->select()->toArray();
  68. $this->success('ok',['list'=>$list]);
  69. }
  70. /**
  71. * @title 用车用车
  72. * @desc 用车用车
  73. * @author qc
  74. * @url /api/User_car/applyCar
  75. * @method GET
  76. * @tag 个人信息
  77. * @header name:Authorization require:1 desc:Token
  78. * @param name:departure type:string default:-- desc:出发地址
  79. * @param name:start_time type:string default:-- desc:出发时间
  80. * @param name:arrive type:string default:-- desc:到达地址
  81. * @param name:end_time type:string default:-- desc:返回时间
  82. * @param name:back_address type:string default:-- desc:返回地址
  83. */
  84. public function applyCar()
  85. {
  86. $departure = input('post.departure');
  87. $start_time = input('post.start_time');
  88. $arrive = input('post.arrive');
  89. $end_time = input('post.end_time');
  90. $back_address = input('post.back_address');
  91. $request_param = input('post.');
  92. $request_param['user_id'] = $this->user_id;
  93. $request_param['apply_user'] = $this->user_id;
  94. $flow = CarFlow::getApproveUser();// 用车审批流程设置
  95. $flow_user = array_column($flow,'user_id');
  96. $flow_key = array_search($request_param['user_id'],$flow_user);// 请用车是否在审批流程人员中
  97. $copy = CarFlow::getCopyTo();
  98. $copy_user = array_column($copy,'user_id');
  99. $copy_key = array_search($request_param['user_id'],$copy_user);// 用车人是否在抄送人员中
  100. $flow_info = CarInfo::create($request_param);//生成用车记录
  101. $flow_data = [];// 审批流程
  102. $flow_num = 0;
  103. foreach ($flow as $fk=>$fv) {
  104. if($flow_key !== false && $flow_key >= $fk) continue;
  105. $flow_num++;
  106. $flow_data[] = [
  107. 'car_id' => $flow_info->id,
  108. 'approve_user' => $fv['user_id'],
  109. 'flow' =>$flow_num,
  110. 'create_at'=>date('Y-m-d H:i:s'),
  111. 'start_time'=> $flow_num == 1 ? date('Y-m-d H:i:s'):null,
  112. 'status'=> $flow_num == 1 ? 1 : 0,
  113. ];
  114. }
  115. foreach ($copy as $ck=>$cv) {
  116. if($copy_key !== false && $copy_key >= $ck) continue;
  117. $flow_data[] = [
  118. 'car_id' => $flow_info->id,
  119. 'approve_user' => $cv['user_id'],
  120. 'approve_type' =>2
  121. ];
  122. }
  123. if(!empty($flow_data)) {
  124. CarInfo::where('id',$flow_info->id)->update(['approve_num'=>$flow_num]);
  125. (new CarApprove())->saveAll($flow_data);
  126. }else{
  127. CarInfo::where('id',$flow_info->id)->update(['status'=>2]);
  128. }
  129. $this->success('用车申请已提交,请等待审核',['detail'=>$flow_info->toArray()]);
  130. }
  131. /**
  132. * @title 我的申请用车记录【列表】
  133. * @desc 我的申请用车记录
  134. * @author qc
  135. * @url /api/User_car/getApplyList
  136. * @method GET
  137. * @tag 个人信息
  138. * @header name:Authorization require:1 desc:Token
  139. * @param name:page type:int default:-- desc:页数
  140. * @param name:page_num type:int default:-- desc:每页数量
  141. * @param name:status type:int default:0 desc:审批状态0全部,1审批中,2审批通过,3审批拒绝,9取消
  142. * @param name:sel_time type:string default:0 desc:时间查询
  143. * @return name:create_at type:string default:-- desc:提交申请用车时间
  144. * @return name:departure type:string default:-- desc:出发地址
  145. * @return name:start_time type:string default:-- desc:出发时间
  146. * @return name:arrive type:string default:-- desc:到达地址
  147. * @return name:end_time type:string default:-- desc:返回时间
  148. * @return name:back_address type:string default:-- desc:返回地址
  149. * @return name:user_name type:string default:-- desc:会员名称
  150. * @return name:headimg type:string default:-- desc:用车会员头像
  151. */
  152. public function getApplyList()
  153. {
  154. $sel_where[] = ['user_id','=',$this->user_id];
  155. if(input('get.status') > 0) $sel_where[] = ['status','=',input('get.status')];
  156. if(input('get.sel_time')) $sel_where[] = ['create|end_date','=',input('get.sel_time')];
  157. $list = CarInfo::where($sel_where)
  158. ->field('c.id,c.create_at,c.departure,c.start_time,c.arrive,c.end_time,c.back_address,u.name user_name,u.headimg')
  159. ->alias('c')
  160. ->leftJoin('StoreMember u','u.id = c.user_id')
  161. ->limit($this->off_set,$this->page_num)
  162. ->select()->toArray();
  163. $this->success('ok',['list'=>$list]);
  164. }
  165. /**
  166. * @title 用车记录详情
  167. * @desc 用车记录详情
  168. * @author qc
  169. * @url /api/User_car/getApplyDetail
  170. * @method GET
  171. * @tag 个人信息
  172. * @header name:Authorization require:1 desc:Token
  173. * @param name:id type:int default:-- desc:用车记录id
  174. * @return name:create_at type:string default:-- desc:提交申请用车时间
  175. * @return name:departure type:string default:-- desc:出发地址
  176. * @return name:start_time type:string default:-- desc:出发时间
  177. * @return name:arrive type:string default:-- desc:到达地址
  178. * @return name:end_time type:string default:-- desc:返回时间
  179. * @return name:back_address type:string default:-- desc:返回地址
  180. * @return name:approve_list type:array default:-- desc:审批记录
  181. * @return name:approve_list.status type:int default:-- desc:审批状态:0待审批(未到该审批人审批),1审批中(已到该审批人审批,还未审批)2审批通过3审批拒绝
  182. * @return name:approve_list.approve_time type:string default:-- desc:审批时间
  183. * @return name:approve_list.remark type:string default:-- desc:审批备注
  184. * @return name:approve_list.user_name type:string default:-- desc:审批人
  185. * @return name:approve_list.headimg type:string default:-- desc:审批人头像
  186. * @return name:approve_list.time type:string default:-- desc:审批用时(上一次审批完成到本次审批的时间,单位秒)
  187. */
  188. public function getApplyDetail()
  189. {
  190. $id = input('get.id');
  191. $detail = CarInfo::field('c.id,c.create_at,c.departure,c.start_time,c.arrive,c.end_time,c.back_address,u.name user_name,u.headimg')
  192. ->alias('c')->with('approveList')->where(['user_id'=>$this->user_id])->where(['id'=>$id])
  193. ->limit($this->off_set,$this->page_num)
  194. ->find()->toArray();
  195. $this->success('ok',['detail'=>$detail]);
  196. }
  197. }