|
|
@@ -16,101 +16,28 @@ use Endroid\QrCode\QrCode;
|
|
|
use Illuminate\Http\Request;
|
|
|
use Illuminate\Http\Response;
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
+use Illuminate\Support\Facades\Date;
|
|
|
use Illuminate\Support\Facades\Validator;
|
|
|
use Ramsey\Uuid\Uuid;
|
|
|
|
|
|
class UserDutyCheckController extends Controller
|
|
|
{
|
|
|
- public function goGetQRCode(){
|
|
|
- $warehouses=Warehouse::get();
|
|
|
- return view("personnel/checking-in/getQRcode",compact('warehouses'));
|
|
|
- }
|
|
|
- //二维码刷新时间
|
|
|
- public function qrCode_refresh_time($userWorkgroups,$beforeTime){
|
|
|
- $qrCode_refresh=config('hr.qrCode_refresh');
|
|
|
- if (!Cache::has('last_refresh_date') || Cache::get('last_refresh_date')<date('Y-m-d H:i:s')){
|
|
|
- $last_refresh_date=date('Y-m-d H:i:s',strtotime('+'.$qrCode_refresh.'second'));
|
|
|
- Cache::put('last_refresh_date',$last_refresh_date);
|
|
|
- return $this->flushQRCode($userWorkgroups);
|
|
|
- }
|
|
|
- if ($beforeTime==Cache::get('last_refresh_date')){
|
|
|
- //刷新 更新cache
|
|
|
- $last_refresh_date=$beforeTime.strtotime('+'.$qrCode_refresh.'second');
|
|
|
- Cache::put('last_refresh_date',$last_refresh_date);
|
|
|
- return $this->flushQRCode($userWorkgroups);
|
|
|
- }
|
|
|
- //每次刷新都标记一个cache 新建 每次刷新前判断这个标记时间
|
|
|
- //直接去本地获取二维码
|
|
|
- return $this->getQRCode($userWorkgroups);
|
|
|
- }
|
|
|
- //刷新二维码
|
|
|
- public function flushQRCode($userWorkgroups){
|
|
|
- foreach ($userWorkgroups as $userWorkgroup){
|
|
|
- $url=url("personnel/checking-in/userDutyCheck/clock");
|
|
|
- $url=$url."?userWorkgroupID=".$userWorkgroup->id;
|
|
|
- $qrCode=new QrCode($url);
|
|
|
- if ($userWorkgroup->id){
|
|
|
- $fileURL=base_path('public/images/QRCodeIMG/'.$userWorkgroup->id.'.png');
|
|
|
- $qrCode->writeFile($fileURL);
|
|
|
- $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
|
|
|
- }
|
|
|
- }
|
|
|
- return $userWorkgroups;
|
|
|
- }
|
|
|
- //获取二维码
|
|
|
- public function getQRCode($userWorkgroups){
|
|
|
- foreach ($userWorkgroups as $userWorkgroup){
|
|
|
- $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
|
|
|
- if ($qrCode_refresh_everyday){
|
|
|
- $date=md5(date('Y-m-d'));
|
|
|
- $url=url("personnel/checking-in/userDutyCheck/clock?key=").$date;
|
|
|
- $url=$url."&&userWorkgroupID=".$userWorkgroup->id;
|
|
|
- }else{
|
|
|
- $url=url("personnel/checking-in/userDutyCheck/clock");
|
|
|
- $url=$url."?userWorkgroupID=".$userWorkgroup->id;
|
|
|
- }
|
|
|
- $qrCode=new QrCode($url);
|
|
|
- if ($userWorkgroup->id){
|
|
|
- $fileURL=base_path('public/images/QRCodeIMG/'.$userWorkgroup->id.'.png');
|
|
|
- if (file_exists($fileURL)){
|
|
|
- $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
|
|
|
- continue;
|
|
|
- }
|
|
|
- $qrCode->writeFile($fileURL);
|
|
|
- $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
|
|
|
- }
|
|
|
- }
|
|
|
- return $userWorkgroups;
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
- //进入刷新二维码页面
|
|
|
- public function refreshQRCode(Request $request){
|
|
|
- $beforeTime=$request->input('beforeTime');
|
|
|
- $warehouseId=$request->input('warehouseId');
|
|
|
- $userWorkgroups=UserWorkgroup::where('warehouse_id',$warehouseId)->get();
|
|
|
- $userWorkgroups=$this->qrCode_refresh_time($userWorkgroups,$beforeTime);
|
|
|
- if (!$userWorkgroups)return view('exception.404',['error'=>'未找到工作组!']);
|
|
|
- return ['userWorkgroups'=>$userWorkgroups,'last_refresh_date'=>Cache::get('last_refresh_date'),];
|
|
|
- }
|
|
|
- //第一次进入二维码显示页面
|
|
|
- public function QRCode(Request $request){
|
|
|
- $warehouseId=$request->input('warehouseId');
|
|
|
- $userWorkgroups=UserWorkgroup::where('warehouse_id',$warehouseId)->get();
|
|
|
- $beforeTime=date('Y-m-d H:i:s');
|
|
|
- $userWorkgroups=$this->qrCode_refresh_time($userWorkgroups,$beforeTime);
|
|
|
- if (!$userWorkgroups)return view('exception.404',['error'=>'未找到工作组!']);
|
|
|
- return view('personnel/checking-in/QRcode',['warehouseId'=>$warehouseId,'userWorkgroups'=>$userWorkgroups,'last_refresh_date'=>Cache::get('last_refresh_date'),]);
|
|
|
- }
|
|
|
//校验二维码进入打卡页面
|
|
|
public function clock(Request $request){
|
|
|
$userWorkgroupID=$request->input('userWorkgroupID');
|
|
|
$qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
|
|
|
+ $qrCode_refresh=config('hr.qrCode_refresh');
|
|
|
if ($qrCode_refresh_everyday){
|
|
|
$key=$request->input('key');
|
|
|
- if (!$key) return "二维码失效!";
|
|
|
+ if (!$key) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
$date=md5(date('Y-m-d'));
|
|
|
- if ($key!=$date) return "二维码失效!";
|
|
|
+ if ($key!=$date) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
+ }
|
|
|
+ if ($qrCode_refresh){
|
|
|
+ $key=$request->input('key');
|
|
|
+ if (!$key) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
+ $date=date('Y-m-d:H:i');
|
|
|
+ if ($key!=$date) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
}
|
|
|
$userLaborToken=$request->cookie('userLaborToken');
|
|
|
if ($userLaborToken && Cache::has('tokenStr_'.$userLaborToken)) {
|
|
|
@@ -121,7 +48,7 @@ class UserDutyCheckController extends Controller
|
|
|
$user=UserToken::getUser($userLaborToken);
|
|
|
$user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
}
|
|
|
- $userDutyCheck=$this->dutyCheck($userDetail->user_id);
|
|
|
+ $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
$userWorkgroups=$userDetail->user->userWorkgroups();
|
|
|
@@ -143,22 +70,33 @@ class UserDutyCheckController extends Controller
|
|
|
$user=User::find($userDetail->user_id);
|
|
|
if (Cache::has('tokenUser_'.$user->id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
|
|
|
if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
+
|
|
|
$userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
|
|
|
$date=date('Y-m-d H:i:s');
|
|
|
- $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
|
|
|
+ $lastDate=Carbon::parse($userDutyCheckOld['checked_at']);
|
|
|
$thisDate=Carbon::parse($date);
|
|
|
$diffDate=$thisDate->diffInMinutes($lastDate);
|
|
|
+ $dateNow=Carbon::now()->format('Y-m-d');
|
|
|
//七天未登录从新选择劳务所
|
|
|
if ($diffDate>7*1440){
|
|
|
return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
|
|
|
}
|
|
|
- $userDutyCheck=$this->dutyCheck($userDetail->user_id);
|
|
|
- var_dump($userDutyCheck->type);
|
|
|
- if ($userDutyCheck->type=='登入'){
|
|
|
- $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
|
|
|
- }
|
|
|
- if ($userDutyCheck->type=='登出'){
|
|
|
- $this->updateLaborReportData($userDetail,$userDutyCheck);
|
|
|
+ $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
+ //24小时之内情况
|
|
|
+// if($diffDate<1440){
|
|
|
+// $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow."%")->where('user_id',$userDetail->user_id)->first();
|
|
|
+// if (!$laborReport&&$userDutyCheckOld->type=='登出'&&$userDutyCheck->type=='登入'){
|
|
|
+// $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
|
|
|
+// }else if ($laborReport&&$userDutyCheck->type=='登出'){
|
|
|
+// $this->updateLaborReportData($laborReport,$userDutyCheck);
|
|
|
+// }
|
|
|
+// }
|
|
|
+ //正常情况
|
|
|
+ $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow."%")->where('user_id',$userDetail->user_id)->first();
|
|
|
+ if(!$laborReport&&$userDutyCheck->type=='登入'){
|
|
|
+ $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
|
|
|
+ }else if ($laborReport&&$userDutyCheck->type=='登出'){
|
|
|
+ $this->updateLaborReportData($laborReport,$userDutyCheck);
|
|
|
}
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
@@ -195,7 +133,7 @@ class UserDutyCheckController extends Controller
|
|
|
'user_id'=>$user->id,
|
|
|
'labor_company_id'=>$labor_company_id,
|
|
|
]);
|
|
|
- $userDutyCheck=$this->dutyCheck($user->id);
|
|
|
+ $userDutyCheck=$this->dutyCheck($user->id,$userWorkgroupID);
|
|
|
//添加临时工报表数据
|
|
|
$this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
@@ -207,8 +145,6 @@ class UserDutyCheckController extends Controller
|
|
|
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])
|
|
|
->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
//提交登记资料
|
|
|
public function storeUserDetail(Request $request){
|
|
|
$this->validator($request)->validate();
|
|
|
@@ -238,7 +174,7 @@ class UserDutyCheckController extends Controller
|
|
|
'labor_company_id'=>$labor_company_id,
|
|
|
]);
|
|
|
$userLabor->save();
|
|
|
- $userDutyCheck=$this->dutyCheck($user->id);
|
|
|
+ $userDutyCheck=$this->dutyCheck($user->id,$userWorkgroupID);
|
|
|
$this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
@@ -251,7 +187,7 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
|
|
|
//根据用户提交打卡记录
|
|
|
- public function dutyCheck($user_id){
|
|
|
+ public function dutyCheck($user_id,$workgroup_id){
|
|
|
$userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
|
|
|
$date=date('Y-m-d H:i:s');
|
|
|
$userDutyCheck=new UserDutyCheck([
|
|
|
@@ -259,6 +195,7 @@ class UserDutyCheckController extends Controller
|
|
|
'checked_at'=>$date,
|
|
|
'source'=>'正常',
|
|
|
'verify_user_id'=>'',
|
|
|
+ 'workgroup_id'=>$workgroup_id,
|
|
|
]);
|
|
|
if (!$userDutyCheckOld){
|
|
|
$userDutyCheck->type="登入";
|
|
|
@@ -276,7 +213,9 @@ class UserDutyCheckController extends Controller
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
if ($diffDate>=1380&&$diffDate<7*1440){
|
|
|
+ $userDutyCheck->type="登入";
|
|
|
$userDutyCheck->verify_user_id=0;
|
|
|
+ $userDutyCheck->save();
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
if($diffDate<=5){
|
|
|
@@ -337,19 +276,14 @@ class UserDutyCheckController extends Controller
|
|
|
return;
|
|
|
}
|
|
|
//修改临时工报表数据
|
|
|
- public function updateLaborReportData($userDetail,$userDutyCheck){
|
|
|
- $check_in_at=UserDutyCheck::where('user_id',$userDetail->user_id)->where('type','登入')->value('checked_at');
|
|
|
- var_dump($check_in_at);
|
|
|
- $laborReport=LaborReport::where('check_in_at',$check_in_at)->first();
|
|
|
- var_dump($laborReport);
|
|
|
- $laborReport['check_out_at']=$userDutyCheck['checked_at'];
|
|
|
- var_dump($laborReport['check_out_at']);
|
|
|
+ public function updateLaborReportData($laborReport,$userDutyCheck){
|
|
|
+ $check_in_at=$laborReport['check_in_at'];
|
|
|
+ $laborReport->check_out_at=$userDutyCheck->checked_at;
|
|
|
$checkInDate=Carbon::parse($check_in_at);
|
|
|
$checkOutDate=Carbon::parse($userDutyCheck->checked_at);
|
|
|
- $diffDate=$checkOutDate->diffInHours($checkInDate);
|
|
|
- dd($diffDate);
|
|
|
- $laborReport['working_duration']=$diffDate;
|
|
|
- $laborReport->save();
|
|
|
+ $hour=($checkOutDate->diffInSeconds($checkInDate))/3600; //在线时长
|
|
|
+ $laborReport['online_duration']=$hour;
|
|
|
+ $laborReport->update();
|
|
|
return;
|
|
|
}
|
|
|
|