UserLeave.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. <?php
  2. namespace app\api\controller;
  3. use AlibabaCloud\SDK\Dingtalk\Vyida_1_0\Models\GetFormDataByIDResponseBody\originator\name;
  4. use app\common\model\LeaveApprove;
  5. use app\common\model\LeaveFlow;
  6. use app\common\model\LeaveInfo;
  7. use app\common\model\LeaveType;
  8. use app\common\service\ApproveService;
  9. use think\Db;
  10. use app\common\model\User;
  11. /**
  12. * @title 员工请假管理
  13. * @controller UserLeave
  14. * @group base
  15. */
  16. class UserLeave extends Base
  17. {
  18. public function initialize()
  19. {
  20. parent::initialize();
  21. parent::checkLogin();
  22. }
  23. /**
  24. * @title 获取审批流程
  25. * @desc 获取审批流程
  26. * @author qc
  27. * @url /api/User_leave/getApproveFlow
  28. * @method GET
  29. * @tag
  30. * @header name:Authorization require:1 desc:Token
  31. * @return name:user_name type:string default:-- desc:会员名称
  32. * @return name:headimg type:string default:-- desc:会员头像
  33. */
  34. public function getApproveFlow()
  35. {
  36. $check_flow = LeaveFlow::where('user_id',$this->user_id)->where('type',1)->find();
  37. $where = [];
  38. $where[] = ['l.type','=',1];
  39. if($check_flow)$where[] = ['l.sort','>',$check_flow->sort];
  40. $list = LeaveFlow::field('l.user_id,u.name user_name,u.headimg')
  41. ->alias('l')
  42. ->where($where)
  43. ->order('l.sort asc')
  44. ->leftJoin('StoreMember u','u.id = l.user_id')
  45. ->select()->toArray();
  46. $this->success('ok',['list'=>$list]);
  47. }
  48. /**
  49. * @title 获取抄送人流程
  50. * @desc 获取抄送人流程
  51. * @author qc
  52. * @url /api/User_leave/getCopyFlow
  53. * @method GET
  54. * @tag
  55. * @header name:Authorization require:1 desc:Token
  56. * @return name:user_name type:string default:-- desc:会员名称
  57. * @return name:headimg type:string default:-- desc:会员头像
  58. */
  59. public function getCopyFlow()
  60. {
  61. $check_flow = LeaveFlow::where('user_id',$this->user_id)->where('type',2)->find();
  62. $where = [];
  63. $where[] = ['l.type','=',2];
  64. if($check_flow)$where[] = ['l.sort','>',$check_flow->sort];
  65. $list = LeaveFlow::field('l.user_id,u.name user_name,u.headimg')
  66. ->alias('l')
  67. ->where($where)
  68. ->order('l.sort asc')
  69. ->leftJoin('StoreMember u','u.id = l.user_id')
  70. ->select()->toArray();
  71. $this->success('ok',['list'=>$list]);
  72. }
  73. /**
  74. * @title 获取请假类型
  75. * @desc 获取请假类型
  76. * @author qc
  77. * @url /api/User_leave/getLeaveType
  78. * @method GET
  79. * @tag
  80. * @header name:Authorization require:1 desc:Token
  81. * @return name:id type:int default:-- desc:会员id
  82. * @return name:title type:int default:-- desc:类型
  83. */
  84. public function getLeaveType()
  85. {
  86. $field = 'id,title';
  87. $user_info = LeaveType::field($field)->where('status',1)->where('is_deleted',0)->select()->toArray();
  88. $this->success('获取成功',['detail'=>$user_info]);
  89. }
  90. /**
  91. * @title 请假申请
  92. * @desc 请假申请
  93. * @author qc
  94. * @url /api/User_leave/applyVacate
  95. * @method GET
  96. * @tag
  97. * @header name:Authorization require:1 desc:Token
  98. * @param name:type type:int default:-- desc:请假类型id
  99. * @param name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  100. * @param name:start_time type:string default:-- desc:开始时间(上午||下午)
  101. * @param name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  102. * @param name:end_time type:string default:-- desc:结束时间(上午||下午)
  103. * @param name:document type:string default:-- desc:附件(文件路径)
  104. * @param name:images type:string default:-- desc:图片(多张|隔开)
  105. * @param name:content type:string default:-- desc:请假详细内容(是否离深)
  106. * @param name:user_id type:int default:-- desc:请假会员id(自己请假可以不传,代为请假传请假人id)
  107. */
  108. public function applyVacate()
  109. {
  110. $request_param = input('post.');
  111. if(empty($request_param['start_date']) || empty($request_param['end_date'])) $this->error('请选择请假期');
  112. if(empty($request_param['type'])) $this->error('请选择请假类型');
  113. if(empty($request_param['user_id'])) $request_param['user_id'] = $this->user_id;
  114. $request_param['apply_user'] = $this->user_id;// 申请会员id
  115. $flow = LeaveFlow::getApproveUser();// 请假审批流程设置
  116. $flow_user = array_column($flow,'user_id');
  117. $flow_key = array_search($request_param['user_id'],$flow_user);// 请假人是否在审批流程人员中
  118. $copy = LeaveFlow::getCopyTo();
  119. $copy_user = array_column($copy,'user_id');
  120. $copy_key = array_search($request_param['user_id'],$copy_user);// 请假人是否在抄送人员中
  121. $flow_info = LeaveInfo::create($request_param);//生成请假记录
  122. $flow_data = [];// 审批流程
  123. $flow_num = 0;
  124. foreach ($flow as $fk=>$fv) {
  125. if($flow_key !== false && $flow_key >= $fk) continue;
  126. $flow_num++;
  127. $flow_data[] = [
  128. 'leave_id' => $flow_info->id,
  129. 'approve_user' => $fv['user_id'],
  130. 'flow' =>$flow_num,
  131. 'create_at'=>date('Y-m-d H:i:s'),
  132. 'start_time'=> $flow_num == 1 ? date('Y-m-d H:i:s'):null,
  133. 'status'=> $flow_num == 1 ? 1 : 0,
  134. ];
  135. }
  136. foreach ($copy as $ck=>$cv) {
  137. if($copy_key !== false && $copy_key >= $ck) continue;
  138. $flow_data[] = [
  139. 'leave_id' => $flow_info->id,
  140. 'approve_user' => $cv['user_id'],
  141. 'approve_type' =>2
  142. ];
  143. }
  144. if(!empty($flow_data)) {
  145. LeaveInfo::where('id',$flow_info->id)->update(['approve_num'=>$flow_num]);
  146. (new LeaveApprove())->saveAll($flow_data);
  147. }else{
  148. LeaveInfo::where('id',$flow_info->id)->update(['status'=>2]);
  149. }
  150. $this->success('请假已提交,请等待审核',['detail'=>$flow_info->toArray()]);
  151. }
  152. /**
  153. * @title 我的请假记录【列表】
  154. * @desc 我的请假记录
  155. * @author qc
  156. * @url /api/User_leave/getVacateList
  157. * @method GET
  158. * @tag
  159. * @header name:Authorization require:1 desc:Token
  160. * @param name:page type:int default:-- desc:页数
  161. * @param name:page_num type:int default:-- desc:每页数量
  162. * @param name:type type:int default:0 desc:请假类型id
  163. * @param name:status type:int default:0 desc:审批状态0全部,1审批中,2审批通过,3审批拒绝,9取消
  164. * @param name:sel_time type:string default:0 desc:时间查询
  165. * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  166. * @return name:start_time type:string default:-- desc:开始时间(上午||下午)
  167. * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  168. * @return name:end_time type:string default:-- desc:结束时间(上午||下午)
  169. * @return name:reason type:string default:-- desc:请假事由
  170. * @return name:document type:string default:-- desc:附件(文件路径)
  171. * @return name:images type:string default:-- desc:图片(多张|隔开)
  172. * @return name:content type:string default:-- desc:请假详细内容(是否离深)
  173. * @return name:type_name type:string default:-- desc:请假类型
  174. * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消
  175. * @return name:user_id type:int default:-- desc:请假会员id
  176. */
  177. public function getVacateList()
  178. {
  179. $all_type = LeaveType::getAllType();
  180. $type = array_column($all_type,null,'id');
  181. $sel_where = [];
  182. $sel_where[] = ['user_id','=',$this->user_id];
  183. if(input('get.status') > 0) $sel_where[] = ['status','=',input('get.status')];
  184. if(input('get.type') > 0) $sel_where[] = ['type','=',input('get.type')];
  185. if(input('get.sel_time')) $sel_where[] = ['start_date|end_date','=',input('get.sel_time')];
  186. $list = LeaveInfo::where($sel_where)->limit($this->off_set,$this->page_num)->select()->toArray();
  187. array_walk($list,function (&$v,$k)use ($type){
  188. $list['type_name'] = $type[$v['type']]['title'];
  189. });
  190. $this->success('ok',['list'=>$list]);
  191. }
  192. /**
  193. * @title 我的请假详情
  194. * @desc 我的请假详情
  195. * @author qc
  196. * @url /api/User_leave/getVacateList
  197. * @method GET
  198. * @tag
  199. * @header name:Authorization require:1 desc:Token
  200. * @param name:id type:int default:-- desc:请假记录id
  201. * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  202. * @return name:start_time type:string default:-- desc:开始时间(上午||下午)
  203. * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  204. * @return name:end_time type:string default:-- desc:结束时间(上午||下午)
  205. * @return name:reason type:string default:-- desc:请假事由
  206. * @return name:type_name type:string default:-- desc:请假类型
  207. * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消
  208. * @return name:user_id type:int default:-- desc:请假会员id
  209. * @return name:document type:string default:-- desc:附件(文件路径)
  210. * @return name:images type:string default:-- desc:图片(多张|隔开)
  211. * @return name:content type:string default:-- desc:请假详细内容(是否离深)
  212. * @return name:approve_list type:array default:-- desc:审批记录
  213. * @return name:approve_list.status type:int default:-- desc:审批状态:0待审批(未到该审批人审批),1审批中(已到该审批人审批,还未审批)2审批通过3审批拒绝
  214. * @return name:approve_list.approve_time type:string default:-- desc:审批时间
  215. * @return name:approve_list.remark type:string default:-- desc:审批备注
  216. * @return name:approve_list.user_name type:string default:-- desc:审批人
  217. * @return name:approve_list.headimg type:string default:-- desc:审批人头像
  218. * @return name:approve_list.time type:string default:-- desc:审批用时(上一次审批完成到本次审批的时间,单位秒)
  219. */
  220. public function getVacateDetail()
  221. {
  222. $id = input('get.id');
  223. $detail = LeaveInfo::with('approveList')->where(['user_id'=>$this->user_id])->where(['id'=>$id])
  224. ->limit($this->off_set,$this->page_num)
  225. ->find()->toArray();
  226. $detail['images_arr'] = $detail['images'] ? explode('|',$detail['images']) : null;
  227. $this->success('ok',['detail'=>$detail]);
  228. }
  229. /**
  230. * @title 需要我审批的
  231. * @desc 需要我审批的
  232. * @author qc
  233. * @url /api/User_leave/getApproveLeave
  234. * @method POST
  235. * @tag
  236. * @header name:Authorization require:1 desc:Token
  237. * @param name:page type:int default:-- desc:页数
  238. * @param name:page_num type:int default:-- desc:每页数量
  239. * @return name:id type:int default:-- desc:请假记录id
  240. * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  241. * @return name:start_time type:string default:-- desc:开始时间(上午||下午)
  242. * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  243. * @return name:end_time type:string default:-- desc:结束时间(上午||下午)
  244. * @return name:document type:string default:-- desc:附件(文件路径)
  245. * @return name:images type:string default:-- desc:图片(多张|隔开)
  246. * @return name:content type:string default:-- desc:请假详细内容(是否离深)
  247. * @return name:reason type:string default:-- desc:请假事由
  248. * @return name:approve_status type:int default:-- desc:审批状态
  249. * @return name:approve_time type:string default:-- desc:审批时间(1审批中2审批通过3审批拒绝)
  250. * @return name:remark type:string default:-- desc:审批备注
  251. *
  252. */
  253. public function getApproveLeave()
  254. {
  255. $list = LeaveApprove::field('i.*,p.status approve_status,p.approve_time,p.remark')
  256. ->alias('p')
  257. ->where(['p.approve_user'=>$this->user_id])
  258. ->where('p.status','>','0')
  259. ->leftJoin('LeaveInfo i','p.leave_id = i.id')
  260. ->limit($this->off_set,$this->page_num)
  261. ->select()->toArray();
  262. array_walk($list,function (&$v){
  263. $v['images_arr'] = $v['image'] ? explode('|',$v['image']) : null;
  264. });
  265. $this->success('ok',['list'=>$list]);
  266. }
  267. /**
  268. * @title 审批请假记录
  269. * @desc 审批请假记录
  270. * @author qc
  271. * @url /api/User_leave/approveLeave
  272. * @method POST
  273. * @tag
  274. * @header name:Authorization require:1 desc:Token
  275. * @param name:approve_id type:string default:-- desc:审批记录id
  276. * @param name:status type:string default:-- desc:审批状态(2审批通过3审批拒绝)
  277. * @param name:remark type:string default:-- desc:审批备注
  278. */
  279. public function approveLeave()
  280. {
  281. $approve_id = input('post.approve_id');
  282. $status = input('post.status');
  283. $remark = input('post.remark');
  284. $res = ApproveService::approveLeave($approve_id,$this->user_id,$status,$remark);
  285. if(!$res['ret_val']) $this->error($res['msg']);
  286. $this->success('审批完成');
  287. }
  288. /**
  289. * @title 撤销请假申请
  290. * @desc 撤销请假申请
  291. * @author qc
  292. * @url /api/User_leave/cancelApply
  293. * @method POST
  294. * @tag
  295. * @header name:Authorization require:1 desc:Token
  296. * @param name:id type:int default:-- desc:请假记录id
  297. *
  298. */
  299. public function cancelApply()
  300. {
  301. $id = input('post.id');
  302. $apply_info = LeaveInfo::where('id',$id)->where('user_id|apply_user',$this->user_id)->find();
  303. if(!$apply_info)$this->error('请假记录有误');
  304. $apply_info->status = 9;
  305. $apply_info->save();
  306. $this->success('撤销成功');
  307. }
  308. }