仓库管理模块完成
This commit is contained in:
@@ -0,0 +1,49 @@
|
||||
package com.ruoyi.oa.service;
|
||||
|
||||
import com.ruoyi.oa.domain.SysOaWarehouse;
|
||||
import com.ruoyi.oa.domain.vo.SysOaWarehouseVo;
|
||||
import com.ruoyi.oa.domain.bo.SysOaWarehouseBo;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 仓库管理Service接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2024-11-02
|
||||
*/
|
||||
public interface ISysOaWarehouseService {
|
||||
|
||||
/**
|
||||
* 查询仓库管理
|
||||
*/
|
||||
SysOaWarehouseVo queryById(Long id);
|
||||
|
||||
/**
|
||||
* 查询仓库管理列表
|
||||
*/
|
||||
TableDataInfo<SysOaWarehouseVo> queryPageList(SysOaWarehouseBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询仓库管理列表
|
||||
*/
|
||||
List<SysOaWarehouseVo> queryList(SysOaWarehouseBo bo);
|
||||
|
||||
/**
|
||||
* 新增仓库管理
|
||||
*/
|
||||
Boolean insertByBo(SysOaWarehouseBo bo);
|
||||
|
||||
/**
|
||||
* 修改仓库管理
|
||||
*/
|
||||
Boolean updateByBo(SysOaWarehouseBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除仓库管理信息
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
}
|
||||
@@ -0,0 +1,127 @@
|
||||
package com.ruoyi.oa.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.ruoyi.common.utils.StringUtils;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.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.ruoyi.oa.domain.bo.SysOaWarehouseBo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaWarehouseVo;
|
||||
import com.ruoyi.oa.domain.SysOaWarehouse;
|
||||
import com.ruoyi.oa.mapper.SysOaWarehouseMapper;
|
||||
import com.ruoyi.oa.service.ISysOaWarehouseService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 仓库管理Service业务层处理
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2024-11-02
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class SysOaWarehouseServiceImpl implements ISysOaWarehouseService {
|
||||
|
||||
private final SysOaWarehouseMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询仓库管理
|
||||
*/
|
||||
@Override
|
||||
public SysOaWarehouseVo queryById(Long id){
|
||||
return baseMapper.selectVoById(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询仓库管理列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<SysOaWarehouseVo> queryPageList(SysOaWarehouseBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw = buildQueryWrapper(bo);
|
||||
Page<SysOaWarehouseVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询仓库管理列表
|
||||
*/
|
||||
@Override
|
||||
public List<SysOaWarehouseVo> queryList(SysOaWarehouseBo bo) {
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<SysOaWarehouse> buildQueryWrapper(SysOaWarehouseBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getInventory() != null, SysOaWarehouse::getInventory, bo.getInventory());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getModel()), SysOaWarehouse::getModel, bo.getModel());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getUnit()), SysOaWarehouse::getUnit, bo.getUnit());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getName()), SysOaWarehouse::getName, bo.getName());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getBrand()), SysOaWarehouse::getBrand, bo.getBrand());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getSpecifications()), SysOaWarehouse::getSpecifications, bo.getSpecifications());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增仓库管理
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(SysOaWarehouseBo bo) {
|
||||
SysOaWarehouse add = BeanUtil.toBean(bo, SysOaWarehouse.class);
|
||||
validEntityBeforeSave(add);
|
||||
// 1、查询仓库中是否有已存在项目
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(SysOaWarehouse::getName, bo.getName());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getModel()), SysOaWarehouse::getModel, bo.getModel());
|
||||
SysOaWarehouseVo selectVo = baseMapper.selectVoOne(lqw);
|
||||
// 2、 无则直接新增项目 有则直接增加库存数量
|
||||
boolean flag;
|
||||
if(selectVo == null ) {
|
||||
flag = baseMapper.insert(add) > 0;
|
||||
|
||||
}
|
||||
|
||||
else {
|
||||
selectVo.setInventory(selectVo.getInventory() + bo.getInventory());
|
||||
SysOaWarehouse update = BeanUtil.toBean(selectVo, SysOaWarehouse.class);
|
||||
flag = baseMapper.updateById(update) > 0;
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改仓库管理
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(SysOaWarehouseBo bo) {
|
||||
SysOaWarehouse update = BeanUtil.toBean(bo, SysOaWarehouse.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(SysOaWarehouse 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