From 392b42c4891cf2e6beda57ab32c51598f290f4b7 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期五, 14 三月 2025 20:56:27 +0800
Subject: [PATCH] bug修改

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java |   76 ++++++++++++++++++++++++--------------
 1 files changed, 48 insertions(+), 28 deletions(-)

diff --git a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java
index 44cb11b..ffc0100 100644
--- a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java
+++ b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java
@@ -21,6 +21,7 @@
 import com.ruoyi.common.core.enums.AuctionOrderTypeEnum;
 import com.ruoyi.common.core.enums.AuctionStartStatusEnum;
 import com.ruoyi.common.core.enums.BidStatusEnum;
+import com.ruoyi.common.core.enums.ClientTypeEnum;
 import com.ruoyi.common.core.enums.OrderFromEnum;
 import com.ruoyi.common.core.exception.ServiceException;
 import com.ruoyi.common.core.utils.DateUtils;
@@ -163,7 +164,10 @@
         forepartAuctionSalesroomGoodsVO.setGoodsSkuName(goodsSku.getSkuName());
         forepartAuctionSalesroomGoodsVO.setGoodsSkustatus(auctionSalesroomGoods.getStatus().getCode());
         forepartAuctionSalesroomGoodsVO.setStartingPrice(auctionSalesroomGoods.getStartingPrice());
-        forepartAuctionSalesroomGoodsVO.setSalesroomStock(auctionSalesroomGoods.getSalesroomStock());
+        // forepartAuctionSalesroomGoodsVO.setSalesroomStock(auctionSalesroomGoods.getSalesroomStock());
+        forepartAuctionSalesroomGoodsVO.setBidNum(auctionSalesroomGoods.getBidNum());
+        forepartAuctionSalesroomGoodsVO.setDealQuantity(auctionSalesroomGoods.getDealQuantity());
+        forepartAuctionSalesroomGoodsVO.setMaxAmount(auctionSalesroomGoods.getMaxAmount());
         forepartAuctionSalesroomGoodsVO.setListingDuration(auctionSalesroomGoods.getListingDuration());
         forepartAuctionSalesroomGoodsVO.setStartTime(auctionSalesroomGoods.getStartTime());
         forepartAuctionSalesroomGoodsVO.setCoverPic(goodsSku.getScreenCoverPic());
@@ -392,7 +396,8 @@
 
                 GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO();
                 goodsStockUpdDTO.setGoodsSkuId(salesroomGoods.getGoodsSkuId());
-                goodsStockUpdDTO.setAuctionStock(salesroomGoods.getSalesroomStock());
+                goodsStockUpdDTO.setAuctionStock(
+                        salesroomGoods.getBidNum() * salesroomGoods.getDealQuantity());
                 goodsSkuClient.updGoodsStock(Lists.newArrayList(goodsStockUpdDTO),
                         SecurityConstants.INNER);
 
