feat(wms): 添加钢卷打包记录功能模块
- 创建钢卷打包明细实体类WmsCoilPackingDetail及业务对象WmsCoilPackingDetailBo - 创建钢卷打包记录主实体类WmsCoilPackingRecord及业务对象WmsCoilPackingRecordBo - 实现钢卷打包明细服务接口IWmsCoilPackingDetailService及其实现类 - 实现钢卷打包记录主服务接口IWmsCoilPackingRecordService及其实现类 - 添加钢卷打包明细和记录的控制器WmsCoilPackingDetailController和WmsCoilPackingRecordController - 创建对应的MyBatis映射器WmsCoilPackingDetailMapper和WmsCoilPackingRecordMapper - 实现数据库映射文件WmsCoilPackingDetailMapper.xml和WmsCoilPackingRecordMapper.xml - 添加视图对象WmsCoilPackingDetailVo和WmsCoilPackingRecordVo支持Excel导出功能
This commit is contained in:
@@ -0,0 +1,49 @@
|
||||
package com.klp.service;
|
||||
|
||||
import com.klp.domain.WmsCoilPackingDetail;
|
||||
import com.klp.domain.vo.WmsCoilPackingDetailVo;
|
||||
import com.klp.domain.bo.WmsCoilPackingDetailBo;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 钢卷打包明细(存储每个钢卷的库区/重量信息)Service接口
|
||||
*
|
||||
* @author klp
|
||||
* @date 2026-03-23
|
||||
*/
|
||||
public interface IWmsCoilPackingDetailService {
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
WmsCoilPackingDetailVo queryById(Long detailId);
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)列表
|
||||
*/
|
||||
TableDataInfo<WmsCoilPackingDetailVo> queryPageList(WmsCoilPackingDetailBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)列表
|
||||
*/
|
||||
List<WmsCoilPackingDetailVo> queryList(WmsCoilPackingDetailBo bo);
|
||||
|
||||
/**
|
||||
* 新增钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
Boolean insertByBo(WmsCoilPackingDetailBo bo);
|
||||
|
||||
/**
|
||||
* 修改钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
Boolean updateByBo(WmsCoilPackingDetailBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除钢卷打包明细(存储每个钢卷的库区/重量信息)信息
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
}
|
||||
@@ -0,0 +1,49 @@
|
||||
package com.klp.service;
|
||||
|
||||
import com.klp.domain.WmsCoilPackingRecord;
|
||||
import com.klp.domain.vo.WmsCoilPackingRecordVo;
|
||||
import com.klp.domain.bo.WmsCoilPackingRecordBo;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 钢卷打包记录主(打包待发区专用)Service接口
|
||||
*
|
||||
* @author klp
|
||||
* @date 2026-03-23
|
||||
*/
|
||||
public interface IWmsCoilPackingRecordService {
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
WmsCoilPackingRecordVo queryById(Long packingId);
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)列表
|
||||
*/
|
||||
TableDataInfo<WmsCoilPackingRecordVo> queryPageList(WmsCoilPackingRecordBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)列表
|
||||
*/
|
||||
List<WmsCoilPackingRecordVo> queryList(WmsCoilPackingRecordBo bo);
|
||||
|
||||
/**
|
||||
* 新增钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
Boolean insertByBo(WmsCoilPackingRecordBo bo);
|
||||
|
||||
/**
|
||||
* 修改钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
Boolean updateByBo(WmsCoilPackingRecordBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除钢卷打包记录主(打包待发区专用)信息
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
}
|
||||
@@ -0,0 +1,113 @@
|
||||
package com.klp.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.klp.domain.bo.WmsCoilPackingDetailBo;
|
||||
import com.klp.domain.vo.WmsCoilPackingDetailVo;
|
||||
import com.klp.domain.WmsCoilPackingDetail;
|
||||
import com.klp.mapper.WmsCoilPackingDetailMapper;
|
||||
import com.klp.service.IWmsCoilPackingDetailService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 钢卷打包明细(存储每个钢卷的库区/重量信息)Service业务层处理
|
||||
*
|
||||
* @author klp
|
||||
* @date 2026-03-23
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class WmsCoilPackingDetailServiceImpl implements IWmsCoilPackingDetailService {
|
||||
|
||||
private final WmsCoilPackingDetailMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
@Override
|
||||
public WmsCoilPackingDetailVo queryById(Long detailId){
|
||||
return baseMapper.selectVoById(detailId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<WmsCoilPackingDetailVo> queryPageList(WmsCoilPackingDetailBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<WmsCoilPackingDetail> lqw = buildQueryWrapper(bo);
|
||||
Page<WmsCoilPackingDetailVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询钢卷打包明细(存储每个钢卷的库区/重量信息)列表
|
||||
*/
|
||||
@Override
|
||||
public List<WmsCoilPackingDetailVo> queryList(WmsCoilPackingDetailBo bo) {
|
||||
LambdaQueryWrapper<WmsCoilPackingDetail> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<WmsCoilPackingDetail> buildQueryWrapper(WmsCoilPackingDetailBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<WmsCoilPackingDetail> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getPackingId() != null, WmsCoilPackingDetail::getPackingId, bo.getPackingId());
|
||||
lqw.eq(bo.getCoilId() != null, WmsCoilPackingDetail::getCoilId, bo.getCoilId());
|
||||
lqw.eq(bo.getFromWarehouseId() != null, WmsCoilPackingDetail::getFromWarehouseId, bo.getFromWarehouseId());
|
||||
lqw.eq(bo.getToWarehouseId() != null, WmsCoilPackingDetail::getToWarehouseId, bo.getToWarehouseId());
|
||||
lqw.eq(bo.getCoilGrossWeight() != null, WmsCoilPackingDetail::getCoilGrossWeight, bo.getCoilGrossWeight());
|
||||
lqw.eq(bo.getCoilNetWeight() != null, WmsCoilPackingDetail::getCoilNetWeight, bo.getCoilNetWeight());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(WmsCoilPackingDetailBo bo) {
|
||||
WmsCoilPackingDetail add = BeanUtil.toBean(bo, WmsCoilPackingDetail.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setDetailId(add.getDetailId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(WmsCoilPackingDetailBo bo) {
|
||||
WmsCoilPackingDetail update = BeanUtil.toBean(bo, WmsCoilPackingDetail.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(WmsCoilPackingDetail entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 批量删除钢卷打包明细(存储每个钢卷的库区/重量信息)
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,118 @@
|
||||
package com.klp.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.klp.common.utils.StringUtils;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.klp.domain.bo.WmsCoilPackingRecordBo;
|
||||
import com.klp.domain.vo.WmsCoilPackingRecordVo;
|
||||
import com.klp.domain.WmsCoilPackingRecord;
|
||||
import com.klp.mapper.WmsCoilPackingRecordMapper;
|
||||
import com.klp.service.IWmsCoilPackingRecordService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 钢卷打包记录主(打包待发区专用)Service业务层处理
|
||||
*
|
||||
* @author klp
|
||||
* @date 2026-03-23
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class WmsCoilPackingRecordServiceImpl implements IWmsCoilPackingRecordService {
|
||||
|
||||
private final WmsCoilPackingRecordMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
@Override
|
||||
public WmsCoilPackingRecordVo queryById(Long packingId){
|
||||
return baseMapper.selectVoById(packingId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<WmsCoilPackingRecordVo> queryPageList(WmsCoilPackingRecordBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<WmsCoilPackingRecord> lqw = buildQueryWrapper(bo);
|
||||
Page<WmsCoilPackingRecordVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询钢卷打包记录主(打包待发区专用)列表
|
||||
*/
|
||||
@Override
|
||||
public List<WmsCoilPackingRecordVo> queryList(WmsCoilPackingRecordBo bo) {
|
||||
LambdaQueryWrapper<WmsCoilPackingRecord> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<WmsCoilPackingRecord> buildQueryWrapper(WmsCoilPackingRecordBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<WmsCoilPackingRecord> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getPackingNo()), WmsCoilPackingRecord::getPackingNo, bo.getPackingNo());
|
||||
lqw.eq(bo.getCoilCount() != null, WmsCoilPackingRecord::getCoilCount, bo.getCoilCount());
|
||||
lqw.eq(bo.getTotalGrossWeight() != null, WmsCoilPackingRecord::getTotalGrossWeight, bo.getTotalGrossWeight());
|
||||
lqw.eq(bo.getTotalNetWeight() != null, WmsCoilPackingRecord::getTotalNetWeight, bo.getTotalNetWeight());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getSaleName()), WmsCoilPackingRecord::getSaleName, bo.getSaleName());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getBatchNo()), WmsCoilPackingRecord::getBatchNo, bo.getBatchNo());
|
||||
lqw.eq(bo.getPackingStatus() != null, WmsCoilPackingRecord::getPackingStatus, bo.getPackingStatus());
|
||||
lqw.eq(bo.getPackingTime() != null, WmsCoilPackingRecord::getPackingTime, bo.getPackingTime());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getPackingBy()), WmsCoilPackingRecord::getPackingBy, bo.getPackingBy());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getWarehouseRemark()), WmsCoilPackingRecord::getWarehouseRemark, bo.getWarehouseRemark());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(WmsCoilPackingRecordBo bo) {
|
||||
WmsCoilPackingRecord add = BeanUtil.toBean(bo, WmsCoilPackingRecord.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setPackingId(add.getPackingId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(WmsCoilPackingRecordBo bo) {
|
||||
WmsCoilPackingRecord update = BeanUtil.toBean(bo, WmsCoilPackingRecord.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(WmsCoilPackingRecord entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 批量删除钢卷打包记录主(打包待发区专用)
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user