|
@@ -10,8 +10,8 @@ import cn.iocoder.yudao.module.erp.dal.dataobject.purchase.ErpPurchaseInItemDO;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import org.apache.ibatis.annotations.Mapper;
|
|
|
|
|
|
-import java.math.BigDecimal;
|
|
|
import java.util.List;
|
|
|
+import java.util.Objects;
|
|
|
|
|
|
/**
|
|
|
* ERP 采购入库 Mapper
|
|
@@ -32,10 +32,16 @@ public interface ErpPurchaseInMapper extends BaseMapperX<ErpPurchaseInDO> {
|
|
|
.eqIfPresent(ErpPurchaseInDO::getAccountId, reqVO.getAccountId())
|
|
|
.likeIfPresent(ErpPurchaseInDO::getOrderNo, reqVO.getOrderNo())
|
|
|
.orderByDesc(ErpPurchaseInDO::getId);
|
|
|
- if (Boolean.TRUE.equals(reqVO.getDebtStatus())) {
|
|
|
- query.gt(ErpPurchaseInDO::getDebtPrice, BigDecimal.ZERO);
|
|
|
- } else if (Boolean.FALSE.equals(reqVO.getDebtStatus())) {
|
|
|
- query.eq(ErpPurchaseInDO::getDebtPrice, BigDecimal.ZERO);
|
|
|
+ // 付款状态。为什么需要 t. 的原因,是因为联表查询时,需要指定表名,不然会报字段不存在的错误
|
|
|
+ if (Objects.equals(reqVO.getPaymentStatus(), ErpPurchaseInPageReqVO.PAYMENT_STATUS_NONE)) {
|
|
|
+ query.eq(ErpPurchaseInDO::getPaymentPrice, 0);
|
|
|
+ } else if (Objects.equals(reqVO.getPaymentStatus(), ErpPurchaseInPageReqVO.PAYMENT_STATUS_PART)) {
|
|
|
+ query.gt(ErpPurchaseInDO::getPaymentPrice, 0).apply("t.payment_price < t.total_price");
|
|
|
+ } else if (Objects.equals(reqVO.getPaymentStatus(), ErpPurchaseInPageReqVO.PAYMENT_STATUS_ALL)) {
|
|
|
+ query.apply("t.payment_price = t.total_price");
|
|
|
+ }
|
|
|
+ if (Boolean.TRUE.equals(reqVO.getPaymentEnable())) {
|
|
|
+ query.apply("t.payment_price < t.total_price");
|
|
|
}
|
|
|
if (reqVO.getWarehouseId() != null || reqVO.getProductId() != null) {
|
|
|
query.leftJoin(ErpPurchaseInItemDO.class, ErpPurchaseInItemDO::getInId, ErpPurchaseInDO::getId)
|