@@ -519,7 +524,7 @@
             if (auctionBidRecordList.size() > 0) {
                 //判断
                 if (auctionBidRecordList.size() >= auctionSalesroomGoods.getBidNum()) {
-                    for (int i = 0; i < auctionSalesroomGoods.getSalesroomStock(); i++) {
+                    for (int i = 0; i < auctionSalesroomGoods.getBidNum(); i++) {
                         AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
                         Long orderId = AddOrder(auctionBidRecord.getTargetId(),
@@ -538,7 +543,9 @@
                 } else {
                     GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO();
                     goodsStockUpdDTO.setGoodsSkuId(auctionSalesroomGoods.getGoodsSkuId());
-                    goodsStockUpdDTO.setAuctionStock(auctionSalesroomGoods.getSalesroomStock()- auctionBidRecordList.size());
+                    goodsStockUpdDTO.setAuctionStock(auctionSalesroomGoods.getBidNum()
+                            * auctionSalesroomGoods.getDealQuantity() - auctionBidRecordList.size()
+                            * auctionSalesroomGoods.getDealQuantity());
                     goodsSkuClient.updGoodsStock(Lists.newArrayList(goodsStockUpdDTO),
                             SecurityConstants.INNER);
 
@@ -548,7 +555,8 @@
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
                         Long orderId = AddOrder(auctionBidRecord.getTargetId(),
                                 auctionBidRecord.getMemberId(),
-                                auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond(), 1);
+                                auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond(),
+                                auctionSalesroomGoods.getDealQuantity());
                         if (Objects.nonNull(orderId)) {
                             orderIdMap.put(auctionBidRecord.getMemberId(), orderId.toString());
                             auctionBidRecord.setOrderId(orderId);
@@ -569,8 +577,9 @@
                             .equals(BidStatusEnum.SUCCESSFUL))
                     .map(AuctionBidRecord::getMemberId)
                     .collect(Collectors.toList());
-            Map<Long, Long> bidMap = auctionBidRecordList.stream().collect(
-                    Collectors.toMap(AuctionBidRecord::getMemberId, AuctionBidRecord::getId));
+            Map<Long, String> bidMap = auctionBidRecordList.stream().collect(
+                    Collectors.toMap(AuctionBidRecord::getMemberId,
+                            item -> item.getId().toString()));
             if (CollUtils.isNotEmpty(successMemberIdList)) {
                 List<Member> successMemberList = memberClient.getMemberListByIds(
                         successMemberIdList, SecurityConstants.INNER).getData();
@@ -606,7 +615,7 @@
         auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.ENDED);
         this.updateById(auctionSalesroomGoods);
 
-       Map<String, Object> map = new ConcurrentHashMap<>();
+        Map<String, Object> map = new ConcurrentHashMap<>();
         map.put("notification_type", NotificationTypeConstant.AUCTION_SALESROOM_GOODS);
         map.put("notification_time", DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:ss"));
         map.put("goodsSkuId", auctionSalesroomGoods.getId().toString());
@@ -632,7 +641,7 @@
      * @param successFlag // 中标状态 1:中标 0:未中标
      */
     private void sendWebsocketMsg(Long id, List<Member> memberList, GoodsSku goodsSku,
-            Integer successFlag, Map<Long, String> userIdMap, Map<Long, Long> bidMap) {
+            Integer successFlag, Map<Long, String> userIdMap, Map<Long, String> bidMap) {
         for (Member member : memberList) {
             Map<String, Object> map = new ConcurrentHashMap<>();
             map.put("notification_type", NotificationTypeConstant.AUCTION_POPUP);
@@ -641,10 +650,12 @@
             map.put("goods_name", Objects.nonNull(goodsSku) ? goodsSku.getSkuName() : "");
             map.put("success_flag", successFlag);
             map.put("order_id", successFlag == 1 ? userIdMap.getOrDefault(member.getId(), "") : "");
-            map.put("auction_bid_record_id", bidMap.getOrDefault(member.getId(), 0L));
+            map.put("auction_bid_record_id", bidMap.getOrDefault(member.getId(), "0"));
+            map.put("member_id", member.getId().toString());
             String msg = JSONObject.toJSONString(map);
-            sysUserClient.pushBatch(
-                    WebsocketMessageDTO.builder().message(msg).userId(member.getUserId()).build(),
+            sysUserClient.pushByClientType(
+                    WebsocketMessageDTO.builder().message(msg).clientType(ClientTypeEnum.MEMBER)
+                            .userId(member.getUserId()).build(),
                     SecurityConstants.INNER);
             log.info("===================>发送websocket通知,消息体{}", msg);
         }
@@ -666,7 +677,10 @@
         AuctionSalesroomGoodsInfoVO.setGoodsSkuId(byId1.getId());
         AuctionSalesroomGoodsInfoVO.setGoodsSkuName(goodsSku.getSkuName());
         AuctionSalesroomGoodsInfoVO.setStartingPrice(byId1.getStartingPrice());
-        AuctionSalesroomGoodsInfoVO.setSalesroomStock(byId1.getSalesroomStock());
+        // AuctionSalesroomGoodsInfoVO.setSalesroomStock(byId1.getSalesroomStock());
+        AuctionSalesroomGoodsInfoVO.setBidNum(byId1.getBidNum());
+        AuctionSalesroomGoodsInfoVO.setMaxAmount(byId1.getMaxAmount());
+        AuctionSalesroomGoodsInfoVO.setDealQuantity(byId1.getDealQuantity());
         AuctionSalesroomGoodsInfoVO.setSalesroomType(byId.getType().getCode());
         AuctionSalesroomGoodsInfoVO.setGoodsSkustatus(byId1.getStatus().getCode());
         AuctionSalesroomGoodsInfoVO.setListingDuration(byId1.getListingDuration());
@@ -790,14 +804,27 @@
         wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
         wrapper.last("limit 10");
         List<AuctionBidRecord> auctionBidRecordList = auctionBidRecordMapper.selectList(wrapper);
+        Set<Long> memberIdSet = auctionBidRecordList.stream().map(AuctionBidRecord::getMemberId)
+                .collect(Collectors.toSet());
+        R<List<Member>> memberListByIds = memberClient.getMemberListByIds(memberIdSet,
+                SecurityConstants.INNER);
+        Map<Long, String> memberMap = new HashMap<>();
+        if (CollUtils.isNotEmpty(memberListByIds.getData())) {
+            memberMap = memberListByIds.getData().stream()
+                    .collect(Collectors.toMap(Member::getId, item -> item.getAvatar()));
+        }
         List<AuctionBidRecordVO> auctionBidRecordVOList=new ArrayList<>();
         for (int i=0;i<auctionBidRecordList.size();i++){
             AuctionBidRecordVO auctionBidRecordVO=new AuctionBidRecordVO();
             auctionBidRecordVO.setSort(i+1);
-            auctionBidRecordVO.setLastBidAmount(auctionBidRecordList.get(i).getLastBidAmount());
-            auctionBidRecordVO.setLastBidTime(auctionBidRecordList.get(i).getLastBidTime());
-            auctionBidRecordVO.setMemberName(auctionBidRecordList.get(i).getNickname());
-            auctionBidRecordVO.setMemberId(auctionBidRecordList.get(i).getMemberId());
+            AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
+            auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount());
+            auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime());
+            auctionBidRecordVO.setMemberName(auctionBidRecord.getNickname());
+            auctionBidRecordVO.setMemberId(auctionBidRecord.getMemberId());
+            auctionBidRecordVO.setStatus(auctionBidRecord.getStatus());
+            auctionBidRecordVO.setAvatar(
+                    memberMap.getOrDefault(auctionBidRecord.getMemberId(), ""));
             auctionBidRecordVOList.add(auctionBidRecordVO);
         }
         LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery();
@@ -822,6 +849,7 @@
                 auctionBidRecordVO.setSort(Integer.valueOf(count.intValue()));
                 auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount());
                 auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime());
+                auctionBidRecordVO.setStatus(auctionBidRecord.getStatus());
                 Member data = memberClient.getMembeOne(auctionBidRecord.getMemberId(),
                         SecurityConstants.INNER).getData();
                 if (data!=null){
@@ -851,7 +879,7 @@
 
 
     public Long AddOrder(Long goodsSkuId, Long memberId, BigDecimal lastBidAmount,
-            BigDecimal bound, Integer goodsQuantity) {
+            BigDecimal bound, Integer dealQuantity) {
         OrderDTO order=new OrderDTO();
         order.setGoodsSkuId(goodsSkuId);
         order.setOrderTime(LocalDateTime.now());
@@ -859,8 +887,8 @@
         order.setMemberId(memberId);
         AuctionSalesroomGoods auctionSalesroomGoods = this.getById(goodsSkuId);
 
-        order.setGoodsQuantity(goodsQuantity);
-        order.setTotalAmount(lastBidAmount);
+        order.setGoodsQuantity(dealQuantity);
+        order.setTotalAmount(lastBidAmount.multiply(new BigDecimal(dealQuantity)));
         order.setAuctionSalesroomId(auctionSalesroomGoods.getAuctionSalesroomId());
 
         R<MemberAddress> memberAddressR = memberClient.getMemberAddressOne(memberId,
@@ -898,12 +926,4 @@
         return orderClient.saveOrderOne(order, SecurityConstants.INNER).getData();
     }
 
-    /**
-     * 设置弹窗状态已弹出
-     * @param id
-     */
-    @Override
-    public void setPopup(Long id) {
-
-    }
 }

--
Gitblit v1.7.1