|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.vincent.rsf.framework.common.R; | 
|---|
|  |  |  | import com.vincent.rsf.framework.exception.CoolException; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.WkOrder; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.WkOrderItem; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.excel.OutStockTemplate; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.AsnExceStatus; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.OrderType; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.vincent.rsf.server.common.utils.CommonUtil; | 
|---|
|  |  |  | import com.vincent.rsf.server.common.utils.ExcelUtil; | 
|---|
|  |  |  | import com.vincent.rsf.server.common.utils.FieldsUtils; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.AsnOrder; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.AsnOrderItem; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.Matnr; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.mapper.AsnOrderItemMapper; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.service.MatnrService; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.service.OutStockItemService; | 
|---|
|  |  |  | 
|---|
|  |  |  | * @create 2025/4/22 11:35 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Service("outStockItemServiceImpl") | 
|---|
|  |  |  | public class OutStockItemServiceImpl extends ServiceImpl<AsnOrderItemMapper, AsnOrderItem> implements OutStockItemService { | 
|---|
|  |  |  | public class OutStockItemServiceImpl extends ServiceImpl<AsnOrderItemMapper, WkOrderItem> implements OutStockItemService { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OutStockService outStockService; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public boolean fieldsSave(Map<String, Object> params) { | 
|---|
|  |  |  | AsnOrderItem asnOrderItem = JSONObject.parseObject(JSONObject.toJSONString(params), AsnOrderItem.class); | 
|---|
|  |  |  | if (StringUtils.isBlank(asnOrderItem.getTrackCode())) { | 
|---|
|  |  |  | String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LABEL_CODE, asnOrderItem); | 
|---|
|  |  |  | asnOrderItem.setTrackCode(ruleCode).setBarcode(ruleCode); | 
|---|
|  |  |  | WkOrderItem wkOrderItem = JSONObject.parseObject(JSONObject.toJSONString(params), WkOrderItem.class); | 
|---|
|  |  |  | if (StringUtils.isBlank(wkOrderItem.getTrackCode())) { | 
|---|
|  |  |  | String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LABEL_CODE, wkOrderItem); | 
|---|
|  |  |  | wkOrderItem.setTrackCode(ruleCode).setBarcode(ruleCode); | 
|---|
|  |  |  | ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (Objects.isNull(asnOrderItem.getAnfme()) || Double.compare(asnOrderItem.getAnfme(), 0.0) <= 0) { | 
|---|
|  |  |  | if (Objects.isNull(wkOrderItem.getAnfme()) || Double.compare(wkOrderItem.getAnfme(), 0.0) <= 0) { | 
|---|
|  |  |  | throw new CoolException("计划收货数不能为空!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //保存扩展字段 | 
|---|
|  |  |  | 
|---|
|  |  |  | String uuid16 = CommonUtil.randomUUID16(); | 
|---|
|  |  |  | Boolean fields = FieldsUtils.saveFields(params, uuid16); | 
|---|
|  |  |  | if (fields) { | 
|---|
|  |  |  | asnOrderItem.setFieldsIndex(uuid16); | 
|---|
|  |  |  | wkOrderItem.setFieldsIndex(uuid16); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | throw new RuntimeException(e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!this.saveOrUpdate(asnOrderItem)) { | 
|---|
|  |  |  | if (!this.saveOrUpdate(wkOrderItem)) { | 
|---|
|  |  |  | throw new CoolException("收货通知单明细保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | 
|---|
|  |  |  | Map<String, List<OutStockTemplate>> listMap = resultList.stream().collect(Collectors.groupingBy(OutStockTemplate::getCode)); | 
|---|
|  |  |  | for (String key : listMap.keySet()) { | 
|---|
|  |  |  | OutStockTemplate template = listMap.get(key).stream().findFirst().get(); | 
|---|
|  |  |  | AsnOrder asnOrder = outStockService.getOne(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getCode, template.getCode())); | 
|---|
|  |  |  | if (!Objects.isNull(asnOrder)) { | 
|---|
|  |  |  | WkOrder wkOrder = outStockService.getOne(new LambdaQueryWrapper<WkOrder>().eq(WkOrder::getCode, template.getCode())); | 
|---|
|  |  |  | if (!Objects.isNull(wkOrder)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | AsnOrder order = new AsnOrder(); | 
|---|
|  |  |  | WkOrder order = new WkOrder(); | 
|---|
|  |  |  | order.setCode(template.getCode()) | 
|---|
|  |  |  | .setPoCode(template.getPoCode()) | 
|---|
|  |  |  | .setMemo(template.getMemo()) | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!outStockService.save(order)) { | 
|---|
|  |  |  | throw new CoolException("单据保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AsnOrderItem> items = new ArrayList<>(); | 
|---|
|  |  |  | List<WkOrderItem> items = new ArrayList<>(); | 
|---|
|  |  |  | for (OutStockTemplate orderTemplate : listMap.get(key)) { | 
|---|
|  |  |  | AsnOrderItem orderItem = new AsnOrderItem(); | 
|---|
|  |  |  | WkOrderItem orderItem = new WkOrderItem(); | 
|---|
|  |  |  | Matnr matnr = null; | 
|---|
|  |  |  | if (StringUtils.isNotBlank(orderTemplate.getMatnrCode())) { | 
|---|
|  |  |  | matnr = matnrService.getOne(new LambdaQueryWrapper<Matnr>() | 
|---|
|  |  |  | .eq(Matnr::getCode, orderTemplate.getMatnrCode())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderItem.setAsnId(order.getId()) | 
|---|
|  |  |  | .setAsnCode(order.getCode()) | 
|---|
|  |  |  | orderItem.setOrderId(order.getId()) | 
|---|
|  |  |  | .setOrderCode(order.getCode()) | 
|---|
|  |  |  | .setSplrBatch(orderTemplate.getSplrBatch()) | 
|---|
|  |  |  | .setAnfme(Double.parseDouble(orderTemplate.getAnfme())) | 
|---|
|  |  |  | .setSplrName(orderTemplate.getSplrName()) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!items.isEmpty()) { | 
|---|
|  |  |  | double purQty = items.stream().mapToDouble(AsnOrderItem::getAnfme).sum(); | 
|---|
|  |  |  | if (!outStockService.update(new LambdaUpdateWrapper<AsnOrder>() | 
|---|
|  |  |  | .set(AsnOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val) | 
|---|
|  |  |  | .set(AsnOrder::getAnfme, purQty).eq(AsnOrder::getId, order.getId()))) { | 
|---|
|  |  |  | double purQty = items.stream().mapToDouble(WkOrderItem::getAnfme).sum(); | 
|---|
|  |  |  | if (!outStockService.update(new LambdaUpdateWrapper<WkOrder>() | 
|---|
|  |  |  | .set(WkOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val) | 
|---|
|  |  |  | .set(WkOrder::getAnfme, purQty).eq(WkOrder::getId, order.getId()))) { | 
|---|
|  |  |  | throw new CoolException("单据数量修改失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * @time 2025/4/22 12:39 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public IPage<Map<String, Object>> listByAsnId(PageParam<AsnOrderItem, BaseParam> pageParam, QueryWrapper<AsnOrderItem> buildWrapper) { | 
|---|
|  |  |  | public IPage<Map<String, Object>> listByAsnId(PageParam<WkOrderItem, BaseParam> pageParam, QueryWrapper<WkOrderItem> buildWrapper) { | 
|---|
|  |  |  | IPage<Map<String, Object>> hsahMap = this.baseMapper.resultForMap(pageParam, buildWrapper); | 
|---|
|  |  |  | if (hsahMap.getRecords().isEmpty()) { | 
|---|
|  |  |  | return hsahMap.setRecords(new ArrayList<>()); | 
|---|