- 新增 selectVoPagePlus 方法以支持自定义 SQL 查询 -重构 queryPageList 方法,使用新的查询方式 - 添加供应商名称和客户名称字段到相应的 VO 类- 更新 XML 文件以包含新的查询 SQL
130 lines
4.7 KiB
Java
130 lines
4.7 KiB
Java
package com.klp.service.impl;
|
||
|
||
import cn.hutool.core.bean.BeanUtil;
|
||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||
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.WmsReceivableBo;
|
||
import com.klp.domain.vo.WmsReceivableVo;
|
||
import com.klp.domain.WmsReceivable;
|
||
import com.klp.mapper.WmsReceivableMapper;
|
||
import com.klp.service.IWmsReceivableService;
|
||
|
||
import java.util.List;
|
||
import java.util.Map;
|
||
import java.util.Collection;
|
||
|
||
/**
|
||
* 应收款管理(宽松版)Service业务层处理
|
||
*
|
||
* @author klp
|
||
* @date 2025-08-13
|
||
*/
|
||
@RequiredArgsConstructor
|
||
@Service
|
||
public class WmsReceivableServiceImpl implements IWmsReceivableService {
|
||
|
||
private final WmsReceivableMapper baseMapper;
|
||
|
||
/**
|
||
* 查询应收款管理(宽松版)
|
||
*/
|
||
@Override
|
||
public WmsReceivableVo queryById(Long receivableId){
|
||
return baseMapper.selectVoById(receivableId);
|
||
}
|
||
|
||
/**
|
||
* 查询应收款管理(宽松版)列表
|
||
*/
|
||
@Override
|
||
public TableDataInfo<WmsReceivableVo> queryPageList(WmsReceivableBo bo, PageQuery pageQuery) {
|
||
QueryWrapper<WmsReceivable> lqw = buildQueryWrapperPlus(bo);
|
||
Page<WmsReceivableVo> result = baseMapper.selectVoPagePlus(pageQuery.build(), lqw);
|
||
return TableDataInfo.build(result);
|
||
}
|
||
|
||
private QueryWrapper<WmsReceivable> buildQueryWrapperPlus(WmsReceivableBo bo) {
|
||
QueryWrapper<WmsReceivable> lqw = Wrappers.query();
|
||
lqw.eq("r.del_flag", 0);
|
||
lqw.eq(bo.getCustomerId() != null, "r.customer_id", bo.getCustomerId());
|
||
lqw.eq(bo.getOrderId() != null, "r.order_id", bo.getOrderId());
|
||
lqw.eq(bo.getDueDate() != null, "r.due_date", bo.getDueDate());
|
||
lqw.eq(bo.getAmount() != null, "r.amount", bo.getAmount());
|
||
lqw.eq(bo.getPaidAmount() != null, "r.paid_amount", bo.getPaidAmount());
|
||
lqw.eq(bo.getBalanceAmount() != null, "r.balance_amount", bo.getBalanceAmount());
|
||
lqw.eq(StringUtils.isNotBlank(bo.getStatus()), "r.status", bo.getStatus());
|
||
return lqw;
|
||
}
|
||
|
||
/**
|
||
* 查询应收款管理(宽松版)列表
|
||
*/
|
||
@Override
|
||
public List<WmsReceivableVo> queryList(WmsReceivableBo bo) {
|
||
LambdaQueryWrapper<WmsReceivable> lqw = buildQueryWrapper(bo);
|
||
return baseMapper.selectVoList(lqw);
|
||
}
|
||
|
||
private LambdaQueryWrapper<WmsReceivable> buildQueryWrapper(WmsReceivableBo bo) {
|
||
Map<String, Object> params = bo.getParams();
|
||
LambdaQueryWrapper<WmsReceivable> lqw = Wrappers.lambdaQuery();
|
||
lqw.eq(bo.getCustomerId() != null, WmsReceivable::getCustomerId, bo.getCustomerId());
|
||
lqw.eq(bo.getOrderId() != null, WmsReceivable::getOrderId, bo.getOrderId());
|
||
lqw.eq(bo.getDueDate() != null, WmsReceivable::getDueDate, bo.getDueDate());
|
||
lqw.eq(bo.getAmount() != null, WmsReceivable::getAmount, bo.getAmount());
|
||
lqw.eq(bo.getPaidAmount() != null, WmsReceivable::getPaidAmount, bo.getPaidAmount());
|
||
lqw.eq(bo.getBalanceAmount() != null, WmsReceivable::getBalanceAmount, bo.getBalanceAmount());
|
||
lqw.eq(StringUtils.isNotBlank(bo.getStatus()), WmsReceivable::getStatus, bo.getStatus());
|
||
return lqw;
|
||
}
|
||
|
||
/**
|
||
* 新增应收款管理(宽松版)
|
||
*/
|
||
@Override
|
||
public Boolean insertByBo(WmsReceivableBo bo) {
|
||
WmsReceivable add = BeanUtil.toBean(bo, WmsReceivable.class);
|
||
validEntityBeforeSave(add);
|
||
boolean flag = baseMapper.insert(add) > 0;
|
||
if (flag) {
|
||
bo.setReceivableId(add.getReceivableId());
|
||
}
|
||
return flag;
|
||
}
|
||
|
||
/**
|
||
* 修改应收款管理(宽松版)
|
||
*/
|
||
@Override
|
||
public Boolean updateByBo(WmsReceivableBo bo) {
|
||
WmsReceivable update = BeanUtil.toBean(bo, WmsReceivable.class);
|
||
validEntityBeforeSave(update);
|
||
return baseMapper.updateById(update) > 0;
|
||
}
|
||
|
||
/**
|
||
* 保存前的数据校验
|
||
*/
|
||
private void validEntityBeforeSave(WmsReceivable entity){
|
||
//TODO 做一些数据校验,如唯一约束
|
||
}
|
||
|
||
/**
|
||
* 批量删除应收款管理(宽松版)
|
||
*/
|
||
@Override
|
||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||
if(isValid){
|
||
//TODO 做一些业务上的校验,判断是否需要校验
|
||
}
|
||
return baseMapper.deleteBatchIds(ids) > 0;
|
||
}
|
||
}
|