From 9bcc40d213a44498c46dae5e678e592b918b40b0 Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期四, 30 五月 2024 18:33:54 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java | 107 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 106 insertions(+), 1 deletions(-) diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java index 5cec9be..67b935f 100644 --- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java +++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java @@ -3,21 +3,31 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.enums.AuctionOrderTypeEnum; import com.ruoyi.common.core.enums.BondStatusEnum; +import com.ruoyi.common.core.enums.PaymentMethodEnum; import com.ruoyi.common.core.utils.StringUtils; -import com.ruoyi.order.domain.pojo.Paylog; +import com.ruoyi.order.domain.Paylog; import com.ruoyi.order.mapper.OrderAuctionBondMapper; import com.ruoyi.order.service.IOrderAuctionBondService; import com.ruoyi.order.service.IPaylogService; +import com.ruoyi.order.util.OrderUtil; import com.ruoyi.order.util.SinataUtil; +import com.ruoyi.system.api.domain.AuctionGoods; +import com.ruoyi.system.api.domain.AuctionSalesroom; import com.ruoyi.system.api.domain.OrderAuctionBond; +import com.ruoyi.system.api.domain.dto.MemberAuctionSalesroomBondDTO; import com.ruoyi.system.api.domain.dto.OrderAuctionBondDTO; +import com.ruoyi.system.api.domain.vo.PayInfoVO; +import com.ruoyi.system.api.feignClient.AuctionClient; import java.util.List; import javax.annotation.Resource; import org.apache.poi.ss.formula.functions.T; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Propagation; +import org.springframework.transaction.annotation.Transactional; /** * <p> @@ -38,6 +48,11 @@ @Resource private PaylogServiceImpl paylogServiceImpl; + + + @Resource + private AuctionClient auctionClient; + @Override public R<T> getOrderAuctionBond(OrderAuctionBondDTO orderAuctionBondDTO) { @@ -96,8 +111,98 @@ * @param bondStatusEnum 保证金状态 */ @Override + @Transactional(propagation = Propagation.REQUIRES_NEW) public void updateOrderAuctionBondStatus(List<Long> ids, BondStatusEnum bondStatusEnum) { this.lambdaUpdate().set(OrderAuctionBond::getBoundStatus, bondStatusEnum) .in(OrderAuctionBond::getId, ids).update(); } + + @Override + public PayInfoVO SaveOrderAuctionBond(MemberAuctionSalesroomBondDTO memberAuctionSalesroomBondDTO) { + PayInfoVO payInfoVO = new PayInfoVO(); + if (memberAuctionSalesroomBondDTO.getBondType() == 2) { + AuctionSalesroom data = auctionClient.getauctionSalesroomOne(memberAuctionSalesroomBondDTO.getAuctionSalesroomId(), SecurityConstants.INNER).getData(); + if (data.getBond().intValue() == 0) { + OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); + orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); + orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + orderAuctionBond.setBond(data.getBond()); + orderAuctionBond.setBoundStatus(BondStatusEnum.PAID); + orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); + iOrderAuctionBondService.save(orderAuctionBond); + payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); + payInfoVO.setType(0); + payInfoVO.setSubject("保证金"); + payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + payInfoVO.setBody("保证金"); + } else { + OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); + orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); + orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + orderAuctionBond.setBond(data.getBond()); + orderAuctionBond.setBoundStatus(BondStatusEnum.TO_PLAY); + orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); + if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { + orderAuctionBond.setPaymentMethod(PaymentMethodEnum.WECHAT); + } else { + orderAuctionBond.setPaymentMethod(PaymentMethodEnum.ALIPAY); + } + + iOrderAuctionBondService.save(orderAuctionBond); + + payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); + if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { + payInfoVO.setType(2); + } else { + payInfoVO.setType(1); + } + payInfoVO.setSubject("保证金"); + payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + payInfoVO.setBody("保证金"); + } + } else { + AuctionGoods data = auctionClient.getauctionGoodsOne(memberAuctionSalesroomBondDTO.getAuctionGoodsId(), SecurityConstants.INNER).getData(); + if (data.getBond().intValue() == 0) { + OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); + orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); + orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + orderAuctionBond.setBond(data.getBond()); + orderAuctionBond.setBoundStatus(BondStatusEnum.PAID); + orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); + iOrderAuctionBondService.save(orderAuctionBond); + payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); + payInfoVO.setType(0); + payInfoVO.setSubject("保证金"); + payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + payInfoVO.setBody("保证金"); + } else { + OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); + orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); + orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + orderAuctionBond.setBond(data.getBond()); + orderAuctionBond.setBoundStatus(BondStatusEnum.TO_PLAY); + orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); + if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { + orderAuctionBond.setPaymentMethod(PaymentMethodEnum.WECHAT); + } else { + orderAuctionBond.setPaymentMethod(PaymentMethodEnum.ALIPAY); + } + iOrderAuctionBondService.save(orderAuctionBond); + payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); + if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { + payInfoVO.setType(2); + } else { + payInfoVO.setType(1); + } + payInfoVO.setSubject("保证金"); + payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); + payInfoVO.setBody("保证金"); + } + } + return payInfoVO; + } } -- Gitblit v1.7.1