with(['user','userDutyCheck','userWorkgroup.signs','laborCompany','已退场','未审核'])->orderBy('labor_reports.id','DESC');
if (!($params["is_export"] ?? false)&&!($params['id']??null)){
$laborReports = $laborReports->whereNotIn('labor_reports.enter_number',function ($builder)use($params){
$builder->select('enter_number')->from('labor_reports')
->leftJoin('labor_report_statuses','labor_reports.id','labor_report_statuses.labor_report_id')
->where('labor_report_statuses.status','已退场');
});
}else unset($params['is_export']);
$columnQueryRules=[
'enter_number' => ['timeLimit' => 15],
'created_at_start' => ['alias' => 'created_at' , 'startDate' => ' 00:00:00'],
'created_at_end' => ['alias' => 'created_at' , 'endDate' => ' 23:59:59'],
'identity_number' => ['timeLimit' => 15],
'name' => ['like' => ''],
'user_workgroup_id' => ['multi' => ','],
'labor_company_id' => ['multi' => ','],
'id' => ['multi' => ',']
];
$laborReports = app(QueryService::class)->query($params,$laborReports,$columnQueryRules,'labor_reports');
if((Gate::allows('人事管理-临时工报表-可见全部组')||Gate::allows('人事管理-门卫审核')) && !($params["user_workgroup_id"] ?? false)){
$laborReports->where(function ($query)use($user){
$query->whereIn('labor_reports.user_workgroup_id',$user?$user->getPermittingWorkgroupIds(Gate::allows('人事管理-临时工报表-可见全部组')):[])
->orWhereNull('labor_reports.user_workgroup_id');
});
}else{
$laborReports->whereIn('labor_reports.user_workgroup_id',
$user?$user->getPermittingWorkgroupIds(Gate::allows('人事管理-临时工报表-可见全部组')):[]);
}
$laborReports = app(QueryService::class)->query($params,$laborReports,$columnQueryRules,'labor_reports');
return $laborReports;
}
public function paginate(array $params){
return $this->conditionQuery($params)->paginate($params['paginate'] ?? 50);
}
public function get(array $params){
return $this->conditionQuery($params)->without("userDutyCheck")->get();
}
public function getSql(array $params){
return $this->conditionQuery($params)->selectRaw("labor_reports.*")
->leftJoin('user_workgroups','labor_reports.user_workgroup_id','user_workgroups.id')
->selectRaw('user_workgroups.name user_workgroup_name')
->leftJoin('labor_companies','labor_reports.labor_company_id','labor_companies.id')
->selectRaw('labor_companies.name labor_company')
->sql();
}
//根据进场记录创建临时工报表
public function makeLaborReportByUserDutyCheck($userDutyCheck){
$dateNow=Carbon::now()->format('Y-m-d');
$laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
if (!$laborReport){
$newReport=$userDutyCheck->makeEnteringRecord();
Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
if ($newReport){
event(new ImportEvent($newReport));
}
}
}
//根据进出场打卡记录 创建或者更新临时工报表记录
public function makeOrChangeLaborReportByUserDutyCheck($userDutyCheck,$importAndExportQRCodeType){
$dateNow=Carbon::now()->format('Y-m-d');
$laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
//判断当前日期下临时工是否有临时工报表记录并且是进场打卡
if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
$newReport=$userDutyCheck->makeEnteringRecord();
Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
if ($newReport) event(new ImportEvent($newReport));
}
if(!$laborReport&&$importAndExportQRCodeType=='export'){
//退场时间跨天情况
$yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
$laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
// if (!$laborReportYesterday->group_user_id&&!$laborReportYesterday->verify_at){
// LaborReport::query()->where('user_id',$userDutyCheck->user_id)->whereNull('group_user_id')->whereNull('verify_at')->orderBy('id','desc')->delete();
// $laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
// }
// if (!$laborReportYesterday->check_out_at&&$laborReportYesterday['user_workgroup_id']){
// UserDutyCheck::where('user_id',$laborReportYesterday->user_id)->where('type','登出')->where('checked_at','like',Carbon::now()->format('Y-m-d H:i').'%')->orderBy('id','desc')->delete();
// return "
您还未退组,暂不可退场,请联系组长!
";
// }
$exportReport=LaborReport::exitAndChangeLaborReport($laborReportYesterday,$userDutyCheck);
Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
if ($exportReport) event(new ExportEvent($exportReport));
}
if($laborReport&&$importAndExportQRCodeType=='export'){
// if (!$laborReport->group_user_id&&!$laborReport->verify_at){
// LaborReport::where('user_id',$userDutyCheck->user_id)->whereNull('group_user_id')->whereNull('verify_at')->orderBy('id','desc')->delete();
// $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
// }
// if (!$laborReport['check_out_at']&&$laborReport['user_workgroup_id']){
// UserDutyCheck::where('user_id',$laborReport->user_id)->where('type','登出')->where('checked_at','like',Carbon::now()->format('Y-m-d H:i').'%')->orderBy('id','desc')->delete();
// return "您还未退组,暂不可退场,请联系组长!
";
// }
$exportReport=LaborReport::exitAndChangeLaborReport($laborReport,$userDutyCheck);
Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
if ($exportReport) event(new ExportEvent($exportReport));
}
}
//补卡出场更新临时工报表信息
public function exportReplenishToCreateLaborReportData($laborReport,$userDutyCheck){
$laborReportStatus=new LaborReportStatus([
'labor_report_id'=>$laborReport['id'],
'status'=>'已退场',
'created_at'=>$userDutyCheck['checked_at'],
]);
$laborReportStatus->save();
$check_in_at=$laborReport->check_in_at;
$exit_at=$userDutyCheck->checked_at;
$online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2);
$laborReport->user_duty_check_id=$userDutyCheck->id;
if ($laborReport->enter_at){
$enter_at=$laborReport['enter_at'];
$laborReport->online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($enter_at))/3600,2);
}else{
$laborReport->online_duration=$online_duration;
}
$laborReport->update();
$laborReport->is_export=$laborReport->getIsExportAttribute();
return $laborReport;
}
//当天第一次进工作组更新临时工报表
public function enterGroupAndUpdateLaborReport($laborReport,$userWorkgroupID){
$laborReport->user_workgroup_id=$userWorkgroupID;
$laborReport->check_in_at=date('Y-m-d H:i:s');
$laborReport->update();
return $laborReport;
}
//换组添加临时工报表数据
public function changeGroupAndMakeLaborReport($user_id,$userWorkgroupID){
$laborReportBefore=LaborReport::where('user_id',$user_id)->orderby('id','desc')->first();
if ($laborReportBefore&&$laborReportBefore['status']!='已退场')$userDutyCheck=$laborReportBefore->userDutyCheck;
if ($laborReportBefore&&!$laborReportBefore['group_user_id']){
if ($laborReportBefore['user_workgroup_id']!=$userWorkgroupID){
$laborReportBefore['user_workgroup_id']=$userWorkgroupID;
$laborReportBefore['check_in_at']=Carbon::now()->format('Y-m-d H:i:s');
$laborReportBefore->update();
return $laborReportBefore;
}
}
$userDetail=UserDetail::find($user_id);
$name=$userDetail['full_name'];
$mobile_phone=$userDetail['mobile_phone'];
$identity_number=$userDetail['identity_number'];
$labor_company_id=UserLabor::where('user_id',$user_id)->value('labor_company_id');
$laborReport=new LaborReport([
'user_workgroup_id'=>$userWorkgroupID,
'user_id'=>$user_id,
'name'=>$name,
'mobile_phone'=>$mobile_phone,
'identity_number'=>$identity_number,
'labor_company_id'=>$labor_company_id,
'check_in_at'=>date('Y-m-d H:i:s'),
'user_duty_check_id'=>$userDutyCheck->id,
]);
$laborReport['enter_number']=$laborReport->makeOrGetEnteringNumber();
$laborReport->save();
$laborReportStatus=new LaborReportStatus([
'labor_report_id'=>$laborReport['id'],
'status'=>'已换组',
]);
$laborReportStatus->save();
return $laborReport;
}
public function 修改劳务所($param){
$laborReports=LaborReport::query()->where('enter_number',$param['enter_number'])->get();
foreach($laborReports as $laborReport){
$laborReport->labor_company_id=$param['laborCompanyId'];
$laborReport->update();
}
Controller::logS(__METHOD__,'修改临时工报表劳务所'.__FUNCTION__,json_encode($param));
}
public function 删除($id){
$laborReport=LaborReport::query()->where('id',$id)->delete();
if ($laborReport>0)LaborReportStatus::create([
'labor_report_id'=>$id,
'status'=>'已删除',
]);
Controller::logS(__METHOD__,'删除盘点记录时修改盘点任务信息'.__FUNCTION__,json_encode($id));
return $laborReport;
}
public function addOrUpdateRemark($remark,$id){
return LaborReport::query()->updateOrCreate(['id'=>$id],['remark'=>$remark]);
}
}