user_id)->where('type',1)->find(); $where = []; $where[] = ['l.type','=',1]; if($check_flow)$where[] = ['l.sort','>',$check_flow->sort]; $list = LeaveFlow::field('l.user_id,u.name user_name,u.headimg') ->alias('l') ->where($where) ->order('l.sort asc') ->leftJoin('StoreMember u','u.id = l.user_id') ->select()->toArray(); $this->success('ok',['list'=>$list]); } /** * @title 获取抄送人流程 * @desc 获取抄送人流程 * @author qc * @url /api/User_leave/getCopyFlow * @method GET * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @return name:user_name type:string default:-- desc:会员名称 * @return name:headimg type:string default:-- desc:会员头像 */ public function getCopyFlow() { $check_flow = LeaveFlow::where('user_id',$this->user_id)->where('type',2)->find(); $where = []; $where[] = ['l.type','=',2]; if($check_flow)$where[] = ['l.sort','>',$check_flow->sort]; $list = LeaveFlow::field('l.user_id,u.name user_name,u.headimg') ->alias('l') ->where($where) ->order('l.sort asc') ->leftJoin('StoreMember u','u.id = l.user_id') ->select()->toArray(); $this->success('ok',['list'=>$list]); } /** * @title 获取请假类型 * @desc 获取请假类型 * @author qc * @url /api/User_leave/getLeaveType * @method GET * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @return name:id type:int default:-- desc:会员id * @return name:title type:int default:-- desc:类型 */ public function getLeaveType() { $field = 'id,title'; $user_info = LeaveType::field($field)->where('status',1)->where('is_deleted',0)->select()->toArray(); $this->success('获取成功',['detail'=>$user_info]); } /** * @title 请假申请 * @desc 请假申请 * @author qc * @url /api/User_leave/applyVacate * @method GET * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @param name:type type:int default:-- desc:请假类型id * @param name:start_date type:string default:-- desc:开始日期(格式:2022-11-01) * @param name:start_time type:string default:-- desc:开始时间(上午||下午) * @param name:end_date type:string default:-- desc:结束日期(格式:2022-11-01) * @param name:end_time type:string default:-- desc:结束时间(上午||下午) * @param name:document type:string default:-- desc:附件(文件路径) * @param name:images type:string default:-- desc:图片(多张|隔开) * @param name:content type:string default:-- desc:请假详细内容(是否离深) * @param name:user_id type:int default:-- desc:请假会员id(自己请假可以不传,代为请假传请假人id) */ public function applyVacate() { $request_param = input('post.'); if(empty($request_param['start_date']) || empty($request_param['end_date'])) $this->error('请选择请假期'); if(empty($request_param['type'])) $this->error('请选择请假类型'); if(empty($request_param['user_id'])) $request_param['user_id'] = $this->user_id; $request_param['apply_user'] = $this->user_id;// 申请会员id $flow = LeaveFlow::getApproveUser();// 请假审批流程设置 $flow_user = array_column($flow,'user_id'); $flow_key = array_search($request_param['user_id'],$flow_user);// 请假人是否在审批流程人员中 $copy = LeaveFlow::getCopyTo(); $copy_user = array_column($copy,'user_id'); $copy_key = array_search($request_param['user_id'],$copy_user);// 请假人是否在抄送人员中 $flow_info = LeaveInfo::create($request_param);//生成请假记录 $flow_data = [];// 审批流程 $flow_num = 0; foreach ($flow as $fk=>$fv) { if($flow_key !== false && $flow_key >= $fk) continue; $flow_num++; $flow_data[] = [ 'leave_id' => $flow_info->id, 'approve_user' => $fv['user_id'], 'flow' =>$flow_num ]; } foreach ($copy as $ck=>$cv) { if($copy_key !== false && $copy_key >= $ck) continue; $flow_data[] = [ 'leave_id' => $flow_info->id, 'approve_user' => $cv['user_id'], 'approve_type' =>2 ]; } if(!empty($flow_data)) { LeaveInfo::where('id',$flow_info->id)->update(['approve_num'=>$flow_num]); (new LeaveApprove())->saveAll($flow_data); }else{ LeaveInfo::where('id',$flow_info->id)->update(['status'=>2]); } $this->success('请假已提交,请等待审核',['detail'=>$flow_info->toArray()]); } /** * @title 我的请假记录【列表】 * @desc 我的请假记录 * @author qc * @url /api/User_leave/getVacateList * @method GET * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @param name:page type:int default:-- desc:页数 * @param name:page_num type:int default:-- desc:每页数量 * @param name:type type:int default:0 desc:请假类型id * @param name:status type:int default:0 desc:审批状态0全部,1审批中,2审批通过,3审批拒绝,9取消 * @param name:sel_time type:string default:0 desc:时间查询 * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01) * @return name:start_time type:string default:-- desc:开始时间(上午||下午) * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01) * @return name:end_time type:string default:-- desc:结束时间(上午||下午) * @return name:reason type:string default:-- desc:请假事由 * @return name:type_name type:string default:-- desc:请假类型 * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消 * @return name:user_id type:int default:-- desc:请假会员id */ public function getVacateList() { $all_type = LeaveType::getAllType(); $type = array_column($all_type,null,'id'); $sel_where = []; $sel_where[] = ['user_id','=',$this->user_id]; if(input('get.status') > 0) $sel_where[] = ['status','=',input('get.status')]; if(input('get.type') > 0) $sel_where[] = ['type','=',input('get.type')]; if(input('get.sel_time')) $sel_where[] = ['start_date|end_date','=',input('get.sel_time')]; $list = LeaveInfo::where($sel_where)->limit($this->off_set,$this->page_num)->select()->toArray(); array_walk($list,function (&$v,$k)use ($type){ $list['type_name'] = $type[$v['type']]['title']; }); $this->success('ok',['list'=>$list]); } /** * @title 我的请假详情 * @desc 我的请假详情 * @author qc * @url /api/User_leave/getVacateList * @method GET * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @param name:id type:int default:-- desc:请假记录id * @return name:start_date type:string default:-- desc:开始日期(格式:2022-11-01) * @return name:start_time type:string default:-- desc:开始时间(上午||下午) * @return name:end_date type:string default:-- desc:结束日期(格式:2022-11-01) * @return name:end_time type:string default:-- desc:结束时间(上午||下午) * @return name:reason type:string default:-- desc:请假事由 * @return name:type_name type:string default:-- desc:请假类型 * @return name:status type:int default:-- desc:状态:1审批中,2审批通过,3审批拒绝,9取消 * @return name:user_id type:int default:-- desc:请假会员id * @return name:approve_list type:array default:-- desc:审批记录 * @return name:approve_list.status type:int default:-- desc:审批状态:0待审批(未到该审批人审批),1审批中(已到该审批人审批,还未审批)2审批通过3审批拒绝 * @return name:approve_list.approve_time type:string default:-- desc:审批时间 * @return name:approve_list.remark type:string default:-- desc:审批备注 * @return name:approve_list.user_name type:string default:-- desc:审批人 * @return name:approve_list.headimg type:string default:-- desc:审批人头像 * @return name:approve_list.time type:string default:-- desc:审批用时(上一次审批完成到本次审批的时间,单位秒) */ public function getVacateDetail() { $id = input('get.id'); $detail = LeaveInfo::with('approveList')->where(['user_id'=>$this->user_id])->where(['id'=>$id]) ->limit($this->off_set,$this->page_num) ->find()->toArray(); $this->success('ok',['detail'=>$detail]); } /** * @title 需要我审批的 * @desc 需要我审批的 * @author qc * @url /api/User_leave/getApproveLeave * @method POST * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @param name:page type:int default:-- desc:页数 * @param name:page_num type:int default:-- desc:每页数量 */ public function getApproveLeave() { $list = LeaveApprove::where(['l.approve_user'=>$this->user_id]) ->alias('l') ->field("l.*") ->where('status','>','0') ->limit($this->off_set,$this->page_num) ->select()->toArray(); $this->success('ok',['list'=>$list]); } /** * @title 审批请假记录 * @desc 审批请假记录 * @author qc * @url /api/User_leave/approveLeave * @method POST * @tag 个人信息 * @header name:Authorization require:1 desc:Token * @param name:approve_id type:string default:-- desc:审批记录id * @param name:status type:string default:-- desc:审批状态 * @param name:remark type:string default:-- desc:审批备注 */ public function approveLeave() { $approve_id = input('post.approve_id'); $status = input('post.status'); $remark = input('post.remark'); $res = LeaveService::approveLeave($approve_id,$this->user_id,$status,$remark); if(!$res['ret_val']) $this->error($res['msg']); $this->success('审批完成'); } }