This commit is contained in:
zt
2025-03-07 14:45:49 +08:00
parent b0e8333724
commit 3ec18b78ae
50 changed files with 511 additions and 188 deletions

View File

@ -1,17 +1,17 @@
package com.ruoyi.web.controller.bgt; package com.ruoyi.web.controller.bgt;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDTO;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDetailDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDetailDTO;
import com.ruoyi.bgt.domain.vo.BgtAttendanceDetailVO; import com.ruoyi.bgt.domain.vo.*;
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
import com.ruoyi.bgt.domain.vo.BgtDayAttendanceCountVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService; import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.wgz.domain.WgzUser;
import com.ruoyi.wgz.service.IWgzAttendanceService; import com.ruoyi.wgz.service.IWgzAttendanceService;
import com.ruoyi.wgz.service.IWgzUserService;
import io.swagger.annotations.Api; import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
@ -33,30 +33,51 @@ public class AppBgtAttendanceController {
private final IBgtProjectRecruitApplyService iBgtProjectRecruitApplyService; private final IBgtProjectRecruitApplyService iBgtProjectRecruitApplyService;
private final IWgzUserService wgzUserService;
@ApiOperation("App包工头总体考勤情况-统计") @ApiOperation("总体考勤情况-统计")
@GetMapping("attendance") @GetMapping("/count")
public AjaxResult<BgtAttendanceVO> attendanceDetail(@Validated BgtAttendanceDTO dto) { public AjaxResult<BgtAttendanceVO> allCount(@Validated BgtAttendanceDTO dto) {
return AjaxResult.success(attendanceService.attendanceDetail(dto)); return AjaxResult.success(attendanceService.allCount(dto));
} }
@ApiOperation("App包工头总体考勤情况-柱状图") @ApiOperation("总体考勤情况-柱状图")
@GetMapping("attendanceList") @GetMapping("/histogram")
public AjaxResult<List<BgtDayAttendanceCountVO>> attendanceList(@Validated BgtAttendanceDTO dto) { public AjaxResult<List<BgtDayAttendanceCountVO>> histogram(@Validated BgtAttendanceDTO dto) {
return AjaxResult.success(attendanceService.attendanceList(dto)); return AjaxResult.success(attendanceService.histogram(dto));
} }
@ApiOperation("App包工头总体考勤情况-人员出勤情况") @ApiOperation("总体考勤情况-人员出勤情况")
@GetMapping("/todayAttendanceList") @GetMapping("/user")
public TableDataInfo<BgtProjectRecruitApplyVO> todayAttendanceList(@Validated BgtAttendanceDayDTO req) { public TableDataInfo<BgtProjectRecruitApplyVO> userList(@Validated BgtAttendanceDayDTO req) {
return iBgtProjectRecruitApplyService.dayAttendanceList(req); return iBgtProjectRecruitApplyService.userList(req);
} }
@ApiOperation("务工者个人考勤统计详情-基础信息")
@GetMapping("/person/baseInfo")
public AjaxResult<BgtAttendancePersonBaseInfoVO> baseInfo(@Validated BgtAttendanceDetailDTO dto) {
@ApiOperation("App包工头考勤统计详情") BgtAttendancePersonBaseInfoVO vo = new BgtAttendancePersonBaseInfoVO();
@GetMapping("attendanceDetail")
public AjaxResult<BgtAttendanceDetailVO> attendanceDetail(@Validated BgtAttendanceDetailDTO dto) { //务工者信息
return AjaxResult.success(attendanceService.bgtAttendanceDetail(dto)); WgzUser wgzUser = wgzUserService.findByUserId(dto.getUserId());
vo.setUserId(wgzUser.getUserId());
vo.setUsername(wgzUser.getUsername());
vo.setAvatarName(wgzUser.getAvatarName());
//务工者的申请信息
BgtProjectRecruitApply recruitApply = iBgtProjectRecruitApplyService.getOne(dto.getTaskId(),wgzUser.getUserId());
vo.setEntryTime(recruitApply.getEntryTime());
vo.setLeaveTime(recruitApply.getLeaveTime());
vo.setStatus(recruitApply.getStatus());
return AjaxResult.success(vo);
}
@ApiOperation("务工者个人考勤统计详情-统计数据")
@GetMapping("/person/count")
public AjaxResult<BgtAttendancePersonCountVO> personCount(@Validated BgtAttendanceDetailDTO dto) {
return AjaxResult.success(attendanceService.personCount(dto));
} }
} }

View File

@ -1,15 +1,21 @@
package com.ruoyi.web.controller.bgt; package com.ruoyi.web.controller.bgt;
import com.ruoyi.bgt.domain.BgtMessage; import com.ruoyi.bgt.domain.BgtMessage;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtMessageDetailDTO; import com.ruoyi.bgt.domain.dto.BgtMessageDetailDTO;
import com.ruoyi.bgt.domain.dto.BgtMessageMyListDTO; import com.ruoyi.bgt.domain.dto.BgtMessageMyListDTO;
import com.ruoyi.bgt.domain.vo.BgtMessageCountVO; import com.ruoyi.bgt.domain.vo.BgtMessageCountVO;
import com.ruoyi.bgt.domain.vo.BgtMessageDetailVO; import com.ruoyi.bgt.domain.vo.BgtMessageDetailVO;
import com.ruoyi.bgt.domain.vo.BgtMessageVO; import com.ruoyi.bgt.domain.vo.BgtMessageVO;
import com.ruoyi.bgt.service.IBgtMessageService; import com.ruoyi.bgt.service.IBgtMessageService;
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.RecruitApplyStatus;
import com.ruoyi.wgz.bo.req.WgzAppPersonalBasicInformationReq;
import com.ruoyi.wgz.bo.res.WgzAppPersonalBasicInformationRes;
import com.ruoyi.wgz.service.IWgzUserService;
import io.swagger.annotations.Api; import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
@ -30,6 +36,10 @@ public class AppBgtMessageController extends BaseController {
private final IBgtMessageService iBgtMessageService; private final IBgtMessageService iBgtMessageService;
private final IBgtProjectRecruitApplyService iBgtProjectRecruitApplyService;
private final IWgzUserService wgzUserService;
@ApiOperation("未读消息统计") @ApiOperation("未读消息统计")
@GetMapping("/countUnread") @GetMapping("/countUnread")
public AjaxResult<BgtMessageCountVO> count() { public AjaxResult<BgtMessageCountVO> count() {
@ -57,5 +67,16 @@ public class AppBgtMessageController extends BaseController {
return AjaxResult.success(iBgtMessageService.updateById(bgtMessage)); return AjaxResult.success(iBgtMessageService.updateById(bgtMessage));
} }
@ApiOperation("App务工者消息个人详情")
@GetMapping("/userInfo")
public AjaxResult<WgzAppPersonalBasicInformationRes> wgzMessageInformation(Long userId, Long recruitApplyId) {
WgzAppPersonalBasicInformationReq req = new WgzAppPersonalBasicInformationReq();
req.setUserId(userId);
WgzAppPersonalBasicInformationRes res = wgzUserService.userPersonalBasicInformation(req);
BgtProjectRecruitApply apply = iBgtProjectRecruitApplyService.getById(recruitApplyId);
res.setIsChoose(!apply.getStatus().equals(RecruitApplyStatus.SIGN_UP.getCode()));
return AjaxResult.success(res);
}
} }

View File

