LaborReportService.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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\Http\Controllers\UserDutyCheckController;
  7. use App\LaborReportStatus;
  8. use App\LaborCompany;
  9. use App\LaborReport;
  10. use App\UserDetail;
  11. use App\UserDutyCheck;
  12. use App\UserLabor;
  13. use Carbon\Carbon;
  14. class LaborReportService
  15. {
  16. //根据进场记录创建临时工报表
  17. public function makeLaborReportByUserDutyCheck($userDutyCheck){
  18. $dateNow=Carbon::now()->format('Y-m-d');
  19. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  20. if (!$laborReport){
  21. $newReport=$userDutyCheck->laborEnterCheck();
  22. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  23. if ($newReport){
  24. event(new ImportEvent($userDutyCheck));
  25. }
  26. }
  27. }
  28. //根据进出场打卡记录 创建或者更新临时工报表记录
  29. public function makeOrChangeLaborReportByUserDutyCheck($userDutyCheck,$importAndExportQRCodeType){
  30. $dateNow=Carbon::now()->format('Y-m-d');
  31. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  32. //判断当前日期下临时工是否有临时工报表记录并且是进场打卡
  33. if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
  34. $newReport=$userDutyCheck->makeEnteringRecord();
  35. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  36. if ($newReport) event(new ImportEvent($userDutyCheck));
  37. }
  38. if(!$laborReport&&$importAndExportQRCodeType=='export'){
  39. //退场时间跨天情况
  40. $yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
  41. $laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
  42. if (!$laborReportYesterday->check_out_at&&$laborReportYesterday['user_workgroup_id']){
  43. 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();
  44. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  45. }
  46. $exportReport=LaborReport::exitAndChangeLaborReport($laborReportYesterday,$userDutyCheck);
  47. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
  48. if ($exportReport) event(new ExportEvent($userDutyCheck));
  49. }
  50. if($laborReport&&$importAndExportQRCodeType=='export'){
  51. if (!$laborReport['check_out_at']&&$laborReport['user_workgroup_id']){
  52. 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();
  53. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  54. }
  55. $exportReport=LaborReport::exitAndChangeLaborReport($laborReport,$userDutyCheck);
  56. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  57. if ($exportReport) event(new ExportEvent($userDutyCheck));
  58. }
  59. }
  60. //补卡出场更新临时工报表信息
  61. public function exportReplenishToCreateLaborReportData($laborReport,$userDutyCheck){
  62. $laborReportStatus=new LaborReportStatus([
  63. 'labor_report_id'=>$laborReport['id'],
  64. 'status'=>'已退场',
  65. 'created_at'=>$userDutyCheck['checked_at'],
  66. ]);
  67. $laborReportStatus->save();
  68. $check_in_at=$laborReport->check_in_at;
  69. $exit_at=$userDutyCheck->checked_at;
  70. $online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2);
  71. if ($laborReport->enter_at){
  72. $enter_at=$laborReport['enter_at'];
  73. $laborReport->online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($enter_at))/3600,2);
  74. }else{
  75. $laborReport->online_duration=$online_duration;
  76. }
  77. $laborReport->update();
  78. $laborReport->is_export=$laborReport->getIsExportAttribute();
  79. return $laborReport;
  80. }
  81. //当天第一次进工作组更新临时工报表
  82. public function enterGroupAndUpdateLaborReport($laborReport,$userWorkgroupID){
  83. $laborReport->user_workgroup_id=$userWorkgroupID;
  84. $laborReport->check_in_at=date('Y-m-d H:i:s');
  85. $laborReport->update();
  86. return $laborReport;
  87. }
  88. //换组添加临时工报表数据
  89. public function changeGroupAndMakeLaborReport($user_id,$userWorkgroupID){
  90. $laborReportBefore=LaborReport::where('user_id',$user_id)->orderby('id','desc')->first();
  91. if ($laborReportBefore&&$laborReportBefore['status']!='已退场')$userDutyCheck=$laborReportBefore->userDutyCheck;
  92. $userDetail=UserDetail::find($user_id);
  93. $name=$userDetail['full_name'];
  94. $mobile_phone=$userDetail['mobile_phone'];
  95. $identity_number=$userDetail['identity_number'];
  96. $labor_company_id=UserLabor::where('user_id',$user_id)->value('labor_company_id');
  97. $labor_company=LaborCompany::where('id',$labor_company_id)->value('name');
  98. $laborReport=new LaborReport([
  99. 'user_workgroup_id'=>$userWorkgroupID,
  100. 'user_id'=>$user_id,
  101. 'name'=>$name,
  102. 'mobile_phone'=>$mobile_phone,
  103. 'identity_number'=>$identity_number,
  104. 'labor_company'=>$labor_company,
  105. 'check_in_at'=>date('Y-m-d H:i:s'),
  106. 'user_duty_check_id'=>$userDutyCheck->id,
  107. ]);
  108. $laborReport['enter_number']=$laborReport->makeOrGetEnteringNumber();
  109. $laborReport->save();
  110. $laborReportStatus=new LaborReportStatus([
  111. 'labor_report_id'=>$laborReport['id'],
  112. 'status'=>'已换组',
  113. ]);
  114. $laborReportStatus->save();
  115. return $laborReport;
  116. }
  117. }