| | |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.core.toolkit.ObjectUtils; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.yuanchu.mom.common.GetLook; |
| | | import com.yuanchu.mom.dto.CostStatisticsDto; |
| | | import com.yuanchu.mom.dto.InsOrderUserDto; |
| | | import com.yuanchu.mom.mapper.*; |
| | | import com.yuanchu.mom.pojo.*; |
| | | import com.yuanchu.mom.service.ReportService; |
| | |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.time.Duration; |
| | | import java.time.LocalDate; |
| | | import java.time.LocalDateTime; |
| | | import java.time.format.DateTimeFormatter; |
| | |
| | | private GetLook getLook; |
| | | private ScheduleMapper scheduleMapper; |
| | | private UserMapper userMapper; |
| | | private RoleMapper roleMapper; |
| | | private InsSampleUserMapper insSampleUserMapper; |
| | | private AuxiliaryOutputWorkingHoursMapper auxiliaryOutputWorkingHoursMapper; |
| | | private InsOrderStateMapper insOrderStateMapper; |
| | | private InsOrderUserMapper insOrderUserMapper; |
| | | |
| | | //每日业务统计 |
| | | @Override |
| | | public Map<String, Object> businessStatisticsByDay() { |
| | | public Map<String, Object> businessStatisticsByDay(String startTime, String endTime, String type) { |
| | | DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); |
| | | LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); |
| | | LocalDateTime oldStart = start; |
| | | LocalDateTime oldEnd = end; |
| | | switch (type) { |
| | | case "周": |
| | | oldStart = start.minusDays(7); |
| | | oldEnd = end.minusDays(7); |
| | | break; |
| | | case "月": |
| | | oldStart = start.minusMonths(1); |
| | | oldEnd = end.minusMonths(1); |
| | | break; |
| | | case "年": |
| | | oldStart = start.minusYears(1); |
| | | oldEnd = end.minusYears(1); |
| | | break; |
| | | } |
| | | Map<String, Object> map = new HashMap<>(); |
| | | /*任务接收*/ |
| | | //今日任务接收 |
| | | Long receive = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE()")); |
| | | Long receive = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 1) |
| | | .between(InsOrder::getCreateTime, start, end)); |
| | | map.put("RECEIVE", receive); |
| | | //昨日任务接收 |
| | | Long received = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); |
| | | Long received = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 1) |
| | | .between(InsOrder::getCreateTime, oldStart, oldEnd)); |
| | | //比例=(今天-昨天)/昨天 |
| | | BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP); |
| | | map.put("RECEIVE_RATIO", ratio); |
| | | |
| | | /*任务已完成*/ |
| | | //今日任务完成 |
| | | Long finishe = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE()")); |
| | | Long finishe = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 4) |
| | | .between(InsOrder::getCreateTime, start, end)); |
| | | map.put("FINISHE", finishe); |
| | | //昨日任务完成 |
| | | Long finished = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); |
| | | Long finished = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 4) |
| | | .between(InsOrder::getCreateTime, oldStart, oldEnd)); |
| | | //任务完成比例=(今天-昨天)/昨天 |
| | | BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP); |
| | | map.put("FINISHE_RATIO", finishedRatio); |
| | |
| | | /*检测费用*/ |
| | | //今日检测费用 |
| | | QueryWrapper<CostStatisticsDto> costStatisticsDtoQueryWrappers = new QueryWrapper<>(); |
| | | costStatisticsDtoQueryWrappers.eq("create_time", LocalDateTime.now()); |
| | | costStatisticsDtoQueryWrappers.between("create_time", start, end); |
| | | IPage<CostStatisticsDto> page = new Page<>(); |
| | | page.setSize(-1); |
| | | page.setCurrent(-1); |
| | | IPage<CostStatisticsDto> iPage = insOrderMapper.selectCostStatistics(page, costStatisticsDtoQueryWrappers); |
| | | BigDecimal price = BigDecimal.ZERO; |
| | | for (CostStatisticsDto record : iPage.getRecords()) { |
| | | price.add(record.getPrice()); |
| | | price = price.add(ObjectUtils.isNotEmpty(record.getPrice()) ? record.getPrice() : BigDecimal.ZERO); |
| | | } |
| | | map.put("PRICE", price); |
| | | //昨日检测费用 |
| | | QueryWrapper<CostStatisticsDto> costWrappers = new QueryWrapper<>(); |
| | | costWrappers.eq("create_time", LocalDateTime.now().minusDays(1)); |
| | | costWrappers.between("create_time", oldStart, oldEnd); |
| | | IPage<CostStatisticsDto> dtoIPage = insOrderMapper.selectCostStatistics(page, costWrappers); |
| | | BigDecimal priced = BigDecimal.ZERO; |
| | | for (CostStatisticsDto record : dtoIPage.getRecords()) { |
| | | priced.add(record.getPrice()); |
| | | priced = priced.add(ObjectUtils.isNotEmpty(record.getPrice()) ? record.getPrice() : BigDecimal.ZERO); |
| | | } |
| | | //比例=(今日-昨日)/昨日 |
| | | BigDecimal priceRatio = (price.subtract(priced)).divide(priced.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ONE : priced, 2, BigDecimal.ROUND_HALF_UP); |
| | |
| | | //今日检测工时 |
| | | Double cost = 0.0; |
| | | for (CostStatisticsDto record : iPage.getRecords()) { |
| | | cost += record.getCost(); |
| | | cost += ObjectUtils.isNotEmpty(record.getCost()) ? record.getCost() : 0.0; |
| | | } |
| | | map.put("COST", cost); |
| | | //昨日检测工时 |
| | | Double costed = 0.0; |
| | | for (CostStatisticsDto record : dtoIPage.getRecords()) { |
| | | costed += record.getCost(); |
| | | costed += ObjectUtils.isNotEmpty(record.getCost()) ? record.getCost() : 0.0; |
| | | } |
| | | //比例=(今日-昨日)/昨日 |
| | | BigDecimal costRatio = new BigDecimal(cost - costed).divide(new BigDecimal(costed == 0 ? 1 : costed), 2, BigDecimal.ROUND_HALF_UP); |
| | |
| | | |
| | | /*检测人员*/ |
| | | //今日检测人员 |
| | | List<InsProductUser> insProductUsers = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE()")); |
| | | List<InsProductUser> insProductUsers = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery() |
| | | .between(InsProductUser::getCreateTime, start, end)); |
| | | long person = insProductUsers.stream().map(InsProductUser::getCreateUser).distinct().count(); |
| | | map.put("PERSON", person); |
| | | //昨日检测人员 |
| | | List<InsProductUser> insProductUserss = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); |
| | | List<InsProductUser> insProductUserss = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery() |
| | | .between(InsProductUser::getCreateTime, oldStart, oldEnd)); |
| | | long persons = insProductUserss.stream().map(InsProductUser::getCreateUser).distinct().count(); |
| | | //比例=(今天-昨天)/昨天 |
| | | BigDecimal personRatio = new BigDecimal(person - persons).divide(new BigDecimal(persons == 0 ? 1 : persons), 2, BigDecimal.ROUND_HALF_UP); |
| | |
| | | |
| | | /*近十日任务接收量与完成量*/ |
| | | //获取近十日的横坐标 |
| | | LocalDate currentDate = LocalDate.now(); |
| | | List<LocalDate> lastTenDays = new ArrayList<>(); |
| | | LocalDate startDate = LocalDate.parse(startTime, format); |
| | | LocalDate endDate = LocalDate.parse(endTime, format); |
| | | List<String> lastTenDays = new ArrayList<>(); |
| | | List<Long> receTenDays = new ArrayList<>(); |
| | | List<Long> finTenDays = new ArrayList<>(); |
| | | for (int i = 9; i > -1; i--) { |
| | | lastTenDays.add(currentDate.minusDays(i)); |
| | | receTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); |
| | | finTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); |
| | | while (!startDate.isAfter(endDate)) { |
| | | if (type.equals("年")) { |
| | | lastTenDays.add(startDate.format(format).substring(0, 7)); |
| | | } else { |
| | | lastTenDays.add(startDate.format(format)); |
| | | } |
| | | receTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 1) |
| | | .between(InsOrder::getCreateTime, startDate.atStartOfDay(), startDate.plusMonths(1).minusDays(1).atTime(23, 59, 59)))); |
| | | finTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() |
| | | .eq(InsOrder::getState, 4) |
| | | .between(InsOrder::getCreateTime, startDate.atStartOfDay(), startDate.plusMonths(1).minusDays(1).atTime(23, 59, 59)))); |
| | | if (type.equals("年")) { |
| | | startDate = startDate.plusMonths(1); |
| | | } else { |
| | | startDate = startDate.plusDays(1); |
| | | } |
| | | } |
| | | map.put("DAYS", lastTenDays); |
| | | map.put("RECETENDAYS", receTenDays); |
| | |
| | | |
| | | //检测项目统计 |
| | | @Override |
| | | public Map<String, Object> testProductByDay() { |
| | | public Map<String, Object> testProductByDay(String startTime, String endTime, String type) { |
| | | DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); |
| | | LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); |
| | | LocalDateTime oldStart = start; |
| | | LocalDateTime oldEnd = end; |
| | | Map<String, Object> map = new HashMap<>(); |
| | | switch (type) { |
| | | case "周": |
| | | oldStart = start.minusDays(7); |
| | | oldEnd = end.minusDays(7); |
| | | break; |
| | | case "月": |
| | | oldStart = start.minusMonths(1); |
| | | oldEnd = end.minusMonths(1); |
| | | break; |
| | | case "年": |
| | | oldStart = start.minusYears(1); |
| | | oldEnd = end.minusYears(1); |
| | | break; |
| | | } |
| | | /*项目接收*/ |
| | | //今日项目接收量 |
| | | Long receive = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE()")); |
| | | Long receive = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .between(InsProduct::getCreateTime, start, end)); |
| | | map.put("RECEVICE", receive); |
| | | //昨日项目接收量 |
| | | Long received = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); |
| | | Long received = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .between(InsProduct::getCreateTime, oldStart, oldEnd)); |
| | | //比例=(今天-昨天)/昨天 |
| | | BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP); |
| | | map.put("RECEIVE_RATIO", ratio); |
| | | |
| | | /*项目完成*/ |
| | | //今日项目完成量 |
| | | Long finishe = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE()")); |
| | | Long finishe = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .isNotNull(InsProduct::getInsResult) |
| | | .between(InsProduct::getCreateTime, start, end)); |
| | | map.put("FINISHE", finishe); |
| | | //昨日项目完成量 |
| | | Long finished = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); |
| | | Long finished = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .isNotNull(InsProduct::getInsResult) |
| | | .between(InsProduct::getCreateTime, oldStart, oldEnd)); |
| | | //任务完成比例=(今天-昨天)/昨天 |
| | | BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP); |
| | | map.put("FINISHE_RATIO", finishedRatio); |
| | |
| | | |
| | | /*今日项目合格率*/ |
| | | //今日完成量中的合格量/今日完成量 |
| | | Long accept = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).eq(InsProduct::getInsResult,1).apply("DATE(create_time) = CURDATE()")); |
| | | Long accept = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .isNotNull(InsProduct::getInsResult) |
| | | .ne(InsProduct::getInsResult, 0) |
| | | .between(InsProduct::getCreateTime, start, end)); |
| | | map.put("ACCEPT", accept); |
| | | BigDecimal acceptRate = new BigDecimal(accept).divide(new BigDecimal(finishe == 0 ? 1 : finishe), 2, BigDecimal.ROUND_HALF_UP); |
| | | map.put("ACCEPT_RATE_TODAY", acceptRate); |
| | |
| | | |
| | | /*近十日的项目接收量与完成量*/ |
| | | //获取近十日的横坐标 |
| | | LocalDate currentDate = LocalDate.now(); |
| | | List<LocalDate> lastTenDays = new ArrayList<>(); |
| | | LocalDate startDate = LocalDate.parse(startTime, format); |
| | | LocalDate endDate = LocalDate.parse(endTime, format); |
| | | List<String> lastTenDays = new ArrayList<>(); |
| | | List<Long> receTenDays = new ArrayList<>(); |
| | | List<Long> finTenDays = new ArrayList<>(); |
| | | for (int i = 9; i > -1; i--) { |
| | | lastTenDays.add(currentDate.minusDays(i)); |
| | | receTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); |
| | | finTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); |
| | | while (!startDate.isAfter(endDate)) { |
| | | if (type.equals("年")) { |
| | | lastTenDays.add(startDate.format(format).substring(0, 7)); |
| | | } else { |
| | | lastTenDays.add(startDate.format(format)); |
| | | } |
| | | receTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .between(InsProduct::getCreateTime, startDate.atStartOfDay(), startDate.plusMonths(1).minusDays(1).atTime(23, 59, 59)))); |
| | | finTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() |
| | | .eq(InsProduct::getState, 1) |
| | | .isNotNull(InsProduct::getInsResult) |
| | | .between(InsProduct::getCreateTime, startDate.atStartOfDay(), startDate.plusMonths(1).minusDays(1).atTime(23, 59, 59)))); |
| | | if (type.equals("年")) { |
| | | startDate = startDate.plusMonths(1); |
| | | } else { |
| | | startDate = startDate.plusDays(1); |
| | | } |
| | | } |
| | | map.put("DAYS", lastTenDays); |
| | | map.put("RECETENDAYS", receTenDays); |
| | |
| | | //首页-->日历任务图 |
| | | @Override |
| | | public Map<String, Object> calendarWorkByWeek() { |
| | | Integer userId = getLook.selectPowerByMethodAndUserId(null).get("userId"); |
| | | String name = roleMapper.selectById(userMapper.selectById(userId).getRoleId()).getName(); |
| | | Map<String, Object> map = new HashMap<>(); |
| | | List<Integer> insState = new ArrayList<>(); |
| | | insState.add(0); |
| | |
| | | .eq(InsOrder::getState, 1) |
| | | .in(InsOrder::getInsState, insState) |
| | | .apply("DATE(create_time) = CURDATE() - INTERVAL " + j + " DAY")); |
| | | //如果当前登录人是测试工程师或者是检测组长,需要过滤出检验人是他们的订单或者是还没检验的订单 |
| | | if (name.equals("测试工程师") || name.equals("检测组长")) { |
| | | insOrders = insOrders.stream().filter(insOrder -> { |
| | | List<InsSample> insSamples = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, insOrder.getId())); |
| | | List<Integer> sampleId = insSamples.stream().map(InsSample::getId).collect(Collectors.toList()); |
| | | List<InsSampleUser> insSampleUsers = insSampleUserMapper.selectList(Wrappers.<InsSampleUser>lambdaQuery() |
| | | .in(InsSampleUser::getInsSampleId, sampleId) |
| | | .eq(InsSampleUser::getState, 0) //检验人 |
| | | ); |
| | | return insSampleUsers.size() == 0 || insSampleUsers.stream().map(InsSampleUser::getUserId).collect(Collectors.toList()).contains(userId); |
| | | }).collect(Collectors.toList()); |
| | | } |
| | | //如果当前登录人是送样员,需过滤出单子的送样员是当前人的订单 |
| | | else if (name.equals("送样员")) { |
| | | insOrders = insOrders.stream().filter(insOrder -> |
| | | ObjectUtils.isNotEmpty(insOrder.getIssueUser()) && insOrder.getIssueUser().equals(userId) |
| | | ).collect(Collectors.toList()); |
| | | } |
| | | List<Map<String, Object>> works = insOrders.stream().map(insOrder -> { |
| | | List<InsSample> insSamples = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, insOrder.getId())); |
| | | HashMap<String, Object> hashMap = new HashMap<>(); |
| | |
| | | LocalDateTime endTime = localDate.plusDays(1).atStartOfDay().minusSeconds(1); |
| | | return scheduleMapper.selectList(Wrappers.<Schedule>lambdaQuery().eq(Schedule::getUserId, userId).between(Schedule::getScheduleTime, startTime, endTime)); |
| | | } |
| | | |
| | | //首页-->各站点的工时 |
| | | @Override |
| | | public String manHourByStation(String startTime, String endTime, String sonLaboratory) { |
| | | DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); |
| | | LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); |
| | | //查询这个时间内所有的工时 |
| | | List<AuxiliaryOutputWorkingHours> auxiliaryOutputWorkingHours = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery() |
| | | .between(AuxiliaryOutputWorkingHours::getCreateTime, start, end)); |
| | | double sum = auxiliaryOutputWorkingHours.stream() |
| | | .filter(auxiliaryOutputWorkingHours1 -> |
| | | insProductMapper.selectById(auxiliaryOutputWorkingHours1.getInsProductId()).getSonLaboratory().equals(sonLaboratory) |
| | | ).mapToDouble(AuxiliaryOutputWorkingHours::getOutputWorkTime).sum(); |
| | | String num = String.format("%.2f", sum); |
| | | return num; |
| | | } |
| | | |
| | | //首页-->各站点工时每个人所占百分比 |
| | | @Override |
| | | public Map<Object, Double> manHourByPerson(String startTime, String endTime, String sonLaboratory) { |
| | | DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); |
| | | LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); |
| | | //查询这个时间内所有的工时 |
| | | List<AuxiliaryOutputWorkingHours> auxiliaryOutputWorkingHours = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery() |
| | | .between(AuxiliaryOutputWorkingHours::getCreateTime, start, end)); |
| | | //根据检验项查出来的站点进行分类 |
| | | List<AuxiliaryOutputWorkingHours> outputWorkingHours = auxiliaryOutputWorkingHours.stream() |
| | | .filter(auxiliaryOutputWorkingHours1 -> |
| | | insProductMapper.selectById(auxiliaryOutputWorkingHours1.getInsProductId()).getSonLaboratory().equals(sonLaboratory) |
| | | ).collect(Collectors.toList()); |
| | | Map<Object, Double> mapMap = outputWorkingHours.stream() |
| | | .collect(Collectors.groupingBy( |
| | | t -> userMapper.selectById(t.getCheck()).getName(), |
| | | Collectors.summingDouble(AuxiliaryOutputWorkingHours::getOutputWorkTime))); |
| | | return mapMap; |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, IPage<InsOrderUserDto>> timeByStation(String startTime, String endTime, Page page, String sonLaboratory) { |
| | | DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); |
| | | LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); |
| | | Map<String, IPage<InsOrderUserDto>> map = new HashMap<>(); |
| | | //查询这个时间内所有检验任务 |
| | | if (ObjectUtils.isNotEmpty(sonLaboratory)) { |
| | | IPage<InsOrderUserDto> insOrderUserDtoIPage = insOrderUserMapper.selectInsOrderUserDto(start, end, sonLaboratory, page); |
| | | map.put(sonLaboratory, insOrderUserDtoIPage); |
| | | }else { |
| | | List<InsOrderState> insOrderStates = insOrderStateMapper.selectList(Wrappers.<InsOrderState>lambdaQuery() |
| | | .between(InsOrderState::getCreateTime, start, end)); |
| | | Map<String, List<InsOrderState>> listMap = insOrderStates.stream().collect(Collectors.groupingBy(InsOrderState::getLaboratory)); |
| | | for (Map.Entry<String, List<InsOrderState>> entry : listMap.entrySet()) { |
| | | List<Integer> ids = entry.getValue().stream().map(InsOrderState::getId).collect(Collectors.toList()); |
| | | IPage<InsOrderUserDto> insOrderUserDtoIPage = insOrderUserMapper.selectInsOrderUserDto2(ids, new Page(1,9)); |
| | | map.put(entry.getKey(), insOrderUserDtoIPage); |
| | | } |
| | | } |
| | | return map; |
| | | } |
| | | } |