@ -1,6 +1,5 @@
package com.ruoyi.web.controller.bgt; package com.ruoyi.web.controller.bgt;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO; import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO; import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
@ -13,7 +12,6 @@ import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType; import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.enums.RecruitApplyStatus;
import com.ruoyi.wgz.bo.req.WgzAppPersonalBasicInformationReq; import com.ruoyi.wgz.bo.req.WgzAppPersonalBasicInformationReq;
import com.ruoyi.wgz.bo.res.WgzAppPersonalBasicInformationRes; import com.ruoyi.wgz.bo.res.WgzAppPersonalBasicInformationRes;
import com.ruoyi.wgz.service.IWgzUserService; import com.ruoyi.wgz.service.IWgzUserService;
@ -56,10 +54,11 @@ public class AppBgtProjectRecruitApplyController extends BaseController {
return iBgtProjectRecruitApplyService.appQueryPageList(dto); return iBgtProjectRecruitApplyService.appQueryPageList(dto);
} }
@ApiOperation("App务工者列表") @ApiOperation("App务工者列表")
@GetMapping("/listAll") @GetMapping("/listAll")
public AjaxResult<List<BgtProjectRecruitApplyVO>> list(@Validated BgtProjectRecruitApplyQueryDTO dto) { public AjaxResult<List<BgtProjectRecruitApplyVO>> list(@Validated BgtProjectRecruitApplyQueryDTO dto) {
return AjaxResult.success(iBgtProjectRecruitApplyService.appQueryList(dto)); return AjaxResult.success(iBgtProjectRecruitApplyService.appAllList(dto));
} }
@ApiOperation("App务工者个人详情") @ApiOperation("App务工者个人详情")
@ -68,18 +67,6 @@ public class AppBgtProjectRecruitApplyController extends BaseController {
return AjaxResult.success(wgzUserService.userPersonalBasicInformation(req)); return AjaxResult.success(wgzUserService.userPersonalBasicInformation(req));
} }
@ApiOperation("App务工者消息个人详情")
@GetMapping("/userMessageInfo")
public AjaxResult<WgzAppPersonalBasicInformationRes> wgzMessageInformation(Long userId,Long recruitId) {
WgzAppPersonalBasicInformationReq req = new WgzAppPersonalBasicInformationReq();
req.setUserId(userId);
WgzAppPersonalBasicInformationRes res = wgzUserService.userPersonalBasicInformation(req);
BgtProjectRecruitApply one = iBgtProjectRecruitApplyService.getOne(Wrappers.<BgtProjectRecruitApply>lambdaQuery()
.eq(BgtProjectRecruitApply::getUserId, userId)
.eq(BgtProjectRecruitApply::getRecruitId, recruitId));
res.setIsChoose(!one.getStatus().equals(RecruitApplyStatus.SIGN_UP.getCode()));
return AjaxResult.success(res);
}
@ApiOperation("App务工者招工报名") @ApiOperation("App务工者招工报名")
@Log(title = "App务工者招工报名", businessType = BusinessType.INSERT) @Log(title = "App务工者招工报名", businessType = BusinessType.INSERT)
@ -98,7 +85,6 @@ public class AppBgtProjectRecruitApplyController extends BaseController {
} }
@ApiOperation("App务工者退场") @ApiOperation("App务工者退场")
@Log(title = "App务工者退场", businessType = BusinessType.UPDATE) @Log(title = "App务工者退场", businessType = BusinessType.UPDATE)
@RepeatSubmit @RepeatSubmit

View File

@ -1,10 +1,13 @@
package com.ruoyi.web.controller.bgt; package com.ruoyi.web.controller.bgt;
import com.ruoyi.bgt.domain.BgtProjectRecruit; import com.ruoyi.bgt.domain.BgtProjectRecruit;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyUserDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitQueryDTO; import com.ruoyi.bgt.domain.dto.BgtProjectRecruitQueryDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailWgzListVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailWgzListVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitVO;
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
import com.ruoyi.bgt.service.IBgtProjectRecruitService; import com.ruoyi.bgt.service.IBgtProjectRecruitService;
import com.ruoyi.common.annotation.Log; import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.annotation.RepeatSubmit; import com.ruoyi.common.annotation.RepeatSubmit;
@ -20,6 +23,7 @@ import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
import java.util.List;
/** /**
* 包工头招工Controller * 包工头招工Controller
@ -35,38 +39,46 @@ public class AppBgtProjectRecruitController extends BaseController {
private final IBgtProjectRecruitService iBgtProjectRecruitService; private final IBgtProjectRecruitService iBgtProjectRecruitService;
private final IBgtProjectRecruitApplyService iBgtProjectRecruitApplyService;
/** /**
* 查询包工头招工列表 状态为通过和报名 * 查询包工头招工列表 状态为通过和报名
*/ */
@ApiOperation(value = "我的招工",notes = "1.查询包工头招工列表 状态为通过(1)和报名(0)") @ApiOperation(value = "我的招工(分页)",notes = "1.查询包工头招工列表 状态为通过(1)和报名(0)")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<BgtProjectRecruitVO> list(@Validated BgtProjectRecruitQueryDTO dto) { public TableDataInfo<BgtProjectRecruitVO> list(@Validated BgtProjectRecruitQueryDTO dto) {
return iBgtProjectRecruitService.appQueryPageList(dto); return iBgtProjectRecruitService.appQueryPageList(dto);
} }
@ApiOperation(value = "我的招工列表",notes = "1.查询包工头招工列表 状态为通过(1)和报名(0)")
@GetMapping("/allList")
public AjaxResult<List<BgtProjectRecruit>> allList() {
return AjaxResult.success(iBgtProjectRecruitService.appQueryList());
}
/** /**
* 获取包工头招工详细信息 * 获取包工头招工详细信息
*/ */
@ApiOperation("我的招工任务详情") @ApiOperation("我的招工任务详情-基础信息")
@GetMapping("/{id}") @GetMapping("/{id}")
public AjaxResult<BgtProjectRecruitDetailVO> getInfo(@NotNull(message = "主键不能为空") public AjaxResult<BgtProjectRecruitDetailVO> getInfo(@NotNull(message = "主键不能为空")
@PathVariable("id") Long id) { @PathVariable("id") Long id) {
return AjaxResult.success(iBgtProjectRecruitService.appQueryById(id)); return AjaxResult.success(iBgtProjectRecruitService.appQueryById(id));
} }
@ApiOperation("我的招工任务详情-务工者申请列表") @ApiOperation(value = "我的招工任务详情-务工者申请列表分页")
@GetMapping("/wgzList/{id}") @GetMapping("/wgzList")
public AjaxResult<BgtProjectRecruitDetailWgzListVO> wgzList(@NotNull(message = "主键不能为空") public TableDataInfo<BgtProjectRecruitApplyVO> listPage(@Validated BgtProjectRecruitApplyUserDTO dto) {
@PathVariable("id") Long id) { return iBgtProjectRecruitApplyService.recruitApplyList(dto);
return AjaxResult.success(iBgtProjectRecruitService.wgzList(id));
} }
@ApiOperation("务工者申请列表数量统计")
@ApiOperation("我的招工任务详情-务工者申请列表数量统计")
@GetMapping("/wgzCount/{id}") @GetMapping("/wgzCount/{id}")
public AjaxResult<BgtProjectRecruitDetailWgzListVO> wgzCount(@NotNull(message = "主键不能为空") public AjaxResult<BgtProjectRecruitDetailWgzListVO> wgzCount(@NotNull(message = "主键不能为空")
@PathVariable("id") Long id) { @PathVariable("id") Long id) {
BgtProjectRecruitDetailWgzListVO bgtProjectRecruitDetailWgzListVO = iBgtProjectRecruitService.wgzList(id); BgtProjectRecruitDetailWgzListVO bgtProjectRecruitDetailWgzListVO = iBgtProjectRecruitService.wgzCount(id);
bgtProjectRecruitDetailWgzListVO.setApplyList(null);
return AjaxResult.success(bgtProjectRecruitDetailWgzListVO); return AjaxResult.success(bgtProjectRecruitDetailWgzListVO);
} }

View File

@ -1,8 +1,16 @@
package com.ruoyi.web.controller.bgt; package com.ruoyi.web.controller.bgt;
import com.ruoyi.bgt.domain.dto.BgtProjectTaskUserDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.domain.vo.BgtProjectTaskUseCountVO;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.annotation.RepeatSubmit;
import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.fbs.domain.FbsProjectTask;
import com.ruoyi.fbs.domain.dto.AppTaskDTO; import com.ruoyi.fbs.domain.dto.AppTaskDTO;
import com.ruoyi.fbs.domain.vo.*; import com.ruoyi.fbs.domain.vo.*;
import com.ruoyi.fbs.service.IFbsProjectTaskService; import com.ruoyi.fbs.service.IFbsProjectTaskService;
@ -11,10 +19,7 @@ import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
import java.util.List; import java.util.List;
@ -38,7 +43,7 @@ public class AppBgtProjectTaskController extends BaseController {
* 我的任务列表 任务状态 申请(0) 进行(1) 完成(2) 是否我的任务 true * 我的任务列表 任务状态 申请(0) 进行(1) 完成(2) 是否我的任务 true
* *
*/ */
@ApiOperation(value = "App包工头任务列表/我的任务" @ApiOperation(value = "包工头任务列表/我的任务"
,notes = "1.首页任务列表 任务状态(status) 申请(0) 是否我的任务(myTask) false\n"+ ,notes = "1.首页任务列表 任务状态(status) 申请(0) 是否我的任务(myTask) false\n"+
"2.我的任务列表 任务状态(status) 申请(0) 进行(1) 完成(2) 是否我的任务(myTask) true") "2.我的任务列表 任务状态(status) 申请(0) 进行(1) 完成(2) 是否我的任务(myTask) true")
@GetMapping("/list") @GetMapping("/list")
@ -46,7 +51,7 @@ public class AppBgtProjectTaskController extends BaseController {
return iFbsProjectTaskService.appQueryPageList(dto); return iFbsProjectTaskService.appQueryPageList(dto);
} }
@ApiOperation("App包工头任务列表不分页") @ApiOperation("包工头进行中任务列表")
@GetMapping("/listAll") @GetMapping("/listAll")
public AjaxResult<List<AppTaskVO>> list() { public AjaxResult<List<AppTaskVO>> list() {
return AjaxResult.success(iFbsProjectTaskService.appQueryList()); return AjaxResult.success(iFbsProjectTaskService.appQueryList());
@ -88,6 +93,33 @@ public class AppBgtProjectTaskController extends BaseController {
return AjaxResult.success(iFbsProjectTaskService.recruit(id)); return AjaxResult.success(iFbsProjectTaskService.recruit(id));
} }
@ApiOperation(value = "项目任务详细信息-务工人员分页")
@GetMapping("/taskUser")
public TableDataInfo<BgtProjectRecruitApplyVO> taskUserList(@Validated BgtProjectTaskUserDTO dto) {
return iFbsProjectTaskService.taskUserList(dto);
}
@ApiOperation(value = "项目任务详细信息-务工人员统计")
@GetMapping("/taskUserCount/{id}")
public AjaxResult<BgtProjectTaskUseCountVO> taskUserCount(@NotNull(message = "主键不能为空")
@PathVariable("id") Long id) {
return AjaxResult.success(iFbsProjectTaskService.taskUserCount(id));
}
@ApiOperation("新增项目")
@Log(title = "包工头新增项目", businessType = BusinessType.INSERT)
@RepeatSubmit
@PostMapping()
public AjaxResult<Boolean> add(@Validated @RequestBody FbsProjectTask bo) {
Long num = 1L;
bo.setProjectId(num);
bo.setSectionId(num);
bo.setSubId(num);
bo.setUserId(SecurityUtils.getAppUserId());
bo.setStatus("1");
return AjaxResult.success(iFbsProjectTaskService.insert(bo));
}
} }

