UserDutyCheckController.php 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Events\ClockinEvent;
  4. use App\Events\ClockoutEvent;
  5. use App\Events\ExportEvent;
  6. use App\Events\ImportEvent;
  7. use App\LaborCompany;
  8. use App\LaborReport;
  9. use App\User;
  10. use App\UserDetail;
  11. use App\UserDutyCheck;
  12. use App\UserLabor;
  13. use App\UserWorkgroup;
  14. use Carbon\Carbon;
  15. use Illuminate\Http\Request;
  16. use Illuminate\Support\Facades\Auth;
  17. use Illuminate\Support\Facades\Cache;
  18. use Illuminate\Support\Facades\Validator;
  19. use Ramsey\Uuid\Uuid;
  20. class UserDutyCheckController extends Controller
  21. {
  22. //校验二维码进入进出场打卡页面
  23. public function importAndExportClock(Request $request){
  24. $importAndExportQRCodeType=$request->input('importAndExportQRCodeType');
  25. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  26. $qrCode_refresh=config('hr.qrCode_refresh');
  27. if ($qrCode_refresh_everyday){
  28. $key=$request->input('key');
  29. if (!$key) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  30. $date=md5(date('Y-m-d'));
  31. if ($key!=$date) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  32. }
  33. if ($qrCode_refresh){
  34. $key=$request->input('key');
  35. if (!$key) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  36. $date=date('Y-m-d H:i:s');
  37. if ($key<$date) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  38. }
  39. $userLaborToken=$request->cookie('userLaborToken');
  40. if ($userLaborToken && Cache::has('dutyCheckTokenStr_'.$userLaborToken)) {
  41. $user_id=Cache::get('dutyCheckTokenStr_'.$userLaborToken);
  42. $userDetail=UserDetail::find($user_id);
  43. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("importAndExportQRCodeType",$importAndExportQRCodeType);
  44. $userDutyCheck=$this->importAndExportDutyCheck($user_id,$importAndExportQRCodeType);
  45. if ($userDutyCheck&&$userDutyCheck->isNotImport==true)return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  46. if ($userDutyCheck&&$userDutyCheck->import==true)return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  47. if ($userDutyCheck&&$userDutyCheck->export==true)return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  48. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  49. $dateNow=Carbon::now()->format('Y-m-d');
  50. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  51. //判断当前日期下临时工是否有临时工报表记录并且是进场打卡
  52. if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
  53. $newReport=LaborReport::importToCreateLaborReportData($userDutyCheck);
  54. $this->log(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  55. if ($newReport) event(new ImportEvent($userDutyCheck));
  56. }
  57. else if(!$laborReport&&$importAndExportQRCodeType=='export'){
  58. //退场时间跨天情况
  59. $yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
  60. $laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
  61. if (!$laborReportYesterday->check_out_at){
  62. UserDutyCheck::where('user_id',$laborReportYesterday->user_id)->where('type','登出')->orderBy('id','desc')->where('checked_at','like',Carbon::now()->format('Y-m-d H:i').'%')->delete();
  63. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  64. }
  65. if ($laborReportYesterday){
  66. $exportReport=LaborReport::exportToCreateLaborReportData($laborReportYesterday,$userDutyCheck);
  67. $this->log(__METHOD__,"退场建临时工报表记录__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
  68. if ($exportReport) event(new ExportEvent($userDutyCheck));
  69. }
  70. }else if($laborReport&&$importAndExportQRCodeType=='export'){
  71. if (!$laborReport->check_out_at){
  72. 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();
  73. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  74. }
  75. $exportReport=LaborReport::exportToCreateLaborReportData($laborReport,$userDutyCheck);
  76. $this->log(__METHOD__,"退场建临时工报表记录__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  77. if ($exportReport) event(new ExportEvent($userDutyCheck));
  78. }
  79. $laravelEchoPrefix = config('database.redis.options.prefix');
  80. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix]);
  81. }
  82. return view("personnel/checking-in/importAndExportClock",compact('importAndExportQRCodeType'));
  83. }
  84. //提交进出场打卡
  85. public function storeClock(Request $request){
  86. $importAndExportQRCodeType=$request->input('importAndExportQRCodeType');
  87. $mobile_phone=$request->input('mobile_phone');
  88. $this->validator($request)->validate();
  89. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  90. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("importAndExportQRCodeType",$importAndExportQRCodeType);
  91. if (Cache::has('dutyCheckTokenUser_'.$userDetail->user_id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  92. $userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  93. $date=date('Y-m-d H:i:s');
  94. $lastDate=Carbon::parse($userDutyCheckOld['checked_at']);
  95. $thisDate=Carbon::parse($date);
  96. $diffDate=$thisDate->diffInMinutes($lastDate);
  97. //七天未登录从新选择劳务所
  98. if ($diffDate>7*1440){
  99. return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("importAndExportQRCodeType",$importAndExportQRCodeType);
  100. }
  101. $userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id,$importAndExportQRCodeType);
  102. if ($userDutyCheck&&$userDutyCheck->isNotImport==true)return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  103. if ($userDutyCheck&&$userDutyCheck->import==true)return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  104. if ($userDutyCheck&&$userDutyCheck->export==true)return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  105. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  106. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  107. $dateNow=Carbon::now()->format('Y-m-d');
  108. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  109. // if (!$laborReport){
  110. // $newReport=LaborReport::importToCreateLaborReportData($userDutyCheck);
  111. // $this->log(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  112. // if ($newReport) event(new ImportEvent($userDutyCheck));
  113. // }
  114. //判断当前日期下临时工是否有临时工报表记录并且是进场打卡
  115. if ($userDutyCheck->type=='登入'&&$importAndExportQRCodeType=='import'){
  116. $newReport=LaborReport::importToCreateLaborReportData($userDutyCheck);
  117. $this->log(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  118. if ($newReport) event(new ImportEvent($userDutyCheck));
  119. }
  120. else if(!$laborReport&&$importAndExportQRCodeType=='export'){
  121. //退场时间跨天情况
  122. $yesterdayDate=Carbon::now()->subDays(1)->format('Y-m-d');
  123. $laborReportYesterday=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$yesterdayDate.'%')->orderBy('id','desc')->first();
  124. if (!$laborReportYesterday->check_out_at){
  125. 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();
  126. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  127. }
  128. if ($laborReportYesterday){
  129. $exportReport=LaborReport::exportToCreateLaborReportData($laborReportYesterday,$userDutyCheck);
  130. $this->log(__METHOD__,"退场建临时工报表记录__".__FUNCTION__,json_encode([$laborReportYesterday,$userDutyCheck]));
  131. if ($exportReport) event(new ExportEvent($userDutyCheck));
  132. }
  133. }else if($laborReport&&$importAndExportQRCodeType=='export'){
  134. if (!$laborReport->check_out_at){
  135. 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();
  136. return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可退场,请联系组长!</h1>";
  137. }
  138. $exportReport=LaborReport::exportToCreateLaborReportData($laborReport,$userDutyCheck);
  139. $this->log(__METHOD__,"退场建临时工报表记录__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  140. if ($exportReport) event(new ExportEvent($userDutyCheck));
  141. }
  142. $laravelEchoPrefix = config('database.redis.options.prefix');
  143. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  144. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  145. }
  146. //根据用户提交进出场打卡记录
  147. public function importAndExportDutyCheck($user_id,$importAndExportQRCodeType){
  148. $dateNow=Carbon::now()->format('Y-m-d');
  149. $userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->where('checked_at','like',$dateNow.'%')->orderBy('id','desc')->limit(10)->first();
  150. $date=date('Y-m-d H:i:s');
  151. $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode([$user_id,$date]));
  152. $userDutyCheck=new UserDutyCheck([
  153. 'user_id'=>$user_id,
  154. 'checked_at'=>$date,
  155. 'source'=>'正常',
  156. ]);
  157. if (!$userDutyCheckOld){
  158. //跨天登出情况
  159. if ($importAndExportQRCodeType&&$importAndExportQRCodeType=='export'){
  160. //当前日期的前一天
  161. $yesterday=Carbon::yesterday()->format('Y-m-d');
  162. $userDutyCheckYesterday=UserDutyCheck::where('user_id',$user_id)->where('checked_at','like',$yesterday.'%')->orderBy('id','desc')->limit(10)->first();
  163. if ($userDutyCheckYesterday&&$userDutyCheckYesterday->type=='登入'){
  164. $userDutyCheck->type='登出';
  165. $userDutyCheck->save();
  166. return $userDutyCheck;
  167. }
  168. }
  169. if ($importAndExportQRCodeType=='export'){
  170. $userDutyCheck->isNotImport=true;//还未进场,不可出场
  171. return$userDutyCheck;
  172. }
  173. $userDutyCheck->type="登入";
  174. $userDutyCheck->save();
  175. return $userDutyCheck;
  176. }
  177. if ($importAndExportQRCodeType&&$importAndExportQRCodeType=='import'){
  178. if ($userDutyCheckOld->type=='登入'){
  179. $userDutyCheck->import=true;//已入场的不能再入场
  180. return $userDutyCheck;
  181. }
  182. $userDutyCheck->type='登入';
  183. }
  184. if ($importAndExportQRCodeType&&$importAndExportQRCodeType=='export'){
  185. if ($userDutyCheckOld->type=='登出'){
  186. $userDutyCheck->export=true;//已出场的不能再出场
  187. return $userDutyCheck;
  188. }
  189. $userDutyCheck->type='登出';
  190. }
  191. $userDutyCheck->save();
  192. return $userDutyCheck;
  193. }
  194. //去往登记资料页面
  195. public function createUserDetail($mobile_phone){
  196. $importAndExportQRCodeType=session("importAndExportQRCodeType");
  197. $laborCompanies=LaborCompany::select('id','name')->get();
  198. return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'importAndExportQRCodeType'=>$importAndExportQRCodeType,'laborCompanies'=>$laborCompanies]);
  199. }
  200. //七天未打卡去往选择劳务所页面
  201. public function updateUserDetail($mobile_phone){
  202. $importAndExportQRCodeType=session("importAndExportQRCodeType");
  203. $laborCompanies=LaborCompany::select('id','name')->get();
  204. return view('personnel/checking-in/updateUserDetail',['mobile_phone'=>$mobile_phone,'importAndExportQRCodeType'=>$importAndExportQRCodeType,'laborCompanies'=>$laborCompanies]);
  205. }
  206. //提交临时工修改资料
  207. public function storeUpdateUserDetail(Request $request){
  208. $this->updateValidator($request)->validate();
  209. $importAndExportQRCodeType=$request->input('importAndExportQRCodeType');
  210. $mobile_phone=$request->input('mobile_phone');
  211. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  212. if (!$userDetail)return view('exception.404',['error'=>'临时工信息不存在!']);
  213. $labor_company_id=$request->input('labor_company_id');
  214. $userLabor=UserLabor::where('user_id',$userDetail->user_id)->first();
  215. $userLabor->update([
  216. 'labor_company_id'=>$labor_company_id,
  217. ]);
  218. $this->log(__METHOD__,"更改临时工劳务所信息".__FUNCTION__,json_encode($userLabor),Auth::user()['id']);
  219. $userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id,$importAndExportQRCodeType);
  220. $dateNow=Carbon::now()->format('Y-m-d');
  221. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  222. if (!$laborReport){
  223. $newReport=LaborReport::importToCreateLaborReportData($userDutyCheck);
  224. $this->log(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  225. if ($newReport){
  226. event(new ImportEvent($userDutyCheck));
  227. }
  228. }
  229. if ($userDutyCheck&&$userDutyCheck->import==true)return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  230. if ($userDutyCheck&&$userDutyCheck->export==true)return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  231. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  232. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  233. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  234. $laravelEchoPrefix = config('database.redis.options.prefix');
  235. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  236. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  237. }
  238. public function updateValidator(Request $request){
  239. $updateValidator=Validator::make($request->input(),[
  240. 'mobile_phone'=>['required','integer','digits:11'],
  241. 'labor_company_id'=>['filled'],
  242. ],[
  243. 'filled' => ':attribute 不能为空',
  244. 'required'=>':attribute 为必填项',
  245. 'integer'=>':attribute 数字类型',
  246. 'digits'=>':attribute 必须是11位',
  247. ],[
  248. 'mobile_phone'=>'手机号',
  249. 'labor_company_id'=>'劳务所',
  250. ]);
  251. return $updateValidator;
  252. }
  253. //提交登记资料
  254. public function storeUserDetail(Request $request){
  255. $this->validator($request)->validate();
  256. $importAndExportQRCodeType=$request->input('importAndExportQRCodeType');
  257. $mobile_phone=$request->input('mobile_phone');
  258. $full_name=$request->input('full_name');
  259. $identity_number=$request->input('identity_number');
  260. $user=new User([
  261. 'name'=>$mobile_phone,
  262. 'password'=>Uuid::uuid1(),
  263. ]);
  264. $user->save();
  265. $userDetail=new UserDetail([
  266. 'user_id'=>$user->id,
  267. 'full_name'=>$full_name,
  268. 'identity_number'=>$identity_number,
  269. 'gender'=>$request->input('gender'),
  270. 'mobile_phone'=>$mobile_phone,
  271. 'type'=>'临时工',
  272. ]);
  273. $userDetail->save();
  274. $labor_company_id=$request->input('labor_company_id');
  275. $userLabor=new UserLabor([
  276. 'user_id'=>$user->id,
  277. 'labor_company_id'=>$labor_company_id,
  278. ]);
  279. $userLabor->save();
  280. $userDutyCheck=$this->importAndExportDutyCheck($user->id,$importAndExportQRCodeType);
  281. $dateNow=Carbon::now()->format('Y-m-d');
  282. $laborReport=LaborReport::where('user_id',$userDutyCheck->user_id)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  283. if (!$laborReport){
  284. $newReport=LaborReport::importToCreateLaborReportData($userDutyCheck);
  285. $this->log(__METHOD__,"进场创建临时工报表记录__".__FUNCTION__,json_encode([$userDutyCheck]));
  286. if ($newReport){
  287. event(new ImportEvent($userDutyCheck));
  288. }
  289. }
  290. if ($userDutyCheck&&$userDutyCheck->import==true)return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  291. if ($userDutyCheck&&$userDutyCheck->export==true)return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  292. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  293. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  294. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  295. $laravelEchoPrefix = config('database.redis.options.prefix');
  296. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  297. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  298. }
  299. public function validator(Request $request){
  300. $validator=Validator::make($request->input(),[
  301. 'full_name'=>['filled'],
  302. 'gender'=>['filled'],
  303. 'mobile_phone'=>['required','integer','digits:11'],
  304. 'identity_number' => ['filled','identity_cards','unique:user_details,identity_number'],
  305. 'labor_company_id'=>['filled'],
  306. ],[
  307. 'unique'=>':attribute 已经存在,不能重复!',
  308. 'filled' => ':attribute 不能为空',
  309. 'required'=>':attribute 为必填项',
  310. 'integer'=>':attribute 数字类型',
  311. 'digits'=>':attribute 必须是11位',
  312. ],[
  313. 'full_name'=>'姓名',
  314. 'gender'=>'性别',
  315. 'mobile_phone'=>'手机号',
  316. 'identity_number' => '身份证号',
  317. 'labor_company_id'=>'劳务所',
  318. ]);
  319. return $validator;
  320. }
  321. //校验工作组二维码进入打卡页面
  322. public function clock(Request $request){
  323. $userWorkgroupID=$request->input('userWorkgroupID');
  324. $userLaborToken=$request->cookie('userLaborToken');
  325. if ($userLaborToken && Cache::has('dutyCheckTokenStr_'.$userLaborToken)) {
  326. $user_id=Cache::get('dutyCheckTokenStr_'.$userLaborToken);
  327. $userDetail=UserDetail::find($user_id);
  328. $dateNow=Carbon::now()->format('Y-m-d');
  329. $group_name=UserWorkgroup::where('id',$userWorkgroupID)->value('name');
  330. $laravelEchoPrefix = config('database.redis.options.prefix');
  331. $userDutyCheck=UserDutyCheck::where('user_id',$userDetail->user_id)->where('checked_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  332. if(!$userDutyCheck->verify_user_id)return "<h1 style='color: red;text-align:center'>进场门卫还未审核,暂无法进组!</h1>";
  333. if($userDutyCheck->type=='登出')return "<h1 style='color: red;text-align:center'>进场是否未打卡?如若未打,请先返回打进场卡!</h1>";
  334. //判断是否是第一次进组
  335. $laborReport=LaborReport::where('user_id',$user_id)->where('user_workgroup_id',null)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  336. if ($laborReport){
  337. $newLaborReport=LaborReport::intoGroupAndUpdateLaborReportData($laborReport,$userWorkgroupID);
  338. $this->log(__METHOD__,"当日首次进组更新临时工报表记录__".__FUNCTION__,json_encode($request->all()));
  339. if (!$newLaborReport)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  340. if ($newLaborReport){
  341. event(new ClockinEvent($newLaborReport));
  342. }
  343. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'check_in_at'=>$newLaborReport->check_in_at,'laravelEchoPrefix'=>$laravelEchoPrefix]);
  344. }else{
  345. //换组判断上一条临时工报表信息是否退组
  346. $laborReportNow=LaborReport::where('user_id',$user_id)->whereNotNull('group_user_id')->orderBy('id','desc')->first();
  347. if ($laborReportNow&&!$laborReportNow['check_out_at'])return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可换组,请联系之前组长!</h1>";
  348. $laborReport=LaborReport::where('user_id',$user_id)->where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  349. //此处表示临时工当日换组操作
  350. if (!$laborReport){
  351. $newLaborReport=LaborReport::changeGroupAndCreateLaborReportData($user_id,$userWorkgroupID);
  352. $this->log(__METHOD__,"当日临时工换组新建临时工报表记录__".__FUNCTION__,json_encode([$user_id,$userWorkgroupID]));
  353. if (!$newLaborReport)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  354. if ($newLaborReport){
  355. event(new ClockinEvent($newLaborReport));
  356. }
  357. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'check_in_at'=>$newLaborReport->check_in_at,'laravelEchoPrefix'=>$laravelEchoPrefix]);
  358. }else{
  359. return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  360. }
  361. }
  362. }
  363. return view("personnel/checking-in/clock",compact('userWorkgroupID'));
  364. }
  365. //进组提交打卡
  366. public function importGroupClock(Request $request){
  367. $mobile_phone=$request->input('mobile_phone');
  368. $userWorkgroupID=$request->input('userWorkgroupID');
  369. $this->validator($request)->validate();
  370. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  371. if (Cache::has('dutyCheckTokenUser_'.$userDetail->user_id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  372. $dateNow=Carbon::now()->format('Y-m-d');
  373. $group_name=UserWorkgroup::where('id',$userWorkgroupID)->value('name');
  374. $laravelEchoPrefix = config('database.redis.options.prefix');
  375. $userDutyCheck=UserDutyCheck::where('user_id',$userDetail->user_id)->where('checked_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  376. if(!$userDutyCheck->verify_user_id)return "<h1 style='color: red;text-align:center'>进场门卫还未审核,暂无法进组!</h1>";
  377. if($userDutyCheck->type=='登出')return "<h1 style='color: red;text-align:center'>进场是否未打卡?如若未打,请先返回打进场卡!</h1>";
  378. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  379. //判断是否是第一次进组
  380. $laborReport=LaborReport::where('user_id',$userDetail->user_id)->where('user_workgroup_id',null)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  381. if ($laborReport){
  382. $newLaborReport=LaborReport::intoGroupAndUpdateLaborReportData($laborReport,$userWorkgroupID);
  383. $this->log(__METHOD__,"当日首次进组更新临时工报表记录__".__FUNCTION__,json_encode($request->all()));
  384. if (!$newLaborReport)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  385. if ($newLaborReport){
  386. event(new ClockinEvent($newLaborReport));
  387. }
  388. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'check_in_at'=>$newLaborReport->check_in_at,'laravelEchoPrefix'=>$laravelEchoPrefix]);
  389. }else{
  390. $laborReport=LaborReport::where('user_id',$userDetail->user_id)->where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  391. //此处表示临时工当日换组操作
  392. if (!$laborReport){
  393. $newLaborReport=LaborReport::changeGroupAndCreateLaborReportData($userDetail->user_id,$userWorkgroupID);
  394. $this->log(__METHOD__,"当日临时工换组新建临时工报表记录__".__FUNCTION__,json_encode([$userDetail->user_id,$userWorkgroupID]));
  395. if (!$newLaborReport)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  396. if ($newLaborReport){
  397. event(new ClockinEvent($newLaborReport));
  398. }
  399. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'check_in_at'=>$newLaborReport->check_in_at,'laravelEchoPrefix'=>$laravelEchoPrefix])
  400. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  401. }else{
  402. return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  403. }
  404. }
  405. }
  406. // //根据用户提交打卡记录
  407. // public function dutyCheck($user_id,$userWorkgroupID){
  408. // $userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  409. // if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']){
  410. // $user=User::find($user_id);
  411. // $user->userWorkgroups()->sync([$userWorkgroupID]);
  412. // }
  413. // $date=date('Y-m-d H:i:s');
  414. // $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode([$user_id,$userWorkgroupID,$date]));
  415. // $userDutyCheck=new UserDutyCheck([
  416. // 'user_id'=>$user_id,
  417. // 'checked_at'=>$date,
  418. // 'source'=>'正常',
  419. // 'verify_user_id'=>'',
  420. // 'workgroup_id'=>$userWorkgroupID,
  421. // ]);
  422. // if (!$userDutyCheckOld){
  423. // $userDutyCheck->type="登入";
  424. // $userDutyCheck->save();
  425. // return $userDutyCheck;
  426. // }
  427. // $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
  428. // $thisDate=Carbon::parse($date);
  429. // $diffDate=$thisDate->diffInMinutes($lastDate);
  430. //// if ($userDutyCheckOld->type=="登出"&&$diffDate<7*1440){
  431. //// $userDutyCheck->type="登入";
  432. //// $userDutyCheck->verify_user_id=0;
  433. //// $userDutyCheck->save();
  434. //// return $userDutyCheck;
  435. //// }
  436. // if($diffDate<=5){
  437. // $userDutyCheck->error=true;//重复打卡
  438. // if($userWorkgroupID!=$userDutyCheckOld['workgroup_id']&&$userDutyCheckOld->type=='登入'){
  439. // if ($userDutyCheck->error){
  440. // $userDutyCheck->error=false;
  441. // }
  442. // $userDutyCheckOld->checked_at=$date;
  443. // $userDutyCheckOld->verify_user_id=null;
  444. // $userDutyCheckOld->workgroup_id=$userWorkgroupID;
  445. // $userDutyCheckOld->group_user_id=null;
  446. // $userDutyCheckOld->update();
  447. // return $userDutyCheckOld;
  448. // }
  449. // return $userDutyCheck;
  450. // }
  451. // if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']&&$userDutyCheckOld->type=="登入"&&$userDutyCheck->type="登出"){
  452. // if ($diffDate>=1380){
  453. // $userDutyCheck->type="登入";
  454. // }else{
  455. // $userDutyCheck->workgroup_id=$userDutyCheckOld['workgroup_id'];
  456. // }
  457. //
  458. // }
  459. // if ($userDutyCheckOld->type=="登入"){
  460. // switch ($diffDate){
  461. // case $diffDate<=20:
  462. // $userDutyCheck->type="登入";
  463. // $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
  464. // break;
  465. // case $diffDate>=1380:
  466. // $userDutyCheck->type="登入";
  467. // break;
  468. // default:
  469. // $userDutyCheck->type="登出";
  470. // $userDutyCheck->verify_user_id=0;
  471. // }
  472. // }
  473. // if ($userDutyCheckOld->type=="登出"){
  474. // switch ($diffDate){
  475. // case $diffDate<=20:
  476. // $userDutyCheck->type="登出";
  477. // $userDutyCheck->verify_user_id=0;
  478. // $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
  479. // break;
  480. // default:
  481. // $userDutyCheck->type="登入";
  482. // }
  483. // }
  484. // $userDutyCheck->save();
  485. // return $userDutyCheck;
  486. // }
  487. //进组提交打卡
  488. // public function importGroupClock(Request $request){
  489. // $mobile_phone=$request->input('mobile_phone');
  490. // $userWorkgroupID=$request->input('userWorkgroupID');
  491. // $this->validator($request)->validate();
  492. // $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  493. // if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  494. // if (Cache::has('dutyCheckTokenUser_'.$userDetail->user_id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  495. // $userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  496. // $date=date('Y-m-d H:i:s');
  497. // $lastDate=Carbon::parse($userDutyCheckOld['checked_at']);
  498. // $thisDate=Carbon::parse($date);
  499. // $diffDate=$thisDate->diffInMinutes($lastDate);
  500. // $dateNow=Carbon::now()->format('Y-m-d');
  501. // //七天未登录从新选择劳务所
  502. // if ($diffDate>7*1440){
  503. // return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  504. // }
  505. // $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
  506. // if ($userDutyCheck&&$userDutyCheck->type=='登入'){
  507. // event(new ClockinEvent($userDutyCheck));
  508. // }else if ($userDutyCheck&&$userDutyCheck->type=='登出'){
  509. // event(new ClockoutEvent($userDutyCheck));
  510. // }
  511. // //正常情况
  512. // $laborReport=LaborReport::where('user_workgroup_id',$userDutyCheck->workgroup_id)->where('user_id',$userDutyCheck->user_id)->orderBy('id','desc')->first();
  513. // if ($laborReport&&$userDutyCheck->type=='登出'){
  514. // LaborReport::updateLaborReportData($laborReport,$userDutyCheck);
  515. // $this->log(__METHOD__,"更新临时工报表记录__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  516. // }
  517. // if ($userDutyCheck&&$userDutyCheck->error==true)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  518. // if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  519. // $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  520. // $group_name=$userDutyCheck->userWorkgroup['name'];
  521. // $laravelEchoPrefix = config('database.redis.options.prefix');
  522. // return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  523. // ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  524. // }
  525. }