|
|
@@ -49,6 +49,7 @@ class UserDutyCheckController extends Controller
|
|
|
$user_id = Cache::get('dutyCheckTokenStr_' . $userLaborToken);
|
|
|
$userDetail = UserDetail::find($user_id);
|
|
|
if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/' . $userDetail->mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
|
|
|
+ if($importAndExportQRCodeType=='import') return redirect('personnel/checking-in/userDutyCheck/updateUserLaborCompanies/' . $userDetail->mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
|
|
|
$userDutyCheck = $this->importAndExportDutyCheck($user_id, $importAndExportQRCodeType);
|
|
|
if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
|
|
|
if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
|
|
|
@@ -77,9 +78,9 @@ class UserDutyCheckController extends Controller
|
|
|
$lastDate = Carbon::parse($userDutyCheckOld['checked_at']);
|
|
|
$thisDate = Carbon::parse($date);
|
|
|
$diffDate = $thisDate->diffInMinutes($lastDate);
|
|
|
- //七天未登录从新选择劳务所
|
|
|
- if ($diffDate > 7 * 1440) {
|
|
|
- return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/' . $mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
|
|
|
+ //未登录从新选择劳务所
|
|
|
+ if ($diffDate > 0.5 * 1440 ||!$userDutyCheckOld) {
|
|
|
+ return redirect('personnel/checking-in/userDutyCheck/updateUserLaborCompanies/' . $mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
|
|
|
}
|
|
|
$userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id, $importAndExportQRCodeType);
|
|
|
if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
|
|
|
@@ -146,7 +147,6 @@ class UserDutyCheckController extends Controller
|
|
|
$userDutyCheck->save();
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
-
|
|
|
//去往登记资料页面
|
|
|
public function createUserDetail($mobile_phone)
|
|
|
{
|
|
|
@@ -154,17 +154,16 @@ class UserDutyCheckController extends Controller
|
|
|
$laborCompanies = LaborCompany::select('id', 'name')->get();
|
|
|
return view('personnel/checking-in/createUserDetail', ['mobile_phone' => $mobile_phone, 'importAndExportQRCodeType' => $importAndExportQRCodeType, 'laborCompanies' => $laborCompanies]);
|
|
|
}
|
|
|
-
|
|
|
- //七天未打卡去往选择劳务所页面
|
|
|
- public function updateUserDetail($mobile_phone)
|
|
|
+ //未打卡去往选择劳务所页面
|
|
|
+ public function updateUserLaborCompanies($mobile_phone)
|
|
|
{
|
|
|
$importAndExportQRCodeType = session("importAndExportQRCodeType");
|
|
|
$laborCompanies = LaborCompany::select('id', 'name')->get();
|
|
|
- return view('personnel/checking-in/updateUserDetail', ['mobile_phone' => $mobile_phone, 'importAndExportQRCodeType' => $importAndExportQRCodeType, 'laborCompanies' => $laborCompanies]);
|
|
|
+ return view('personnel/checking-in/updateUserLaborCompanies', ['mobile_phone' => $mobile_phone, 'importAndExportQRCodeType' => $importAndExportQRCodeType, 'laborCompanies' => $laborCompanies]);
|
|
|
}
|
|
|
|
|
|
//打卡修改临时工劳务所信息并生成进场记录 AndMakeEnterRecord
|
|
|
- public function storeUpdateUserDetail(Request $request)
|
|
|
+ public function storeUpdateUserLaborCompanies(Request $request)
|
|
|
{
|
|
|
$this->updateValidator($request)->validate();
|
|
|
$importAndExportQRCodeType = $request->input('importAndExportQRCodeType');
|
|
|
@@ -178,12 +177,16 @@ class UserDutyCheckController extends Controller
|
|
|
]);
|
|
|
$this->log(__METHOD__, "更改临时工劳务所信息" . __FUNCTION__, json_encode($userLabor), Auth::user()['id']);
|
|
|
$userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id,$importAndExportQRCodeType);
|
|
|
+ if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
|
|
|
+ if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
|
|
|
+ if ($userDutyCheck && $userDutyCheck->export == true) return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
|
|
|
+ if (!$userDutyCheck) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
+ $userLaborToken = $userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
|
|
|
$laborReportService = app('LaborReportService');
|
|
|
- $laborReportService->makeLaborReportByUserDutyCheck($userDutyCheck);
|
|
|
+ $laborReportService->makeOrChangeLaborReportByUserDutyCheck($userDutyCheck, $importAndExportQRCodeType);
|
|
|
$laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
- $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
|
|
|
return response()->view('personnel/checking-in/importAndExportSuccess',['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'),'/');
|
|
|
+ ->cookie('userLaborToken', $userLaborToken, config('users.token_check_in_expire_minutes'), '/');
|
|
|
}
|
|
|
|
|
|
public function updateValidator(Request $request)
|
|
|
@@ -285,50 +288,34 @@ class UserDutyCheckController extends Controller
|
|
|
$html=$this->updateLaborReport($user_id,$userWorkgroupID);
|
|
|
if ($html)return $html;
|
|
|
}
|
|
|
- //return view("personnel/checking-in/clock", compact('userWorkgroupID'));
|
|
|
+ return "<h1 style='color: red;text-align:center'>进场还未打卡,暂无法进组!</h1>";
|
|
|
}
|
|
|
- public function updateLaborReport($user_id,$userWorkgroupID){
|
|
|
+ public function updateLaborReport($user_id,$userWorkgroupID)
|
|
|
+ {
|
|
|
$userDetail = UserDetail::find($user_id);
|
|
|
$group_name = UserWorkgroup::where('id', $userWorkgroupID)->value('name');
|
|
|
$laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
$laborReportService = app('LaborReportService');
|
|
|
//判断是否是第一次进组
|
|
|
- $laborReport = LaborReport::where('user_id', $user_id)->where('user_workgroup_id', null)->where('created_at', 'like',Carbon::now()->format('Y-m-d'). '%')->orderBy('id', 'desc')->first();
|
|
|
+ $laborReport = LaborReport::where('user_id', $user_id)->where('user_workgroup_id', null)->where('created_at', 'like', Carbon::now()->format('Y-m-d') . '%')->orderBy('id', 'desc')->first();
|
|
|
if ($laborReport) {
|
|
|
$newLaborReport = $laborReportService->enterGroupAndUpdateLaborReport($laborReport, $userWorkgroupID);
|
|
|
$this->log(__METHOD__, "当日首次进组更新临时工报表记录__" . __FUNCTION__, json_encode($userWorkgroupID));
|
|
|
if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
- if ($newLaborReport) {
|
|
|
- event(new ClockinEvent($newLaborReport));
|
|
|
- }
|
|
|
- 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]);
|
|
|
+ if ($newLaborReport) event(new ClockinEvent($newLaborReport));
|
|
|
} else {
|
|
|
//换组判断上一条临时工报表信息是否退组
|
|
|
- $laborReportNow = LaborReport::where('user_id', $user_id)->whereNotNull('user_workgroup_id')->orderBy('id', 'desc')->first();
|
|
|
- if ($laborReportNow&&$laborReportNow['group_user_id']&&!$laborReportNow['check_out_at']) return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可换组,请联系之前组长!</h1>";
|
|
|
- if ($laborReportNow && $laborReportNow['user_workgroup_id']==$userWorkgroupID) return "<h1 style='color: darkred;text-align:center'>您已进组,不可再次进组!</h1>";
|
|
|
- $laborReport = LaborReport::where('user_id', $user_id)->where('user_workgroup_id', $userWorkgroupID)->where('created_at', 'like', Carbon::now()->format('Y-m-d'). '%')->orderBy('id', 'desc')->first();
|
|
|
- //此处表示临时工当日换组操作
|
|
|
- if (!$laborReport) {
|
|
|
- $newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
|
|
|
- $this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
|
|
|
- if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
- if ($newLaborReport) {
|
|
|
- event(new ClockinEvent($newLaborReport));
|
|
|
- }
|
|
|
- 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]);
|
|
|
- } else if ($laborReport['enter_number'] != $laborReportNow['enter_number']) {
|
|
|
- $newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
|
|
|
- $this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
|
|
|
- if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
- if ($newLaborReport) {
|
|
|
- event(new ClockinEvent($newLaborReport));
|
|
|
- }
|
|
|
- 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]);
|
|
|
- } else {
|
|
|
- return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
- }
|
|
|
+ $laborReportNow = LaborReport::where('user_id', $user_id)->orderBy('id', 'desc')->first();
|
|
|
+ if ($laborReportNow['group_user_id'] && !$laborReportNow['check_out_at']) return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可换组,请联系之前组长!</h1>";
|
|
|
+ if ($laborReportNow['user_workgroup_id'] == $userWorkgroupID) return "<h1 style='color: darkred;text-align:center'>您已进组,不可再次进组!</h1>";
|
|
|
+ //if (!$laborReportNow['group_user_id']) return "<h1 style='color: darkred;text-align:center'>换组前是否已经其他组!</h1>";
|
|
|
+ //此处表示临时工换组操作
|
|
|
+ $newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
|
|
|
+ $this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
|
|
|
+ if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
+ if ($newLaborReport) event(new ClockinEvent($newLaborReport));
|
|
|
}
|
|
|
+ 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]);
|
|
|
}
|
|
|
|
|
|
|
|
|
@@ -347,10 +334,29 @@ class UserDutyCheckController extends Controller
|
|
|
|
|
|
|
|
|
|
|
|
+//$laborReport = LaborReport::where('user_id', $user_id)->where('user_workgroup_id', $userWorkgroupID)->where('created_at', 'like', Carbon::now()->format('Y-m-d'). '%')->orderBy('id', 'desc')->first();
|
|
|
+// //此处表示临时工当日换组操作
|
|
|
+//if (!$laborReport) {
|
|
|
+//$newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
|
|
|
+//$this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
|
|
|
+//if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
+//if ($newLaborReport) {
|
|
|
+//event(new ClockinEvent($newLaborReport));
|
|
|
+//}
|
|
|
+//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]);
|
|
|
+//} else if ($laborReport['enter_number'] != $laborReportNow['enter_number']) {
|
|
|
+// $newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
|
|
|
+// $this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
|
|
|
+// if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
+// if ($newLaborReport) {
|
|
|
+// event(new ClockinEvent($newLaborReport));
|
|
|
+// }
|
|
|
+// 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]);
|
|
|
+//} else {
|
|
|
+// return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
+//}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
- //进组提交打卡
|
|
|
+ //进组提交打卡
|
|
|
// public function importGroupClock(Request $request)
|
|
|
// {
|
|
|
// $mobile_phone = $request->input('mobile_phone');
|
|
|
@@ -395,4 +401,4 @@ class UserDutyCheckController extends Controller
|
|
|
// }
|
|
|
|
|
|
|
|
|
-}
|
|
|
+ }
|