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