TaskStocktakingServiceImpl.java 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. package com.jsh.erp.service.impl;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.jsh.erp.datasource.dto.TaskStocktakingDTO;
  6. import com.jsh.erp.datasource.entities.*;
  7. import com.jsh.erp.datasource.mappers.MaterialExtendMapper;
  8. import com.jsh.erp.datasource.mappers.TaskStocktakingItemMapper;
  9. import com.jsh.erp.datasource.mappers.TaskStocktakingMapper;
  10. import com.jsh.erp.datasource.mappers.UserMapper;
  11. import com.jsh.erp.datasource.vo.TaskStocktakingItemVO;
  12. import com.jsh.erp.datasource.vo.TaskStocktakingVO;
  13. import com.jsh.erp.query.LambdaQueryWrapperX;
  14. import com.jsh.erp.service.DepotService;
  15. import com.jsh.erp.service.TaskStocktakingService;
  16. import lombok.RequiredArgsConstructor;
  17. import lombok.extern.slf4j.Slf4j;
  18. import org.springframework.beans.BeanUtils;
  19. import org.springframework.stereotype.Service;
  20. import java.math.BigDecimal;
  21. import java.util.ArrayList;
  22. import java.util.Collections;
  23. import java.util.List;
  24. import java.util.stream.Collectors;
  25. @Service
  26. @RequiredArgsConstructor
  27. @Slf4j
  28. public class TaskStocktakingServiceImpl extends ServiceImpl<TaskStocktakingMapper, TaskStocktaking> implements TaskStocktakingService {
  29. private final MaterialExtendMapper materialExtendMapper;
  30. private final UserMapper userMapper;
  31. private final DepotService depotService;
  32. private final TaskStocktakingItemMapper taskStocktakingItemMapper;
  33. /**
  34. * 创建盘点任务
  35. * @param taskStocktakingDTO
  36. * @return
  37. */
  38. @Override
  39. public boolean add(TaskStocktakingDTO taskStocktakingDTO) {
  40. //商品库位范围处理
  41. List<String> collect;
  42. if (taskStocktakingDTO.getTaskType() == 1) {
  43. collect = materialExtendMapper.selectList(new LambdaQueryWrapper<MaterialExtend>().ne(MaterialExtend::getInventory, BigDecimal.ZERO)).stream().map(MaterialExtend::getPosition).collect(Collectors.toList());
  44. } else {
  45. collect = materialExtendMapper.selectList(new LambdaQueryWrapper<MaterialExtend>().in(MaterialExtend::getId, taskStocktakingDTO.getMaterialExtendIdList())).stream().map(MaterialExtend::getPosition).collect(Collectors.toList());
  46. }
  47. String positionRange = extractRangePair(collect);
  48. this.save(taskStocktakingDTO);
  49. return true;
  50. }
  51. /**
  52. * 任务-详情
  53. * @param id 任务ID
  54. * @return
  55. * @throws Exception
  56. */
  57. @Override
  58. public TaskStocktakingVO detail(Long id) throws Exception{
  59. TaskStocktaking one = getOne(new LambdaQueryWrapperX<TaskStocktaking>().eq(TaskStocktaking::getId, id));
  60. TaskStocktakingVO taskStocktakingVO = new TaskStocktakingVO();
  61. BeanUtils.copyProperties(one, taskStocktakingVO);
  62. //获取负责人名称
  63. User user = userMapper.selectOne(new LambdaQueryWrapper<User>().eq(User::getId, one.getCreator()));
  64. taskStocktakingVO.setCreatorName(user.getLoginName());
  65. //获取创建人名称
  66. User user1 = userMapper.selectOne(new LambdaQueryWrapper<User>().eq(User::getId, one.getCreateBy()));
  67. taskStocktakingVO.setCreateByName(user1.getLoginName());
  68. //获取仓库名称
  69. Depot depot = depotService.getDepot(one.getDepotId());
  70. taskStocktakingVO.setDepotName(depot.getName());
  71. //当任务类型是抽盘时,返回商品盘点信息
  72. return taskStocktakingVO;
  73. }
  74. /**
  75. * 任务详情-商品明细
  76. * @param taskStocktakingId 盘点任务ID
  77. * @return
  78. */
  79. @Override
  80. public List<TaskStocktakingItemVO> listByTaskStocktakingId(Long taskStocktakingId) {
  81. return taskStocktakingItemMapper.listByTaskStocktakingId(taskStocktakingId);
  82. }
  83. /**
  84. * 计算库位范围
  85. * @param data 库位集合
  86. * @return
  87. */
  88. public static String extractRangePair(List<String> data) {
  89. // 用于存储提取的前两部分
  90. List<String> rangeParts = new ArrayList<>();
  91. for (String item : data) {
  92. // 提取前两部分(假设格式固定,以 "-" 分割,取前两部分)
  93. String[] parts = item.split("-");
  94. if (parts.length >= 2) {
  95. String rangePart = parts[0] + "-" + parts[1];
  96. rangeParts.add(rangePart); // 添加到列表
  97. }
  98. }
  99. // 如果范围为空,直接返回空字符串
  100. if (rangeParts.isEmpty()) {
  101. return "";
  102. }
  103. // 找到最小和最大范围
  104. String minRange = Collections.min(rangeParts); // 字典序最小
  105. String maxRange = Collections.max(rangeParts); // 字典序最大
  106. // 返回范围对
  107. return minRange + "——" + maxRange;
  108. }
  109. }