View File

@ -39,7 +39,7 @@ public class AppBgtProjectTaskProgressController extends BaseController {
/** /**
* 查询包工头项目任务进度列表 * 查询包工头项目任务进度列表
*/ */
@ApiOperation("App查询包工头项目任务进度列表") @ApiOperation("查询项目任务进度列表")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<BgtProjectTaskProgressVO> list(@Validated BgtProjectTaskProgressQueryDTO bo) { public TableDataInfo<BgtProjectTaskProgressVO> list(@Validated BgtProjectTaskProgressQueryDTO bo) {
return iBgtProjectTaskProgressService.appQueryPageList(bo); return iBgtProjectTaskProgressService.appQueryPageList(bo);
@ -49,7 +49,7 @@ public class AppBgtProjectTaskProgressController extends BaseController {
/** /**
* 获取包工头项目任务进度详细信息 * 获取包工头项目任务进度详细信息
*/ */
@ApiOperation("App获取包工头项目任务进度详细信息") @ApiOperation("获取项目任务进度详细信息")
@GetMapping("/{id}") @GetMapping("/{id}")
public AjaxResult<BgtProjectTaskProgressDetailVO> getInfo(@NotNull(message = "主键不能为空") public AjaxResult<BgtProjectTaskProgressDetailVO> getInfo(@NotNull(message = "主键不能为空")
@PathVariable("id") Long id) { @PathVariable("id") Long id) {
@ -59,7 +59,7 @@ public class AppBgtProjectTaskProgressController extends BaseController {
/** /**
* 新增包工头项目任务进度 * 新增包工头项目任务进度
*/ */
@ApiOperation("App上传任务进度") @ApiOperation("上传任务进度")
@Log(title = "App上传任务进度", businessType = BusinessType.INSERT) @Log(title = "App上传任务进度", businessType = BusinessType.INSERT)
@RepeatSubmit @RepeatSubmit
@PostMapping() @PostMapping()

View File

@ -1,5 +1,8 @@
package com.ruoyi.common.enums; package com.ruoyi.common.enums;
import java.util.Arrays;
import java.util.List;
/** /**
* 招工申请状态 * 招工申请状态
* *
@ -34,4 +37,8 @@ public enum RecruitApplyStatus
{ {
return info; return info;
} }
public static List<String> getTaskStatus(){
return Arrays.asList(WGZ_PASS.getCode(),WORKING.getCode(), OUT_WORK.getCode());
}
} }

View File

@ -8,6 +8,7 @@ import lombok.NoArgsConstructor;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import org.springframework.format.annotation.DateTimeFormat; import org.springframework.format.annotation.DateTimeFormat;
import javax.validation.constraints.NotNull;
import java.time.LocalDate; import java.time.LocalDate;
@Data @Data
@ -20,6 +21,7 @@ public class BgtAttendanceDetailDTO {
private Long userId; private Long userId;
@ApiModelProperty("任务Id") @ApiModelProperty("任务Id")
@NotNull(message = "任务Id不能为空")
private Long taskId; private Long taskId;
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8") @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")

View File

@ -25,7 +25,6 @@ public class BgtLeaveUpdateDTO {
@ApiModelProperty("审核状态0待审核 1审核中 2已同意 3已拒绝 4=已取消)") @ApiModelProperty("审核状态0待审核 1审核中 2已同意 3已拒绝 4=已取消)")
private String auditorType; private String auditorType;
@ApiModelProperty("审核意见") @ApiModelProperty("审核意见")
private String auditorOpinion; private String auditorOpinion;

View File

@ -5,6 +5,8 @@ import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty; import io.swagger.annotations.ApiModelProperty;
import lombok.Data; import lombok.Data;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.List; import java.util.List;
@ -23,12 +25,15 @@ public class BgtProjectRecruitApplyConsentDTO{
private Long id; private Long id;
@ApiModelProperty("进场时间") @ApiModelProperty("进场时间")
@NotNull(message = "进场时间不能为空")
private LocalDate entryTime; private LocalDate entryTime;
@ApiModelProperty("入场材料") @ApiModelProperty("入场材料")
@Size(min = 1, message = "入场材料不能为空")
List<AnnexDTO> entryMaterials; List<AnnexDTO> entryMaterials;
@ApiModelProperty("保险") @ApiModelProperty("保险")
@Size(min = 1, message = "保险不能为空")
List<AnnexDTO> insurances; List<AnnexDTO> insurances;
} }

View File

@ -0,0 +1,28 @@
package com.ruoyi.bgt.domain.dto;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import javax.validation.constraints.NotNull;
@Data
@ApiModel("包工头招工详情务工者申请列表查询对象")
public class BgtProjectRecruitApplyUserDTO {
@ApiModelProperty("分页大小")
private Integer pageSize;
/** 当前页数 */
@ApiModelProperty("当前页数")
private Integer pageNum;
@ApiModelProperty("招工任务Id")
@NotNull(message = "招工任务Id不能为空")
private Long recruitId;
@ApiModelProperty("选择状态0选择 1未选择")
private Integer status;
@ApiModelProperty("务工者名字")
private String username;
}

View File

@ -0,0 +1,28 @@
package com.ruoyi.bgt.domain.dto;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import javax.validation.constraints.NotNull;
@Data
@ApiModel("包工头任务详情务工者申请列表查询对象")
public class BgtProjectTaskUserDTO {
@ApiModelProperty("分页大小")
private Integer pageSize;
/** 当前页数 */
@ApiModelProperty("当前页数")
private Integer pageNum;
@ApiModelProperty("任务Id")
@NotNull(message = "任务Id不能为空")
private Long taskId;
@ApiModelProperty("选择状态3-未进场5-进场6-离场")
private Integer status;
@ApiModelProperty("务工者名字")
private String username;
}

View File

@ -0,0 +1,36 @@
package com.ruoyi.bgt.domain.vo;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import java.time.LocalDate;
@Data
@NoArgsConstructor
@Accessors(chain = true)
@ApiModel("App包工头总体考勤视图对象")
public class BgtAttendancePersonBaseInfoVO {
@ApiModelProperty("务工者Id")
@JsonFormat(shape = JsonFormat.Shape.STRING)
private Long userId;
@ApiModelProperty("姓名")
private String username;
@ApiModelProperty("头像")
private String avatarName;
@ApiModelProperty("进场时间")
private LocalDate entryTime;
@ApiModelProperty("离场时间")
private LocalDate leaveTime;
@ApiModelProperty("选择状态0未选择 1已选择")
private String status;
}

View File

@ -1,36 +1,18 @@
package com.ruoyi.bgt.domain.vo; package com.ruoyi.bgt.domain.vo;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty; import io.swagger.annotations.ApiModelProperty;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import java.time.LocalDate;
import java.util.List; import java.util.List;
@Data @Data
@NoArgsConstructor @NoArgsConstructor
@Accessors(chain = true) @Accessors(chain = true)
@ApiModel("App包工头总体考勤视图对象") @ApiModel("App包工头总体考勤视图对象")
public class BgtAttendanceDetailVO { public class BgtAttendancePersonCountVO {
@ApiModelProperty("务工者Id")
@JsonFormat(shape = JsonFormat.Shape.STRING)
private Long userId;
@ApiModelProperty("姓名")
private String username;
@ApiModelProperty("头像")
private String avatarName;
@ApiModelProperty("进场时间")
private LocalDate entryTime;
@ApiModelProperty("选择状态0未选择 1已选择")
private String status;
@ApiModelProperty("出勤天数") @ApiModelProperty("出勤天数")
private Double dayNum=0D; private Double dayNum=0D;

View File

@ -6,9 +6,6 @@ import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import java.io.Serializable;
import java.util.List;
/** /**
* 包工头招工对象 bgt_project_recruit * 包工头招工对象 bgt_project_recruit
* *
@ -18,17 +15,8 @@ import java.util.List;
@Data @Data
@NoArgsConstructor @NoArgsConstructor
@Accessors(chain = true) @Accessors(chain = true)
@ApiModel("App包工头招工详情-务工者申请列表对象") @ApiModel("App包工头招工详情-务工者申请列表统计对象")
public class BgtProjectRecruitDetailWgzListVO implements Serializable { public class BgtProjectRecruitDetailWgzListVO {
private static final long serialVersionUID=1L;
/** 主键ID */
@ApiModelProperty("主键ID")
private Long id;
@ApiModelProperty("申请者列表")
List<BgtProjectRecruitApplyVO> applyList;
@ApiModelProperty("总人数") @ApiModelProperty("总人数")
private Integer totalNum; private Integer totalNum;

View File

@ -0,0 +1,24 @@
package com.ruoyi.bgt.domain.vo;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
@ApiModel("包工头任务详情务工者申请列表统计视图对象")
public class BgtProjectTaskUseCountVO {
@ApiModelProperty("未进场")
private Long wgzPassNum;
/** 当前页数 */
@ApiModelProperty("进场")
private Long workingNum;
@ApiModelProperty("离场")
private Long outWorkNum;
}

View File

@ -4,6 +4,8 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO; import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyUserDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectTaskUserDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache; import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
@ -30,8 +32,15 @@ public interface BgtProjectRecruitApplyMapper extends BaseMapperPlus<BgtProjectR
// Page<BgtProjectRecruitApplyVO> dayAttendanceList(@Param("page")Page<BgtAttendanceDayDTO> queryDTOPage,@Param("dto") BgtAttendanceDayDTO dto); // Page<BgtProjectRecruitApplyVO> dayAttendanceList(@Param("page")Page<BgtAttendanceDayDTO> queryDTOPage,@Param("dto") BgtAttendanceDayDTO dto);
// 总体考勤情况-人员出勤情况
Page<BgtProjectRecruitApplyVO> todayAttendanceList(@Param("page")Page<BgtAttendanceDayDTO> queryDTOPage,@Param("dto") BgtAttendanceDayDTO dto); Page<BgtProjectRecruitApplyVO> todayAttendanceList(@Param("page")Page<BgtAttendanceDayDTO> queryDTOPage,@Param("dto") BgtAttendanceDayDTO dto);
// 获取指定项目下的所有成员(分页) // 获取指定项目下的所有成员(分页)
Page<WgzAppUnderwayRes> underwayPage (@Param("page") Page<WgzAppUnderwayReq> page,@Param("req") WgzAppUnderwayReq req); Page<WgzAppUnderwayRes> underwayPage (@Param("page") Page<WgzAppUnderwayReq> page,@Param("req") WgzAppUnderwayReq req);
// 我的招工任务详情-务工者申请列表分页
Page<BgtProjectRecruitApplyVO> recruitApplyList(@Param("page")Page<BgtProjectRecruitApplyUserDTO> queryDTOPage,@Param("dto") BgtProjectRecruitApplyUserDTO dto);
// 我的任务详情-务工者人员列表分页
Page<BgtProjectRecruitApplyVO> taskUserList(@Param("page")Page<BgtProjectTaskUserDTO> queryDTOPage, @Param("dto") BgtProjectTaskUserDTO dto);
} }

View File

@ -2,10 +2,7 @@ package com.ruoyi.bgt.service;
import com.ruoyi.bgt.bo.BgtProjectRecruitApplyQueryBo; import com.ruoyi.bgt.bo.BgtProjectRecruitApplyQueryBo;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO; import com.ruoyi.bgt.domain.dto.*;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
import com.ruoyi.bgt.domain.dto.BgtScoreDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.common.core.mybatisplus.core.IServicePlus; import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
@ -68,10 +65,21 @@ public interface IBgtProjectRecruitApplyService extends IServicePlus<BgtProjectR
*/ */
TableDataInfo<BgtProjectRecruitApplyVO> appQueryPageList(BgtProjectRecruitApplyQueryDTO dto); TableDataInfo<BgtProjectRecruitApplyVO> appQueryPageList(BgtProjectRecruitApplyQueryDTO dto);
/**
* 我的招工任务详情-务工者申请列表分页
*/
TableDataInfo<BgtProjectRecruitApplyVO> recruitApplyList(BgtProjectRecruitApplyUserDTO dto);
/**
* 我的任务详情-务工者人员列表分页
*/
TableDataInfo<BgtProjectRecruitApplyVO> taskUserList(BgtProjectTaskUserDTO dto);
/** /**
* 查询列表 * 查询列表
*/ */
List<BgtProjectRecruitApplyVO> appQueryList(BgtProjectRecruitApplyQueryDTO dto); List<BgtProjectRecruitApplyVO> appAllList(BgtProjectRecruitApplyQueryDTO dto);
/** /**
* LC-APP相关 * LC-APP相关
@ -96,9 +104,9 @@ public interface IBgtProjectRecruitApplyService extends IServicePlus<BgtProjectR
Boolean consent(BgtProjectRecruitApplyConsentDTO dto); Boolean consent(BgtProjectRecruitApplyConsentDTO dto);
/** /**
* 指定日期打卡记录 * 指定日期所有人员出勤情况
*/ */
TableDataInfo<BgtProjectRecruitApplyVO> dayAttendanceList(BgtAttendanceDayDTO dto); TableDataInfo<BgtProjectRecruitApplyVO> userList(BgtAttendanceDayDTO dto);
/** /**
* 退场 * 退场
@ -130,6 +138,8 @@ public interface IBgtProjectRecruitApplyService extends IServicePlus<BgtProjectR
*/ */
Boolean userConfirmRegistration(@Validated WgzAppConfirmRegistrationReq req); Boolean userConfirmRegistration(@Validated WgzAppConfirmRegistrationReq req);
/**
BgtProjectRecruitApply getOne(Long recruitId,Long userId); * 根据任务和务工者Id获该务工者的报名信息
*/
BgtProjectRecruitApply getOne(Long taskId,Long userId);
} }

View File

@ -66,19 +66,24 @@ public interface IBgtProjectRecruitService extends IServicePlus<BgtProjectRecrui
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
/** /**
* 查询列表 * 查询分页列表
*/ */
TableDataInfo<BgtProjectRecruitVO> appQueryPageList(BgtProjectRecruitQueryDTO dto); TableDataInfo<BgtProjectRecruitVO> appQueryPageList(BgtProjectRecruitQueryDTO dto);
/**
* 查询我发布的所有招工
*/
List<BgtProjectRecruit> appQueryList();
/** /**
* 查询单个 * 查询单个
*/ */
BgtProjectRecruitDetailVO appQueryById(Long id); BgtProjectRecruitDetailVO appQueryById(Long id);
/** /**
* 务工者统计 * 务工者申请列表统计
*/ */
BgtProjectRecruitDetailWgzListVO wgzList(Long id); BgtProjectRecruitDetailWgzListVO wgzCount(Long id);
/** /**
* 获取任务下的所有招工Id * 获取任务下的所有招工Id

View File

@ -11,10 +11,7 @@ import com.ruoyi.bgt.bo.BgtProjectRecruitApplyQueryBo;
import com.ruoyi.bgt.domain.BgtMessage; import com.ruoyi.bgt.domain.BgtMessage;
import com.ruoyi.bgt.domain.BgtProjectRecruit; import com.ruoyi.bgt.domain.BgtProjectRecruit;
import com.ruoyi.bgt.domain.BgtProjectRecruitApply; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDayDTO; import com.ruoyi.bgt.domain.dto.*;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
import com.ruoyi.bgt.domain.dto.BgtScoreDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.mapper.BgtProjectRecruitApplyMapper; import com.ruoyi.bgt.mapper.BgtProjectRecruitApplyMapper;
import com.ruoyi.bgt.service.IBgtMessageService; import com.ruoyi.bgt.service.IBgtMessageService;
@ -159,7 +156,25 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
} }
@Override @Override
public List<BgtProjectRecruitApplyVO> appQueryList(BgtProjectRecruitApplyQueryDTO dto) { public TableDataInfo<BgtProjectRecruitApplyVO> recruitApplyList(BgtProjectRecruitApplyUserDTO dto) {
Page<BgtProjectRecruitApplyUserDTO> queryDTOPage = new Page<>();
queryDTOPage.setCurrent(dto.getPageNum());
queryDTOPage.setSize(dto.getPageSize());
Page<BgtProjectRecruitApplyVO> queryVOPage = baseMapper.recruitApplyList(queryDTOPage, dto);
return PageUtils.buildDataInfo(queryVOPage);
}
@Override
public TableDataInfo<BgtProjectRecruitApplyVO> taskUserList(BgtProjectTaskUserDTO dto) {
Page<BgtProjectTaskUserDTO> queryDTOPage = new Page<>();
queryDTOPage.setCurrent(dto.getPageNum());
queryDTOPage.setSize(dto.getPageSize());
Page<BgtProjectRecruitApplyVO> queryVOPage = baseMapper.taskUserList(queryDTOPage, dto);
return PageUtils.buildDataInfo(queryVOPage);
}
@Override
public List<BgtProjectRecruitApplyVO> appAllList(BgtProjectRecruitApplyQueryDTO dto) {
if (dto.getTaskId() != null) { if (dto.getTaskId() != null) {
List<Long> recruitIdsByTaskId = iBgtProjectRecruitService.getRecruitIdsByTaskId(dto.getTaskId()); List<Long> recruitIdsByTaskId = iBgtProjectRecruitService.getRecruitIdsByTaskId(dto.getTaskId());
if (dto.getRecruitIds() == null) { if (dto.getRecruitIds() == null) {
@ -168,6 +183,11 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
dto.getRecruitIds().addAll(recruitIdsByTaskId); dto.getRecruitIds().addAll(recruitIdsByTaskId);
} }
} }
if(dto.getDate()!=null){
LocalDate date = dto.getDate();
dto.setBeginDate(date.with(TemporalAdjusters.firstDayOfMonth()));
dto.setEndDate(date.with(TemporalAdjusters.lastDayOfMonth()));
}
return baseMapper.appQueryList(dto); return baseMapper.appQueryList(dto);
} }
@ -325,7 +345,8 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
return false; return false;
} }
public TableDataInfo<BgtProjectRecruitApplyVO> dayAttendanceList(BgtAttendanceDayDTO dto) { @Override
public TableDataInfo<BgtProjectRecruitApplyVO> userList(BgtAttendanceDayDTO dto) {
Page<BgtAttendanceDayDTO> queryDTOPage = new Page<>(); Page<BgtAttendanceDayDTO> queryDTOPage = new Page<>();
queryDTOPage.setCurrent(dto.getPageNum()); queryDTOPage.setCurrent(dto.getPageNum());
queryDTOPage.setSize(dto.getPageSize()); queryDTOPage.setSize(dto.getPageSize());
@ -368,7 +389,7 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
BgtProjectRecruitApplyQueryDTO dto = new BgtProjectRecruitApplyQueryDTO(); BgtProjectRecruitApplyQueryDTO dto = new BgtProjectRecruitApplyQueryDTO();
dto.setTaskId(taskId); dto.setTaskId(taskId);
dto.setStatus(Collections.singletonList(RecruitApplyStatus.WORKING.getCode())); dto.setStatus(Collections.singletonList(RecruitApplyStatus.WORKING.getCode()));
List<BgtProjectRecruitApplyVO> bgtProjectRecruitApplyVOS = appQueryList(dto); List<BgtProjectRecruitApplyVO> bgtProjectRecruitApplyVOS = appAllList(dto);
if (CollectionUtil.isNotEmpty(bgtProjectRecruitApplyVOS)) { if (CollectionUtil.isNotEmpty(bgtProjectRecruitApplyVOS)) {
//发消息 //发消息
@ -560,9 +581,9 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
@Override @Override
public BgtProjectRecruitApply getOne(Long recruitId, Long userId) { public BgtProjectRecruitApply getOne(Long taskId, Long userId) {
List<BgtProjectRecruitApply> list = baseMapper.selectList(Wrappers.<BgtProjectRecruitApply>lambdaQuery().eq(BgtProjectRecruitApply::getRecruitId, recruitId) List<BgtProjectRecruitApply> list = baseMapper.selectList(Wrappers.<BgtProjectRecruitApply>lambdaQuery().eq(BgtProjectRecruitApply::getTaskId, taskId)
.eq(BgtProjectRecruitApply::getUserId, userId)); .eq(BgtProjectRecruitApply::getUserId, userId));
return list.get(0); return CollectionUtil.isNotEmpty(list)?list.get(0):new BgtProjectRecruitApply();
} }
} }

View File

@ -7,7 +7,8 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.bgt.bo.BgtProjectRecruitQueryBo; import com.ruoyi.bgt.bo.BgtProjectRecruitQueryBo;
import com.ruoyi.bgt.domain.BgtProjectRecruit; import com.ruoyi.bgt.domain.BgtProjectRecruit;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyUserDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitQueryDTO; import com.ruoyi.bgt.domain.dto.BgtProjectRecruitQueryDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitDetailVO;
@ -139,14 +140,23 @@ public class BgtProjectRecruitServiceImpl extends ServicePlusImpl<BgtProjectRecr
queryDTOPage.setSize(dto.getPageSize()); queryDTOPage.setSize(dto.getPageSize());
Page<BgtProjectRecruitVO> queryVOPage = baseMapper.appQueryPageList(queryDTOPage, dto); Page<BgtProjectRecruitVO> queryVOPage = baseMapper.appQueryPageList(queryDTOPage, dto);
for(BgtProjectRecruitVO vo : queryVOPage.getRecords()) { for(BgtProjectRecruitVO vo : queryVOPage.getRecords()) {
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO(); BgtProjectRecruitApplyUserDTO userDTO = new BgtProjectRecruitApplyUserDTO();
bgtProjectRecruitApplyQueryDTO.setRecruitIds(Collections.singletonList(vo.getId())); userDTO.setPageNum(1);
bgtProjectRecruitApplyQueryDTO.setStatus(applyStatus); userDTO.setPageSize(3);
vo.setApplyList(bgtProjectRecruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO)); userDTO.setRecruitId(vo.getId());
TableDataInfo<BgtProjectRecruitApplyVO> page = bgtProjectRecruitApplyService.recruitApplyList(userDTO);
vo.setApplyList(page.getRows());
} }
return PageUtils.buildDataInfo(queryVOPage); return PageUtils.buildDataInfo(queryVOPage);
} }
@Override
public List<BgtProjectRecruit> appQueryList() {
return list(Wrappers.<BgtProjectRecruit>lambdaQuery()
.eq(BgtProjectRecruit::getUserId, SecurityUtils.getAppUserId()));
}
@Override @Override
public BgtProjectRecruitDetailVO appQueryById(Long id) { public BgtProjectRecruitDetailVO appQueryById(Long id) {
BgtProjectRecruit recruit = getById(id); BgtProjectRecruit recruit = getById(id);
@ -157,19 +167,19 @@ public class BgtProjectRecruitServiceImpl extends ServicePlusImpl<BgtProjectRecr
} }
@Override @Override
public BgtProjectRecruitDetailWgzListVO wgzList(Long id) { public BgtProjectRecruitDetailWgzListVO wgzCount(Long id) {
BgtProjectRecruitDetailWgzListVO vo = new BgtProjectRecruitDetailWgzListVO(); BgtProjectRecruitDetailWgzListVO vo = new BgtProjectRecruitDetailWgzListVO();
vo.setId(id);
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
bgtProjectRecruitApplyQueryDTO.setRecruitIds(Collections.singletonList(id));
bgtProjectRecruitApplyQueryDTO.setStatus(applyStatus);
List<BgtProjectRecruitApplyVO> bgtProjectRecruitApplyVOS = bgtProjectRecruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO);
vo.setTotalNum(bgtProjectRecruitApplyVOS.size());
int count = (int)bgtProjectRecruitApplyVOS.stream().filter(apply -> apply.getStatus().equals(RecruitApplyStatus.BGT_PASS.getCode())).count(); LambdaQueryWrapper<BgtProjectRecruitApply> wrapper = new LambdaQueryWrapper<>();
vo.setPassNum(count); wrapper.eq(BgtProjectRecruitApply::getRecruitId, id);
vo.setNotSelectNum(vo.getTotalNum()-vo.getPassNum()); wrapper.orderByDesc(BgtProjectRecruitApply::getCreateTime);
vo.setApplyList(bgtProjectRecruitApplyVOS.subList(0, Math.min(vo.getTotalNum(), 3))); List<BgtProjectRecruitApply> list = bgtProjectRecruitApplyService.list(wrapper);
List<BgtProjectRecruitApplyVO> bgtProjectRecruitApplyVOS = BeanUtil.copyToList(list, BgtProjectRecruitApplyVO.class);
int count = (int)bgtProjectRecruitApplyVOS.stream().filter(apply -> apply.getStatus().equals(RecruitApplyStatus.SIGN_UP.getCode())).count();
vo.setTotalNum(bgtProjectRecruitApplyVOS.size());
vo.setNotSelectNum(count);
vo.setPassNum(vo.getTotalNum()-count);
return vo; return vo;
} }

View File

@ -1,6 +1,9 @@
package com.ruoyi.fbs.service; package com.ruoyi.fbs.service;
import com.ruoyi.bgt.domain.dto.BgtProjectTaskUserDTO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.domain.vo.BgtProjectTaskUseCountVO;
import com.ruoyi.common.core.mybatisplus.core.IServicePlus; import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.fbs.bo.FbsProjectTaskQueryBo; import com.ruoyi.fbs.bo.FbsProjectTaskQueryBo;
@ -92,6 +95,16 @@ public interface IFbsProjectTaskService extends IServicePlus<FbsProjectTask> {
*/ */
AppTaskDetailRecruitVO recruit(Long id); AppTaskDetailRecruitVO recruit(Long id);
/**
* 任务详情-务工人员分页
*/
TableDataInfo<BgtProjectRecruitApplyVO> taskUserList(BgtProjectTaskUserDTO dto);
/**
* 任务详情-务工人员统计
*/
BgtProjectTaskUseCountVO taskUserCount(Long id);
/** /**
* 查询所有在进行中的任务 * 查询所有在进行中的任务
*/ */

View File

@ -6,15 +6,14 @@ import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.bgt.bo.BgtProjectRecruitQueryBo; import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
import com.ruoyi.bgt.domain.BgtProjectRecruit; import com.ruoyi.bgt.domain.dto.BgtProjectTaskUserDTO;
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
import com.ruoyi.bgt.domain.dto.BgtWageApplicationQueryDTO; import com.ruoyi.bgt.domain.dto.BgtWageApplicationQueryDTO;
import com.ruoyi.bgt.domain.vo.BgtDayAttendanceCountVO; import com.ruoyi.bgt.domain.vo.BgtDayAttendanceCountVO;
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO; import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
import com.ruoyi.bgt.domain.vo.BgtProjectTaskUseCountVO;
import com.ruoyi.bgt.domain.vo.BgtWageApplicationListVO; import com.ruoyi.bgt.domain.vo.BgtWageApplicationListVO;
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService; import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
import com.ruoyi.bgt.service.IBgtProjectRecruitService;
import com.ruoyi.bgt.service.IBgtProjectTaskProgressService; import com.ruoyi.bgt.service.IBgtProjectTaskProgressService;
import com.ruoyi.bgt.service.IBgtWageApplicationService; import com.ruoyi.bgt.service.IBgtWageApplicationService;
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
@ -43,10 +42,8 @@ import java.math.BigDecimal;
import java.math.RoundingMode; import java.math.RoundingMode;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.stream.Collectors;
/** /**
* 分包商项目任务Service业务层处理 * 分包商项目任务Service业务层处理
@ -59,8 +56,7 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
@Autowired @Autowired
private IZbfProjectService zbfProjectService; private IZbfProjectService zbfProjectService;
@Autowired
private IBgtProjectRecruitService recruitService;
@Autowired @Autowired
private IBgtProjectRecruitApplyService recruitApplyService; private IBgtProjectRecruitApplyService recruitApplyService;
@Autowired @Autowired
@ -261,20 +257,34 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
public AppTaskDetailRecruitVO recruit(Long id) { public AppTaskDetailRecruitVO recruit(Long id) {
AppTaskDetailRecruitVO appTaskDetailVO = new AppTaskDetailRecruitVO(); AppTaskDetailRecruitVO appTaskDetailVO = new AppTaskDetailRecruitVO();
appTaskDetailVO.setId(id); appTaskDetailVO.setId(id);
//务工者数量列表
BgtProjectRecruitQueryBo bgtProjectRecruitQueryBo = new BgtProjectRecruitQueryBo();
bgtProjectRecruitQueryBo.setTaskId(id);
List<Long> recruitIds = recruitService.queryList(bgtProjectRecruitQueryBo).stream().map(BgtProjectRecruit::getId).collect(Collectors.toList());
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO(); BgtProjectTaskUserDTO dto = new BgtProjectTaskUserDTO();
bgtProjectRecruitApplyQueryDTO.setRecruitIds(recruitIds); dto.setPageNum(1);
bgtProjectRecruitApplyQueryDTO.setStatus(Collections.singletonList(RecruitApplyStatus.WORKING.getCode())); dto.setPageSize(3);
List<BgtProjectRecruitApplyVO> vos = recruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO); dto.setTaskId(id);
appTaskDetailVO.setTotal(vos.size()); TableDataInfo<BgtProjectRecruitApplyVO> page = recruitApplyService.taskUserList(dto);
appTaskDetailVO.setApplyList(vos.subList(0, Math.min(vos.size(), 3))); appTaskDetailVO.setTotal((int)page.getTotal());
appTaskDetailVO.setApplyList(page.getRows());
return appTaskDetailVO; return appTaskDetailVO;
} }
@Override
public TableDataInfo<BgtProjectRecruitApplyVO> taskUserList(BgtProjectTaskUserDTO dto) {
return recruitApplyService.taskUserList(dto);
}
@Override
public BgtProjectTaskUseCountVO taskUserCount(Long id) {
LambdaQueryWrapper<BgtProjectRecruitApply> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(BgtProjectRecruitApply::getTaskId, id);
wrapper.in(BgtProjectRecruitApply::getStatus, RecruitApplyStatus.getTaskStatus());
List<BgtProjectRecruitApply> list = recruitApplyService.list(wrapper);
long wgzPassNum = list.stream().filter(apply -> apply.getStatus().equals(RecruitApplyStatus.WGZ_PASS.getCode())).count();
long outWorkNum = list.stream().filter(apply -> apply.getStatus().equals(RecruitApplyStatus.OUT_WORK.getCode())).count();
long workingNum = list.stream().filter(apply -> apply.getStatus().equals(RecruitApplyStatus.WORKING.getCode())).count();
return new BgtProjectTaskUseCountVO(wgzPassNum,workingNum,outWorkNum);
}
@Override @Override
public List<FbsProjectTask> findOngoingTask() { public List<FbsProjectTask> findOngoingTask() {

View File

@ -96,7 +96,7 @@ public class BusinessTask
{ {
Console.log("开始招工进场任务"); Console.log("开始招工进场任务");
recruitApplyService.lambdaUpdate() recruitApplyService.lambdaUpdate()
.eq(BgtProjectRecruitApply::getEntryTime, LocalDate.now()) .le(BgtProjectRecruitApply::getEntryTime, LocalDate.now())
.eq(BgtProjectRecruitApply::getStatus,RecruitApplyStatus.WGZ_PASS.getCode()) .eq(BgtProjectRecruitApply::getStatus,RecruitApplyStatus.WGZ_PASS.getCode())
.set(BgtProjectRecruitApply::getStatus,RecruitApplyStatus.BGT_REFUSE.getCode()) .set(BgtProjectRecruitApply::getStatus,RecruitApplyStatus.BGT_REFUSE.getCode())
.update(); .update();

View File

@ -3,7 +3,7 @@ package com.ruoyi.wgz.service;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDTO;
import com.ruoyi.bgt.domain.dto.BgtAttendanceDetailDTO; import com.ruoyi.bgt.domain.dto.BgtAttendanceDetailDTO;
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO; import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
import com.ruoyi.bgt.domain.vo.BgtAttendanceDetailVO; import com.ruoyi.bgt.domain.vo.BgtAttendancePersonCountVO;
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO; import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
import com.ruoyi.bgt.domain.vo.BgtDayAttendanceCountVO; import com.ruoyi.bgt.domain.vo.BgtDayAttendanceCountVO;
import com.ruoyi.common.core.mybatisplus.core.IServicePlus; import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
@ -121,9 +121,9 @@ public interface IWgzAttendanceService extends IServicePlus<WgzAttendance> {
/** /**
* 总体考勤情况-统计 * 总体考勤情况-统计
*/ */
BgtAttendanceVO attendanceDetail(BgtAttendanceDTO dto); BgtAttendanceVO allCount(BgtAttendanceDTO dto);
List<BgtDayAttendanceCountVO> attendanceList(BgtAttendanceDTO dto); List<BgtDayAttendanceCountVO> histogram(BgtAttendanceDTO dto);
/** /**
* 考勤详情,查询指定用户指定项目的指定天数考勤情况统计如若用户输入20但实际只有2天出勤 * 考勤详情,查询指定用户指定项目的指定天数考勤情况统计如若用户输入20但实际只有2天出勤
@ -132,9 +132,9 @@ public interface IWgzAttendanceService extends IServicePlus<WgzAttendance> {
Integer attendanceDetail(Long userId,Long recruitId, Integer num); Integer attendanceDetail(Long userId,Long recruitId, Integer num);
/** /**
* 考勤统计详情 * 务工者个人考勤统计
*/ */
BgtAttendanceDetailVO bgtAttendanceDetail(BgtAttendanceDetailDTO dto); BgtAttendancePersonCountVO personCount(BgtAttendanceDetailDTO dto);
/** /**
* 添加缺卡记录 * 添加缺卡记录

View File

@ -31,7 +31,6 @@ import com.ruoyi.wgz.bo.rests.WgzAppCardReplacementApplicationTwo;
import com.ruoyi.wgz.bo.rests.WgzAppPunchTheCalendarRecordThree; import com.ruoyi.wgz.bo.rests.WgzAppPunchTheCalendarRecordThree;
import com.ruoyi.wgz.bo.rests.WgzAppPunchTheCalendarRecordTwo; import com.ruoyi.wgz.bo.rests.WgzAppPunchTheCalendarRecordTwo;
import com.ruoyi.wgz.domain.WgzAttendance; import com.ruoyi.wgz.domain.WgzAttendance;
import com.ruoyi.wgz.domain.WgzUser;
import com.ruoyi.wgz.mapper.WgzAttendanceMapper; import com.ruoyi.wgz.mapper.WgzAttendanceMapper;
import com.ruoyi.wgz.service.IWgzAttendanceService; import com.ruoyi.wgz.service.IWgzAttendanceService;
import com.ruoyi.wgz.service.IWgzLeaveService; import com.ruoyi.wgz.service.IWgzLeaveService;
@ -416,9 +415,7 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
} }
@Override @Override
public BgtAttendanceVO attendanceDetail(BgtAttendanceDTO dto) { public BgtAttendanceVO allCount(BgtAttendanceDTO dto) {
BgtAttendanceVO bgtAttendanceVO = new BgtAttendanceVO(); BgtAttendanceVO bgtAttendanceVO = new BgtAttendanceVO();
FbsProjectTask task = taskService.getById(dto.getTaskId()); FbsProjectTask task = taskService.getById(dto.getTaskId());
@ -467,7 +464,7 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
} }
@Override @Override
public List<BgtDayAttendanceCountVO> attendanceList(BgtAttendanceDTO dto) { public List<BgtDayAttendanceCountVO> histogram(BgtAttendanceDTO dto) {
FbsProjectTask task = taskService.getById(dto.getTaskId()); FbsProjectTask task = taskService.getById(dto.getTaskId());
validTaskTime(task, dto.getDate()); validTaskTime(task, dto.getDate());
@ -604,103 +601,100 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
} }
@Override @Override
public BgtAttendanceDetailVO bgtAttendanceDetail(BgtAttendanceDetailDTO dto) { public BgtAttendancePersonCountVO personCount(BgtAttendanceDetailDTO dto) {
BgtAttendanceDetailVO bgtAttendanceDetailVO = new BgtAttendanceDetailVO(); BgtAttendancePersonCountVO bgtAttendanceDetailVO = new BgtAttendancePersonCountVO();
WgzUser wgzUser = wgzUserService.findByUserId(dto.getUserId());
bgtAttendanceDetailVO.setUserId(wgzUser.getUserId());
bgtAttendanceDetailVO.setUsername(wgzUser.getUsername());
bgtAttendanceDetailVO.setAvatarName(wgzUser.getAvatarName());
//获取任务下的所有招工
List<BgtProjectRecruit> bgtProjectRecruits = iBgtProjectRecruitService.getBaseMapper().selectList(Wrappers.<BgtProjectRecruit>lambdaQuery() List<BgtProjectRecruit> bgtProjectRecruits = iBgtProjectRecruitService.getBaseMapper().selectList(Wrappers.<BgtProjectRecruit>lambdaQuery()
.eq(BgtProjectRecruit::getTaskId, dto.getTaskId())); .eq(BgtProjectRecruit::getTaskId, dto.getTaskId()));
List<Long> recruitIds = bgtProjectRecruits.stream().map(BgtProjectRecruit::getId).collect(Collectors.toList()); List<Long> recruitIds = bgtProjectRecruits.stream().map(BgtProjectRecruit::getId).collect(Collectors.toList());
BgtProjectRecruitApply recruitApply = iBgtProjectRecruitApplyService.getOne(recruitIds.get(0),wgzUser.getUserId()); //查询该务工者在这个项目里指定月份的所有考勤数据
bgtAttendanceDetailVO.setEntryTime(recruitApply.getEntryTime());
bgtAttendanceDetailVO.setStatus(recruitApply.getStatus());
LambdaQueryWrapper<WgzAttendance> wrapper = new LambdaQueryWrapper<>(); LambdaQueryWrapper<WgzAttendance> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(WgzAttendance::getUserId, dto.getUserId()); wrapper.eq(WgzAttendance::getUserId, dto.getUserId());
wrapper.in(WgzAttendance::getRecruitId, recruitIds); wrapper.in(WgzAttendance::getRecruitId, recruitIds);
LocalDate date = dto.getDate(); LocalDate date = dto.getDate();
LocalDate startDate = date.with(TemporalAdjusters.firstDayOfMonth()); LocalDate startDate = date.with(TemporalAdjusters.firstDayOfMonth());
LocalDate endData = date.with(TemporalAdjusters.lastDayOfMonth()); LocalDate endData = date.with(TemporalAdjusters.lastDayOfMonth());
wrapper.between(WgzAttendance::getDate, startDate, endData); wrapper.between(WgzAttendance::getDate, startDate, endData);
List<WgzAttendance> wgzAttendances = baseMapper.selectList(wrapper); List<WgzAttendance> wgzAttendances = baseMapper.selectList(wrapper);
// 创建SimpleDateFormat对象格式化日期为中文星期
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("EEEE", Locale.CHINA);
//获取招工打卡时间 //获取招工打卡时间
List<BgtProjectRecruit> list = iBgtProjectRecruitService.list(Wrappers.<BgtProjectRecruit>lambdaQuery().in(BgtProjectRecruit::getId,recruitIds)); List<BgtProjectRecruit> list = iBgtProjectRecruitService.list(Wrappers.<BgtProjectRecruit>lambdaQuery().in(BgtProjectRecruit::getId,recruitIds));
Map<Long, BgtProjectRecruit> recruitMap = list.stream().collect(Collectors.toMap(BgtProjectRecruit::getId, recruit -> recruit)); Map<Long, BgtProjectRecruit> recruitMap = list.stream().collect(Collectors.toMap(BgtProjectRecruit::getId, recruit -> recruit));
// 创建SimpleDateFormat对象格式化日期为中文星期
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("EEEE", Locale.CHINA);
//考勤数据分类
List<WgzAttendanceRecordVO> lateRecords = new ArrayList<>(); List<WgzAttendanceRecordVO> lateRecords = new ArrayList<>();
List<WgzAttendanceRecordVO> earlyLeaveRecords = new ArrayList<>(); List<WgzAttendanceRecordVO> earlyLeaveRecords = new ArrayList<>();
List<WgzAttendanceRecordVO> missRecords = new ArrayList<>(); List<WgzAttendanceRecordVO> missRecords = new ArrayList<>();
List<WgzAttendanceRecordVO> records = new ArrayList<>(); List<WgzAttendanceRecordVO> records = new ArrayList<>();
for (WgzAttendance wgzAttendance : wgzAttendances) { for (WgzAttendance wgzAttendance : wgzAttendances) {
//上下班时间
BgtProjectRecruit recruit = recruitMap.get(wgzAttendance.getRecruitId());
LocalTime beginWorkTime = recruit.getBeginWorkTime();
LocalTime endWorkTime = recruit.getEndWorkTime();
//上下班打卡时间
LocalDateTime clockInTime = wgzAttendance.getClockInTime();
LocalDateTime clockOutTime = wgzAttendance.getClockOutTime();
WgzAttendanceRecordVO recordVO = new WgzAttendanceRecordVO(); WgzAttendanceRecordVO recordVO = new WgzAttendanceRecordVO();
recordVO.setDate(wgzAttendance.getDate()); recordVO.setDate(wgzAttendance.getDate());
recordVO.setWeek(wgzAttendance.getDate().format(formatter)); recordVO.setWeek(wgzAttendance.getDate().format(formatter));
if (wgzAttendance.getMissedIn() == 0 && wgzAttendance.getMissedOut() == 0) { //统计出勤天数
if (clockInTime != null && clockOutTime != null) {
recordVO.setDay(1D); recordVO.setDay(1D);
records.add(recordVO); records.add(recordVO);
} else if (wgzAttendance.getMissedIn() == 1 && wgzAttendance.getMissedOut() == 1) { } else if (clockInTime == null && clockOutTime == null) {
recordVO.setDay(0D); recordVO.setDay(0D);
} else { } else {
recordVO.setDay(0.5D); recordVO.setDay(0.5D);
records.add(recordVO); records.add(recordVO);
} }
BgtProjectRecruit recruit = recruitMap.get(wgzAttendance.getRecruitId()); //统计迟到天数
LocalDateTime clockInTime = wgzAttendance.getClockInTime();
LocalDateTime clockOutTime = wgzAttendance.getClockOutTime();
LocalTime beginWorkTime = recruit.getBeginWorkTime();
LocalTime endWorkTime = recruit.getEndWorkTime();
if (wgzAttendance.getLate() == 1) { if (wgzAttendance.getLate() == 1) {
WgzAttendanceRecordVO LateRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class); WgzAttendanceRecordVO LateRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
LateRecordVO.setTime(clockInTime.toLocalTime()); LateRecordVO.setTime(clockInTime.toLocalTime());
LateRecordVO.setMinutes(DataUtil.getMinutes(clockInTime, beginWorkTime)); LateRecordVO.setMinutes(DataUtil.getMinutes(clockInTime, beginWorkTime));
lateRecords.add(LateRecordVO); lateRecords.add(LateRecordVO);
} }
//统计早退天数
if (wgzAttendance.getEarlyLeave() == 1) { if (wgzAttendance.getEarlyLeave() == 1) {
WgzAttendanceRecordVO earlyLeaveRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class); WgzAttendanceRecordVO earlyLeaveRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
earlyLeaveRecordVO.setTime(clockOutTime.toLocalTime()); earlyLeaveRecordVO.setTime(clockOutTime.toLocalTime());
earlyLeaveRecordVO.setMinutes(DataUtil.getMinutes(clockOutTime, endWorkTime)); earlyLeaveRecordVO.setMinutes(DataUtil.getMinutes(clockOutTime, endWorkTime));
earlyLeaveRecords.add(earlyLeaveRecordVO); earlyLeaveRecords.add(earlyLeaveRecordVO);
} }
//统计缺卡天数
if (wgzAttendance.getMissedIn() == 1) { if (wgzAttendance.getMissedIn() == 1) {
WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class); WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
missRecordVO.setTime(beginWorkTime); missRecordVO.setTime(beginWorkTime);
missRecords.add(missRecordVO); missRecords.add(missRecordVO);
} }
if (wgzAttendance.getMissedOut() == 1) { if (wgzAttendance.getMissedOut() == 1) {
WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class); WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
missRecordVO.setTime(endWorkTime); missRecordVO.setTime(endWorkTime);
missRecords.add(missRecordVO); missRecords.add(missRecordVO);
} }
} }
//出勤数据
bgtAttendanceDetailVO.setDayNum(records.stream().mapToDouble(WgzAttendanceRecordVO::getDay).sum()); bgtAttendanceDetailVO.setDayNum(records.stream().mapToDouble(WgzAttendanceRecordVO::getDay).sum());
//迟到数据
bgtAttendanceDetailVO.setLateNum(lateRecords.size()); bgtAttendanceDetailVO.setLateNum(lateRecords.size());
bgtAttendanceDetailVO.setLateMinute(lateRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum()); bgtAttendanceDetailVO.setLateMinute(lateRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum());
bgtAttendanceDetailVO.setLateRecords(lateRecords); bgtAttendanceDetailVO.setLateRecords(lateRecords);
//早退数据
bgtAttendanceDetailVO.setEarlyLeaveNum(earlyLeaveRecords.size()); bgtAttendanceDetailVO.setEarlyLeaveNum(earlyLeaveRecords.size());
bgtAttendanceDetailVO.setEarlyLeaveMinute(earlyLeaveRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum()); bgtAttendanceDetailVO.setEarlyLeaveMinute(earlyLeaveRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum());
bgtAttendanceDetailVO.setEarlyLeaveRecords(earlyLeaveRecords); bgtAttendanceDetailVO.setEarlyLeaveRecords(earlyLeaveRecords);
//缺卡数据
bgtAttendanceDetailVO.setMissNum(missRecords.size()); bgtAttendanceDetailVO.setMissNum(missRecords.size());
bgtAttendanceDetailVO.setMissRecords(missRecords); bgtAttendanceDetailVO.setMissRecords(missRecords);
return bgtAttendanceDetailVO; return bgtAttendanceDetailVO;
} }

View File

@ -251,12 +251,18 @@ public class WgzReissueacardServiceImpl extends ServicePlusImpl<WgzReissueacardM
attendance.setExceptionType(exceptionType); attendance.setExceptionType(exceptionType);
attendance.setLate(1); attendance.setLate(1);
attendance.setMissedIn(1); attendance.setMissedIn(1);
} else { if(attendance.getClockInTime() == null){
attendance.setClockInTime(byId.getNowTime());
}
} else { //下班补卡
exceptionType = exceptionType.replace("\\b2\\b", "6"); exceptionType = exceptionType.replace("\\b2\\b", "6");
exceptionType = exceptionType.replace("\\b4\\b", "6"); exceptionType = exceptionType.replace("\\b4\\b", "6");
attendance.setExceptionType(exceptionType); attendance.setExceptionType(exceptionType);
attendance.setEarlyLeave(1); attendance.setEarlyLeave(1);
attendance.setMissedOut(1); attendance.setMissedOut(1);
if(attendance.getClockOutTime() == null){
attendance.setClockOutTime(byId.getNowTime());
}
} }
iWgzAttendanceService.updateById(attendance); iWgzAttendanceService.updateById(attendance);

View File

@ -160,4 +160,78 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</where> </where>
</select> </select>
<select id="recruitApplyList" resultType="com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO">
select bpra.id,
bpra.entry_time,
bpra.leave_time,
bpra.recruit_id,
wu.user_id,
wu.phone,
wu.score,
wu.avatar_name,
wu.username,
bpra.status,
wu.type_of_work,
bpr.recruit_name,
fpt.task_name,
bpr.task_id
from bgt_project_recruit_apply bpra
left join wgz_user wu on bpra.user_id = wu.user_id
left join bgt_project_recruit bpr on bpr.id = bpra.recruit_id
left join fbs_project_task fpt on fpt.id = bpr.task_id
<where>
<if test="dto.username !=null and dto.username !='' ">
and wu.username like concat('%', #{dto.username}, '%')
</if>
<if test="dto.recruitId != null">
and bpra.recruit_id = #{dto.recruitId}
</if>
<if test="dto.status != null and dto.status == 0">
AND bpra.status = '0'
</if>
<if test="dto.status != null and dto.status == 1">
AND bpra.status != '0'
</if>
</where>
order by bpra.create_time desc
</select>
<select id="taskUserList" resultType="com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO">
select bpra.id,
bpra.entry_time,
bpra.leave_time,
bpra.recruit_id,
wu.user_id,
wu.phone,
wu.score,
wu.avatar_name,
wu.username,
bpra.status,
wu.type_of_work,
bpr.recruit_name,
fpt.task_name,
bpr.task_id
from bgt_project_recruit_apply bpra
left join wgz_user wu on bpra.user_id = wu.user_id
left join bgt_project_recruit bpr on bpr.id = bpra.recruit_id
left join fbs_project_task fpt on fpt.id = bpr.task_id
<where>
<if test="dto.username !=null and dto.username !='' ">
and wu.username like concat('%', #{dto.username}, '%')
</if>
<if test="dto.taskId != null">
and bpra.task_id = #{dto.taskId}
</if>
<if test="dto.status != null">
AND bpra.status = #{dto.status}
</if>
<if test="dto.status != null">
AND bpra.status in ('3','5','6')
</if>
</where>
order by bpra.create_time desc
</select>
</mapper> </mapper>

View File

@ -5,7 +5,7 @@ VUE_APP_TITLE = RuoYi-Vue-Plus后台管理系统
ENV = 'development' ENV = 'development'
# 若依管理系统/开发环境 # 若依管理系统/开发环境
VUE_APP_BASE_API = 'http://127.0.0.1:9099/ruoyi' VUE_APP_BASE_API = 'http://192.168.110.3:9099/ruoyi'
# 路由懒加载 # 路由懒加载
VUE_CLI_BABEL_TRANSPILE_MODULES = true VUE_CLI_BABEL_TRANSPILE_MODULES = true

View File

@ -5,4 +5,4 @@ VUE_APP_TITLE = RuoYi-Vue-Plus后台管理系统
ENV = 'production' ENV = 'production'
# 若依管理系统/生产环境 # 若依管理系统/生产环境
VUE_APP_BASE_API = '/prod-api' VUE_APP_BASE_API = 'http://192.168.110.3:9099/ruoyi'

Binary file not shown.

After

Width:  |  Height:  |  Size: 64 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 29 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 MiB