LaborReportService.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  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\User;
  11. use App\UserDetail;
  12. use App\UserDutyCheck;
  13. use App\UserLabor;
  14. use Carbon\Carbon;
  15. use Illuminate\Database\Eloquent\Builder;
  16. use Illuminate\Http\Request;
  17. use Illuminate\Support\Facades\Auth;
  18. use Illuminate\Support\Facades\DB;
  19. use Illuminate\Support\Facades\Gate;
  20. use App\Traits\ServiceAppAop;
  21. class LaborReportService
  22. {
  23. use ServiceAppAop;
  24. protected $modelClass=LaborReport::class;
  25. private function conditionQuery(array $params){
  26. $user=Auth::user();
  27. $laborReports=LaborReport::query()
  28. ->with(['user','userDutyCheck','userWorkgroup.signs','laborCompany','laborReportStatus','laborReports'])->orderBy('labor_reports.id','DESC');
  29. if (!($params["is_export"] ?? false)&&!($params['id']??null)){
  30. $laborReports = $laborReports->whereNotIn('labor_reports.enter_number',function ($builder)use($params){
  31. $builder->select('enter_number')->from('labor_reports')
  32. ->leftJoin('labor_report_statuses','labor_reports.id','labor_report_statuses.labor_report_id')
  33. ->where('labor_report_statuses.status','已退场');
  34. });
  35. }else unset($params['is_export']);
  36. $columnQueryRules=[
  37. 'enter_number' => ['batch'=>'','timeLimit' => 15],
  38. 'created_at_start' => ['alias' => 'created_at' , 'startDate' => ' 00:00:00'],
  39. 'created_at_end' => ['alias' => 'created_at' , 'endDate' => ' 23:59:59'],
  40. 'identity_number' => ['batch'=>'','timeLimit' => 15],
  41. 'name' => ['batch' => ''],
  42. 'mobile_phone' => ['batch' => ''],
  43. 'user_workgroup_id' => ['multi' => ','],
  44. 'labor_company_id' => ['multi' => ','],
  45. 'id' => ['multi' => ',']
  46. ];
  47. // if((Gate::allows('人事管理-临时工报表-可见全部组')||Gate::allows('人事管理-门卫审核')) && !($params["user_workgroup_id"] ?? false)){
  48. if(Gate::allows('人事管理-门卫审核') && !($params["user_workgroup_id"] ?? false)){
  49. $laborReports->where(function ($query)use($user){
  50. $query->whereIn('labor_reports.user_workgroup_id',$user?$user->getPermittingWorkgroupIds(Gate::allows('人事管理-临时工报表-可见全部组')):[])
  51. ->whereIn('labor_reports.labor_company_id',$user?$user->getPermittingLaborCompanyIdsAttribute():[])
  52. ->orWhereNull('labor_reports.user_workgroup_id');
  53. });
  54. }else{
  55. $laborReports->whereIn('labor_reports.user_workgroup_id',$user?$user->getPermittingWorkgroupIds(Gate::allows('人事管理-临时工报表-可见全部组')):[])
  56. ->whereIn('labor_reports.labor_company_id',$user?$user->getPermittingLaborCompanyIdsAttribute():[]);
  57. }
  58. $laborReports = app(QueryService::class)->query($params,$laborReports,$columnQueryRules,'labor_reports');
  59. return $laborReports;
  60. }
  61. public function recycleQuery(array $params){
  62. $query=LaborReport::query()->with(['user','userDutyCheck','userWorkgroup','laborCompany'])->orderByDesc('id')->onlyTrashed();
  63. $rule=['name' => ['batch' => ''],];
  64. $laborReports = app(QueryService::class)->query($params,$query,$rule,'labor_reports')->paginate($params['paginate'] ?? 50);
  65. return $laborReports;
  66. }
  67. public function paginate(array $params){
  68. return $this->conditionQuery($params)->paginate($params['paginate'] ?? 50);
  69. }
  70. public function get(array $params){
  71. return $this->conditionQuery($params)->without("userDutyCheck")->get();
  72. }
  73. public function getSql(array $params){
  74. return $this->conditionQuery($params)->selectRaw("labor_reports.*")
  75. ->leftJoin('user_workgroups','labor_reports.user_workgroup_id','user_workgroups.id')
  76. ->selectRaw('user_workgroups.name user_workgroup_name')
  77. ->leftJoin('labor_companies','labor_reports.labor_company_id','labor_companies.id')
  78. ->selectRaw('labor_companies.name labor_company')
  79. ->sql();
  80. }
  81. //根据进场记录创建临时工报表
  82. public function makeLaborReportByUserDutyCheck($userDutyCheck){
  83. $dateNow=Carbon::now()->format('Y-m-d');
  84. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  85. if (!$laborReport){
  86. $newReport=$userDutyCheck->makeEnteringRecord();
  87. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  88. if ($newReport) event(new ImportEvent($newReport));
  89. }
  90. }
  91. //根据进出场打卡记录 创建或者更新临时工报表记录
  92. public function makeOrChangeLaborReportByUserDutyCheck($userDutyCheck,$importAndExportQRCodeType){
  93. $dateNow=Carbon::now()->format('Y-m-d');
  94. $laborReport=LaborReport::query()->where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  95. //判断当前日期下临时工是否有临时工报表记录并且是进场打卡
  96. if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
  97. $newReport=$userDutyCheck->makeEnteringRecord();
  98. Controller::logS(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  99. if ($newReport) event(new ImportEvent($newReport));
  100. }
  101. if(!$laborReport&&$importAndExportQRCodeType=='export'){
  102. //退场时间跨天情况
  103. $yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
  104. $laborReportYesterday=LaborReport::query()->where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
  105. if ($laborReportYesterday){
  106. if (!$laborReportYesterday->check_out_at&&$laborReportYesterday['user_workgroup_id']){
  107. 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();
  108. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  109. }
  110. $exportReport=LaborReport::exitAndChangeLaborReport($laborReportYesterday,$userDutyCheck);
  111. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
  112. if ($exportReport) event(new ExportEvent($exportReport));
  113. }
  114. }
  115. if($laborReport&&$importAndExportQRCodeType=='export'){
  116. if (!$laborReport['check_out_at']&&$laborReport['user_workgroup_id']){
  117. 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();
  118. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  119. }
  120. $exportReport=LaborReport::exitAndChangeLaborReport($laborReport,$userDutyCheck);
  121. Controller::logS(__METHOD__,"退场更改临时工报表信息__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  122. if ($exportReport) event(new ExportEvent($exportReport));
  123. }
  124. }
  125. //补卡出场更新临时工报表信息
  126. public function exportReplenishToCreateLaborReportData($laborReport,$userDutyCheck){
  127. $laborReportStatus=new LaborReportStatus([
  128. 'labor_report_id'=>$laborReport['id'],
  129. 'status'=>'已退场',
  130. 'created_at'=>$userDutyCheck['checked_at'],
  131. ]);
  132. $laborReportStatus->save();
  133. $check_in_at=$laborReport->check_in_at;
  134. $exit_at=$userDutyCheck->checked_at;
  135. $online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($check_in_at))/3600,2);
  136. $laborReport->user_duty_check_id=$userDutyCheck->id;
  137. if ($laborReport->enter_at){
  138. $enter_at=$laborReport['enter_at'];
  139. $laborReport->online_duration=round(Carbon::parse($exit_at)->diffInSeconds(Carbon::parse($enter_at))/3600,2);
  140. }else{
  141. $laborReport->online_duration=$online_duration;
  142. }
  143. $laborReport->update();
  144. $laborReport->is_export=true;
  145. return $laborReport;
  146. }
  147. //当天第一次进工作组更新临时工报表
  148. public function enterGroupAndUpdateLaborReport($laborReport,$userWorkgroupID){
  149. $laborReport->user_workgroup_id=$userWorkgroupID;
  150. $laborReport->check_in_at=date('Y-m-d H:i:s');
  151. $laborReport->update();
  152. return $laborReport;
  153. }
  154. //换组添加临时工报表数据
  155. public function changeGroupAndMakeLaborReport($user_id,$userWorkgroupID){
  156. $laborReportBefore=LaborReport::where('user_id',$user_id)->orderby('id','desc')->first();
  157. if ($laborReportBefore&&$laborReportBefore['status']!='已退场')$userDutyCheck=$laborReportBefore->userDutyCheck;
  158. if ($laborReportBefore&&!$laborReportBefore['group_user_id']){
  159. if ($laborReportBefore['user_workgroup_id']!=$userWorkgroupID){
  160. $laborReportBefore['user_workgroup_id']=$userWorkgroupID;
  161. $laborReportBefore['check_in_at']=Carbon::now()->format('Y-m-d H:i:s');
  162. $laborReportBefore->update();
  163. return $laborReportBefore;
  164. }
  165. }
  166. $userDetail=UserDetail::find($user_id);
  167. $name=$userDetail['full_name'];
  168. $mobile_phone=$userDetail['mobile_phone'];
  169. $identity_number=$userDetail['identity_number'];
  170. $labor_company_id=UserLabor::where('user_id',$user_id)->value('labor_company_id');
  171. $laborReport=new LaborReport([
  172. 'user_workgroup_id'=>$userWorkgroupID,
  173. 'user_id'=>$user_id,
  174. 'name'=>$name,
  175. 'mobile_phone'=>$mobile_phone,
  176. 'identity_number'=>$identity_number,
  177. 'labor_company_id'=>$labor_company_id,
  178. 'check_in_at'=>date('Y-m-d H:i:s'),
  179. 'user_duty_check_id'=>$userDutyCheck->id,
  180. ]);
  181. $laborReport['enter_number']=$laborReport->makeOrGetEnteringNumber();
  182. $laborReport->save();
  183. $laborReportStatus=new LaborReportStatus([
  184. 'labor_report_id'=>$laborReport['id'],
  185. 'status'=>'已换组',
  186. ]);
  187. $laborReportStatus->save();
  188. return $laborReport;
  189. }
  190. public function 修改劳务所($param){
  191. $laborReports=LaborReport::query()->where('enter_number',$param['enter_number'])->get();
  192. foreach($laborReports as $laborReport){
  193. $laborReport->labor_company_id=$param['laborCompanyId'];
  194. $laborReport->update();
  195. }
  196. Controller::logS(__METHOD__,'修改临时工报表劳务所'.__FUNCTION__,json_encode($param));
  197. }
  198. public function 删除($id){
  199. $laborReport=LaborReport::query()->where('id',$id)->delete();
  200. // if ($laborReport>0)LaborReportStatus::create([
  201. // 'labor_report_id'=>$id,
  202. // 'status'=>'已删除',
  203. // ]);
  204. Controller::logS(__METHOD__,'删除临时工报表记录'.__FUNCTION__,json_encode($id));
  205. return $laborReport;
  206. }
  207. public function addOrUpdateRemark($remark,$id){
  208. return LaborReport::query()->updateOrCreate(['id'=>$id],['remark'=>$remark]);
  209. }
  210. }