diff --git a/wisenergy-mapper/src/main/resources/mapper/WorkTimeOrderMapper.xml b/wisenergy-mapper/src/main/resources/mapper/WorkTimeOrderMapper.xml index 4e09516ad2a051c8f9315fe8d4191f4908defb42..8ec178b9bda3ac4084ae84fdcaf0f78ca0d14036 100644 --- a/wisenergy-mapper/src/main/resources/mapper/WorkTimeOrderMapper.xml +++ b/wisenergy-mapper/src/main/resources/mapper/WorkTimeOrderMapper.xml @@ -122,7 +122,7 @@ </foreach> </if> </where> - ORDER BY work_day,project_name DESC + ORDER BY work_day,project_id DESC </select> <!-- 通用查询结果列 --> diff --git a/wisenergy-service/src/main/java/cn/wisenergy/service/impl/WorkTimeOrderServiceImpl.java b/wisenergy-service/src/main/java/cn/wisenergy/service/impl/WorkTimeOrderServiceImpl.java index bedb3c6cd3882690c5c26d19146a93b939beb9fc..d8760f2b39f19c8cde3d46afb99cb42a39898bc0 100644 --- a/wisenergy-service/src/main/java/cn/wisenergy/service/impl/WorkTimeOrderServiceImpl.java +++ b/wisenergy-service/src/main/java/cn/wisenergy/service/impl/WorkTimeOrderServiceImpl.java @@ -164,6 +164,7 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { List<WorkTimeOrderDto> result = this.saveWorkOrderInfo(dto.getWorkTimeOrders()); log.info("WorkOrderServiceImpl[]add[]add.success"); return result; + } /** @@ -183,10 +184,24 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { // åˆ¤æ–æ˜¯å¦è¶…过8å°æ—¶ int count = 0; List<WorkTimeOrder> byDayToDto = getByDayToDto(workTimeOrders.get(0).getUserId(), workTimeOrders.get(0).getWorkDay()); + // åˆ¤æ–æ˜¯å¦é‡å¤å¡«æŠ¥ + isRepeat(workTimeOrders); for (WorkTimeOrder orderDto : byDayToDto) { - if (2 == orderDto.getStatus() || 5 == orderDto.getStatus()) + if (2 == orderDto.getStatus() || 5 == orderDto.getStatus()) { count += orderDto.getWorkTime(); + for (WorkTimeOrderDto workTimeOrder : workTimeOrders) { + if (orderDto.getType().equals(workTimeOrder.getType())) { + if (1 == orderDto.getType() || 2 == orderDto.getType() && + orderDto.getProjectId().equals(workTimeOrder.getProjectId())) { + throw new BaseCustomException(BASE_RESP_CODE_ENUM.INPUT_PARAM_IS_NULL); + } + throw new BaseCustomException(BASE_RESP_CODE_ENUM.INPUT_PARAM_IS_NULL); + } + } + + } + } // åˆ¤æ–æ˜¯å¦è¶…过8å°æ—¶ @@ -198,6 +213,23 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { } + private void isRepeat(List<WorkTimeOrderDto> list) { + if (CollectionUtils.isEmpty(list)) { + throw new BaseCustomException(BASE_RESP_CODE_ENUM.INPUT_PARAM_IS_NULL); + } + int size = list.size(); + for (int i = 0; i < size; i++) { + for (int j = i + 1; j < size; j++) { + if (list.get(i).getType().equals(list.get(j).getType())) { + if (1 == list.get(i).getType() || 2 == list.get(i).getType() && list.get(i).getProjectId().equals(list.get(j).getProjectId())) { + throw new BaseCustomException(BASE_RESP_CODE_ENUM.WORK_ORDER_ALREADY_COMMIT); + } + throw new BaseCustomException(BASE_RESP_CODE_ENUM.WORK_ORDER_ALREADY_COMMIT); + } + } + } + } + /** * 功能:获å–å¾…å®¡æ‰¹æ•°æ® * @@ -414,7 +446,7 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { List<ProjectManagerDto> projectManagerDtos = new ArrayList<>(); if (1 == user.getLevel()) { List<ProjectDto> projectDtos = workProjectService.getByManagerId(userId); - ProjectManagerDto projectManagerDto ; + ProjectManagerDto projectManagerDto; for (ProjectDto projectDto : projectDtos) { projectManagerDto = new ProjectManagerDto(); BeanUtils.copyProperties(projectDto, projectManagerDto); @@ -423,7 +455,7 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { } if (2 == user.getLevel()) { ProjectManagerDto projectManagerDto = new ProjectManagerDto(); - for (int i = 5; i <8 ; i++) { + for (int i = 5; i < 8; i++) { projectManagerDto.setType(i).setTypeName(getTypeName(i)); projectManagerDtos.add(projectManagerDto); } @@ -448,7 +480,7 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { ProjectInfoDto projectInfoDto2 = new ProjectInfoDto().setType(2).setTypeName(getTypeName(2)).setDeptManagerName(deptManagerName); List<ProjectDto> projectDto1 = new ArrayList<>(); List<ProjectDto> projectDto2 = new ArrayList<>(); - WorkProject workProject ; + WorkProject workProject; for (Integer projectId : projectIds) { workProject = workProjectService.getById(projectId); if (1 == workProject.getType()) { @@ -469,10 +501,11 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { projectList.add(new ProjectInfoDto().setType(7).setTypeName(getTypeName(7)).setDeptManagerName(deptManagerName)); return projectList; } + // project转ProjectDto private ProjectDto projectToProjectDto(WorkProject workProject) { ProjectDto projectDto = new ProjectDto(); - BeanUtils.copyProperties(workProject,projectDto); + BeanUtils.copyProperties(workProject, projectDto); // 获å–é¡¹ç›®ç®¡ç† projectDto.setManagerName(workUserService.getById(workProject.getManagerId()).getName()); @@ -527,6 +560,11 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { Date date = new Date(); WorkSubmitAdopt workSubmitAdopt = workSubmitAdoptService.getById(1); Integer submitTime = workSubmitAdopt.getSubmitTime(); + + // åˆ¤æ–æ˜¯å¦é‡å¤å¡«æŠ¥ + isRepeat(list); + + for (WorkTimeOrderDto dto : list) { if (null == dto.getDes()) { throw new BaseCustomException(BASE_RESP_CODE_ENUM.DES_NOT_NULL); @@ -563,7 +601,7 @@ public class WorkTimeOrderServiceImpl implements WorkTimeOrderService { //3.æ¯å¤©å·¥æ—¶ç´¯åŠ ä¸å¾—è¶…è¿‡å…«å°æ—¶ private void timeNotEight(int count, List<WorkTimeOrderDto> list) { for (WorkTimeOrderDto workOrder : list) { - if (null == workOrder.getWorkDay() ) { + if (null == workOrder.getWorkDay()) { throw new BaseCustomException(BASE_RESP_CODE_ENUM.INPUT_PARAM_IS_NULL); } if (0 == workOrder.getWorkTime()) { diff --git a/wisenergy-web-admin/src/main/java/cn/wisenergy/web/admin/controller/app/WorkTimeOrderController.java b/wisenergy-web-admin/src/main/java/cn/wisenergy/web/admin/controller/app/WorkTimeOrderController.java index 9694bff7d260d67d33293284e03b7ab8b08c3165..8cb45c5171932442c6ac75caa2d16b9db13a8b60 100644 --- a/wisenergy-web-admin/src/main/java/cn/wisenergy/web/admin/controller/app/WorkTimeOrderController.java +++ b/wisenergy-web-admin/src/main/java/cn/wisenergy/web/admin/controller/app/WorkTimeOrderController.java @@ -32,19 +32,6 @@ public class WorkTimeOrderController extends BaseController { @Autowired private WorkTimeOrderService workTimeOrderService; - @Autowired - private WorkProjectService workProjectService; - - @Autowired - private WorkUserProjectService workUserProjectService; - - - @Autowired - private WorkUserDeptService workUserDeptService; - - @Autowired - private WorkUserService workUserService; - @ApiOperation(value = "èŽ·å–æŸæ—¥å·¥å•详情", notes = "èŽ·å–æŸæ—¥å·¥å•详情", httpMethod = "GET") @ApiImplicitParams({ @@ -182,6 +169,4 @@ public class WorkTimeOrderController extends BaseController { return getResult(workTimeOrderDtos); } - - }