1.0.4 add物料信息
parent
a6ce138bac
commit
25ae52a03b
@ -0,0 +1,141 @@
|
||||
package org.dromara.oa.base.service.impl;
|
||||
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.github.yulichang.toolkit.JoinWrappers;
|
||||
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.dromara.oa.base.domain.bo.BaseMaterialInfoBo;
|
||||
import org.dromara.oa.base.domain.vo.BaseMaterialInfoVo;
|
||||
import org.dromara.oa.base.domain.BaseMaterialInfo;
|
||||
import org.dromara.oa.base.mapper.BaseMaterialInfoMapper;
|
||||
import org.dromara.oa.base.service.IBaseMaterialInfoService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* SAP物料信息Service业务层处理
|
||||
*
|
||||
* @author Yinq
|
||||
* @date 2025-09-30
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class BaseMaterialInfoServiceImpl implements IBaseMaterialInfoService {
|
||||
|
||||
private final BaseMaterialInfoMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询SAP物料信息
|
||||
*
|
||||
* @param materialId 主键
|
||||
* @return SAP物料信息
|
||||
*/
|
||||
@Override
|
||||
public BaseMaterialInfoVo queryById(Long materialId){
|
||||
return baseMapper.selectVoById(materialId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 分页查询SAP物料信息列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return SAP物料信息分页列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<BaseMaterialInfoVo> queryPageList(BaseMaterialInfoBo bo, PageQuery pageQuery) {
|
||||
MPJLambdaWrapper<BaseMaterialInfo> lqw = buildQueryWrapper(bo);
|
||||
Page<BaseMaterialInfoVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询符合条件的SAP物料信息列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return SAP物料信息列表
|
||||
*/
|
||||
@Override
|
||||
public List<BaseMaterialInfoVo> queryList(BaseMaterialInfoBo bo) {
|
||||
MPJLambdaWrapper<BaseMaterialInfo> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private MPJLambdaWrapper<BaseMaterialInfo> buildQueryWrapper(BaseMaterialInfoBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
MPJLambdaWrapper<BaseMaterialInfo> lqw = JoinWrappers.lambda(BaseMaterialInfo.class)
|
||||
.selectAll(BaseMaterialInfo.class)
|
||||
.eq(StringUtils.isNotBlank(bo.getMaterialCode()), BaseMaterialInfo::getMaterialCode, bo.getMaterialCode())
|
||||
.like(StringUtils.isNotBlank(bo.getMaterialName()), BaseMaterialInfo::getMaterialName, bo.getMaterialName())
|
||||
.eq(StringUtils.isNotBlank(bo.getMaterialBrand()), BaseMaterialInfo::getMaterialBrand, bo.getMaterialBrand())
|
||||
.eq(StringUtils.isNotBlank(bo.getMaterialModel()), BaseMaterialInfo::getMaterialModel, bo.getMaterialModel())
|
||||
.eq(bo.getUnitId() != null, BaseMaterialInfo::getUnitId, bo.getUnitId())
|
||||
.eq(StringUtils.isNotBlank(bo.getMaterialParameter()), BaseMaterialInfo::getMaterialParameter, bo.getMaterialParameter())
|
||||
.eq(bo.getPurchasePrice() != null, BaseMaterialInfo::getPurchasePrice, bo.getPurchasePrice())
|
||||
.eq(bo.getForeignPrice() != null, BaseMaterialInfo::getForeignPrice, bo.getForeignPrice())
|
||||
.eq(bo.getStockingPeriod() != null, BaseMaterialInfo::getStockingPeriod, bo.getStockingPeriod())
|
||||
.eq(StringUtils.isNotBlank(bo.getActiveFlag()), BaseMaterialInfo::getActiveFlag, bo.getActiveFlag())
|
||||
;
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增SAP物料信息
|
||||
*
|
||||
* @param bo SAP物料信息
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(BaseMaterialInfoBo bo) {
|
||||
BaseMaterialInfo add = MapstructUtils.convert(bo, BaseMaterialInfo.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setMaterialId(add.getMaterialId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改SAP物料信息
|
||||
*
|
||||
* @param bo SAP物料信息
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(BaseMaterialInfoBo bo) {
|
||||
BaseMaterialInfo update = MapstructUtils.convert(bo, BaseMaterialInfo.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(BaseMaterialInfo entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 校验并批量删除SAP物料信息信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteByIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
@ -1,143 +0,0 @@
|
||||
package org.dromara.oa.base.service.impl;
|
||||
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.github.yulichang.toolkit.JoinWrappers;
|
||||
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.dromara.oa.base.domain.BaseUnitInfo;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.dromara.oa.base.domain.bo.BaseMaterielInfoBo;
|
||||
import org.dromara.oa.base.domain.vo.BaseMaterielInfoVo;
|
||||
import org.dromara.oa.base.domain.BaseMaterielInfo;
|
||||
import org.dromara.oa.base.mapper.BaseMaterielInfoMapper;
|
||||
import org.dromara.oa.base.service.IBaseMaterielInfoService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* SAP物料信息Service业务层处理
|
||||
*
|
||||
* @author Yinq
|
||||
* @date 2025-09-28
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class BaseMaterielInfoServiceImpl implements IBaseMaterielInfoService {
|
||||
|
||||
private final BaseMaterielInfoMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询SAP物料信息
|
||||
*
|
||||
* @param materielId 主键
|
||||
* @return SAP物料信息
|
||||
*/
|
||||
@Override
|
||||
public BaseMaterielInfoVo queryById(Long materielId) {
|
||||
return baseMapper.selectVoById(materielId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 分页查询SAP物料信息列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return SAP物料信息分页列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<BaseMaterielInfoVo> queryPageList(BaseMaterielInfoBo bo, PageQuery pageQuery) {
|
||||
MPJLambdaWrapper<BaseMaterielInfo> lqw = buildQueryWrapper(bo);
|
||||
Page<BaseMaterielInfoVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询符合条件的SAP物料信息列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return SAP物料信息列表
|
||||
*/
|
||||
@Override
|
||||
public List<BaseMaterielInfoVo> queryList(BaseMaterielInfoBo bo) {
|
||||
MPJLambdaWrapper<BaseMaterielInfo> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private MPJLambdaWrapper<BaseMaterielInfo> buildQueryWrapper(BaseMaterielInfoBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
MPJLambdaWrapper<BaseMaterielInfo> lqw = JoinWrappers.lambda(BaseMaterielInfo.class)
|
||||
.selectAll(BaseMaterielInfo.class)
|
||||
.select(BaseUnitInfo::getUnitName)
|
||||
.leftJoin(BaseUnitInfo.class, BaseUnitInfo::getUnitId, BaseMaterielInfo::getUnitId)
|
||||
.like(StringUtils.isNotBlank(bo.getMaterielCode()), BaseMaterielInfo::getMaterielCode, bo.getMaterielCode())
|
||||
.like(StringUtils.isNotBlank(bo.getMaterielName()), BaseMaterielInfo::getMaterielName, bo.getMaterielName())
|
||||
.like(StringUtils.isNotBlank(bo.getMaterielBrand()), BaseMaterielInfo::getMaterielBrand, bo.getMaterielBrand())
|
||||
.like(StringUtils.isNotBlank(bo.getMaterielModel()), BaseMaterielInfo::getMaterielModel, bo.getMaterielModel())
|
||||
.eq(bo.getUnitId() != null, BaseMaterielInfo::getUnitId, bo.getUnitId())
|
||||
.like(StringUtils.isNotBlank(bo.getMaterialParameter()), BaseMaterielInfo::getMaterialParameter, bo.getMaterialParameter())
|
||||
.eq(bo.getPurchasePrice() != null, BaseMaterielInfo::getPurchasePrice, bo.getPurchasePrice())
|
||||
.eq(bo.getForeignPrice() != null, BaseMaterielInfo::getForeignPrice, bo.getForeignPrice())
|
||||
.eq(bo.getStockingPeriod() != null, BaseMaterielInfo::getStockingPeriod, bo.getStockingPeriod())
|
||||
.eq(StringUtils.isNotBlank(bo.getActiveFlag()), BaseMaterielInfo::getActiveFlag, bo.getActiveFlag());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增SAP物料信息
|
||||
*
|
||||
* @param bo SAP物料信息
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(BaseMaterielInfoBo bo) {
|
||||
BaseMaterielInfo add = MapstructUtils.convert(bo, BaseMaterielInfo.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setMaterielId(add.getMaterielId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改SAP物料信息
|
||||
*
|
||||
* @param bo SAP物料信息
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(BaseMaterielInfoBo bo) {
|
||||
BaseMaterielInfo update = MapstructUtils.convert(bo, BaseMaterielInfo.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(BaseMaterielInfo entity) {
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 校验并批量删除SAP物料信息信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if (isValid) {
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteByIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue