UserLeave.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  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\LeaveService;
  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. ];
  132. }
  133. foreach ($copy as $ck=>$cv) {
  134. if($copy_key !== false && $copy_key >= $ck) continue;
  135. $flow_data[] = [
  136. 'leave_id' => $flow_info->id,
  137. 'approve_user' => $cv['user_id'],
  138. 'approve_type' =>2
  139. ];
  140. }
  141. if(!empty($flow_data)) {
  142. LeaveInfo::where('id',$flow_info->id)->update(['approve_num'=>$flow_num]);
  143. (new LeaveApprove())->saveAll($flow_data);
  144. }else{
  145. LeaveInfo::where('id',$flow_info->id)->update(['status'=>2]);
  146. }
  147. $this->success('请假已提交,请等待审核',['detail'=>$flow_info->toArray()]);
  148. }
  149. /**
  150. * @title 我的请假记录【列表】
  151. * @desc 我的请假记录
  152. * @author qc
  153. * @url /api/User_leave/getVacateList
  154. * @method GET
  155. * @tag 个人信息
  156. * @header name:Authorization require:1 desc:Token
  157. * @param name:page type:int default:-- desc:页数
  158. * @param name:page_num type:int default:-- desc:每页数量
  159. * @param name:type type:int default:0 desc:请假类型id
  160. * @param name:status type:int default:0 desc:审批状态0全部,1审批中,2审批通过,3审批拒绝,9取消
  161. * @param name:sel_time type:string default:0 desc:时间查询
  162. * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  163. * @return name:start_time type:string default:-- desc:开始时间(上午||下午)
  164. * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  165. * @return name:end_time type:string default:-- desc:结束时间(上午||下午)
  166. * @return name:reason type:string default:-- desc:请假事由
  167. * @return name:type_name type:string default:-- desc:请假类型
  168. * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消
  169. * @return name:user_id type:int default:-- desc:请假会员id
  170. */
  171. public function getVacateList()
  172. {
  173. $all_type = LeaveType::getAllType();
  174. $type = array_column($all_type,null,'id');
  175. $sel_where = [];
  176. $sel_where[] = ['user_id','=',$this->user_id];
  177. if(input('get.status') > 0) $sel_where[] = ['status','=',input('get.status')];
  178. if(input('get.type') > 0) $sel_where[] = ['type','=',input('get.type')];
  179. if(input('get.sel_time')) $sel_where[] = ['start_date|end_date','=',input('get.sel_time')];
  180. $list = LeaveInfo::where($sel_where)->limit($this->off_set,$this->page_num)->select()->toArray();
  181. array_walk($list,function (&$v,$k)use ($type){
  182. $list['type_name'] = $type[$v['type']]['title'];
  183. });
  184. $this->success('ok',['list'=>$list]);
  185. }
  186. /**
  187. * @title 我的请假详情
  188. * @desc 我的请假详情
  189. * @author qc
  190. * @url /api/User_leave/getVacateList
  191. * @method GET
  192. * @tag 个人信息
  193. * @header name:Authorization require:1 desc:Token
  194. * @param name:id type:int default:-- desc:请假记录id
  195. * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01)
  196. * @return name:start_time type:string default:-- desc:开始时间(上午||下午)
  197. * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01)
  198. * @return name:end_time type:string default:-- desc:结束时间(上午||下午)
  199. * @return name:reason type:string default:-- desc:请假事由
  200. * @return name:type_name type:string default:-- desc:请假类型
  201. * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消
  202. * @return name:user_id type:int default:-- desc:请假会员id
  203. * @return name:approve_list type:array default:-- desc:审批记录
  204. * @return name:approve_list.status type:int default:-- desc:审批状态:0待审批(未到该审批人审批),1审批中(已到该审批人审批,还未审批)2审批通过3审批拒绝
  205. * @return name:approve_list.approve_time type:string default:-- desc:审批时间
  206. * @return name:approve_list.remark type:string default:-- desc:审批备注
  207. * @return name:approve_list.user_name type:string default:-- desc:审批人
  208. * @return name:approve_list.headimg type:string default:-- desc:审批人头像
  209. * @return name:approve_list.time type:string default:-- desc:审批用时(上一次审批完成到本次审批的时间,单位秒)
  210. */
  211. public function getVacateDetail()
  212. {
  213. $id = input('get.id');
  214. $detail = LeaveInfo::with('approveList')->where(['user_id'=>$this->user_id])->where(['id'=>$id])
  215. ->limit($this->off_set,$this->page_num)
  216. ->find()->toArray();
  217. $this->success('ok',['detail'=>$detail]);
  218. }
  219. /**
  220. * @title 需要我审批的
  221. * @desc 需要我审批的
  222. * @author qc
  223. * @url /api/User_leave/getApproveLeave
  224. * @method POST
  225. * @tag 个人信息
  226. * @header name:Authorization require:1 desc:Token
  227. * @param name:page type:int default:-- desc:页数
  228. * @param name:page_num type:int default:-- desc:每页数量
  229. */
  230. public function getApproveLeave()
  231. {
  232. $list = LeaveApprove::where(['l.approve_user'=>$this->user_id])
  233. ->alias('l')
  234. ->field("l.*")
  235. ->where('status','>','0')
  236. ->limit($this->off_set,$this->page_num)
  237. ->select()->toArray();
  238. $this->success('ok',['list'=>$list]);
  239. }
  240. /**
  241. * @title 审批请假记录
  242. * @desc 审批请假记录
  243. * @author qc
  244. * @url /api/User_leave/approveLeave
  245. * @method POST
  246. * @tag 个人信息
  247. * @header name:Authorization require:1 desc:Token
  248. * @param name:approve_id type:string default:-- desc:审批记录id
  249. * @param name:status type:string default:-- desc:审批状态
  250. * @param name:remark type:string default:-- desc:审批备注
  251. */
  252. public function approveLeave()
  253. {
  254. $approve_id = input('post.approve_id');
  255. $status = input('post.status');
  256. $remark = input('post.remark');
  257. $res = LeaveService::approveLeave($approve_id,$this->user_id,$status,$remark);
  258. if(!$res['ret_val']) $this->error($res['msg']);
  259. $this->success('审批完成');
  260. }
  261. }