You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
213 lines
8.5 KiB
213 lines
8.5 KiB
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | Niucloud-admin 企业快速开发的多应用管理平台
|
|
// +----------------------------------------------------------------------
|
|
// | 官方网址:https://www.niucloud.com
|
|
// +----------------------------------------------------------------------
|
|
// | niucloud团队 版权所有 开源版本可自由商用
|
|
// +----------------------------------------------------------------------
|
|
// | Author: Niucloud Team
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace app\api\controller\apiController;
|
|
|
|
use app\Request;
|
|
use app\service\admin\campus\CampusService;
|
|
use app\service\api\apiService\AttendanceService;
|
|
use app\service\api\apiService\CommonService;
|
|
use core\base\BaseApiService;
|
|
use think\facade\Db;
|
|
|
|
/**
|
|
* 员工考勤控制器相关接口
|
|
* Class Personnel
|
|
* @package app\api\controller\apiController
|
|
*/
|
|
class Attendance extends BaseApiService
|
|
{
|
|
|
|
//列表
|
|
public function index(Request $request){
|
|
|
|
$where = [
|
|
'campus_id' => $request->param('campus_id', ''),//
|
|
'staff_id' => $request->param('staff_id', ''),//
|
|
'attendance_date' => $request->param('attendance_date', ''),//
|
|
'status' => $request->param('status', ''),//
|
|
'status_arr' => $request->param('status_arr', []),//
|
|
];
|
|
|
|
$res = (new AttendanceService())->getList($where);
|
|
return success($res);
|
|
}
|
|
|
|
//员工考勤-编辑(员工打卡/请假/签退)
|
|
public function edit(Request $request){
|
|
$id =$request->param('id','');//考勤表id
|
|
$campus_id =$request->param('campus_id','');//校区ID
|
|
$staff_id =$this->member_id;//人员ID
|
|
$attendance_date =$request->param('attendance_date','');//考勤日期
|
|
$leave_start_time =$request->param('leave_start_time','');//请假开始时间
|
|
$leave_end_time =$request->param('leave_end_time','');//请假结束时间
|
|
$remarks =$request->param('remarks','');//备注
|
|
$status =$request->param('status','');//考勤状态: present-出勤, absent-缺勤, late-迟到, leave_early-早退,leave-请假,sign_out-签退
|
|
$longitude = $request->param('longitude','');//经度
|
|
$latitude = $request->param('latitude','');//纬度
|
|
$coordinate = '';//坐标
|
|
if(!empty($longitude) && !empty($latitude)){
|
|
$coordinate = "{$longitude},{$latitude}";
|
|
}else{
|
|
return fail('缺少定位坐标');
|
|
}
|
|
|
|
if(empty($attendance_date) || empty($status)){
|
|
return fail('缺少参数');
|
|
}
|
|
|
|
if(!in_array($status,['present','absent','late','leave_early','leave','sign_out'])){
|
|
return fail('状态类型不正确');
|
|
}
|
|
|
|
|
|
//判断签到+签退时是否超出打卡范围
|
|
if(in_array($status,['present','sign_out']) && !empty($campus_id)){
|
|
//获取校区的经纬度坐标
|
|
$campus_data = (new CampusService)->getInfo($campus_id);//查校区详情
|
|
$campus_lng = $campus_data['campus_coordinates']['lng'];//校区经度坐标
|
|
$campus_lat = $campus_data['campus_coordinates']['lat'];//校区纬度坐标
|
|
$radius = 1500.0;//打卡半径(米)
|
|
|
|
$isInCheckRange = (new CommonService())->isInCheckRange((float)$campus_lng, (float)$campus_lat, (float)$longitude, (float)$latitude, (float)$radius);//判断是否在打卡范围内
|
|
if(!$isInCheckRange){
|
|
return fail("超出打卡范围,规定打卡范围({$radius}米)");
|
|
}
|
|
}
|
|
|
|
|
|
//查询数据是否存在,一天一个校区同一个人可能有多条打卡记录数据,只要有1条打卡没签退就不能新增新的打卡记录
|
|
$date_h = date('H:i:s');
|
|
|
|
$obj = (new AttendanceService());
|
|
$info = $obj->info([
|
|
'id'=>$id,
|
|
'campus_id'=>$campus_id,
|
|
'staff_id'=>$staff_id,
|
|
'attendance_date'=>$attendance_date,
|
|
])['data'];
|
|
|
|
|
|
//判断是打卡
|
|
if($status == 'present'){
|
|
$model = new \app\model\attendance\Attendance();
|
|
$model = $model->where('staff_id',$staff_id)->where('status','present');
|
|
if($campus_id === '0' || $campus_id === 0 || !empty($campus_id)){
|
|
$model = $model->where('campus_id',$campus_id);
|
|
}
|
|
if(!empty($attendance_date)){
|
|
$model = $model->where('attendance_date',$attendance_date);
|
|
}
|
|
|
|
// 获取今天所有考勤记录
|
|
$records = $model->order('id', 'desc')->select()->toArray();
|
|
// Step 1: 检查是否有未签退的记录
|
|
foreach ($records as $record) {
|
|
if (empty($record['check_out_time'])) {
|
|
return fail('今日有签到记录未签退,请先签退后再试');
|
|
}
|
|
}
|
|
|
|
//获取今天请假的数据(leave_end_time>当前时间的 && attendance_date=当前日期的)请假数据,更新leave_end_time=当前时间
|
|
//请假的id
|
|
$leave_id_arr = new \app\model\attendance\Attendance();
|
|
if($campus_id === '0' || $campus_id === 0 || !empty($campus_id)){
|
|
$leave_id_arr = $leave_id_arr->where('campus_id',$campus_id);
|
|
}
|
|
$leave_id_arr = $leave_id_arr->where('staff_id',$staff_id)
|
|
->where('status','leave')
|
|
->where('attendance_date',$attendance_date)
|
|
->where('leave_end_time','>=',$date_h)->column('id');
|
|
|
|
Db::startTrans();
|
|
try {
|
|
if($leave_id_arr){
|
|
$update = \app\model\attendance\Attendance::whereIn('id',$leave_id_arr)->update([
|
|
'leave_end_time'=>$date_h,
|
|
'updated_at'=>$date_h,
|
|
]);
|
|
if(!$update){
|
|
// Db::rollback();
|
|
// return fail('更新请假数据失败');
|
|
}
|
|
}
|
|
|
|
//插入打卡记录
|
|
$data = [
|
|
'campus_id'=>$campus_id ?? 0,//
|
|
'staff_id'=>$staff_id,//
|
|
'attendance_date'=>$attendance_date,//
|
|
'check_in_time'=>$date_h,//
|
|
'status'=>$status,//
|
|
'coordinate'=>$coordinate,//坐标|经度,纬度
|
|
'remarks'=>$remarks,//
|
|
];
|
|
$res = $obj->addData($data);
|
|
Db::commit();
|
|
if(!$res['code']){
|
|
Db::rollback();
|
|
return fail($res['msg']);
|
|
}
|
|
return success($res['data']);
|
|
}catch (\Exception $e){
|
|
Db::rollback();
|
|
return fail('操作失败');
|
|
}
|
|
}
|
|
//判断是签退
|
|
if($status == 'sign_out'){
|
|
if($info['attendance_date'] != $attendance_date && $info['status'] != 'present'){
|
|
return fail('为找到今日签到记录');
|
|
}
|
|
|
|
//签退的情况
|
|
$where = [
|
|
'id'=>$info['id']
|
|
];
|
|
$data = [
|
|
'check_out_time'=>$date_h,//签退时间
|
|
'coordinate'=>$coordinate,//坐标|经度,纬度
|
|
'remarks' => $remarks,//
|
|
];
|
|
//执行修改操作
|
|
$res = $obj->editData($where,$data);
|
|
if(!$res['code']){
|
|
return fail($res['msg']);
|
|
}
|
|
return success($res['data']);
|
|
}
|
|
//判断是请假
|
|
if($status == 'leave'){
|
|
//判断今日是否存在打卡记录,判断今日的打开记录是否已经签退,是则不可以再请假了
|
|
if($info && $info['status'] == 'present' && $info['attendance_date'] == $attendance_date && !empty($info['check_out_time'])){
|
|
return fail('今日已签退,无法进行请假操作');
|
|
}
|
|
|
|
$data = [
|
|
'campus_id' => $campus_id ?? 0,
|
|
'staff_id' => $staff_id,
|
|
'attendance_date' => $attendance_date,
|
|
'leave_start_time' => $leave_start_time,
|
|
'leave_end_time' => $leave_end_time,
|
|
'status' => $status,
|
|
'coordinate' => $coordinate,
|
|
'remarks' => $remarks,
|
|
];
|
|
|
|
//创建请假记录
|
|
$res = $obj->addData($data);
|
|
if(!$res['code']){
|
|
return fail($res['msg']);
|
|
}
|
|
return success($res['data']);
|
|
}
|
|
}
|
|
}
|
|
|