Merge remote-tracking branch 'origin/master'
This commit is contained in:
@ -2,6 +2,8 @@ package com.ruoyi.web.controller.bgt;
|
|||||||
|
|
||||||
|
|
||||||
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.vo.BgtAttendanceDetailVO;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
||||||
import com.ruoyi.common.core.domain.AjaxResult;
|
import com.ruoyi.common.core.domain.AjaxResult;
|
||||||
import com.ruoyi.wgz.service.IWgzAttendanceService;
|
import com.ruoyi.wgz.service.IWgzAttendanceService;
|
||||||
@ -23,10 +25,16 @@ public class AppBgtAttendanceController {
|
|||||||
private final IWgzAttendanceService attendanceService;
|
private final IWgzAttendanceService attendanceService;
|
||||||
|
|
||||||
@ApiOperation("App包工头总体考勤情况")
|
@ApiOperation("App包工头总体考勤情况")
|
||||||
@GetMapping()
|
@GetMapping("attendance")
|
||||||
public AjaxResult<BgtAttendanceVO> attendanceDetail(@Validated BgtAttendanceDTO dto) {
|
public AjaxResult<BgtAttendanceVO> attendanceDetail(@Validated BgtAttendanceDTO dto) {
|
||||||
return AjaxResult.success(attendanceService.attendanceDetail(dto));
|
return AjaxResult.success(attendanceService.attendanceDetail(dto));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ApiOperation("App包工头考勤统计详情")
|
||||||
|
@GetMapping("attendanceDetail")
|
||||||
|
public AjaxResult<BgtAttendanceDetailVO> attendanceDetail(@Validated BgtAttendanceDetailDTO dto) {
|
||||||
|
return AjaxResult.success(attendanceService.bgtAttendanceDetail(dto));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
package com.ruoyi.web.controller.bgt;
|
package com.ruoyi.web.controller.bgt;
|
||||||
|
|
||||||
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.BgtProjectRecruitApplyConsentDTO;
|
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
|
||||||
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
|
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.service.IBgtProjectRecruitApplyService;
|
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
|
||||||
import com.ruoyi.common.annotation.Log;
|
import com.ruoyi.common.annotation.Log;
|
||||||
@ -20,6 +22,7 @@ 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.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -40,8 +43,8 @@ public class AppBgtProjectRecruitApplyController extends BaseController {
|
|||||||
|
|
||||||
@ApiOperation("App务工者列表")
|
@ApiOperation("App务工者列表")
|
||||||
@GetMapping("/list")
|
@GetMapping("/list")
|
||||||
public List<BgtProjectRecruitApplyVO> list(@Validated BgtProjectRecruitApplyQueryDTO dto) {
|
public AjaxResult<List<BgtProjectRecruitApplyVO>> list(@Validated BgtProjectRecruitApplyQueryDTO dto) {
|
||||||
return iBgtProjectRecruitApplyService.appQueryList(dto);
|
return AjaxResult.success(iBgtProjectRecruitApplyService.appQueryList(dto));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiOperation("App务工者个人详情")
|
@ApiOperation("App务工者个人详情")
|
||||||
@ -67,5 +70,28 @@ public class AppBgtProjectRecruitApplyController extends BaseController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("指定日期打卡记录")
|
||||||
|
@GetMapping("/todayAttendanceList")
|
||||||
|
public AjaxResult<List<BgtProjectRecruitApplyVO>> todayAttendanceList(@Validated BgtAttendanceDayDTO req) {
|
||||||
|
return AjaxResult.success(iBgtProjectRecruitApplyService.todayAttendanceList(req));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("App务工者退场")
|
||||||
|
@Log(title = "App务工者退场", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PutMapping("/quit/{id}")
|
||||||
|
public AjaxResult<Void> quit(@NotNull(message = "主键不能为空")
|
||||||
|
@PathVariable("id") Long id) {
|
||||||
|
return toAjax(iBgtProjectRecruitApplyService.quit(id) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiOperation("App务工者打分")
|
||||||
|
@Log(title = "App务工者打分", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PutMapping("/score")
|
||||||
|
public AjaxResult<Void> score(@Validated @RequestBody BgtScoreDTO dto) {
|
||||||
|
return toAjax(iBgtProjectRecruitApplyService.score(dto) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,109 @@
|
|||||||
|
package com.ruoyi.web.controller.wgz.controller;
|
||||||
|
|
||||||
|
import com.ruoyi.common.annotation.Log;
|
||||||
|
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||||
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
|
import com.ruoyi.common.core.domain.AjaxResult;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
|
import com.ruoyi.common.utils.poi.ExcelUtil;
|
||||||
|
import com.ruoyi.wgz.bo.WgzScoreRecordQueryBo;
|
||||||
|
import com.ruoyi.wgz.domain.WgzScoreRecord;
|
||||||
|
import com.ruoyi.wgz.service.IWgzScoreRecordService;
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotEmpty;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录Controller
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Api(value = "务工者评分记录控制器", tags = {"务工者评分记录管理"})
|
||||||
|
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/wgz/record")
|
||||||
|
public class WgzScoreRecordController extends BaseController {
|
||||||
|
|
||||||
|
private final IWgzScoreRecordService iWgzScoreRecordService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询务工者评分记录列表
|
||||||
|
*/
|
||||||
|
@ApiOperation("查询务工者评分记录列表")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:list')")
|
||||||
|
@GetMapping("/list")
|
||||||
|
public TableDataInfo<WgzScoreRecord> list(@Validated WgzScoreRecordQueryBo bo) {
|
||||||
|
return iWgzScoreRecordService.queryPageList(bo);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导出务工者评分记录列表
|
||||||
|
*/
|
||||||
|
@ApiOperation("导出务工者评分记录列表")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:export')")
|
||||||
|
@Log(title = "务工者评分记录", businessType = BusinessType.EXPORT)
|
||||||
|
@GetMapping("/export")
|
||||||
|
public AjaxResult<WgzScoreRecord> export(@Validated WgzScoreRecordQueryBo bo) {
|
||||||
|
List<WgzScoreRecord> list = iWgzScoreRecordService.queryList(bo);
|
||||||
|
ExcelUtil<WgzScoreRecord> util = new ExcelUtil<WgzScoreRecord>(WgzScoreRecord.class);
|
||||||
|
return util.exportExcel(list, "务工者评分记录");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取务工者评分记录详细信息
|
||||||
|
*/
|
||||||
|
@ApiOperation("获取务工者评分记录详细信息")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:query')")
|
||||||
|
@GetMapping("/{id}")
|
||||||
|
public AjaxResult<WgzScoreRecord> getInfo(@NotNull(message = "主键不能为空")
|
||||||
|
@PathVariable("id") Long id) {
|
||||||
|
return AjaxResult.success(iWgzScoreRecordService.queryById(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 新增务工者评分记录
|
||||||
|
*/
|
||||||
|
@ApiOperation("新增务工者评分记录")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:add')")
|
||||||
|
@Log(title = "务工者评分记录", businessType = BusinessType.INSERT)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PostMapping()
|
||||||
|
public AjaxResult<Void> add(@Validated @RequestBody WgzScoreRecord bo) {
|
||||||
|
return toAjax(iWgzScoreRecordService.insert(bo) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 修改务工者评分记录
|
||||||
|
*/
|
||||||
|
@ApiOperation("修改务工者评分记录")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:edit')")
|
||||||
|
@Log(title = "务工者评分记录", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PutMapping()
|
||||||
|
public AjaxResult<Void> edit(@Validated @RequestBody WgzScoreRecord bo) {
|
||||||
|
return toAjax(iWgzScoreRecordService.update(bo) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除务工者评分记录
|
||||||
|
*/
|
||||||
|
@ApiOperation("删除务工者评分记录")
|
||||||
|
@PreAuthorize("@ss.hasPermi('wgz:record:remove')")
|
||||||
|
@Log(title = "务工者评分记录" , businessType = BusinessType.DELETE)
|
||||||
|
@DeleteMapping("/{ids}")
|
||||||
|
public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||||
|
@PathVariable Long[] ids) {
|
||||||
|
return toAjax(iWgzScoreRecordService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
|
||||||
|
}
|
||||||
|
}
|
@ -7,7 +7,14 @@ package com.ruoyi.common.enums;
|
|||||||
*/
|
*/
|
||||||
public enum RecruitApplyStatus
|
public enum RecruitApplyStatus
|
||||||
{
|
{
|
||||||
TO_PASS("0", "未选择"), PASS("1", "已选择"), ;
|
SIGN_UP("0", "报名"),
|
||||||
|
BGT_PASS("1", "包工头同意"),
|
||||||
|
BGT_REFUSE("2", "包工头拒绝"),
|
||||||
|
WGZ_PASS("3", "务工者同意"),
|
||||||
|
WGZ_REFUSE("4", "务工者拒绝"),
|
||||||
|
WORKING("5", "进场"),
|
||||||
|
OUT_WORK("6", "离场"),
|
||||||
|
;
|
||||||
|
|
||||||
private final String code;
|
private final String code;
|
||||||
private final String info;
|
private final String info;
|
||||||
|
@ -24,6 +24,10 @@ public class DateUtils extends org.apache.commons.lang3.time.DateUtils
|
|||||||
|
|
||||||
public static String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";
|
public static String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";
|
||||||
|
|
||||||
|
public static String DAY = "1";
|
||||||
|
|
||||||
|
public static String MONTH = "2";
|
||||||
|
|
||||||
private static String[] parsePatterns = {
|
private static String[] parsePatterns = {
|
||||||
"yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM",
|
"yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM",
|
||||||
"yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM",
|
"yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM",
|
||||||
|
@ -10,6 +10,7 @@ import lombok.experimental.Accessors;
|
|||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
|
import java.time.LocalDate;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.LocalTime;
|
import java.time.LocalTime;
|
||||||
|
|
||||||
@ -94,9 +95,14 @@ public class BgtProjectRecruit implements Serializable {
|
|||||||
/**
|
/**
|
||||||
* 招工开始时间
|
* 招工开始时间
|
||||||
*/
|
*/
|
||||||
@Excel(name = "招工开始时间")
|
|
||||||
@ApiModelProperty("招工开始时间")
|
@ApiModelProperty("招工开始时间")
|
||||||
private String recruitBeginTime;
|
private LocalDate recruitBeginTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("招工结束时间")
|
||||||
|
private LocalDate recruitEndTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("招工开工时间")
|
||||||
|
private LocalDate recruitWorkBeginTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 联系人
|
* 联系人
|
||||||
|
@ -1,10 +1,14 @@
|
|||||||
package com.ruoyi.bgt.domain.dto;
|
package com.ruoyi.bgt.domain.dto;
|
||||||
|
|
||||||
|
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 org.springframework.format.annotation.DateTimeFormat;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@ -15,8 +19,10 @@ public class BgtAttendanceDTO {
|
|||||||
@ApiModelProperty("任务ID")
|
@ApiModelProperty("任务ID")
|
||||||
private Long taskId;
|
private Long taskId;
|
||||||
|
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||||
|
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||||
@ApiModelProperty("日期")
|
@ApiModelProperty("日期")
|
||||||
private String date;
|
private LocalDate date;
|
||||||
|
|
||||||
@ApiModelProperty("日期类型(1日 2月)")
|
@ApiModelProperty("日期类型(1日 2月)")
|
||||||
private String dateType;
|
private String dateType;
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
package com.ruoyi.bgt.domain.dto;
|
||||||
|
|
||||||
|
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 org.springframework.format.annotation.DateTimeFormat;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("App包工头总体考勤查询对象")
|
||||||
|
public class BgtAttendanceDayDTO {
|
||||||
|
|
||||||
|
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||||
|
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||||
|
@ApiModelProperty("日期")
|
||||||
|
private LocalDate date;
|
||||||
|
|
||||||
|
@ApiModelProperty("考勤类型(1出勤 2缺勤 3迟到)")
|
||||||
|
private Integer attendanceType;
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
package com.ruoyi.bgt.domain.dto;
|
||||||
|
|
||||||
|
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 org.springframework.format.annotation.DateTimeFormat;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("App包工头总体考勤查询对象")
|
||||||
|
public class BgtAttendanceDetailDTO {
|
||||||
|
|
||||||
|
@ApiModelProperty("务工者ID")
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
@ApiModelProperty("任务Id")
|
||||||
|
private Long taskId;
|
||||||
|
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||||
|
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||||
|
@ApiModelProperty("日期")
|
||||||
|
private LocalDate date;
|
||||||
|
|
||||||
|
}
|
@ -18,8 +18,8 @@ public class BgtProjectRecruitApplyQueryDTO extends BaseEntity {
|
|||||||
@NotEmpty(message = "招工ID列表不能为空")
|
@NotEmpty(message = "招工ID列表不能为空")
|
||||||
private List<Long> recruitIds;
|
private List<Long> recruitIds;
|
||||||
|
|
||||||
@ApiModelProperty("选择状态(0未选择 1已选择)")
|
@ApiModelProperty("选择状态(0报名 1包工同意 2包工头拒绝(截止时间)3务工者同意 4务工者拒绝 5进场 6离场)")
|
||||||
private String status;
|
private List<String> status;
|
||||||
|
|
||||||
@ApiModelProperty("务工者名字")
|
@ApiModelProperty("务工者名字")
|
||||||
private String username;
|
private String username;
|
||||||
|
@ -6,6 +6,8 @@ import io.swagger.annotations.ApiModelProperty;
|
|||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 包工头招工分页查询对象 bgt_project_recruit
|
* 包工头招工分页查询对象 bgt_project_recruit
|
||||||
*
|
*
|
||||||
@ -31,8 +33,8 @@ public class BgtProjectRecruitQueryDTO extends BaseEntity {
|
|||||||
@ApiModelProperty("招工名称")
|
@ApiModelProperty("招工名称")
|
||||||
private String recruitName;
|
private String recruitName;
|
||||||
|
|
||||||
@ApiModelProperty("选择状态(0未选择 1已选择)")
|
@ApiModelProperty("选择状态(0报名 1包工同意 2包工头拒绝(截止时间)3务工者同意 4务工者拒绝 5进场 6离场)")
|
||||||
private String status;
|
private List<String> status;
|
||||||
|
|
||||||
// /** 项目ID */
|
// /** 项目ID */
|
||||||
// @ApiModelProperty("项目ID")
|
// @ApiModelProperty("项目ID")
|
||||||
|
@ -0,0 +1,31 @@
|
|||||||
|
package com.ruoyi.bgt.domain.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("App包工头打分对象")
|
||||||
|
public class BgtScoreDTO {
|
||||||
|
/** 招工ID */
|
||||||
|
@ApiModelProperty("招工ID")
|
||||||
|
private Long recruitId;
|
||||||
|
/** 被评人ID(务工者) */
|
||||||
|
@ApiModelProperty("被评人ID(务工者)")
|
||||||
|
private Long userId;
|
||||||
|
/** 打分人ID(包工头) */
|
||||||
|
@ApiModelProperty("打分人ID(包工头)")
|
||||||
|
private Long scoreBy;
|
||||||
|
/** 评分 */
|
||||||
|
@ApiModelProperty("评分")
|
||||||
|
private BigDecimal score;
|
||||||
|
/** 评分内容 */
|
||||||
|
@ApiModelProperty("评分内容")
|
||||||
|
private String content;
|
||||||
|
}
|
@ -2,6 +2,7 @@ package com.ruoyi.bgt.domain.vo;
|
|||||||
|
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import lombok.experimental.Accessors;
|
import lombok.experimental.Accessors;
|
||||||
@ -17,6 +18,7 @@ import java.time.LocalDate;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
@Accessors(chain = true)
|
@Accessors(chain = true)
|
||||||
@ApiModel("包工头考勤打卡统计对象")
|
@ApiModel("包工头考勤打卡统计对象")
|
||||||
public class BgtAttendanceCountVO implements Serializable {
|
public class BgtAttendanceCountVO implements Serializable {
|
||||||
@ -32,5 +34,8 @@ public class BgtAttendanceCountVO implements Serializable {
|
|||||||
@ApiModelProperty("日期")
|
@ApiModelProperty("日期")
|
||||||
private LocalDate date;
|
private LocalDate date;
|
||||||
|
|
||||||
|
@ApiModelProperty("缺勤人数")
|
||||||
|
private Integer absenceDutyNum;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,63 @@
|
|||||||
|
package com.ruoyi.bgt.domain.vo;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("App包工头总体考勤视图对象")
|
||||||
|
public class BgtAttendanceDetailVO {
|
||||||
|
|
||||||
|
@ApiModelProperty("务工者Id")
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
@ApiModelProperty("姓名")
|
||||||
|
private String username;
|
||||||
|
|
||||||
|
@ApiModelProperty("头像")
|
||||||
|
private String avatarName;
|
||||||
|
|
||||||
|
@ApiModelProperty("进场时间")
|
||||||
|
private LocalDate entryTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("选择状态(0未选择 1已选择)")
|
||||||
|
private String status;
|
||||||
|
|
||||||
|
@ApiModelProperty("出勤天数")
|
||||||
|
private Double dayNum=0D;
|
||||||
|
|
||||||
|
@ApiModelProperty("迟到次数")
|
||||||
|
private Integer lateNum = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("迟到分钟")
|
||||||
|
private Integer lateMinute = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("迟到记录")
|
||||||
|
private List<WgzAttendanceRecordVO> lateRecords;
|
||||||
|
|
||||||
|
@ApiModelProperty("早退次数")
|
||||||
|
private Integer earlyLeaveNum = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("早退分钟")
|
||||||
|
private Integer earlyLeaveMinute = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("早退记录")
|
||||||
|
private List<WgzAttendanceRecordVO> earlyLeaveRecords;
|
||||||
|
|
||||||
|
@ApiModelProperty("缺卡次数")
|
||||||
|
private Integer missNum = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("缺卡记录")
|
||||||
|
private List<WgzAttendanceRecordVO> missRecords;
|
||||||
|
|
||||||
|
@ApiModelProperty("考勤记录")
|
||||||
|
private List<WgzAttendanceRecordVO> records;
|
||||||
|
|
||||||
|
}
|
@ -21,22 +21,25 @@ public class BgtAttendanceVO {
|
|||||||
private String taskName;
|
private String taskName;
|
||||||
|
|
||||||
@ApiModelProperty("到岗人数")
|
@ApiModelProperty("到岗人数")
|
||||||
private Integer reportToDutyNum;
|
private Integer reportToDutyNum = 0;
|
||||||
|
|
||||||
@ApiModelProperty("总人数")
|
@ApiModelProperty("总人数")
|
||||||
private Integer totalNum;
|
private Integer totalNum = 0;
|
||||||
|
|
||||||
@ApiModelProperty("缺勤人数")
|
@ApiModelProperty("缺勤人数")
|
||||||
private Integer absenceDutyNum;
|
private Integer absenceDutyNum = 0;
|
||||||
|
|
||||||
@ApiModelProperty("请假人数")
|
@ApiModelProperty("请假人数")
|
||||||
private Integer leaveNum;
|
private Integer leaveNum = 0;
|
||||||
|
|
||||||
@ApiModelProperty("迟到人数")
|
@ApiModelProperty("迟到人数")
|
||||||
private Integer lateNum;
|
private Integer lateNum = 0;
|
||||||
|
|
||||||
|
@ApiModelProperty("外勤人数")
|
||||||
|
private Integer outDutyNum = 0;
|
||||||
|
|
||||||
@ApiModelProperty("考勤列表")
|
@ApiModelProperty("考勤列表")
|
||||||
List<BgtAttendanceCountVO> countVOS;
|
List<BgtAttendanceCountVO> countVOs;
|
||||||
|
|
||||||
//务工者列表
|
//务工者列表
|
||||||
@ApiModelProperty("申请者列表")
|
@ApiModelProperty("申请者列表")
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
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;
|
||||||
@ -7,6 +8,7 @@ import lombok.NoArgsConstructor;
|
|||||||
import lombok.experimental.Accessors;
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 包工头招工申请对象 bgt_project_recruit_apply
|
* 包工头招工申请对象 bgt_project_recruit_apply
|
||||||
@ -25,6 +27,10 @@ public class BgtProjectRecruitApplyVO implements Serializable {
|
|||||||
@ApiModelProperty("主键ID")
|
@ApiModelProperty("主键ID")
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
|
@ApiModelProperty("进场时间")
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd")
|
||||||
|
private LocalDate entryTime;
|
||||||
|
|
||||||
@ApiModelProperty("务工者用户ID")
|
@ApiModelProperty("务工者用户ID")
|
||||||
private Long userId;
|
private Long userId;
|
||||||
|
|
||||||
@ -40,4 +46,14 @@ public class BgtProjectRecruitApplyVO implements Serializable {
|
|||||||
@ApiModelProperty("头像")
|
@ApiModelProperty("头像")
|
||||||
private String avatarName;
|
private String avatarName;
|
||||||
|
|
||||||
|
@ApiModelProperty("工种")
|
||||||
|
private String typeOfWork;
|
||||||
|
|
||||||
|
@ApiModelProperty("招工主题")
|
||||||
|
private String recruitName;
|
||||||
|
|
||||||
|
@ApiModelProperty("任务名")
|
||||||
|
private String taskName;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@ import lombok.NoArgsConstructor;
|
|||||||
import lombok.experimental.Accessors;
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDate;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -60,8 +61,15 @@ public class BgtProjectRecruitDetailVO implements Serializable {
|
|||||||
@ApiModelProperty("招工数量")
|
@ApiModelProperty("招工数量")
|
||||||
private Integer recruitStaffNum;
|
private Integer recruitStaffNum;
|
||||||
|
|
||||||
|
|
||||||
@ApiModelProperty("招工开始时间")
|
@ApiModelProperty("招工开始时间")
|
||||||
private String recruitBeginTime;
|
private LocalDate recruitBeginTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("招工结束时间")
|
||||||
|
private LocalDate recruitEndTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("招工开工时间")
|
||||||
|
private LocalDate recruitWorkBeginTime;
|
||||||
|
|
||||||
@ApiModelProperty("联系人")
|
@ApiModelProperty("联系人")
|
||||||
private String recruitContactPerson;
|
private String recruitContactPerson;
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
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.io.Serializable;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.time.LocalTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 考勤打卡对象 wgz_attendance
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-20
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("考勤打卡视图对象")
|
||||||
|
public class WgzAttendanceRecordVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("打卡日期")
|
||||||
|
private LocalDate date;
|
||||||
|
|
||||||
|
@ApiModelProperty("星期")
|
||||||
|
private String week;
|
||||||
|
|
||||||
|
@ApiModelProperty("天数")
|
||||||
|
private Double day;
|
||||||
|
|
||||||
|
@ApiModelProperty("时间")
|
||||||
|
@JsonFormat(pattern = "HH:mm")
|
||||||
|
private LocalTime time;
|
||||||
|
|
||||||
|
@ApiModelProperty("分钟")
|
||||||
|
private Integer minutes;
|
||||||
|
|
||||||
|
}
|
@ -2,10 +2,11 @@ package com.ruoyi.bgt.mapper;
|
|||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
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.BgtProjectRecruitApplyQueryDTO;
|
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
|
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
|
||||||
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
|
||||||
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.wgz.bo.req.WgzAppUnderwayReq;
|
import com.ruoyi.wgz.bo.req.WgzAppUnderwayReq;
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
||||||
import org.apache.ibatis.annotations.CacheNamespace;
|
import org.apache.ibatis.annotations.CacheNamespace;
|
||||||
@ -25,6 +26,8 @@ public interface BgtProjectRecruitApplyMapper extends BaseMapperPlus<BgtProjectR
|
|||||||
|
|
||||||
List<BgtProjectRecruitApplyVO> appQueryList(@Param("dto") BgtProjectRecruitApplyQueryDTO dto);
|
List<BgtProjectRecruitApplyVO> appQueryList(@Param("dto") BgtProjectRecruitApplyQueryDTO dto);
|
||||||
|
|
||||||
|
List<BgtProjectRecruitApplyVO> todayAttendanceList(@Param("dto") BgtAttendanceDayDTO dto);
|
||||||
|
|
||||||
// 获取指定项目下的所有成员(分页)
|
// 获取指定项目下的所有成员(分页)
|
||||||
Page<WgzAppUnderwayRes> underwayPage (@Param("page") Page<WgzAppUnderwayReq> page, @Param("userId") Long userId);
|
Page<WgzAppUnderwayRes> underwayPage (@Param("page") Page<WgzAppUnderwayReq> page, @Param("userId") Long userId);
|
||||||
}
|
}
|
||||||
|
@ -2,11 +2,15 @@ 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.BgtProjectRecruitApplyConsentDTO;
|
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
|
||||||
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
|
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;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
import com.ruoyi.wgz.bo.req.WgzAppUnderwayReq;
|
import com.ruoyi.wgz.bo.req.WgzAppUnderwayReq;
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
@ -81,12 +85,26 @@ public interface IBgtProjectRecruitApplyService extends IServicePlus<BgtProjectR
|
|||||||
*/
|
*/
|
||||||
Boolean userApplyForRegistration(Long id);
|
Boolean userApplyForRegistration(Long id);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 同意申请
|
* 同意申请
|
||||||
*/
|
*/
|
||||||
Boolean consent(BgtProjectRecruitApplyConsentDTO dto);
|
Boolean consent(BgtProjectRecruitApplyConsentDTO dto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 指定日期打卡记录
|
||||||
|
*/
|
||||||
|
List<BgtProjectRecruitApplyVO> todayAttendanceList(BgtAttendanceDayDTO dto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 退场
|
||||||
|
*/
|
||||||
|
Boolean quit(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 评分
|
||||||
|
*/
|
||||||
|
Boolean score(@Validated @RequestBody BgtScoreDTO dto);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 务工者取消报名
|
* 务工者取消报名
|
||||||
*/
|
*/
|
||||||
|
@ -8,8 +8,10 @@ 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.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.BgtProjectRecruitApplyConsentDTO;
|
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyConsentDTO;
|
||||||
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
|
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.IBgtProjectRecruitApplyService;
|
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
|
||||||
@ -23,10 +25,17 @@ import com.ruoyi.common.utils.SecurityUtils;
|
|||||||
import com.ruoyi.wgz.bo.req.WgzAppRegisteredProjectReq;
|
import com.ruoyi.wgz.bo.req.WgzAppRegisteredProjectReq;
|
||||||
import com.ruoyi.wgz.bo.req.WgzAppUnderwayReq;
|
import com.ruoyi.wgz.bo.req.WgzAppUnderwayReq;
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
import com.ruoyi.wgz.bo.res.WgzAppUnderwayRes;
|
||||||
|
import com.ruoyi.wgz.domain.WgzScoreRecord;
|
||||||
|
import com.ruoyi.wgz.domain.WgzUser;
|
||||||
|
import com.ruoyi.wgz.service.IWgzScoreRecordService;
|
||||||
|
import com.ruoyi.wgz.service.IWgzUserService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import java.text.DecimalFormat;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -43,6 +52,10 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
|
|||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private IAnnexService annexService;
|
private IAnnexService annexService;
|
||||||
|
@Autowired
|
||||||
|
private IWgzScoreRecordService scoreRecordService;
|
||||||
|
@Autowired
|
||||||
|
private IWgzUserService wgzUserService;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BgtProjectRecruitApply queryById(Long id){
|
public BgtProjectRecruitApply queryById(Long id){
|
||||||
@ -111,14 +124,14 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
|
|||||||
BgtProjectRecruitApply recruitApply = getById(dto.getId());
|
BgtProjectRecruitApply recruitApply = getById(dto.getId());
|
||||||
List<BgtProjectRecruitApply> list = baseMapper.selectList(Wrappers.<BgtProjectRecruitApply>lambdaQuery()
|
List<BgtProjectRecruitApply> list = baseMapper.selectList(Wrappers.<BgtProjectRecruitApply>lambdaQuery()
|
||||||
.eq(BgtProjectRecruitApply::getUserId, recruitApply.getUserId())
|
.eq(BgtProjectRecruitApply::getUserId, recruitApply.getUserId())
|
||||||
.eq(BgtProjectRecruitApply::getStatus,RecruitApplyStatus.PASS.getCode())
|
.in(BgtProjectRecruitApply::getStatus, Arrays.asList(RecruitApplyStatus.WGZ_PASS.getCode(), RecruitApplyStatus.WORKING.getCode()))
|
||||||
.isNotNull(BgtProjectRecruitApply::getLeaveTime));
|
.isNotNull(BgtProjectRecruitApply::getLeaveTime));
|
||||||
|
|
||||||
if(CollectionUtil.isNotEmpty(list)){
|
if(CollectionUtil.isNotEmpty(list)){
|
||||||
throw new BaseException("该务工者已进入其他工地");
|
throw new BaseException("该务工者已进入其他工地");
|
||||||
}
|
}
|
||||||
recruitApply.setEntryTime(dto.getEntryTime());
|
recruitApply.setEntryTime(dto.getEntryTime());
|
||||||
recruitApply.setStatus(RecruitApplyStatus.PASS.getCode());
|
recruitApply.setStatus(RecruitApplyStatus.BGT_PASS.getCode());
|
||||||
dto.getEntryMaterials().addAll(dto.getInsurances());
|
dto.getEntryMaterials().addAll(dto.getInsurances());
|
||||||
annexService.insertBatch(dto.getEntryMaterials());
|
annexService.insertBatch(dto.getEntryMaterials());
|
||||||
return updateById(recruitApply);
|
return updateById(recruitApply);
|
||||||
@ -173,6 +186,37 @@ public class BgtProjectRecruitApplyServiceImpl extends ServicePlusImpl<BgtProjec
|
|||||||
return baseMapper.insert(bgtProjectRecruitApply) >0;
|
return baseMapper.insert(bgtProjectRecruitApply) >0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<BgtProjectRecruitApplyVO> todayAttendanceList(BgtAttendanceDayDTO dto){
|
||||||
|
return baseMapper.todayAttendanceList(dto);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean quit(Long id) {
|
||||||
|
return super.lambdaUpdate().eq(BgtProjectRecruitApply::getId, id)
|
||||||
|
.set(BgtProjectRecruitApply::getLeaveTime, LocalDate.now())
|
||||||
|
.set(BgtProjectRecruitApply::getStatus, RecruitApplyStatus.OUT_WORK.getCode())
|
||||||
|
.update();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public Boolean score(BgtScoreDTO dto) {
|
||||||
|
dto.setScoreBy(SecurityUtils.getAppUserId());
|
||||||
|
Boolean insert = scoreRecordService.insert(BeanUtil.copyProperties(dto, WgzScoreRecord.class));
|
||||||
|
|
||||||
|
List<WgzScoreRecord> wgzScoreRecords = scoreRecordService.getBaseMapper().selectList(Wrappers.<WgzScoreRecord>lambdaQuery()
|
||||||
|
.eq(WgzScoreRecord::getUserId, dto.getUserId()));
|
||||||
|
double rawNewScore = wgzScoreRecords.stream()
|
||||||
|
.mapToDouble(WgzScoreRecord::getScore)
|
||||||
|
.sum();
|
||||||
|
// 使用 DecimalFormat 格式化结果
|
||||||
|
DecimalFormat df = new DecimalFormat("#.0");
|
||||||
|
String formatted = df.format(rawNewScore);
|
||||||
|
Double newScore = Double.parseDouble(formatted);
|
||||||
|
//更新务工者
|
||||||
|
wgzUserService.lambdaUpdate().set(WgzUser::getScore, newScore).eq(WgzUser::getUserId, dto.getUserId()).update();
|
||||||
|
return insert;
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
@Transactional
|
@Transactional
|
||||||
public Boolean userCancelRegistration(Long recruitId) {
|
public Boolean userCancelRegistration(Long recruitId) {
|
||||||
|
@ -139,7 +139,7 @@ public class BgtProjectRecruitServiceImpl extends ServicePlusImpl<BgtProjectRecr
|
|||||||
vo.setTaskName(task.getTaskName());
|
vo.setTaskName(task.getTaskName());
|
||||||
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
|
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
|
||||||
bgtProjectRecruitApplyQueryDTO.setRecruitIds(Collections.singletonList(vo.getId()));
|
bgtProjectRecruitApplyQueryDTO.setRecruitIds(Collections.singletonList(vo.getId()));
|
||||||
bgtProjectRecruitApplyQueryDTO.setStatus(RecruitApplyStatus.TO_PASS.getCode());
|
bgtProjectRecruitApplyQueryDTO.setStatus(Collections.singletonList(RecruitApplyStatus.SIGN_UP.getCode()));
|
||||||
vo.setApplylist(bgtProjectRecruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO));
|
vo.setApplylist(bgtProjectRecruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO));
|
||||||
return vo;
|
return vo;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,93 @@
|
|||||||
|
package com.ruoyi.common.util;
|
||||||
|
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
||||||
|
|
||||||
|
import java.time.*;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class DataUtil {
|
||||||
|
|
||||||
|
public static List<BgtAttendanceCountVO> fillMissingDates(List<BgtAttendanceCountVO> countVOS, LocalDate startDate, LocalDate endDate) {
|
||||||
|
// 使用 HashSet 存储已有的日期,方便快速查找
|
||||||
|
Set<LocalDate> existingDates = new HashSet<>();
|
||||||
|
for (BgtAttendanceCountVO vo : countVOS) {
|
||||||
|
existingDates.add(vo.getDate());
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建一个新的列表,用于存储补充后的结果
|
||||||
|
List<BgtAttendanceCountVO> filledList = new ArrayList<>(countVOS);
|
||||||
|
|
||||||
|
// 遍历日期范围,补充缺失的日期
|
||||||
|
LocalDate currentDate = startDate;
|
||||||
|
while (!currentDate.isAfter(endDate)) {
|
||||||
|
if (!existingDates.contains(currentDate)) {
|
||||||
|
// 如果当前日期不在已有日期集合中,创建一个新的 BgtAttendanceCountVO 对象并添加到结果列表中
|
||||||
|
filledList.add(new BgtAttendanceCountVO(0,0,currentDate,0));
|
||||||
|
}
|
||||||
|
// 日期递增一天
|
||||||
|
currentDate = currentDate.plusDays(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 对结果列表按日期排序
|
||||||
|
filledList.sort(Comparator.comparing(BgtAttendanceCountVO::getDate));
|
||||||
|
|
||||||
|
return filledList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static List<BgtAttendanceCountVO> statisticsByMonth(List<BgtAttendanceCountVO> countVOS, LocalDate startDate, LocalDate endDate) {
|
||||||
|
// 用于存储每个月的统计结果
|
||||||
|
Map<YearMonth, BgtAttendanceCountVO> monthMap = new TreeMap<>();
|
||||||
|
|
||||||
|
// 遍历所有的 BgtAttendanceCountVO 对象
|
||||||
|
for (BgtAttendanceCountVO countVO : countVOS) {
|
||||||
|
LocalDate date = countVO.getDate();
|
||||||
|
YearMonth yearMonth = YearMonth.from(date);
|
||||||
|
|
||||||
|
// 如果该月份已经在 map 中,则累加该月份的到岗人数和总人数
|
||||||
|
if (monthMap.containsKey(yearMonth)) {
|
||||||
|
BgtAttendanceCountVO existingVO = monthMap.get(yearMonth);
|
||||||
|
existingVO.setReportToDutyNum(existingVO.getReportToDutyNum() + countVO.getReportToDutyNum());
|
||||||
|
existingVO.setTotalNum(existingVO.getTotalNum()>countVO.getTotalNum()?existingVO.getTotalNum():countVO.getTotalNum());
|
||||||
|
existingVO.setAbsenceDutyNum(existingVO.getAbsenceDutyNum() + countVO.getTotalNum()-countVO.getReportToDutyNum());
|
||||||
|
} else {
|
||||||
|
// 如果该月份不在 map 中,则创建一个新的 BgtAttendanceCountVO 对象
|
||||||
|
BgtAttendanceCountVO newVO = new BgtAttendanceCountVO(countVO.getReportToDutyNum(), countVO.getTotalNum(), date.withDayOfMonth(1),0);
|
||||||
|
monthMap.put(yearMonth, newVO);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 找出日期范围的起始月份和结束月份
|
||||||
|
if (monthMap.isEmpty()) {
|
||||||
|
return new ArrayList<>();
|
||||||
|
}
|
||||||
|
YearMonth startMonth = YearMonth.from(startDate);
|
||||||
|
YearMonth endMonth = YearMonth.from(endDate);
|
||||||
|
|
||||||
|
// 补足空白月份
|
||||||
|
List<BgtAttendanceCountVO> result = new ArrayList<>();
|
||||||
|
for (YearMonth currentMonth = startMonth; !currentMonth.isAfter(endMonth); currentMonth = currentMonth.plusMonths(1)) {
|
||||||
|
if (monthMap.containsKey(currentMonth)) {
|
||||||
|
result.add(monthMap.get(currentMonth));
|
||||||
|
} else {
|
||||||
|
// 如果该月份没有统计数据,则创建一个新的 BgtAttendanceCountVO 对象,将到岗人数和总人数都设置为 0
|
||||||
|
BgtAttendanceCountVO emptyVO = new BgtAttendanceCountVO(0, 0, currentMonth.atDay(1),0);
|
||||||
|
result.add(emptyVO);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static Integer getMinutes(LocalDateTime clockInTime,LocalTime beginWorkTime){
|
||||||
|
LocalDateTime workDateTime = LocalDateTime.of(clockInTime.toLocalDate(), beginWorkTime);
|
||||||
|
|
||||||
|
// 计算两个 LocalDateTime 对象之间的时间差
|
||||||
|
Duration duration = Duration.between(workDateTime, clockInTime);
|
||||||
|
|
||||||
|
// 将时间差转换为分钟数
|
||||||
|
long minutes = duration.toMinutes();
|
||||||
|
return (int) minutes;
|
||||||
|
}
|
||||||
|
}
|
@ -11,6 +11,7 @@ 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.dto.BgtProjectRecruitApplyQueryDTO;
|
||||||
import com.ruoyi.bgt.domain.dto.BgtWageApplicationQueryDTO;
|
import com.ruoyi.bgt.domain.dto.BgtWageApplicationQueryDTO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
||||||
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.IBgtProjectRecruitService;
|
||||||
@ -21,6 +22,7 @@ import com.ruoyi.common.core.page.TableDataInfo;
|
|||||||
import com.ruoyi.common.enums.AuditStatus;
|
import com.ruoyi.common.enums.AuditStatus;
|
||||||
import com.ruoyi.common.enums.ProjectTaskStatus;
|
import com.ruoyi.common.enums.ProjectTaskStatus;
|
||||||
import com.ruoyi.common.enums.RecruitApplyStatus;
|
import com.ruoyi.common.enums.RecruitApplyStatus;
|
||||||
|
import com.ruoyi.common.util.DataUtil;
|
||||||
import com.ruoyi.common.utils.PageUtils;
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
import com.ruoyi.fbs.bo.FbsProjectTaskQueryBo;
|
import com.ruoyi.fbs.bo.FbsProjectTaskQueryBo;
|
||||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||||
@ -30,7 +32,6 @@ import com.ruoyi.fbs.domain.vo.AppTaskVO;
|
|||||||
import com.ruoyi.fbs.mapper.FbsProjectTaskMapper;
|
import com.ruoyi.fbs.mapper.FbsProjectTaskMapper;
|
||||||
import com.ruoyi.fbs.service.IFbsProjectTaskApplyService;
|
import com.ruoyi.fbs.service.IFbsProjectTaskApplyService;
|
||||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
|
||||||
import com.ruoyi.wgz.service.IWgzAttendanceService;
|
import com.ruoyi.wgz.service.IWgzAttendanceService;
|
||||||
import com.ruoyi.zbf.domain.ZbfProject;
|
import com.ruoyi.zbf.domain.ZbfProject;
|
||||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||||
@ -39,9 +40,7 @@ import org.springframework.context.annotation.Lazy;
|
|||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.time.LocalDate;
|
import java.time.LocalDate;
|
||||||
import java.util.Collection;
|
import java.util.*;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -163,7 +162,7 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
|||||||
|
|
||||||
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
|
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
|
||||||
bgtProjectRecruitApplyQueryDTO.setRecruitIds(recruitIds);
|
bgtProjectRecruitApplyQueryDTO.setRecruitIds(recruitIds);
|
||||||
bgtProjectRecruitApplyQueryDTO.setStatus(RecruitApplyStatus.PASS.getCode());
|
bgtProjectRecruitApplyQueryDTO.setStatus(Collections.singletonList(RecruitApplyStatus.WORKING.getCode()));
|
||||||
appTaskDetailVO.setApplyList(recruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO));
|
appTaskDetailVO.setApplyList(recruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO));
|
||||||
//任务进度
|
//任务进度
|
||||||
appTaskDetailVO.setProgress(progressService.getLastProgress(id));
|
appTaskDetailVO.setProgress(progressService.getLastProgress(id));
|
||||||
@ -187,7 +186,7 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
|||||||
List<BgtAttendanceCountVO> countVOS = attendanceService.countByTaskId(id, startOfMonth, date);
|
List<BgtAttendanceCountVO> countVOS = attendanceService.countByTaskId(id, startOfMonth, date);
|
||||||
if(CollectionUtil.isNotEmpty(countVOS)){
|
if(CollectionUtil.isNotEmpty(countVOS)){
|
||||||
BgtAttendanceCountVO vo = countVOS.get(0);
|
BgtAttendanceCountVO vo = countVOS.get(0);
|
||||||
appTaskDetailVO.setCountVOS(countVOS);
|
appTaskDetailVO.setCountVOS(DataUtil.fillMissingDates(countVOS, startOfMonth, date));
|
||||||
appTaskDetailVO.setTotalNum(vo.getTotalNum());
|
appTaskDetailVO.setTotalNum(vo.getTotalNum());
|
||||||
appTaskDetailVO.setReportToDutyNum(vo.getReportToDutyNum());
|
appTaskDetailVO.setReportToDutyNum(vo.getReportToDutyNum());
|
||||||
appTaskDetailVO.setReportToDutyRate(vo.getReportToDutyNum()/vo.getTotalNum()*100);
|
appTaskDetailVO.setReportToDutyRate(vo.getReportToDutyNum()/vo.getTotalNum()*100);
|
||||||
@ -195,4 +194,6 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
|||||||
|
|
||||||
return appTaskDetailVO;
|
return appTaskDetailVO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,51 @@
|
|||||||
|
package com.ruoyi.wgz.bo;
|
||||||
|
|
||||||
|
import com.ruoyi.common.core.domain.BaseEntity;
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录分页查询对象 wgz_score_record
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@ApiModel("务工者评分记录分页查询对象")
|
||||||
|
public class WgzScoreRecordQueryBo extends BaseEntity {
|
||||||
|
|
||||||
|
/** 分页大小 */
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
/** 排序列 */
|
||||||
|
@ApiModelProperty("排序列")
|
||||||
|
private String orderByColumn;
|
||||||
|
/** 排序的方向desc或者asc */
|
||||||
|
@ApiModelProperty(value = "排序的方向", example = "asc,desc")
|
||||||
|
private String isAsc;
|
||||||
|
|
||||||
|
|
||||||
|
/** 招工ID */
|
||||||
|
@ApiModelProperty("招工ID")
|
||||||
|
private Long recruitId;
|
||||||
|
/** 被评人ID(务工者) */
|
||||||
|
@ApiModelProperty("被评人ID(务工者)")
|
||||||
|
private Long userId;
|
||||||
|
/** 打分人ID(包工头) */
|
||||||
|
@ApiModelProperty("打分人ID(包工头)")
|
||||||
|
private Long scoreBy;
|
||||||
|
/** 评分 */
|
||||||
|
@ApiModelProperty("评分")
|
||||||
|
private Double score;
|
||||||
|
/** 评分内容 */
|
||||||
|
@ApiModelProperty("评分内容")
|
||||||
|
private String content;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,96 @@
|
|||||||
|
package com.ruoyi.wgz.domain;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.FieldFill;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import com.ruoyi.common.annotation.Excel;
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录对象 wgz_score_record
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@TableName("wgz_score_record")
|
||||||
|
@ApiModel("务工者评分记录视图对象")
|
||||||
|
public class WgzScoreRecord implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
/** 主键ID */
|
||||||
|
@ApiModelProperty("主键ID")
|
||||||
|
@TableId(value = "id")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 招工ID */
|
||||||
|
@Excel(name = "招工ID")
|
||||||
|
@ApiModelProperty("招工ID")
|
||||||
|
private Long recruitId;
|
||||||
|
|
||||||
|
/** 被评人ID(务工者) */
|
||||||
|
@Excel(name = "被评人ID(务工者)")
|
||||||
|
@ApiModelProperty("被评人ID(务工者)")
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
/** 打分人ID(包工头) */
|
||||||
|
@Excel(name = "打分人ID(包工头)")
|
||||||
|
@ApiModelProperty("打分人ID(包工头)")
|
||||||
|
private Long scoreBy;
|
||||||
|
|
||||||
|
/** 评分 */
|
||||||
|
@Excel(name = "评分")
|
||||||
|
@ApiModelProperty("评分")
|
||||||
|
private Double score;
|
||||||
|
|
||||||
|
/** 评分内容 */
|
||||||
|
@Excel(name = "评分内容")
|
||||||
|
@ApiModelProperty("评分内容")
|
||||||
|
private String content;
|
||||||
|
|
||||||
|
/** 删除标志(0代表存在 2代表删除) */
|
||||||
|
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
|
||||||
|
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||||
|
private String delFlag;
|
||||||
|
|
||||||
|
/** 创建者 */
|
||||||
|
@Excel(name = "创建者")
|
||||||
|
@ApiModelProperty("创建者")
|
||||||
|
@TableField(fill = FieldFill.INSERT)
|
||||||
|
private String createBy;
|
||||||
|
|
||||||
|
/** 创建时间 */
|
||||||
|
@Excel(name = "创建时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||||
|
@ApiModelProperty("创建时间")
|
||||||
|
@TableField(fill = FieldFill.INSERT)
|
||||||
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
|
/** 更新者 */
|
||||||
|
@Excel(name = "更新者")
|
||||||
|
@ApiModelProperty("更新者")
|
||||||
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||||
|
private String updateBy;
|
||||||
|
|
||||||
|
/** 更新时间 */
|
||||||
|
@Excel(name = "更新时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||||
|
@ApiModelProperty("更新时间")
|
||||||
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||||
|
private LocalDateTime updateTime;
|
||||||
|
|
||||||
|
/** 备注 */
|
||||||
|
@Excel(name = "备注")
|
||||||
|
@ApiModelProperty("备注")
|
||||||
|
private String remark;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
package com.ruoyi.wgz.mapper;
|
||||||
|
|
||||||
|
import com.ruoyi.wgz.domain.WgzScoreRecord;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||||
|
import org.apache.ibatis.annotations.CacheNamespace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录Mapper接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
// 如使需切换数据源 请勿使用缓存 会造成数据不一致现象
|
||||||
|
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
||||||
|
public interface WgzScoreRecordMapper extends BaseMapperPlus<WgzScoreRecord> {
|
||||||
|
|
||||||
|
}
|
@ -1,19 +1,17 @@
|
|||||||
package com.ruoyi.wgz.service;
|
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.vo.BgtAttendanceCountVO;
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceDetailVO;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
||||||
import com.ruoyi.common.core.domain.AjaxResult;
|
|
||||||
import com.ruoyi.wgz.bo.req.WgzAppSubmitTheClockReq;
|
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppCardReplacementApplicationRes;
|
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppPunchTheCalendarRecordRes;
|
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppUserClockingConditionRes;
|
|
||||||
import com.ruoyi.wgz.domain.WgzAttendance;
|
|
||||||
import com.ruoyi.wgz.bo.WgzAttendanceQueryBo;
|
|
||||||
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.wgz.bo.WgzAttendanceQueryBo;
|
import com.ruoyi.wgz.bo.WgzAttendanceQueryBo;
|
||||||
import com.ruoyi.wgz.bo.req.WgzAppSubmitTheClockReq;
|
import com.ruoyi.wgz.bo.req.WgzAppSubmitTheClockReq;
|
||||||
|
import com.ruoyi.wgz.bo.res.WgzAppCardReplacementApplicationRes;
|
||||||
|
import com.ruoyi.wgz.bo.res.WgzAppPunchTheCalendarRecordRes;
|
||||||
|
import com.ruoyi.wgz.bo.res.WgzAppUserClockingConditionRes;
|
||||||
import com.ruoyi.wgz.domain.WgzAttendance;
|
import com.ruoyi.wgz.domain.WgzAttendance;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
@ -120,4 +118,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);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,55 @@
|
|||||||
|
package com.ruoyi.wgz.service;
|
||||||
|
|
||||||
|
import com.ruoyi.wgz.domain.WgzScoreRecord;
|
||||||
|
import com.ruoyi.wgz.bo.WgzScoreRecordQueryBo;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录Service接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
public interface IWgzScoreRecordService extends IServicePlus<WgzScoreRecord> {
|
||||||
|
/**
|
||||||
|
* 查询单个
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
WgzScoreRecord queryById(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<WgzScoreRecord> queryPageList(WgzScoreRecordQueryBo bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*/
|
||||||
|
List<WgzScoreRecord> queryList(WgzScoreRecordQueryBo bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据新增业务对象插入务工者评分记录
|
||||||
|
* @param bo 务工者评分记录新增业务对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean insert(WgzScoreRecord bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据编辑业务对象修改务工者评分记录
|
||||||
|
* @param bo 务工者评分记录编辑业务对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean update(WgzScoreRecord bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 校验并删除数据
|
||||||
|
* @param ids 主键集合
|
||||||
|
* @param isValid 是否校验,true-删除前校验,false-不校验
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
package com.ruoyi.wgz.service.impl;
|
package com.ruoyi.wgz.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.collection.CollectionUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
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;
|
||||||
@ -8,13 +9,21 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|||||||
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.BgtAttendanceDTO;
|
import com.ruoyi.bgt.domain.dto.BgtAttendanceDTO;
|
||||||
|
import com.ruoyi.bgt.domain.dto.BgtAttendanceDetailDTO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceDetailVO;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
import com.ruoyi.bgt.domain.vo.BgtAttendanceVO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.WgzAttendanceRecordVO;
|
||||||
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
|
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
|
||||||
import com.ruoyi.bgt.service.IBgtProjectRecruitService;
|
import com.ruoyi.bgt.service.IBgtProjectRecruitService;
|
||||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.common.util.DataUtil;
|
||||||
|
import com.ruoyi.common.utils.DateUtils;
|
||||||
import com.ruoyi.common.utils.PageUtils;
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
import com.ruoyi.common.utils.SecurityUtils;
|
import com.ruoyi.common.utils.SecurityUtils;
|
||||||
|
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||||
|
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||||
import com.ruoyi.wgz.bo.WgzAttendanceQueryBo;
|
import com.ruoyi.wgz.bo.WgzAttendanceQueryBo;
|
||||||
import com.ruoyi.wgz.bo.req.WgzAppSubmitTheClockReq;
|
import com.ruoyi.wgz.bo.req.WgzAppSubmitTheClockReq;
|
||||||
import com.ruoyi.wgz.bo.res.WgzAppCardReplacementApplicationRes;
|
import com.ruoyi.wgz.bo.res.WgzAppCardReplacementApplicationRes;
|
||||||
@ -24,24 +33,22 @@ 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.WgzLeave;
|
import com.ruoyi.wgz.domain.WgzUser;
|
||||||
import com.ruoyi.bgt.domain.vo.BgtAttendanceCountVO;
|
|
||||||
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;
|
||||||
import org.aspectj.weaver.ast.Var;
|
import com.ruoyi.wgz.service.IWgzUserService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.time.*;
|
import java.time.*;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.time.temporal.TemporalAdjusters;
|
import java.time.temporal.TemporalAdjusters;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Collection;
|
import java.util.stream.Collectors;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 考勤打卡Service业务层处理
|
* 考勤打卡Service业务层处理
|
||||||
@ -65,6 +72,12 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
|
|||||||
@Autowired
|
@Autowired
|
||||||
private IWgzLeaveService iWgzLeaveService;
|
private IWgzLeaveService iWgzLeaveService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private IFbsProjectTaskService taskService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private IWgzUserService wgzUserService;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public WgzAttendance queryById(Long id){
|
public WgzAttendance queryById(Long id){
|
||||||
@ -325,6 +338,7 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
|
|||||||
return baseMapper.selectCount(apply);
|
return baseMapper.selectCount(apply);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<BgtAttendanceCountVO> countByTaskId(Long taskId, LocalDate beginDate, LocalDate endDate) {
|
public List<BgtAttendanceCountVO> countByTaskId(Long taskId, LocalDate beginDate, LocalDate endDate) {
|
||||||
return baseMapper.countByTaskId(taskId, beginDate, endDate);
|
return baseMapper.countByTaskId(taskId, beginDate, endDate);
|
||||||
@ -332,14 +346,62 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BgtAttendanceVO attendanceDetail(BgtAttendanceDTO dto) {
|
public BgtAttendanceVO attendanceDetail(BgtAttendanceDTO dto) {
|
||||||
|
BgtAttendanceVO bgtAttendanceVO = new BgtAttendanceVO();
|
||||||
|
FbsProjectTask task = taskService.getById(dto.getTaskId());
|
||||||
|
bgtAttendanceVO.setTaskId(task.getId());
|
||||||
|
bgtAttendanceVO.setTaskName(task.getTaskName());
|
||||||
|
LocalDate date = dto.getDate();
|
||||||
|
|
||||||
|
LocalDate startData = null;
|
||||||
|
LocalDate endData = null;
|
||||||
|
|
||||||
|
if(dto.getDateType().equals(DateUtils.DAY)){
|
||||||
|
// 获取本月开始日期
|
||||||
|
startData = date.with(TemporalAdjusters.firstDayOfMonth());
|
||||||
|
endData = date;
|
||||||
|
|
||||||
|
List<BgtAttendanceCountVO> countVOS = countByTaskId(dto.getTaskId(), startData, endData);
|
||||||
return null;
|
if(CollectionUtil.isNotEmpty(countVOS)){
|
||||||
|
bgtAttendanceVO.setCountVOs(DataUtil.fillMissingDates(countVOS, startData, endData));
|
||||||
|
BgtAttendanceCountVO countVO = countVOS.stream()
|
||||||
|
.filter(vo -> vo.getDate().isEqual(date))
|
||||||
|
.findFirst().orElse(null);
|
||||||
|
bgtAttendanceVO.setReportToDutyNum(countVO.getReportToDutyNum());
|
||||||
|
bgtAttendanceVO.setTotalNum(countVO.getTotalNum());
|
||||||
|
bgtAttendanceVO.setAbsenceDutyNum(countVO.getTotalNum()-countVO.getReportToDutyNum());
|
||||||
|
}
|
||||||
|
}else if(dto.getDateType().equals(DateUtils.MONTH)){
|
||||||
|
// 获取本年开始日期
|
||||||
|
startData = date.with(TemporalAdjusters.firstDayOfYear());
|
||||||
|
endData = date.with(TemporalAdjusters.lastDayOfMonth());
|
||||||
|
List<BgtAttendanceCountVO> countVOS = countByTaskId(dto.getTaskId(), startData, endData);
|
||||||
|
if(CollectionUtil.isNotEmpty(countVOS)){
|
||||||
|
bgtAttendanceVO.setCountVOs(DataUtil.statisticsByMonth(countVOS,startData, endData));
|
||||||
|
}
|
||||||
|
BgtAttendanceCountVO countVO = countVOS.stream()
|
||||||
|
.filter(vo -> YearMonth.from(vo.getDate()).equals(YearMonth.from(date)))
|
||||||
|
.findFirst().orElse(null);
|
||||||
|
bgtAttendanceVO.setReportToDutyNum(countVO.getReportToDutyNum());
|
||||||
|
bgtAttendanceVO.setTotalNum(countVO.getTotalNum());
|
||||||
|
bgtAttendanceVO.setAbsenceDutyNum(countVO.getAbsenceDutyNum());
|
||||||
|
}
|
||||||
|
getLateAndLeave(bgtAttendanceVO, startData, endData);
|
||||||
|
return bgtAttendanceVO;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Override
|
public void getLateAndLeave(BgtAttendanceVO vo,LocalDate startDate, LocalDate endDate){
|
||||||
|
List<BgtProjectRecruit> bgtProjectRecruits = iBgtProjectRecruitService.getBaseMapper().selectList(Wrappers.<BgtProjectRecruit>lambdaQuery()
|
||||||
|
.eq(BgtProjectRecruit::getTaskId, vo.getTaskId()));
|
||||||
|
List<Long> recruitIds = bgtProjectRecruits.stream().map(BgtProjectRecruit::getId).collect(Collectors.toList());
|
||||||
|
Integer late = baseMapper.selectCount(Wrappers.<WgzAttendance>lambdaQuery().eq(WgzAttendance::getLate, 1)
|
||||||
|
.in(WgzAttendance::getRecruitId, recruitIds).between(WgzAttendance::getDate, startDate, endDate));
|
||||||
|
Integer leave = baseMapper.selectCount(Wrappers.<WgzAttendance>lambdaQuery().isNotNull(WgzAttendance::getLeaveMarkId)
|
||||||
|
.in(WgzAttendance::getRecruitId, recruitIds).between(WgzAttendance::getDate, startDate, endDate));
|
||||||
|
vo.setLateNum(late);
|
||||||
|
vo.setLeaveNum(leave);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Override
|
||||||
// public WgzAttendance findByUserIdWait(Long appUserId, Long recruitId, String date) {
|
// public WgzAttendance findByUserIdWait(Long appUserId, Long recruitId, String date) {
|
||||||
// LambdaQueryWrapper<WgzAttendance> qw = new LambdaQueryWrapper<>();
|
// LambdaQueryWrapper<WgzAttendance> qw = new LambdaQueryWrapper<>();
|
||||||
// qw.eq(WgzAttendance::getRecruitId,recruitId);
|
// qw.eq(WgzAttendance::getRecruitId,recruitId);
|
||||||
@ -444,4 +506,105 @@ public class WgzAttendanceServiceImpl extends ServicePlusImpl<WgzAttendanceMappe
|
|||||||
.setFillingDataTime(fillingDataTime);
|
.setFillingDataTime(fillingDataTime);
|
||||||
list.add(two);
|
list.add(two);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BgtAttendanceDetailVO bgtAttendanceDetail(BgtAttendanceDetailDTO dto) {
|
||||||
|
BgtAttendanceDetailVO bgtAttendanceDetailVO = new BgtAttendanceDetailVO();
|
||||||
|
|
||||||
|
WgzUser wgzUser = wgzUserService.getById(dto.getUserId());
|
||||||
|
bgtAttendanceDetailVO.setUserId(wgzUser.getUserId());
|
||||||
|
bgtAttendanceDetailVO.setUsername(wgzUser.getUsername());
|
||||||
|
bgtAttendanceDetailVO.setAvatarName(wgzUser.getAvatarName());
|
||||||
|
|
||||||
|
List<BgtProjectRecruit> bgtProjectRecruits = iBgtProjectRecruitService.getBaseMapper().selectList(Wrappers.<BgtProjectRecruit>lambdaQuery()
|
||||||
|
.eq(BgtProjectRecruit::getTaskId, dto.getTaskId()));
|
||||||
|
List<Long> recruitIds = bgtProjectRecruits.stream().map(BgtProjectRecruit::getId).collect(Collectors.toList());
|
||||||
|
|
||||||
|
BgtProjectRecruitApply recruitApply = iBgtProjectRecruitApplyService.getById(recruitIds.get(0));
|
||||||
|
bgtAttendanceDetailVO.setEntryTime(recruitApply.getEntryTime());
|
||||||
|
bgtAttendanceDetailVO.setStatus(recruitApply.getStatus());
|
||||||
|
|
||||||
|
LambdaQueryWrapper<WgzAttendance> wrapper = new LambdaQueryWrapper<>();
|
||||||
|
wrapper.eq(WgzAttendance::getUserId,dto.getUserId());
|
||||||
|
|
||||||
|
wrapper.in(WgzAttendance::getRecruitId,recruitIds);
|
||||||
|
LocalDate date = dto.getDate();
|
||||||
|
LocalDate startDate = date.with(TemporalAdjusters.firstDayOfMonth());
|
||||||
|
LocalDate endData = date.with(TemporalAdjusters.lastDayOfMonth());
|
||||||
|
wrapper.between(WgzAttendance::getDate,startDate,endData);
|
||||||
|
List<WgzAttendance> wgzAttendances = baseMapper.selectList(wrapper);
|
||||||
|
// 创建SimpleDateFormat对象,格式化日期为中文星期
|
||||||
|
SimpleDateFormat sdf = new SimpleDateFormat("EEEE", java.util.Locale.CHINESE);
|
||||||
|
|
||||||
|
//获取招工打卡时间
|
||||||
|
List<BgtProjectRecruit> list = iBgtProjectRecruitService.list(Wrappers.<BgtProjectRecruit>lambdaQuery().in(BgtProjectRecruit::getId));
|
||||||
|
Map<Long, BgtProjectRecruit> recruitMap = list.stream().collect(Collectors.toMap(BgtProjectRecruit::getId, recruit -> recruit));
|
||||||
|
|
||||||
|
|
||||||
|
List<WgzAttendanceRecordVO> lateRecords = new ArrayList<>();
|
||||||
|
List<WgzAttendanceRecordVO> earlyLeaveRecords= new ArrayList<>();
|
||||||
|
List<WgzAttendanceRecordVO> missRecords= new ArrayList<>();
|
||||||
|
List<WgzAttendanceRecordVO> records= new ArrayList<>();
|
||||||
|
|
||||||
|
|
||||||
|
for (WgzAttendance wgzAttendance:wgzAttendances){
|
||||||
|
WgzAttendanceRecordVO recordVO = new WgzAttendanceRecordVO();
|
||||||
|
recordVO.setDate(wgzAttendance.getDate());
|
||||||
|
recordVO.setWeek(sdf.format(date));
|
||||||
|
if(wgzAttendance.getMissedIn()==0 && wgzAttendance.getMissedOut()==0){
|
||||||
|
recordVO.setDay(1D);
|
||||||
|
records.add(recordVO);
|
||||||
|
}else if(wgzAttendance.getMissedIn()==1 && wgzAttendance.getMissedOut()==1){
|
||||||
|
recordVO.setDay(0D);
|
||||||
|
}else {
|
||||||
|
recordVO.setDay(0.5D);
|
||||||
|
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) {
|
||||||
|
WgzAttendanceRecordVO LateRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
|
||||||
|
LateRecordVO.setTime(clockInTime.toLocalTime());
|
||||||
|
LateRecordVO.setMinutes(DataUtil.getMinutes(clockInTime,beginWorkTime));
|
||||||
|
lateRecords.add(LateRecordVO);
|
||||||
|
}
|
||||||
|
if (wgzAttendance.getEarlyLeave() == 1) {
|
||||||
|
WgzAttendanceRecordVO earlyLeaveRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
|
||||||
|
earlyLeaveRecordVO.setTime(clockOutTime.toLocalTime());
|
||||||
|
earlyLeaveRecordVO.setMinutes(DataUtil.getMinutes(clockOutTime,endWorkTime));
|
||||||
|
earlyLeaveRecords.add(earlyLeaveRecordVO);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wgzAttendance.getMissedIn() == 1) {
|
||||||
|
WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
|
||||||
|
missRecordVO.setTime(beginWorkTime);
|
||||||
|
missRecords.add(missRecordVO);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wgzAttendance.getMissedOut() == 1) {
|
||||||
|
WgzAttendanceRecordVO missRecordVO = BeanUtil.copyProperties(recordVO, WgzAttendanceRecordVO.class);
|
||||||
|
missRecordVO.setTime(endWorkTime);
|
||||||
|
missRecords.add(missRecordVO);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
bgtAttendanceDetailVO.setDayNum(records.stream().mapToDouble(WgzAttendanceRecordVO::getDay).sum());
|
||||||
|
|
||||||
|
bgtAttendanceDetailVO.setLateNum(lateRecords.size());
|
||||||
|
bgtAttendanceDetailVO.setLateMinute(lateRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum());
|
||||||
|
bgtAttendanceDetailVO.setLateRecords(lateRecords);
|
||||||
|
|
||||||
|
bgtAttendanceDetailVO.setEarlyLeaveNum(earlyLeaveRecords.size());
|
||||||
|
bgtAttendanceDetailVO.setEarlyLeaveMinute(earlyLeaveRecords.stream().mapToInt(WgzAttendanceRecordVO::getMinutes).sum());
|
||||||
|
bgtAttendanceDetailVO.setEarlyLeaveRecords(earlyLeaveRecords);
|
||||||
|
|
||||||
|
bgtAttendanceDetailVO.setMissNum(earlyLeaveRecords.size());
|
||||||
|
bgtAttendanceDetailVO.setMissRecords(earlyLeaveRecords);
|
||||||
|
return bgtAttendanceDetailVO;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,88 @@
|
|||||||
|
package com.ruoyi.wgz.service.impl;
|
||||||
|
|
||||||
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.util.StrUtil;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
|
import com.ruoyi.common.core.page.PagePlus;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
|
import com.ruoyi.wgz.bo.WgzScoreRecordQueryBo;
|
||||||
|
import com.ruoyi.wgz.domain.WgzScoreRecord;
|
||||||
|
import com.ruoyi.wgz.mapper.WgzScoreRecordMapper;
|
||||||
|
import com.ruoyi.wgz.service.IWgzScoreRecordService;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 务工者评分记录Service业务层处理
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class WgzScoreRecordServiceImpl extends ServicePlusImpl<WgzScoreRecordMapper, WgzScoreRecord> implements IWgzScoreRecordService {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public WgzScoreRecord queryById(Long id){
|
||||||
|
return getById(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<WgzScoreRecord> queryPageList(WgzScoreRecordQueryBo bo) {
|
||||||
|
Page<WgzScoreRecord> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||||
|
return PageUtils.buildDataInfo(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<WgzScoreRecord> queryList(WgzScoreRecordQueryBo bo) {
|
||||||
|
return list(buildQueryWrapper(bo));
|
||||||
|
}
|
||||||
|
|
||||||
|
private LambdaQueryWrapper<WgzScoreRecord> buildQueryWrapper(WgzScoreRecordQueryBo bo) {
|
||||||
|
Map<String, Object> params = bo.getParams();
|
||||||
|
LambdaQueryWrapper<WgzScoreRecord> lqw = Wrappers.lambdaQuery();
|
||||||
|
lqw.eq(bo.getRecruitId() != null, WgzScoreRecord::getRecruitId, bo.getRecruitId());
|
||||||
|
lqw.eq(bo.getUserId() != null, WgzScoreRecord::getUserId, bo.getUserId());
|
||||||
|
lqw.eq(bo.getScoreBy() != null, WgzScoreRecord::getScoreBy, bo.getScoreBy());
|
||||||
|
lqw.eq(bo.getScore() != null, WgzScoreRecord::getScore, bo.getScore());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getContent()), WgzScoreRecord::getContent, bo.getContent());
|
||||||
|
return lqw;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean insert(WgzScoreRecord bo) {
|
||||||
|
WgzScoreRecord add = BeanUtil.toBean(bo, WgzScoreRecord.class);
|
||||||
|
validEntityBeforeSave(add);
|
||||||
|
return save(add);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean update(WgzScoreRecord bo) {
|
||||||
|
WgzScoreRecord update = BeanUtil.toBean(bo, WgzScoreRecord.class);
|
||||||
|
validEntityBeforeSave(update);
|
||||||
|
return updateById(update);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存前的数据校验
|
||||||
|
*
|
||||||
|
* @param entity 实体类数据
|
||||||
|
*/
|
||||||
|
private void validEntityBeforeSave(WgzScoreRecord entity){
|
||||||
|
//TODO 做一些数据校验,如唯一约束
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||||
|
if(isValid){
|
||||||
|
//TODO 做一些业务上的校验,判断是否需要校验
|
||||||
|
}
|
||||||
|
return removeByIds(ids);
|
||||||
|
}
|
||||||
|
}
|
@ -17,16 +17,65 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
</resultMap>
|
</resultMap>
|
||||||
|
|
||||||
<select id="appQueryList" resultType="com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO">
|
<select id="appQueryList" resultType="com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO">
|
||||||
select bpra.id, wu.user_id, wu.phone, wu.score, wu.avatar_name, wu.username
|
select bpra.id,
|
||||||
|
bpra.entry_time,
|
||||||
|
wu.user_id,
|
||||||
|
wu.phone,
|
||||||
|
wu.score,
|
||||||
|
wu.avatar_name,
|
||||||
|
wu.username,
|
||||||
|
wu.type_of_work,
|
||||||
|
bpr.recruit_name,
|
||||||
|
fpt.task_name
|
||||||
from bgt_project_recruit_apply bpra
|
from bgt_project_recruit_apply bpra
|
||||||
left join wgz_user wu on bpra.user_id = wu.user_id
|
left join wgz_user wu on bpra.user_id = wu.user_id
|
||||||
where bpra.recruit_id = #{dto.recruitId}
|
left join bgt_project_recruit bpr on bpr.id = bpra.recruit_id
|
||||||
<if test="dto.status !=null and dto.status !='' ">
|
left join fbs_project_task fpt on fpt.id = bpr.task_id
|
||||||
and bpra.status = #{dto.status}
|
<where>
|
||||||
</if>
|
|
||||||
<if test="dto.username !=null and dto.username !='' ">
|
<if test="dto.username !=null and dto.username !='' ">
|
||||||
and wu.username like concat('%', #{dto.username}, '%')
|
and wu.username like concat('%', #{dto.username}, '%')
|
||||||
</if>
|
</if>
|
||||||
|
<if test="dto.recruitIds != null and dto.recruitIds.size() > 0">
|
||||||
|
AND bpra.recruit_id IN
|
||||||
|
<foreach collection="dto.recruitIds" item="recruitId" open="(" separator="," close=")">
|
||||||
|
#{recruitId}
|
||||||
|
</foreach>
|
||||||
|
</if>
|
||||||
|
<if test="dto.status != null and dto.status.size() > 0">
|
||||||
|
AND bpra.status IN
|
||||||
|
<foreach collection="dto.status" item="item" open="(" separator="," close=")">
|
||||||
|
#{item}
|
||||||
|
</foreach>
|
||||||
|
</if>
|
||||||
|
</where>
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<select id="todayAttendanceList" resultType="com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO">
|
||||||
|
select bpra.id,
|
||||||
|
bpra.entry_time,
|
||||||
|
wu.user_id,
|
||||||
|
wu.phone,
|
||||||
|
wu.score,
|
||||||
|
wu.avatar_name,
|
||||||
|
wu.username,
|
||||||
|
wu.type_of_work,
|
||||||
|
bpr.recruit_name,
|
||||||
|
fpt.task_name
|
||||||
|
from wgz_attendance wa
|
||||||
|
left join wgz_user wu on wa.user_id = wu.user_id
|
||||||
|
left join bgt_project_recruit_apply bpra on wa.recruit_id = bpra.recruit_id and bpra.user_id = wa.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 wa.date = #{dto.date}'
|
||||||
|
<if test="dto.attendanceType !=null and dto.attendanceType ==1 ">
|
||||||
|
and (wa.missed_in =0 or missed_out = 0 )
|
||||||
|
</if>
|
||||||
|
<if test="dto.attendanceType !=null and dto.attendanceType ==2 ">
|
||||||
|
and (wa.missed_in =1 and missed_out = 1 )
|
||||||
|
</if>
|
||||||
|
<if test="dto.attendanceType !=null and dto.attendanceType ==3 ">
|
||||||
|
and wa.late =1
|
||||||
|
</if>
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="underwayPage" resultType="com.ruoyi.wgz.bo.res.WgzAppUnderwayRes">
|
<select id="underwayPage" resultType="com.ruoyi.wgz.bo.res.WgzAppUnderwayRes">
|
||||||
|
@ -0,0 +1,23 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.ruoyi.wgz.mapper.WgzScoreRecordMapper">
|
||||||
|
|
||||||
|
<resultMap type="com.ruoyi.wgz.domain.WgzScoreRecord" id="WgzScoreRecordResult">
|
||||||
|
<result property="id" column="id"/>
|
||||||
|
<result property="recruitId" column="recruit_id"/>
|
||||||
|
<result property="userId" column="user_id"/>
|
||||||
|
<result property="scoreBy" column="score_by"/>
|
||||||
|
<result property="score" column="score"/>
|
||||||
|
<result property="content" column="content"/>
|
||||||
|
<result property="delFlag" column="del_flag"/>
|
||||||
|
<result property="createBy" column="create_by"/>
|
||||||
|
<result property="createTime" column="create_time"/>
|
||||||
|
<result property="updateBy" column="update_by"/>
|
||||||
|
<result property="updateTime" column="update_time"/>
|
||||||
|
<result property="remark" column="remark"/>
|
||||||
|
</resultMap>
|
||||||
|
|
||||||
|
|
||||||
|
</mapper>
|
Reference in New Issue
Block a user