feat(wms): 扩展钢卷打包记录详情功能

- 在 WmsCoilPackingDetailVo 中新增钢卷相关字段包括入场钢卷号、当前钢卷号、厂家原料卷号等
- 添加 WmsMaterialCoilVo 引用到 WmsCoilPackingDetailVo 中存储钢卷完整信息
- 在 WmsCoilPackingRecordVo 中增加明细列表用于存储打包详情
- 实现服务层查询时自动关联钢卷详细信息并填充到返回结果中
- 优化查询逻辑支持分页和列表查询时同时获取关联的钢卷详情数据
This commit is contained in:
2026-03-23 10:57:09 +08:00
parent 3ed5b6a6ab
commit 7a14cf7cb6
3 changed files with 104 additions and 5 deletions

View File

@@ -1,6 +1,7 @@
package com.klp.domain.vo;
import java.math.BigDecimal;
import com.klp.domain.vo.WmsMaterialCoilVo;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.klp.common.annotation.ExcelDictFormat;
@@ -71,5 +72,44 @@ public class WmsCoilPackingDetailVo {
@ExcelDictFormat(readConverterExp = "如=库区A-钢卷1001")
private String remark;
/**
* 钢卷入场钢卷号
*/
private String coilEnterCoilNo;
/**
* 钢卷当前钢卷号
*/
private String coilCurrentCoilNo;
/**
* 钢卷厂家原料卷号
*/
private String coilSupplierCoilNo;
/**
* 钢卷物品类型
*/
private String coilItemType;
/**
* 钢卷物品ID
*/
private Long coilItemId;
/**
* 钢卷材料类型
*/
private String coilMaterialType;
/**
* 钢卷状态
*/
private Integer coilStatus;
/**
* 钢卷完整信息
*/
private WmsMaterialCoilVo coil;
}

View File

@@ -2,6 +2,7 @@ package com.klp.domain.vo;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
@@ -102,5 +103,10 @@ public class WmsCoilPackingRecordVo {
@ExcelProperty(value = "整体打包备注")
private String remark;
/**
* 明细列表
*/
private List<WmsCoilPackingDetailVo> details;
}

View File

@@ -11,22 +11,23 @@ import com.klp.common.utils.StringUtils;
import com.klp.domain.WmsCoilPackingDetail;
import com.klp.domain.WmsMaterialCoil;
import com.klp.domain.bo.WmsCoilPackingDetailBo;
import com.klp.domain.bo.WmsMaterialCoilBo;
import com.klp.domain.vo.WmsMaterialCoilVo;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.klp.domain.bo.WmsCoilPackingRecordBo;
import com.klp.domain.vo.WmsCoilPackingRecordVo;
import com.klp.domain.vo.WmsCoilPackingDetailVo;
import com.klp.domain.WmsCoilPackingRecord;
import com.klp.mapper.WmsCoilPackingRecordMapper;
import com.klp.mapper.WmsCoilPackingDetailMapper;
import com.klp.mapper.WmsMaterialCoilMapper;
import com.klp.service.IWmsCoilPackingRecordService;
import com.klp.service.IWmsMaterialCoilService;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Collection;
import java.util.*;
/**
* 钢卷打包记录主打包待发区专用Service业务层处理
@@ -41,6 +42,7 @@ public class WmsCoilPackingRecordServiceImpl implements IWmsCoilPackingRecordSer
private final WmsCoilPackingRecordMapper baseMapper;
private final WmsMaterialCoilMapper wmsMaterialCoilMapper;
private final WmsCoilPackingDetailMapper detailMapper;
private final IWmsMaterialCoilService iWmsMaterialCoilService;
/**
* 查询钢卷打包记录主(打包待发区专用)
@@ -57,16 +59,67 @@ public class WmsCoilPackingRecordServiceImpl implements IWmsCoilPackingRecordSer
public TableDataInfo<WmsCoilPackingRecordVo> queryPageList(WmsCoilPackingRecordBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<WmsCoilPackingRecord> lqw = buildQueryWrapper(bo);
Page<WmsCoilPackingRecordVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
if (result.getRecords() != null && !result.getRecords().isEmpty()) {
for (WmsCoilPackingRecordVo recordVo : result.getRecords()) {
enrichRecordWithDetails(recordVo);
}
}
return TableDataInfo.build(result);
}
private void enrichRecordWithDetails(WmsCoilPackingRecordVo recordVo) {
Long packingId = recordVo.getPackingId();
LambdaQueryWrapper<WmsCoilPackingDetail> detailLqw = Wrappers.lambdaQuery();
detailLqw.eq(WmsCoilPackingDetail::getPackingId, packingId);
List<WmsCoilPackingDetail> details = detailMapper.selectList(detailLqw);
if (details == null || details.isEmpty()) {
return;
}
List<Long> coilIds = new ArrayList<>();
for (WmsCoilPackingDetail detail : details) {
coilIds.add(detail.getCoilId());
}
Map<Long, WmsMaterialCoilVo> coilMap = new HashMap<>();
if (!coilIds.isEmpty()) {
WmsMaterialCoilBo coilBo = new WmsMaterialCoilBo();
coilBo.setCoilIds(StringUtils.join(coilIds, ","));
List<WmsMaterialCoilVo> coilVoList = iWmsMaterialCoilService.queryList(coilBo);
for (WmsMaterialCoilVo coilVo : coilVoList) {
coilMap.put(coilVo.getCoilId(), coilVo);
}
}
List<WmsCoilPackingDetailVo> detailVos = new ArrayList<>();
for (WmsCoilPackingDetail detail : details) {
WmsCoilPackingDetailVo detailVo = BeanUtil.toBean(detail, WmsCoilPackingDetailVo.class);
detailVo.setCoil(coilMap.get(detail.getCoilId()));
detailVos.add(detailVo);
}
recordVo.setDetails(detailVos);
}
/**
* 查询钢卷打包记录主(打包待发区专用)列表
*/
@Override
public List<WmsCoilPackingRecordVo> queryList(WmsCoilPackingRecordBo bo) {
LambdaQueryWrapper<WmsCoilPackingRecord> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw);
List<WmsCoilPackingRecordVo> list = baseMapper.selectVoList(lqw);
if (list != null && !list.isEmpty()) {
for (WmsCoilPackingRecordVo recordVo : list) {
enrichRecordWithDetails(recordVo);
}
}
return list;
}
private LambdaQueryWrapper<WmsCoilPackingRecord> buildQueryWrapper(WmsCoilPackingRecordBo bo) {