feat: 订单支持优惠金额字段,优先使用优惠金额
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
Agent
2026-03-27 13:45:22 +00:00
parent 2f8a34e2e0
commit 0fe6f473df
3 changed files with 39 additions and 6 deletions

View File

@@ -117,9 +117,21 @@ public class OrderServiceImpl implements OrderService {
order.setTotalAmount(totalAmount);
// 5. 计算优惠金额和实付金额
BigDecimal discountAmount;
BigDecimal discountRate = order.getDiscountRate();
BigDecimal discountAmount = totalAmount.multiply(new BigDecimal("100").subtract(discountRate))
.divide(new BigDecimal("100"), 2, RoundingMode.HALF_UP);
BigDecimal discountMoney = request.getDiscountMoney();
// 优先使用优惠金额,如果没有填则用折扣率计算
if (discountMoney != null && discountMoney.compareTo(BigDecimal.ZERO) > 0) {
discountAmount = discountMoney;
} else {
// 折扣率默认100即不打折
if (discountRate == null) {
discountRate = new BigDecimal("100");
}
discountAmount = totalAmount.multiply(new BigDecimal("100").subtract(discountRate))
.divide(new BigDecimal("100"), 2, RoundingMode.HALF_UP);
}
BigDecimal actualAmount = totalAmount.subtract(discountAmount);
order.setDiscountAmount(discountAmount);
@@ -342,9 +354,20 @@ public class OrderServiceImpl implements OrderService {
order.setTotalAmount(totalAmount);
BigDecimal discountAmount;
BigDecimal discountRate = order.getDiscountRate();
BigDecimal discountAmount = totalAmount.multiply(new BigDecimal("100").subtract(discountRate))
.divide(new BigDecimal("100"), 2, RoundingMode.HALF_UP);
BigDecimal discountMoney = order.getDiscountMoney();
// 优先使用优惠金额,如果没有填则用折扣率计算
if (discountMoney != null && discountMoney.compareTo(BigDecimal.ZERO) > 0) {
discountAmount = discountMoney;
} else {
if (discountRate == null) {
discountRate = new BigDecimal("100");
}
discountAmount = totalAmount.multiply(new BigDecimal("100").subtract(discountRate))
.divide(new BigDecimal("100"), 2, RoundingMode.HALF_UP);
}
BigDecimal actualAmount = totalAmount.subtract(discountAmount);
order.setDiscountAmount(discountAmount);