subDays(15); $laborReportsTem=clone $laborReports; $laborReportsTem=$laborReportsTem->where($column,'like','%'.$request->input($column).'%')->where('created_at','>',$today->format('Y-m-d')); if($laborReportsTem->count()==0 ||$laborReportsTem->get()[0][$column]==$request->input($column)){ $laborReports=$laborReports->where($column,$request->input($column)); }else{ $laborReports=$laborReportsTem; } return $laborReports; } public function conditionQuery(Request $request,$laborReports){ if ($request->input('enter_number')){ $laborReports=$this->preciseQuery('enter_number',$request,$laborReports); } if ($request->input('user_workgroup_id')){ $laborReports=$this->preciseQuery('user_workgroup_id',$request,$laborReports); } if ($request->input('created_at_start')){ $created_at_start=$request->input('created_at_start')." 00:00:00"; $laborReports=$laborReports->where('created_at','>=',$created_at_start); } if ($request->input('created_at_end')){ $created_at_end=$request->input('created_at_end')." 23:59:59"; $laborReports=$laborReports->where('created_at','<=',$created_at_end); } if ($request->input('mobile_phone')){ $laborReports=$laborReports->where('mobile_phone',$request->input('mobile_phone')); } if ($request->input('identity_number')){ $laborReports=$this->preciseQuery('identity_number',$request,$laborReports); } return $laborReports; } /** * Display a listing of the resource. *@param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response * 临时工报表 */ public function index(Request $request) { if(!Gate::allows('人事管理')){ return redirect(url('/')); } $user=Auth::user(); if (!$user)return redirect('/'); $userWorkgroupIds=$user->getPermittingWorkgroupIds(); $permittingWorkgroups=UserWorkgroup::whereIn('id',$userWorkgroupIds)->get(); if($permittingWorkgroups->isEmpty())$permittingWorkgroups="[]"; $laravelEchoPrefix = config('database.redis.options.prefix'); if (!Gate::allows('人事管理-临时工报表-可见全部组')){return redirect(url('/')); } if ($request->input()){ $laborReports=LaborReport::orderBy('id','DESC'); $laborReports=$this->conditionQuery($request,$laborReports); $laborReports=$laborReports->paginate($request->input('paginate')?$request->input('paginate'):50); $userWorkGroups=UserWorkgroup::select('id','name')->get(); return view('personnel.laborReport.index',['laborReports'=>$laborReports,'userWorkGroups'=>$userWorkGroups,'request'=>$request->input(),'permittingWorkgroups'=>$permittingWorkgroups,'laravelEchoPrefix'=>$laravelEchoPrefix,]); } $laborReports=LaborReport::with(['userWorkgroup','user','userDutyCheck'])->orderBy('id','DESC')->paginate(50); foreach ($laborReports as $laborReport){ if (!$laborReport->group_user_id){ //十分钟之内组长未审核实行软删除 $tenMinutesLater=Carbon::parse($laborReport->created_at)->subMinutes(-10)->format('Y-m-d H:i:s'); if (Carbon::now()->format('Y-m-d H:i:s')>$tenMinutesLater){ $laborReport->delete(); $this->log(__METHOD__,"组长未审核该条记录将在10分钟后实行软删除__".__FUNCTION__,$laborReport->toJson(),Auth::user()['id']); } } //换场登入(当天有进场 退场 又进场 情况) //换组登入 (当天进场后 换组 ) if ($laborReport->user_workgroup_id){ $createdAtDate=Carbon::parse($laborReport->created_at)->format('Y-m-d'); $userDutyCheck=UserDutyCheck::where('user_id',$laborReport->user_id)->where('type','登入')->where('checked_at','like',$createdAtDate.'%')->first(); $this->guardClock($laborReport,$userDutyCheck); }else if (!$laborReport->user_workgroup_id){ $createdAtDate=Carbon::parse($laborReport->created_at)->format('Y-m-d H:i'); $userDutyCheck=UserDutyCheck::where('user_id',$laborReport->user_id)->where('type','登入')->where('checked_at','like',$createdAtDate.'%')->first(); $this->guardClock($laborReport,$userDutyCheck); } } $userWorkGroups=UserWorkgroup::select('id','name')->get(); return view('personnel/laborReport/index',['laborReports'=>$laborReports,'userWorkGroups'=>$userWorkGroups,'laravelEchoPrefix'=>$laravelEchoPrefix,'permittingWorkgroups'=>$permittingWorkgroups]); } public function guardClock($laborReport,$userDutyCheck){ if(!$userDutyCheck)$addOneHourCheckedAt=Carbon::parse($laborReport['created_at'])->subHours(-1)->format('Y-m-d H:i:s'); else $addOneHourCheckedAt=Carbon::parse($userDutyCheck['checked_at'])->subHours(-1)->format('Y-m-d H:i:s'); if ($userDutyCheck['verify_user_id']) $laborReport->userDutyCheck=$userDutyCheck; if (!$userDutyCheck['verify_user_id']&&Carbon::now()->format('Y-m-d H:i:s')<$addOneHourCheckedAt){ $laborReport->userDutyCheck=$userDutyCheck; } else if (!$userDutyCheck['verify_user_id']&&Carbon::now()->format('Y-m-d H:i:s')>$addOneHourCheckedAt){ $laborReport->delete(); $this->log(__METHOD__,"进场门卫未审核该条记录将在一小时后实行软删除__".__FUNCTION__,$laborReport->toJson(),Auth::user()['id']); } } public function export($id,Request $request){ if (!Gate::allows('人事管理-临时工报表-可见全部组')){return redirect(url('/')); } ini_set('max_execution_time',3500); ini_set('memory_limit','3526M'); if ($id==-1){ $id=[]; $laborReports=LaborReport::select('id'); $laborReports=$this->conditionQuery($request,$laborReports); $laborReports=$laborReports->get(); foreach ($laborReports as $laborReports){ array_push($id,$laborReports->id); } }else $id = explode( ',',$id); if (!$id)return ; $row=[[ 'id'=>'ID', 'created_at'=>'创建时间', 'enter_number'=>'进厂编号', 'user_workgroup_name'=>'小组', 'name'=>'临时工', 'mobile_phone'=>'电话', 'identity_number'=>'身份证号', 'labor_company'=>'劳务所', 'check_in_at'=>'打卡时间', 'verify_at'=>'审核时间', 'group_user_id'=>'审核人', 'check_out_at'=>'退场时间', 'relax_time'=>'晚饭时间', 'online_duration'=>'在线时长', 'working_duration'=>'本次工作时长', ]]; $list=[]; for ($i=0; $ifind($id[$i]); $w=[ 'id'=>isset($laborReport->id)?$laborReport->id:'', 'created_at'=>isset($laborReport->created_at)?$laborReport->created_at:'', 'enter_number'=>isset($laborReport->enter_number)?$laborReport->enter_number:'', 'user_workgroup_name'=>isset($laborReport->userWorkgroup->name)?$laborReport->userWorkgroup->name:'', 'name'=>isset($laborReport->name)?$laborReport->name:'', 'mobile_phone'=>isset($laborReport->mobile_phone)?$laborReport->mobile_phone:'', 'identity_number'=>isset($laborReport->identity_number)?$laborReport->identity_number:'', 'labor_company'=>isset($laborReport->labor_company)?$laborReport->labor_company:'', 'check_in_at'=>isset($laborReport->check_in_at)?$laborReport->check_in_at:'', 'verify_at'=>isset($laborReport->verify_at)?$laborReport->verify_at:'', 'group_user_id'=>isset($laborReport->user->name)?$laborReport->user->name:'', 'check_out_at'=>isset($laborReport->check_out_at)?$laborReport->check_out_at:'', 'relax_time'=>isset($laborReport->relax_time)?$laborReport->relax_time:'', 'online_duration'=>isset($laborReport->online_duration)?$laborReport->online_duration:'', 'working_duration'=>isset($laborReport->working_duration)?$laborReport->working_duration:'', ]; $list[$i]=$w; } return Excel::download(new Export($row,$list),date('YmdHis', time()).'-临时工报表记录单.xlsx'); } //门卫打卡审核` public function guardClockAudit(Request $request){ if(!Gate::allows('人事管理-门卫审核')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $id=$request->input('id'); $type=$request->input('type'); $userDutyCheck=UserDutyCheck::find($id); $userDutyCheck->type=$type; $userDutyCheck->verify_user_id=Auth::user()['id']; $userDutyCheck->update(); event(new GuardAuditEvent($userDutyCheck)); $this->log(__METHOD__,"打卡审核".__FUNCTION__,json_encode($userDutyCheck),Auth::user()['id']); return ["success"=>true,"data"=>$userDutyCheck->verify_user_id]; } //打卡组长审核 public function groupClockAudit(Request $request){ if(!Gate::allows('人事管理')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $id=$request->input('id'); $laborReport=LaborReport::find($id); if(!Gate::allows('人事管理-组长审核')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $laborReport->group_user_id=Auth::user()['id']; $laborReport->verify_at=date('Y-m-d H:i:s'); $laborReport->update(); $laborReport->verifyPerson=Auth::user()['name']; $this->log(__METHOD__,"打卡组长审核".__FUNCTION__,json_encode($laborReport),Auth::user()['id']); event(new TeamAuditEvent($laborReport)); return ["success"=>true,"data"=>$laborReport]; } //组长点击退场 public function groupExport(Request $request){ if(!Gate::allows('人事管理')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $id=$request->input('id'); $laborReport=LaborReport::find($id); if(!Gate::allows('人事管理-组长审核')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $check_out_at=Carbon::now()->format('Y-m-d H:i:s'); $check_in_at=$laborReport->check_in_at; $laborReport->check_out_at=$check_out_at; $online_duration=round(Carbon::parse($check_out_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2); $laborReport->online_duration=$online_duration; $laborReport->working_duration=$this->minusLunchTime($laborReport,$online_duration); $laborReport->update(); $laborReport->is_exportGroup=$laborReport->getIsExportGroupAttribute(); $this->log(__METHOD__,"退场".__FUNCTION__,json_encode($laborReport),Auth::user()['id']); return ["success"=>true,"data"=>$laborReport]; } //晚19点后组长点击退场,判断是否有晚餐情况 public function groupExportEnsure(Request $request){ if(!Gate::allows('人事管理')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $id=$request->input('id'); $relax_time=$request->input('relax_time'); if(!$relax_time){ return ["success"=>false,"data"=>"未选择确切晚饭时间,请重新选择!"]; } $laborReport=LaborReport::find($id); if(!Gate::allows('人事管理-组长审核')){ return ["success"=>false,"data"=>"您无此权限操作!!!"]; } $check_out_at=Carbon::now()->format('Y-m-d H:i:s'); $check_in_at=$laborReport->check_in_at; $laborReport->check_out_at=$check_out_at; $online_duration=round(Carbon::parse($check_out_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2); $laborReport->online_duration=$online_duration; if ($relax_time){ $laborReport->relax_time=$relax_time; $laborReport->working_duration=$this->minusLunchTime($laborReport,$online_duration)-$relax_time/60;//减去晚饭时间 }else{ $laborReport->working_duration=$this->minusLunchTime($laborReport,$online_duration); } $laborReport->update(); $laborReport->is_exportGroup=$laborReport->getIsExportGroupAttribute(); $this->log(__METHOD__,"退场".__FUNCTION__,json_encode($laborReport),Auth::user()['id']); return ["success"=>true,"data"=>$laborReport]; } //工作时长减午饭休息时间 public function minusLunchTime($laborReport,$hour){ $date=$laborReport->check_in_at; $date=Carbon::parse($date)->format('H'); if ((int)$date<=12){ $hour=$hour-1; } return $hour; } }