更新计量单为
This commit is contained in:
@@ -3,10 +3,7 @@ package com.zt.plat.module.contractorder.api;
|
||||
import cn.hutool.extra.spring.SpringUtil;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.module.contractorder.api.dto.order.OrdDtlDTO;
|
||||
import com.zt.plat.module.contractorder.api.dto.order.OrderDTO;
|
||||
import com.zt.plat.module.contractorder.api.dto.order.PurchaseOrderWithDetailsDTO;
|
||||
import com.zt.plat.module.contractorder.api.dto.order.SalesOrdDtlDTO;
|
||||
import com.zt.plat.module.contractorder.api.dto.order.*;
|
||||
import com.zt.plat.module.contractorder.dal.dataobject.purchaseorder.PrchOrdDtlDO;
|
||||
import com.zt.plat.module.contractorder.dal.dataobject.purchaseorder.PurchaseOrderDO;
|
||||
import com.zt.plat.module.contractorder.dal.dataobject.salesorder.SalesOrderDO;
|
||||
@@ -18,12 +15,15 @@ import com.zt.plat.module.contractorder.dal.mysql.salesorder.SalesOrderMapper;
|
||||
import com.zt.plat.module.contractorder.service.purchaseorder.PurchaseOrderService;
|
||||
import jakarta.annotation.Resource;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
import java.util.Optional;
|
||||
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
@@ -61,7 +61,7 @@ public class OrderApiImpl implements OrderApi {
|
||||
if (!salesOrderIds.isEmpty()) {
|
||||
order.addAll(getSalesOrdByIds(salesOrderIds));
|
||||
}
|
||||
return success(order);
|
||||
return success(order);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -92,6 +92,40 @@ public class OrderApiImpl implements OrderApi {
|
||||
return success(order);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public CommonResult<Boolean> UpdateOrderLstQty(List<UpdateOrderLstQtyDTO> updateOrderLstQtyDTOS) {
|
||||
if (updateOrderLstQtyDTOS == null || updateOrderLstQtyDTOS.isEmpty()) {
|
||||
throw new RuntimeException("请求数据错误");
|
||||
}
|
||||
SalesOrderDetailMapper salesOrderDetailMapper = SpringUtil.getBean(SalesOrderDetailMapper.class);
|
||||
PrchOrdDtlMapper prchOrdDtlMapper = SpringUtil.getBean(PrchOrdDtlMapper.class);
|
||||
updateOrderLstQtyDTOS.forEach(f -> {
|
||||
if ("SALE".equals(f.getSplyBsnTp())) {
|
||||
SalesOrderDetailDO salesOrderDetailDO = salesOrderDetailMapper.selectById(f.getId());
|
||||
// 处理 trfQty 可能为 null 的情况,默认值 0
|
||||
BigDecimal trfQty = Optional.ofNullable(salesOrderDetailDO.getTrfQty())
|
||||
.orElse(BigDecimal.ZERO);
|
||||
SalesOrderDetailDO updateDO = new SalesOrderDetailDO();
|
||||
updateDO.setId(f.getId()); // 给更新对象设 ID
|
||||
updateDO.setTrfQty(trfQty.add(f.getLstQty())); // 累加(trfQty )
|
||||
salesOrderDetailMapper.updateById(updateDO);
|
||||
} else if ("PUR".equals(f.getSplyBsnTp())) {
|
||||
// 采购
|
||||
PrchOrdDtlDO prchOrdDtlDO = prchOrdDtlMapper.selectById(f.getId());
|
||||
BigDecimal trfQty = Optional.ofNullable(prchOrdDtlDO.getTrfQty())
|
||||
.orElse(BigDecimal.ZERO);
|
||||
PrchOrdDtlDO updateDO = new PrchOrdDtlDO();
|
||||
updateDO.setId(f.getId());
|
||||
updateDO.setTrfQty(trfQty.add(f.getLstQty()));
|
||||
prchOrdDtlMapper.updateById(updateDO);
|
||||
} else {
|
||||
throw new RuntimeException("请求数据错误");
|
||||
}
|
||||
});
|
||||
return success(true);
|
||||
}
|
||||
|
||||
private List<SalesOrderDO> getOrderByIds(List<Long> ids) {
|
||||
return SpringUtil.getBean(SalesOrderMapper.class).selectByIds(ids); // 采购订单与销售订单的
|
||||
}
|
||||
|
||||
@@ -155,4 +155,6 @@ public class SalesOrderDetailDO extends BusinessBaseDO {
|
||||
@TableField("TAX_RTE")
|
||||
private BigDecimal taxRte;
|
||||
|
||||
@TableField("TRF_QTY")
|
||||
private BigDecimal trfQty;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user