src/main/java/com/ruoyi/approve/utils/StartAndEndDateDto.java
@@ -1,5 +1,6 @@ package com.ruoyi.approve.utils; import com.baomidou.mybatisplus.annotation.TableField; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; @@ -13,9 +14,11 @@ public class StartAndEndDateDto { @ApiModelProperty("å¼å§æ¶é´") @TableField(exist = false) private String startDate; @ApiModelProperty("ç»ææ¶é´") @TableField(exist = false) private String endDate; } src/main/java/com/ruoyi/home/controller/HomeController.java
@@ -21,6 +21,7 @@ import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import java.text.ParseException; import java.util.List; /** @@ -63,7 +64,7 @@ @GetMapping("/todos") @Log(title = "å¾ åäºé¡¹", businessType = BusinessType.OTHER) @ApiOperation("å¾ åäºé¡¹") public AjaxResult todos(ApproveProcess req) { public AjaxResult todos(ApproveProcess req) throws ParseException { List<ApproveProcess> approveProcessList = homeService.todos(); return AjaxResult.success(approveProcessList); } src/main/java/com/ruoyi/home/service/HomeService.java
@@ -6,6 +6,7 @@ import com.ruoyi.home.dto.QualityStatisticsDto; import com.ruoyi.home.dto.StatisticsReceivablePayableDto; import java.text.ParseException; import java.util.List; /** @@ -22,7 +23,7 @@ QualityStatisticsDto qualityStatistics(); List<ApproveProcess> todos(); List<ApproveProcess> todos() throws ParseException; StatisticsReceivablePayableDto statisticsReceivablePayable(Integer type); } src/main/java/com/ruoyi/home/service/impl/HomeServiceImpl.java
@@ -8,6 +8,8 @@ import com.ruoyi.framework.security.LoginUser; import com.ruoyi.home.dto.*; import com.ruoyi.home.service.HomeService; import com.ruoyi.lavorissue.mapper.LavorIssueMapper; import com.ruoyi.lavorissue.pojo.LaborIssue; import com.ruoyi.procurementrecord.mapper.ProcurementRecordMapper; import com.ruoyi.procurementrecord.mapper.ProcurementRecordOutMapper; import com.ruoyi.procurementrecord.pojo.ProcurementRecordOut; @@ -33,6 +35,8 @@ import java.math.BigDecimal; import java.math.RoundingMode; import java.text.ParseException; import java.text.SimpleDateFormat; import java.time.*; import java.time.temporal.TemporalAdjusters; import java.util.*; @@ -73,6 +77,9 @@ @Autowired private PaymentRegistrationMapper paymentRegistrationMapper; @Autowired private LavorIssueMapper lavorIssueMapper; @Autowired private SysDeptMapper sysDeptMapper; @@ -302,14 +309,35 @@ } @Override public List<ApproveProcess> todos() { public List<ApproveProcess> todos() throws ParseException { LoginUser loginUser = SecurityUtils.getLoginUser(); LambdaQueryWrapper<ApproveProcess> approveProcessLambdaQueryWrapper = new LambdaQueryWrapper<>(); approveProcessLambdaQueryWrapper.eq(ApproveProcess::getApproveDelete, 0) .eq(ApproveProcess::getApproveUserCurrentId, loginUser.getUserId()) .ne(ApproveProcess::getApproveStatus, 2) .eq(ApproveProcess::getTenantId, loginUser.getTenantId()); return approveProcessMapper.selectList(approveProcessLambdaQueryWrapper); List<ApproveProcess> approveProcesses = approveProcessMapper.selectList(approveProcessLambdaQueryWrapper); if(CollectionUtils.isEmpty(approveProcesses)){ approveProcesses = new ArrayList<>(); } // æ¥è¯¢æªé¢ç¨å³ä¿è®°å½ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); LaborIssue laborIssue1 = new LaborIssue(); laborIssue1.setAdoptedDate(new Date()); laborIssue1.setIssueDate(sdf.parse(sdf.format(new Date()))); List<LaborIssue> laborIssues = lavorIssueMapper.list(laborIssue1); if(!CollectionUtils.isEmpty(laborIssues)){ for (LaborIssue laborIssue : laborIssues) { ApproveProcess approveProcess = new ApproveProcess(); approveProcess.setApproveId(laborIssue.getOrderNo()); approveProcess.setApproveDeptName(sysDeptMapper.selectDeptById(loginUser.getTenantId()).getDeptName()); approveProcess.setApproveTime(laborIssue.getIssueDate()); approveProcess.setApproveReason(laborIssue.getDictTypeName() + "-" + laborIssue.getDictName() + "è¶ æ¶æªé¢å"); approveProcesses.add(approveProcess); } } return approveProcesses; } /** src/main/java/com/ruoyi/lavorissue/controller/LavorIssueController.java
@@ -1,13 +1,18 @@ package com.ruoyi.lavorissue.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.ruoyi.approve.pojo.ApproveProcess; import com.ruoyi.approve.utils.DailyRedisCounter; import com.ruoyi.approve.utils.StartAndEndDateDto; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.framework.aspectj.lang.annotation.Log; import com.ruoyi.framework.aspectj.lang.enums.BusinessType; import com.ruoyi.framework.web.controller.BaseController; import com.ruoyi.framework.web.domain.AjaxResult; import com.ruoyi.lavorissue.dto.StatisticsLaborIssue; import com.ruoyi.lavorissue.mapper.LavorIssueMapper; import com.ruoyi.lavorissue.pojo.LaborIssue; import com.ruoyi.lavorissue.service.LavorIssueService; @@ -20,6 +25,8 @@ import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.util.List; /** @@ -53,6 +60,13 @@ @ApiOperation("å³ä¿åæ¾-æ·»å ") @Transactional(rollbackFor = Exception.class) public AjaxResult add(@RequestBody LaborIssue laborIssue){ String today = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd")); StartAndEndDateDto dateTime = DailyRedisCounter.getDateTime(); Long approveId = lavorIssueMapper.selectCount(new LambdaQueryWrapper<LaborIssue>() .gt(LaborIssue::getCreateTime, dateTime.getStartDate()) .lt(LaborIssue::getCreateTime, dateTime.getEndDate())); String formattedCount = String.format("%03d", approveId + 1); laborIssue.setOrderNo(today + formattedCount); boolean save = laborIssueService.save(laborIssue); return save ? AjaxResult.success() : AjaxResult.error(); } @@ -75,6 +89,14 @@ return delete ? AjaxResult.success() : AjaxResult.error(); } @GetMapping("/statistics") @ApiOperation("å³ä¿åæ¾-ç»è®¡") public AjaxResult statistics(StatisticsLaborIssue req) throws Exception { StatisticsLaborIssue statisticsLaborIssue = laborIssueService.statistics(req); return AjaxResult.success(statisticsLaborIssue); } /** * å³ä¿åæ¾-å¯¼åº @@ -85,7 +107,7 @@ public void export(HttpServletResponse response) { Long tenantId = SecurityUtils.getLoginUser().getTenantId(); ExcelUtil<LaborIssue> util = new ExcelUtil<LaborIssue>(LaborIssue.class); List<LaborIssue> list = lavorIssueMapper.list(); List<LaborIssue> list = lavorIssueMapper.list(new LaborIssue()); SysDept sysDept = sysDeptMapper.selectDeptById(tenantId); if(sysDept == null){ throw new RuntimeException("é¨é¨ä¸åå¨!"); src/main/java/com/ruoyi/lavorissue/dto/StatisticsLaborIssue.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,30 @@ package com.ruoyi.lavorissue.dto; import io.swagger.annotations.ApiModel; import lombok.Data; import org.springframework.format.annotation.DateTimeFormat; import java.util.Date; /** * @author :yys * @date : 2025/8/14 11:53 */ @Data @ApiModel public class StatisticsLaborIssue { private Integer season; @DateTimeFormat(pattern = "yyyy-MM-dd") private Date issueDate; private Long ylqNum = 0L; private Long wlqNum = 0L; private Long csylqNum = 0L; private Long cswlqNum = 0L; } src/main/java/com/ruoyi/lavorissue/mapper/LavorIssueMapper.java
@@ -23,5 +23,5 @@ */ IPage<LaborIssue> listPage(Page page, @Param("req") LaborIssue laborIssue); List<LaborIssue> list(); List<LaborIssue> list(@Param("req") LaborIssue laborIssue); } src/main/java/com/ruoyi/lavorissue/pojo/LaborIssue.java
@@ -2,6 +2,7 @@ import com.baomidou.mybatisplus.annotation.*; import com.fasterxml.jackson.annotation.JsonFormat; import com.ruoyi.approve.utils.StartAndEndDateDto; import com.ruoyi.framework.aspectj.lang.annotation.Excel; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; @@ -18,12 +19,19 @@ @Data @TableName("labor_issue") @ApiModel public class LaborIssue { public class LaborIssue extends StartAndEndDateDto { private static final long serialVersionUID = 1L; @TableId(value = "id", type = IdType.AUTO) private Long id; @TableField(exist = false) @ApiModelProperty("1-å·²é¢åå³ä¿æ°é 2-æªé¢åå³ä¿æ°é 3-è¶ æ¶å·²é¢åå³ä¿æ°é 4-è¶ æ¶æªé¢åå³ä¿æ°é") private Integer status; @TableField(exist = false) private Integer season; /** * é¨é¨åç§° @@ -32,6 +40,12 @@ @Excel(name = "é¨é¨åç§°") @TableField(exist = false) private String deptName; /** * å³ä¿åå· */ @ApiModelProperty("å³ä¿åå·") private String orderNo; /** * åå·¥id @@ -54,6 +68,20 @@ @Excel(name = "åå·¥ç¼å·") @TableField(exist = false) private String staffNo; /** * å³ä¿ç±»å-åå ¸ */ @ApiModelProperty("å³ä¿ç±»å-åå ¸") private String dictType; /** * å³ä¿ç±»å */ @ApiModelProperty("å³ä¿ç±»å") @Excel(name = "å³ä¿ç±»å") @TableField(exist = false) private String dictTypeName; /** * é²å ·åç§°-åå ¸ @@ -86,6 +114,24 @@ private Date adoptedDate; /** * è¿åæ¥æ */ @ApiModelProperty("è¿åæ¥æ") @Excel(name = "è¿åæ¥æ", width = 30, dateFormat = "yyyy-MM-dd") @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8") @DateTimeFormat(pattern = "yyyy-MM-dd") private Date factoryDate; /** * åæ¾æ¥æ */ @ApiModelProperty("åæ¾æ¥æ") @Excel(name = "åæ¾æ¥æ", width = 30, dateFormat = "yyyy-MM-dd") @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8") @DateTimeFormat(pattern = "yyyy-MM-dd") private Date issueDate; /** * ç¾å */ @Excel(name = "ç¾å") src/main/java/com/ruoyi/lavorissue/service/LavorIssueService.java
@@ -3,6 +3,7 @@ import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.IService; import com.ruoyi.lavorissue.dto.StatisticsLaborIssue; import com.ruoyi.lavorissue.pojo.LaborIssue; /** @@ -19,4 +20,6 @@ * @return */ IPage<LaborIssue> listPage(Page page, LaborIssue laborIssue); StatisticsLaborIssue statistics(StatisticsLaborIssue req) throws Exception; } src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java
@@ -1,14 +1,24 @@ package com.ruoyi.lavorissue.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.approve.utils.StartAndEndDateDto; import com.ruoyi.lavorissue.dto.StatisticsLaborIssue; import com.ruoyi.lavorissue.mapper.LavorIssueMapper; import com.ruoyi.lavorissue.pojo.LaborIssue; import com.ruoyi.lavorissue.service.LavorIssueService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.util.List; import java.util.stream.Collectors; /** * @author :yys @@ -23,7 +33,89 @@ @Override public IPage<LaborIssue> listPage(Page page, LaborIssue laborIssue) { IPage<LaborIssue> listPage = lavorIssueMapper.listPage(page, laborIssue); return listPage; StartAndEndDateDto startAndEndDateDto = getStartAndEndDateDto(laborIssue.getSeason(), laborIssue.getIssueDate()); laborIssue.setStartDate(startAndEndDateDto.getStartDate()); laborIssue.setEndDate(startAndEndDateDto.getEndDate()); IPage<LaborIssue> laborIssueIPage = lavorIssueMapper.listPage(page, laborIssue); return laborIssueIPage; } public StartAndEndDateDto getStartAndEndDateDto(Integer season,Date payDate){ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); StartAndEndDateDto startAndEndDateDto = new StartAndEndDateDto(); if(season != null){ Calendar calendar = Calendar.getInstance(); int currentYear = calendar.get(Calendar.YEAR); switch (season){ case 1: startAndEndDateDto.setStartDate(currentYear + "-01-01"); startAndEndDateDto.setEndDate(currentYear + "-03-31"); break; case 2: startAndEndDateDto.setStartDate(currentYear + "-04-01"); startAndEndDateDto.setEndDate(currentYear + "-06-30"); break; case 3: startAndEndDateDto.setStartDate(currentYear + "-07-01"); startAndEndDateDto.setEndDate(currentYear + "-09-30"); break; case 4: startAndEndDateDto.setStartDate(currentYear + "-10-01"); startAndEndDateDto.setEndDate(currentYear + "-12-31"); break; } } if(payDate != null){ Date lastDayOfMonth = getLastDayOfMonth(payDate); startAndEndDateDto.setStartDate(sdf.format(payDate)); startAndEndDateDto.setEndDate(sdf.format(lastDayOfMonth)); } return startAndEndDateDto; } @Override public StatisticsLaborIssue statistics(StatisticsLaborIssue req) throws Exception{ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); StatisticsLaborIssue statisticsLaborIssue = new StatisticsLaborIssue(); StartAndEndDateDto startAndEndDateDto = getStartAndEndDateDto(req.getSeason(), req.getIssueDate()); LambdaQueryWrapper<LaborIssue> laborIssueLambdaQueryWrapper = new LambdaQueryWrapper<>(); if(req.getSeason() != null || req.getIssueDate() != null){ laborIssueLambdaQueryWrapper.ge(LaborIssue::getIssueDate, startAndEndDateDto.getStartDate()) .le(LaborIssue::getIssueDate, startAndEndDateDto.getEndDate()); } List<LaborIssue> laborIssues = lavorIssueMapper.selectList(laborIssueLambdaQueryWrapper); if(!CollectionUtils.isEmpty(laborIssues)){ Long sum = laborIssues.stream() .filter(laborIssue -> laborIssue.getAdoptedDate() != null) .mapToLong(LaborIssue::getNum) .sum(); statisticsLaborIssue.setYlqNum(sum); statisticsLaborIssue.setWlqNum(laborIssues.stream() .filter(laborIssue -> laborIssue.getAdoptedDate() == null) .mapToLong(LaborIssue::getNum) .sum()); Date currentDate = new Date(); Date parse = sdf.parse(sdf.format(currentDate)); statisticsLaborIssue.setCsylqNum(laborIssues.stream() .filter(laborIssue -> laborIssue.getIssueDate() != null && laborIssue.getAdoptedDate() != null && (laborIssue.getIssueDate().before(laborIssue.getAdoptedDate()))) .mapToLong(LaborIssue::getNum) .sum()); statisticsLaborIssue.setCswlqNum(laborIssues.stream() .filter(laborIssue -> laborIssue.getIssueDate() != null && laborIssue.getIssueDate().before(parse) && laborIssue.getAdoptedDate() == null) .mapToLong(LaborIssue::getNum) .sum()); } return statisticsLaborIssue; } public Date getLastDayOfMonth(Date date) { Calendar calendar = Calendar.getInstance(); calendar.setTime(date); // è®¾ç½®ä¼ å ¥çDate calendar.set(Calendar.DAY_OF_MONTH, calendar.getActualMaximum(Calendar.DAY_OF_MONTH)); // è®¾ç½®ä¸ºå½ææåä¸å¤© return calendar.getTime(); // è¿åDate对象 } } src/main/resources/mapper/lavorissue/LavorIssueMapper.xml
@@ -7,13 +7,33 @@ t1.*, t2.staff_name as staffName, t2.staff_no as staffNo, t3.dict_label as dictName t3.dict_label as dictName, t4.dict_label as dictTypeName from labor_issue t1 left join staff_join_leave_record t2 on t1.staff_id = t2.id left join sys_dict_data t3 on t1.dict_id = t3.dict_value left join sys_dict_data t4 on t1.dict_type = t4.dict_value <where> <if test="req.season != null and req.season != ''"> and (t1.issue_date >= #{req.startDate} and t1.issue_date <= #{req.endDate}) </if> <if test="req.issueDate != null"> and (t1.issue_date >= #{req.startDate} and t1.issue_date <= #{req.endDate}) </if> <if test="req.staffName != null and req.staffName != ''"> and t2.staff_name like ('%',#{req.staffName},'%') and t2.staff_name like concat('%',#{req.staffName},'%') </if> <if test="req.status != null and req.status == 1"> and t1.adopted_date is not null </if> <if test="req.status != null and req.status == 2"> and t1.adopted_date is null </if> <if test="req.status != null and req.status == 3"> and t1.adopted_date is not null and t1.issue_date < t1.adopted_date </if> <if test="req.status != null and req.status == 4"> and t1.adopted_date is null and t1.issue_date < current_date() </if> </where> </select> @@ -22,9 +42,19 @@ t1.*, t2.staff_name as staffName, t2.staff_no as staffNo, t3.dict_label as dictName t3.dict_label as dictName, t4.dict_label as dictTypeName from labor_issue t1 left join staff_join_leave_record t2 on t1.staff_id = t2.id left join sys_dict_data t3 on t1.dict_id = t3.dict_value left join sys_dict_data t4 on t1.dict_type = t4.dict_value <where> <if test="req.adoptedDate != null"> and t1.adopted_date is null </if> <if test="req.issueDate != null"> and t1.issue_date < #{req.issueDate} </if> </where> </select> </mapper>