LaborReportService.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. namespace App\Services;
  3. use App\Events\ExportEvent;
  4. use App\Events\ImportEvent;
  5. use App\Http\Controllers\Controller;
  6. use App\LaborReportStatus;
  7. use App\LaborCompany;
  8. use App\LaborReport;
  9. use App\Services\common\QueryService;
  10. use App\UserDetail;
  11. use App\UserDutyCheck;
  12. use App\UserLabor;
  13. use Carbon\Carbon;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Support\Facades\Auth;
  16. use Illuminate\Support\Facades\Gate;
  17. class LaborReportService
  18. {
  19. private function conditionQuery(Request $request){
  20. $user=Auth::user();
  21. $laborReports=LaborReport::query()->with(['user','userDutyCheck','userWorkgroup'])->orderBy('id','DESC')->whereIn('user_workgroup_id',
  22. $user?$user->getPermittingWorkgroupIds(Gate::allows('人事管理-临时工报表-可见全部组')):[]);
  23. $laborStatus=LaborReportStatus::select('labor_report_id')->where('status','已退场')->get();
  24. $enterNumbers=[];
  25. foreach ($laborStatus as $laborId){
  26. $enterNumber=LaborReport::where('id',$laborId['labor_report_id'])->value('enter_number');
  27. array_push($enterNumbers,$enterNumber);
  28. }
  29. if (!$request->is_export){
  30. $laborReports->whereNotIn('enter_number',$enterNumbers);
  31. }else $request->offsetUnset('is_export');
  32. if(Gate::allows('人事管理-临时工报表-可见全部组')||Gate::allows('人事管理-门卫审核')){
  33. $laborReports->orWhereNull('user_workgroup_id');
  34. }
  35. $columnQueryRules=[
  36. 'enter_number' => ['like' => ''],
  37. 'created_at_start' => ['alias' => 'created_at' , 'startDate' => ' 00:00:00'],
  38. 'created_at_end' => ['alias' => 'created_at' , 'endDate' => ' 23:59:59'],
  39. 'identity_number' => ['like' => ''],
  40. 'mobile_phone' => ['like' => ''],
  41. ];
  42. $laborReports = app(QueryService::class)->query($request,$laborReports,$columnQueryRules);
  43. return $laborReports;
  44. }
  45. public function paginate(Request $request){
  46. return $this->conditionQuery($request)->paginate($request->paginate ?? 50);
  47. }
  48. public function get(Request $request){
  49. return $this->conditionQuery($request)->get();
  50. }
  51. public function some(Request $request){
  52. return LaborReport::query()->orderBy('id','DESC')
  53. ->whereIn('id',explode(',',$request->data))->get();
  54. }
  55. //根据进场记录创建临时工报表
  56. public function makeLaborReportByUserDutyCheck($userDutyCheck){
  57. $dateNow=Carbon::now()->format('Y-m-d');
  58. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  59. if (!$laborReport){
  60. $newReport=$userDutyCheck->laborEnterCheck();
  61. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  62. if ($newReport){
  63. event(new ImportEvent($newReport));
  64. }
  65. }
  66. }
  67. //根据进出场打卡记录 创建或者更新临时工报表记录
  68. public function makeOrChangeLaborReportByUserDutyCheck($userDutyCheck,$importAndExportQRCodeType){
  69. $dateNow=Carbon::now()->format('Y-m-d');
  70. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  71. //判断当前日期下临时工是否有临时工报表记录并且是进场打卡
  72. if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
  73. $newReport=$userDutyCheck->makeEnteringRecord();
  74. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  75. if ($newReport) event(new ImportEvent($newReport));
  76. }
  77. if(!$laborReport&&$importAndExportQRCodeType=='export'){
  78. //退场时间跨天情况
  79. $yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
  80. $laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
  81. if (!$laborReportYesterday->check_out_at&&$laborReportYesterday['user_workgroup_id']){
  82. 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();
  83. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  84. }
  85. $exportReport=LaborReport::exitAndChangeLaborReport($laborReportYesterday,$userDutyCheck);
  86. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
  87. if ($exportReport) event(new ExportEvent($exportReport));
  88. }
  89. if($laborReport&&$importAndExportQRCodeType=='export'){
  90. if (!$laborReport['check_out_at']&&$laborReport['user_workgroup_id']){
  91. 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();
  92. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  93. }
  94. $exportReport=LaborReport::exitAndChangeLaborReport($laborReport,$userDutyCheck);
  95. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  96. if ($exportReport) event(new ExportEvent($exportReport));
  97. }
  98. }
  99. //补卡出场更新临时工报表信息
  100. public function exportReplenishToCreateLaborReportData($laborReport,$userDutyCheck){
  101. $laborReportStatus=new LaborReportStatus([
  102. 'labor_report_id'=>$laborReport['id'],
  103. 'status'=>'已退场',
  104. 'created_at'=>$userDutyCheck['checked_at'],
  105. ]);
  106. $laborReportStatus->save();
  107. $check_in_at=$laborReport->check_in_at;
  108. $exit_at=$userDutyCheck->checked_at;
  109. $online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2);
  110. if ($laborReport->enter_at){
  111. $enter_at=$laborReport['enter_at'];
  112. $laborReport->online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($enter_at))/3600,2);
  113. }else{
  114. $laborReport->online_duration=$online_duration;
  115. }
  116. $laborReport->update();
  117. $laborReport->is_export=$laborReport->getIsExportAttribute();
  118. return $laborReport;
  119. }
  120. //当天第一次进工作组更新临时工报表
  121. public function enterGroupAndUpdateLaborReport($laborReport,$userWorkgroupID){
  122. $laborReport->user_workgroup_id=$userWorkgroupID;
  123. $laborReport->check_in_at=date('Y-m-d H:i:s');
  124. $laborReport->update();
  125. return $laborReport;
  126. }
  127. //换组添加临时工报表数据
  128. public function changeGroupAndMakeLaborReport($user_id,$userWorkgroupID){
  129. $laborReportBefore=LaborReport::where('user_id',$user_id)->orderby('id','desc')->first();
  130. if ($laborReportBefore&&$laborReportBefore['status']!='已退场')$userDutyCheck=$laborReportBefore->userDutyCheck;
  131. $userDetail=UserDetail::find($user_id);
  132. $name=$userDetail['full_name'];
  133. $mobile_phone=$userDetail['mobile_phone'];
  134. $identity_number=$userDetail['identity_number'];
  135. $labor_company_id=UserLabor::where('user_id',$user_id)->value('labor_company_id');
  136. $labor_company=LaborCompany::where('id',$labor_company_id)->value('name');
  137. $laborReport=new LaborReport([
  138. 'user_workgroup_id'=>$userWorkgroupID,
  139. 'user_id'=>$user_id,
  140. 'name'=>$name,
  141. 'mobile_phone'=>$mobile_phone,
  142. 'identity_number'=>$identity_number,
  143. 'labor_company'=>$labor_company,
  144. 'check_in_at'=>date('Y-m-d H:i:s'),
  145. 'user_duty_check_id'=>$userDutyCheck->id,
  146. ]);
  147. $laborReport['enter_number']=$laborReport->makeOrGetEnteringNumber();
  148. $laborReport->save();
  149. $laborReportStatus=new LaborReportStatus([
  150. 'labor_report_id'=>$laborReport['id'],
  151. 'status'=>'已换组',
  152. ]);
  153. $laborReportStatus->save();
  154. return $laborReport;
  155. }
  156. }