新增两张bom表的增删改查,以及产品和原料表添加bom_id的修改

This commit is contained in:
2025-07-29 13:27:23 +08:00
parent 7e0b3681dd
commit 620d16fcb0
26 changed files with 973 additions and 0 deletions

View File

@@ -0,0 +1,111 @@
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.WmsBomItemBo;
import com.klp.domain.vo.WmsBomItemVo;
import com.klp.domain.WmsBomItem;
import com.klp.mapper.WmsBomItemMapper;
import com.klp.service.IWmsBomItemService;
import java.util.List;
import java.util.Map;
import java.util.Collection;
/**
* BOM 明细存放属性值Service业务层处理
*
* @author Joshi
* @date 2025-07-29
*/
@RequiredArgsConstructor
@Service
public class WmsBomItemServiceImpl implements IWmsBomItemService {
private final WmsBomItemMapper baseMapper;
/**
* 查询BOM 明细,存放属性–值
*/
@Override
public WmsBomItemVo queryById(Long itemId){
return baseMapper.selectVoById(itemId);
}
/**
* 查询BOM 明细,存放属性–值列表
*/
@Override
public TableDataInfo<WmsBomItemVo> queryPageList(WmsBomItemBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<WmsBomItem> lqw = buildQueryWrapper(bo);
Page<WmsBomItemVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result);
}
/**
* 查询BOM 明细,存放属性–值列表
*/
@Override
public List<WmsBomItemVo> queryList(WmsBomItemBo bo) {
LambdaQueryWrapper<WmsBomItem> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw);
}
private LambdaQueryWrapper<WmsBomItem> buildQueryWrapper(WmsBomItemBo bo) {
Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<WmsBomItem> lqw = Wrappers.lambdaQuery();
lqw.eq(StringUtils.isNotBlank(bo.getAttrKey()), WmsBomItem::getAttrKey, bo.getAttrKey());
lqw.eq(StringUtils.isNotBlank(bo.getAttrValue()), WmsBomItem::getAttrValue, bo.getAttrValue());
lqw.eq(bo.getIsEnabled() != null, WmsBomItem::getIsEnabled, bo.getIsEnabled());
return lqw;
}
/**
* 新增BOM 明细,存放属性–值
*/
@Override
public Boolean insertByBo(WmsBomItemBo bo) {
WmsBomItem add = BeanUtil.toBean(bo, WmsBomItem.class);
validEntityBeforeSave(add);
boolean flag = baseMapper.insert(add) > 0;
if (flag) {
bo.setItemId(add.getItemId());
}
return flag;
}
/**
* 修改BOM 明细,存放属性–值
*/
@Override
public Boolean updateByBo(WmsBomItemBo bo) {
WmsBomItem update = BeanUtil.toBean(bo, WmsBomItem.class);
validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0;
}
/**
* 保存前的数据校验
*/
private void validEntityBeforeSave(WmsBomItem entity){
//TODO 做一些数据校验,如唯一约束
}
/**
* 批量删除BOM 明细,存放属性–值
*/
@Override
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
if(isValid){
//TODO 做一些业务上的校验,判断是否需要校验
}
return baseMapper.deleteBatchIds(ids) > 0;
}
}

View File

@@ -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 com.klp.common.utils.StringUtils;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import com.klp.domain.bo.WmsBomBo;
import com.klp.domain.vo.WmsBomVo;
import com.klp.domain.WmsBom;
import com.klp.mapper.WmsBomMapper;
import com.klp.service.IWmsBomService;
import java.util.List;
import java.util.Map;
import java.util.Collection;
/**
* BOM 头关联产品或原材料Service业务层处理
*
* @author Joshi
* @date 2025-07-29
*/
@RequiredArgsConstructor
@Service
public class WmsBomServiceImpl implements IWmsBomService {
private final WmsBomMapper baseMapper;
/**
* 查询BOM 头,关联产品或原材料
*/
@Override
public WmsBomVo queryById(Long bomId){
return baseMapper.selectVoById(bomId);
}
/**
* 查询BOM 头,关联产品或原材料列表
*/
@Override
public TableDataInfo<WmsBomVo> queryPageList(WmsBomBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<WmsBom> lqw = buildQueryWrapper(bo);
Page<WmsBomVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result);
}
/**
* 查询BOM 头,关联产品或原材料列表
*/
@Override
public List<WmsBomVo> queryList(WmsBomBo bo) {
LambdaQueryWrapper<WmsBom> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw);
}
private LambdaQueryWrapper<WmsBom> buildQueryWrapper(WmsBomBo bo) {
Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<WmsBom> lqw = Wrappers.lambdaQuery();
lqw.eq(StringUtils.isNotBlank(bo.getBomCode()), WmsBom::getBomCode, bo.getBomCode());
lqw.like(StringUtils.isNotBlank(bo.getBomName()), WmsBom::getBomName, bo.getBomName());
lqw.eq(StringUtils.isNotBlank(bo.getParentType()), WmsBom::getParentType, bo.getParentType());
lqw.eq(bo.getParentId() != null, WmsBom::getParentId, bo.getParentId());
lqw.eq(bo.getIsEnabled() != null, WmsBom::getIsEnabled, bo.getIsEnabled());
return lqw;
}
/**
* 新增BOM 头,关联产品或原材料
*/
@Override
public Boolean insertByBo(WmsBomBo bo) {
WmsBom add = BeanUtil.toBean(bo, WmsBom.class);
validEntityBeforeSave(add);
boolean flag = baseMapper.insert(add) > 0;
if (flag) {
bo.setBomId(add.getBomId());
}
return flag;
}
/**
* 修改BOM 头,关联产品或原材料
*/
@Override
public Boolean updateByBo(WmsBomBo bo) {
WmsBom update = BeanUtil.toBean(bo, WmsBom.class);
validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0;
}
/**
* 保存前的数据校验
*/
private void validEntityBeforeSave(WmsBom entity){
//TODO 做一些数据校验,如唯一约束
}
/**
* 批量删除BOM 头,关联产品或原材料
*/
@Override
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
if(isValid){
//TODO 做一些业务上的校验,判断是否需要校验
}
return baseMapper.deleteBatchIds(ids) > 0;
}
}

View File

@@ -74,6 +74,7 @@ public class WmsProductServiceImpl implements IWmsProductService {
lqw.eq(bo.getWidth() != null, WmsProduct::getWidth, bo.getWidth());
lqw.eq(bo.getInnerDiameter() != null, WmsProduct::getInnerDiameter, bo.getInnerDiameter());
lqw.eq(bo.getIsEnabled() != null, WmsProduct::getIsEnabled, bo.getIsEnabled());
lqw.eq(bo.getBomId() != null, WmsProduct::getBomId, bo.getBomId());
return lqw;
}

View File

@@ -83,6 +83,7 @@ public class WmsRawMaterialServiceImpl implements IWmsRawMaterialService {
lqw.eq(bo.getHeadTailCutFlag() != null, WmsRawMaterial::getHeadTailCutFlag, bo.getHeadTailCutFlag());
lqw.eq(StringUtils.isNotBlank(bo.getInspectionResult()), WmsRawMaterial::getInspectionResult, bo.getInspectionResult());
lqw.eq(bo.getIsEnabled() != null, WmsRawMaterial::getIsEnabled, bo.getIsEnabled());
lqw.eq(bo.getBomId() != null, WmsRawMaterial::getBomId, bo.getBomId());
return lqw;
}