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 |  398 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 311 insertions(+), 87 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 2e40960..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
@@ -1,5 +1,6 @@
 package com.ruoyi.auction.service.impl;
 
+import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -7,8 +8,8 @@
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.google.common.collect.Lists;
 import com.ruoyi.auction.domain.AuctionBidRecord;
-import com.ruoyi.auction.domain.AuctionSalesroomGoods;
 import com.ruoyi.auction.mapper.AuctionBidRecordMapper;
+import com.ruoyi.auction.mapper.AuctionBondJlMapper;
 import com.ruoyi.auction.mapper.AuctionSalesroomGoodsMapper;
 import com.ruoyi.auction.mapper.AuctionSalesroomMapper;
 import com.ruoyi.auction.service.IAuctionBrowseRecordService;
@@ -20,25 +21,58 @@
 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;
+import com.ruoyi.common.core.utils.page.CollUtils;
 import com.ruoyi.system.api.constants.NotificationTypeConstant;
-import com.ruoyi.system.api.domain.*;
+import com.ruoyi.system.api.domain.AuctionBondJl;
+import com.ruoyi.system.api.domain.AuctionSalesroom;
+import com.ruoyi.system.api.domain.AuctionSalesroomGoods;
+import com.ruoyi.system.api.domain.CustomConfig;
+import com.ruoyi.system.api.domain.GoodsBrand;
+import com.ruoyi.system.api.domain.GoodsCategory;
+import com.ruoyi.system.api.domain.GoodsFlavorType;
+import com.ruoyi.system.api.domain.GoodsSeries;
+import com.ruoyi.system.api.domain.GoodsSku;
+import com.ruoyi.system.api.domain.Member;
+import com.ruoyi.system.api.domain.MemberAddress;
+import com.ruoyi.system.api.domain.Order;
+import com.ruoyi.system.api.domain.WebsocketMessageDTO;
 import com.ruoyi.system.api.domain.dto.AuctionSalesroomDTO;
 import com.ruoyi.system.api.domain.dto.AuctionSalesroomGoodsInfoDTO;
 import com.ruoyi.system.api.domain.dto.GoodsStockUpdDTO;
 import com.ruoyi.system.api.domain.dto.OrderAuctionBondDTO;
 import com.ruoyi.system.api.domain.dto.OrderDTO;
-import com.ruoyi.system.api.domain.vo.*;
+import com.ruoyi.system.api.domain.dto.SmsSendDTO;
+import com.ruoyi.system.api.domain.vo.AuctionBidRecordVO;
+import com.ruoyi.system.api.domain.vo.AuctionSalesroomGoodsInfoVO;
+import com.ruoyi.system.api.domain.vo.AuctionSalesroomVO;
+import com.ruoyi.system.api.domain.vo.ForepartAuctionSalesroomGoodsVO;
+import com.ruoyi.system.api.domain.vo.GoodsInfoTitleValueVO;
+import com.ruoyi.system.api.domain.vo.getHomeGoodsSkuXxiVO;
+import com.ruoyi.system.api.feignClient.AuthClient;
 import com.ruoyi.system.api.feignClient.GoodsSkuClient;
 import com.ruoyi.system.api.feignClient.MemberClient;
 import com.ruoyi.system.api.feignClient.OrderClient;
 import com.ruoyi.system.api.feignClient.SysUserClient;
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.time.LocalDateTime;
-import java.util.*;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Objects;
+import java.util.Set;
 import java.util.concurrent.ConcurrentHashMap;
+import java.util.stream.Collectors;
 import javax.annotation.Resource;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 
 
@@ -50,6 +84,7 @@
  * @author mitao
  * @since 2024-05-16
  */
+@Slf4j
 @Service
 public class AuctionSalesroomGoodsServiceImpl extends ServiceImpl<AuctionSalesroomGoodsMapper, AuctionSalesroomGoods> implements IAuctionSalesroomGoodsService {
     @Resource
@@ -62,7 +97,7 @@
     private AuctionBidRecordMapper auctionBidRecordMapper;
 
     @Resource
-    private MemberClient emberClient;
+    private MemberClient memberClient;
 
     @Resource
     private OrderClient orderClient;
@@ -77,10 +112,15 @@
     @Resource
     private IAuctionSalesroomService  iAuctionSalesroomService;
 
+
+    @Resource
+    private AuctionBondJlMapper auctionBondJlMapper;
+    @Resource
+    private AuthClient authClient;
     private static final ObjectMapper objectMapper = new ObjectMapper();
 
-
-
+    private static final String SUCCESS_TEMPLATE = "【酒鼎老酒】恭喜!您参与的“content”竞拍已中拍!";
+    private static final String FAILED_TEMPLATE = "【酒鼎老酒】很遗憾!您参与的”content“竞拍未中拍!";
 
 
     /**
@@ -105,7 +145,7 @@
             wrapper1.eq(AuctionSalesroomGoods::getStatus,2);
             wrapper1.eq(AuctionSalesroomGoods::getDelFlag,0);
             wrapper1.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
-            wrapper1.orderByAsc(AuctionSalesroomGoods::getSortNum);
+            wrapper1.orderByDesc(AuctionSalesroomGoods::getEndTime);
             wrapper1.last("limit 1");
             auctionSalesroomGoods = this.getOne(wrapper1);
             if (auctionSalesroomGoods==null){
@@ -122,18 +162,25 @@
                 .getData();
         forepartAuctionSalesroomGoodsVO.setGoodsSkuId(auctionSalesroomGoods.getId());
         forepartAuctionSalesroomGoodsVO.setGoodsSkuName(goodsSku.getSkuName());
-        forepartAuctionSalesroomGoodsVO.setGoodsSkustatus(auctionSalesroomGoods.getStatus());
+        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.getCoverPic());
+        forepartAuctionSalesroomGoodsVO.setCoverPic(goodsSku.getScreenCoverPic());
         forepartAuctionSalesroomGoodsVO.setDescription(goodsSku.getDescription());
         forepartAuctionSalesroomGoodsVO.setDetail(goodsSku.getDetail());
         forepartAuctionSalesroomGoodsVO.setYears(String.valueOf(goodsSku.getYears().getYear()));
         forepartAuctionSalesroomGoodsVO.setUnit(goodsSku.getUnit());
         forepartAuctionSalesroomGoodsVO.setSpec(goodsSku.getSpec());
         forepartAuctionSalesroomGoodsVO.setSpecUnit(goodsSku.getSpecUnit());
+        forepartAuctionSalesroomGoodsVO.setMinimumMarkupAmount(
+                auctionSalesroomGoods.getMinimumMarkupAmount());
+        forepartAuctionSalesroomGoodsVO.setGoodsDescription(
+                auctionSalesroomGoods.getDescription());
         if (auctionSalesroomGoods.getStatus().getCode()==0 || auctionSalesroomGoods.getStatus().getCode()==2){
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper1=Wrappers.lambdaQuery();
             wrapper1.eq(AuctionSalesroomGoods::getDelFlag,0);
@@ -174,8 +221,9 @@
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper=Wrappers.lambdaQuery();
             wrapper.eq(AuctionSalesroomGoods::getStatus,0);
             wrapper.eq(AuctionSalesroomGoods::getDelFlag,0);
+            wrapper.eq(AuctionSalesroomGoods::getBackupStatus,false);
             wrapper.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
-            wrapper.orderByAsc(AuctionSalesroomGoods::getSortNum);
+            wrapper.orderByDesc(AuctionSalesroomGoods::getSortNum);
             List<AuctionSalesroomGoods> auctionSalesroomGoods = this.list(wrapper);
             for (AuctionSalesroomGoods salesroomGoods:auctionSalesroomGoods){
                 ForepartAuctionSalesroomGoodsVO forepartAuctionSalesroomGoodsVO1=new ForepartAuctionSalesroomGoodsVO();
@@ -191,7 +239,9 @@
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper=Wrappers.lambdaQuery();
             wrapper.eq(AuctionSalesroomGoods::getStatus,1);
             wrapper.eq(AuctionSalesroomGoods::getDelFlag,0);
+            wrapper.eq(AuctionSalesroomGoods::getBackupStatus,false);
             wrapper.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
+            wrapper.orderByDesc(AuctionSalesroomGoods::getSortNum);
             wrapper.last("limit 1");
             AuctionSalesroomGoods auctionSalesroomGoods = this.getOne(wrapper);
             ForepartAuctionSalesroomGoodsVO currentAuctionSalesroomGoods=  new ForepartAuctionSalesroomGoodsVO();
@@ -203,42 +253,22 @@
                 currentAuctionSalesroomGoods.setGoodsSkuId(auctionSalesroomGoods.getId());
                 currentAuctionSalesroomGoods.setCoverPic(goodsSku.getCoverPic());
                 currentAuctionSalesroomGoods.setStartTime(auctionSalesroomGoods.getStartTime());
-                currentAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods.getStatus());
+                currentAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods.getStatus().getCode());
                 currentAuctionSalesroomGoods.setListingDuration(auctionSalesroomGoods.getListingDuration());
                 auctionSalesroomVO.setCurrentAuctionSalesroomGoods(currentAuctionSalesroomGoods);
-                list.add(auctionSalesroomGoods.getSortNum());
+                list.add(auctionSalesroomGoods.getId());
             }
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper1=Wrappers.lambdaQuery();
             wrapper1.eq(AuctionSalesroomGoods::getDelFlag,0);
             wrapper1.eq(AuctionSalesroomGoods::getStatus,0);
+            wrapper1.eq(AuctionSalesroomGoods::getBackupStatus,false);
             wrapper1.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
+
             if (auctionSalesroomGoods!=null) {
-                wrapper1.eq(AuctionSalesroomGoods::getSortNum, auctionSalesroomGoods.getSortNum() + 1);
-                list.add(auctionSalesroomGoods.getSortNum()+1);
+                wrapper1.eq(AuctionSalesroomGoods::getSortNum, auctionSalesroomGoods.getSortNum() - 1);
+
             }else{
-                LambdaQueryWrapper<AuctionSalesroomGoods> wrappers=Wrappers.lambdaQuery();
-                wrappers.eq(AuctionSalesroomGoods::getStatus,0);
-                wrappers.eq(AuctionSalesroomGoods::getDelFlag,0);
-                wrappers.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
-                wrappers.orderByAsc(AuctionSalesroomGoods::getSortNum);
-                wrappers.last("limit 1");
-                AuctionSalesroomGoods auctionSalesroomGoodss = this.getOne(wrappers);
-                if (auctionSalesroomGoodss!=null){
-                    R<GoodsSku> goodsSkuOne = goodsSkuClient.getGoodsSkuOne(
-                            auctionSalesroomGoodss.getGoodsSkuId(), SecurityConstants.INNER);
-                    GoodsSku goodsSku=goodsSkuOne.getData();
-                    currentAuctionSalesroomGoods.setGoodsSkuName(goodsSku.getSkuName());
-                    currentAuctionSalesroomGoods.setGoodsSkuId(auctionSalesroomGoodss.getId());
-                    currentAuctionSalesroomGoods.setCoverPic(goodsSku.getCoverPic());
-                    currentAuctionSalesroomGoods.setStartTime(auctionSalesroomGoodss.getStartTime());
-                    currentAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoodss.getStatus());
-                    currentAuctionSalesroomGoods.setListingDuration(auctionSalesroomGoodss.getListingDuration());
-                    auctionSalesroomVO.setCurrentAuctionSalesroomGoods(currentAuctionSalesroomGoods);
-                    wrappers.eq(AuctionSalesroomGoods::getSortNum, auctionSalesroomGoodss.getSortNum());
-                    list.add(auctionSalesroomGoodss.getSortNum());
-                }
-
-
+                wrapper.orderByDesc(AuctionSalesroomGoods::getSortNum);
             }
             wrapper1.last("limit 1");
             AuctionSalesroomGoods auctionSalesroomGoods1 = this.getOne(wrapper1);
@@ -250,17 +280,19 @@
                 GoodsSku goodsSku1=goodsSkuOne1.getData();
                 nextAuctionSalesroomGoods.setNextGoodsSkuName(goodsSku1.getSkuName());
                 nextAuctionSalesroomGoods.setCoverPic(goodsSku1.getCoverPic());
-                nextAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods1.getStatus());
+                nextAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods1.getStatus().getCode());
                 nextAuctionSalesroomGoods.setGoodsSkuId(auctionSalesroomGoods1.getId());
                 auctionSalesroomVO.setNextAuctionSalesroomGoods(nextAuctionSalesroomGoods);
+                list.add(auctionSalesroomGoods1.getId());
             }
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
             if(list.size()>0){
-                wrapper2.notIn(AuctionSalesroomGoods::getSortNum,list);
+                wrapper2.notIn(AuctionSalesroomGoods::getId,list);
             }
             wrapper2.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
-            wrapper2.orderByAsc(AuctionSalesroomGoods::getSortNum);
             wrapper2.orderByAsc(AuctionSalesroomGoods::getStatus);
+            wrapper2.orderByDesc(AuctionSalesroomGoods::getSortNum);
+            wrapper2.eq(AuctionSalesroomGoods::getBackupStatus,false);
             List<AuctionSalesroomGoods> auctionSalesroomGoods2 = this.list(wrapper2);
             for (AuctionSalesroomGoods salesroomGoods:auctionSalesroomGoods2){
                 ForepartAuctionSalesroomGoodsVO forepartAuctionSalesroomGoodsVO1=new ForepartAuctionSalesroomGoodsVO();
@@ -270,7 +302,7 @@
                 forepartAuctionSalesroomGoodsVO1.setGoodsSkuName(goodsSku2.getSkuName());
                 forepartAuctionSalesroomGoodsVO1.setCoverPic(goodsSku2.getCoverPic());
                 forepartAuctionSalesroomGoodsVO1.setGoodsSkuId(salesroomGoods.getId());
-                forepartAuctionSalesroomGoodsVO1.setGoodsSkustatus(salesroomGoods.getStatus());
+                forepartAuctionSalesroomGoodsVO1.setGoodsSkustatus(salesroomGoods.getStatus().getCode());
                 auctionSalesroomGoodsVOS.add(forepartAuctionSalesroomGoodsVO1);
             }
 
@@ -297,9 +329,15 @@
     public void auctionSalesroomStart(AuctionSalesroomDTO ationSalesroomGoodsDTO) {
         AuctionSalesroom auctionSalesroom = auctionSalesroomMapper.selectById(
                 ationSalesroomGoodsDTO.getAuctionSalesroomId());
+
+        if (auctionSalesroom.getStatus().getCode()==1){
+            throw new ServiceException("拍卖会已开始,请勿点击");
+        }
+
         auctionSalesroom.setStatus(AuctionStartStatusEnum.IN_AUCTION);
         auctionSalesroom.setStartTime(LocalDateTime.now());
         auctionSalesroomMapper.updateById(auctionSalesroom);
+
 
         LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
         wrapper2.eq(AuctionSalesroomGoods::getStatus,0);
@@ -308,6 +346,11 @@
         wrapper2.orderByAsc(AuctionSalesroomGoods::getSortNum);
         wrapper2.last("limit 1");
         AuctionSalesroomGoods auctionSalesroomGoods = this.getOne(wrapper2);
+
+        if (auctionSalesroomGoods==null){
+            throw new ServiceException("以没有待拍卖商品");
+        }
+
         if(auctionSalesroomGoods!=null){
             auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.IN_PROGRESS);
             auctionSalesroomGoods.setStartTime(LocalDateTime.now());
@@ -353,23 +396,30 @@
 
                 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);
 
             }
 
         }
-        List<Long> list=new ArrayList<>();
+        Set<Long> list=new HashSet<>();
         LambdaQueryWrapper<AuctionBidRecord> wrapper = Wrappers.lambdaQuery();
         wrapper.eq(AuctionBidRecord::getAuctionSalesroomId, ationSalesroomGoodsDTO.getAuctionSalesroomId());
         wrapper.eq(AuctionBidRecord::getDelFlag, 0);
-        wrapper.eq(AuctionBidRecord::getStatus,0);
+        wrapper.eq(AuctionBidRecord::getStatus,2);
         List<AuctionBidRecord> auctionBidRecordList = auctionBidRecordMapper.selectList(wrapper);
         for (AuctionBidRecord auctionBidRecord:auctionBidRecordList){
             list.add(auctionBidRecord.getMemberId());
         }
         if (list.size()>0){
+            OrderAuctionBondDTO orderAuctionBondDTO=new OrderAuctionBondDTO();
+            orderAuctionBondDTO.setAuctionSalesroomId(auctionSalesroom.getId());
+            orderAuctionBondDTO.setUserList(list);
+            orderClient.getOrderAuctionBond(orderAuctionBondDTO,
+                    SecurityConstants.INNER);
+        }else{
             OrderAuctionBondDTO orderAuctionBondDTO=new OrderAuctionBondDTO();
             orderAuctionBondDTO.setAuctionSalesroomId(auctionSalesroom.getId());
             orderAuctionBondDTO.setUserList(list);
@@ -418,8 +468,14 @@
         wrapper2.eq(AuctionSalesroomGoods::getDelFlag,0);
         wrapper2.eq(AuctionSalesroomGoods::getId,auctionSalesroomGoodsDTO.getGoodsSkuId());
         AuctionSalesroomGoods auctionSalesroomGoods=this.getOne(wrapper2);
+        if (auctionSalesroomGoods==null){
+            throw new ServiceException("拍卖会已没有待开始拍卖商品");
+        }
         auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.IN_PROGRESS);
         auctionSalesroomGoods.setStartTime(LocalDateTime.now());
+        if (auctionSalesroomGoods.getBackupStatus()){
+            auctionSalesroomGoods.setBackupStatus(false);
+        }
         this.updateById(auctionSalesroomGoods);
 
        Map<String, Object> map = new ConcurrentHashMap<>();
@@ -462,21 +518,34 @@
             wrapper.eq(AuctionBidRecord::getTargetId, auctionSalesroomGoodsDTO.getGoodsSkuId());
             wrapper.eq(AuctionBidRecord::getDelFlag, 0);
             wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
+            wrapper.orderByAsc(AuctionBidRecord::getLastBidTime);
             auctionBidRecordList = auctionBidRecordMapper.selectList(wrapper);
-            if(auctionBidRecordList.size()>0){
+            Map<Long, String> orderIdMap = new HashMap<>();
+            if (auctionBidRecordList.size() > 0) {
                 //判断
-                if (auctionBidRecordList.size() >= auctionSalesroomGoods.getSalesroomStock()) {
-                    for (int i = 0; i < auctionSalesroomGoods.getSalesroomStock(); i++) {
+                if (auctionBidRecordList.size() >= auctionSalesroomGoods.getBidNum()) {
+                    for (int i = 0; i < auctionSalesroomGoods.getBidNum(); i++) {
                         AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
+                        Long orderId = AddOrder(auctionBidRecord.getTargetId(),
+                                auctionBidRecord.getMemberId(),
+                                auctionBidRecord.getLastBidAmount()
+                                        .multiply(new BigDecimal(
+                                                auctionSalesroomGoods.getDealQuantity())),
+                                auctionSalesroom.getBond(),
+                                auctionSalesroomGoods.getDealQuantity());
+                        if (Objects.nonNull(orderId)) {
+                            orderIdMap.put(auctionBidRecord.getMemberId(), orderId.toString());
+                            auctionBidRecord.setOrderId(orderId);
+                        }
                         auctionBidRecordMapper.updateById(auctionBidRecord);
-                        AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
-                                auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                     }
                 } 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);
 
@@ -484,18 +553,69 @@
                     for (int i = 0; i < auctionBidRecordList.size(); i++) {
                         AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
+                        Long orderId = AddOrder(auctionBidRecord.getTargetId(),
+                                auctionBidRecord.getMemberId(),
+                                auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond(),
+                                auctionSalesroomGoods.getDealQuantity());
+                        if (Objects.nonNull(orderId)) {
+                            orderIdMap.put(auctionBidRecord.getMemberId(), orderId.toString());
+                            auctionBidRecord.setOrderId(orderId);
+                        }
                         auctionBidRecordMapper.updateById(auctionBidRecord);
-                        AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
-                                auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                     }
                 }
             }
+            GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(auctionSalesroomGoods.getGoodsSkuId(),
+                    SecurityConstants.INNER).getData();
+            List<Long> successMemberIdList = auctionBidRecordList.stream()
+                    .filter(auctionBidRecord -> auctionBidRecord.getStatus()
+                            .equals(BidStatusEnum.SUCCESSFUL))
+                    .map(AuctionBidRecord::getMemberId)
+                    .collect(Collectors.toList());
+            List<Long> failedMemberIdList = auctionBidRecordList.stream()
+                    .filter(auctionBidRecord -> !auctionBidRecord.getStatus()
+                            .equals(BidStatusEnum.SUCCESSFUL))
+                    .map(AuctionBidRecord::getMemberId)
+                    .collect(Collectors.toList());
+            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();
+                if (CollUtils.isNotEmpty(successMemberList)) {
+                    // 推送websocket消息
+                    sendWebsocketMsg(auctionSalesroomGoods.getId(), successMemberList, goodsSku, 1,
+                            orderIdMap, bidMap);
+                    // 发送短信通知
+                    List<String> mobileList = successMemberList.stream().map(Member::getPhone)
+                            .collect(Collectors.toList());
+                    authClient.sendSms(SmsSendDTO.builder().mobileList(mobileList)
+                            .content(SUCCESS_TEMPLATE.replace("content", goodsSku.getSkuName()))
+                            .build(), SecurityConstants.INNER);
+                }
+            }
+            if (CollUtils.isNotEmpty(failedMemberIdList)) {
+                List<Member> failedMemberList = memberClient.getMemberListByIds(
+                        failedMemberIdList, SecurityConstants.INNER).getData();
+                if (CollUtils.isNotEmpty(failedMemberList)) {
+                    // 推送websocket消息
+                    sendWebsocketMsg(auctionSalesroomGoods.getId(), failedMemberList, goodsSku, 0,
+                            orderIdMap, bidMap);
+                    // 发送短信通知
+                    List<String> mobileList = failedMemberList.stream().map(Member::getPhone)
+                            .collect(Collectors.toList());
+                    authClient.sendSms(SmsSendDTO.builder().mobileList(mobileList)
+                            .content(FAILED_TEMPLATE.replace("content", goodsSku.getSkuName()))
+                            .build(), SecurityConstants.INNER);
+                }
+            }
         }
-
+        auctionSalesroomGoods.setEndTime(LocalDateTime.now());
         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());
@@ -513,9 +633,42 @@
 
     }
 
+    /**
+     * 发送websocket通知
+     * @param id
+     * @param memberList
+     * @param goodsSku
+     * @param successFlag // 中标状态 1:中标 0:未中标
+     */
+    private void sendWebsocketMsg(Long id, List<Member> memberList, GoodsSku goodsSku,
+            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);
+            map.put("notification_time", DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:ss"));
+            map.put("target_id", id);
+            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(), "0"));
+            map.put("member_id", member.getId().toString());
+            String msg = JSONObject.toJSONString(map);
+            sysUserClient.pushByClientType(
+                    WebsocketMessageDTO.builder().message(msg).clientType(ClientTypeEnum.MEMBER)
+                            .userId(member.getUserId()).build(),
+                    SecurityConstants.INNER);
+            log.info("===================>发送websocket通知,消息体{}", msg);
+        }
+    }
     @Override
     public AuctionSalesroomGoodsInfoVO getAuctionSalesroomGoodsInfo(AuctionSalesroomGoodsInfoDTO auctionSalesroomGoodsInfoDTO) {
         AuctionSalesroom byId = auctionSalesroomMapper.selectById(auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        if (byId==null){
+            LambdaQueryWrapper<AuctionSalesroom> wrapper=Wrappers.lambdaQuery();
+            wrapper.eq(AuctionSalesroom::getAuctionSalesroomNo,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+            wrapper.eq(AuctionSalesroom::getDelFlag,0);
+            byId =auctionSalesroomMapper.selectOne(wrapper);
+        }
         AuctionSalesroomGoods byId1 = this.getById(auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
         GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(byId1.getGoodsSkuId(), SecurityConstants.INNER).getData();
         AuctionSalesroomGoodsInfoVO AuctionSalesroomGoodsInfoVO=new AuctionSalesroomGoodsInfoVO();
@@ -524,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());
@@ -555,6 +711,18 @@
         AuctionSalesroomGoodsInfoVO.setAlbum(goodsSku.getAlbum());
         AuctionSalesroomGoodsInfoVO.setSpec(goodsSku.getSpec());
         AuctionSalesroomGoodsInfoVO.setSpecUnit(goodsSku.getSpecUnit());
+
+
+        LambdaQueryWrapper<AuctionBondJl> wrapper=Wrappers.lambdaQuery();
+        wrapper.eq(AuctionBondJl::getAuctionSalesroomId,byId.getId());
+        wrapper.eq(AuctionBondJl::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
+        wrapper.eq(AuctionBondJl::getIsState,0);
+        AuctionBondJl auctionBondJl = auctionBondJlMapper.selectOne(wrapper);
+        if (auctionBondJl!=null){
+            AuctionSalesroomGoodsInfoVO.setIsApply(2);
+        }else{
+            AuctionSalesroomGoodsInfoVO.setIsApply(1);
+        }
 
         CustomConfig returnAddressUserName = sysUserClient.getconfig("MALL_ORDER_DESCRIPTION").getData();
         AuctionSalesroomGoodsInfoVO.setExplain(returnAddressUserName.getConfigValue());
@@ -593,19 +761,24 @@
         wrapper2.eq(AuctionBidRecord::getAuctionType,2);
         wrapper2.eq(AuctionBidRecord::getTargetId,byId1.getId());
         wrapper2.eq(AuctionBidRecord::getDelFlag,0);
-        AuctionBidRecord list2 = auctionBidRecordMapper.selectOne(wrapper1);
+        wrapper2.orderByDesc(AuctionBidRecord::getLastBidAmount);
+        wrapper2.last("limit 1");
+        AuctionBidRecord list2 = auctionBidRecordMapper.selectOne(wrapper2);
         if (list2!=null){
             AuctionSalesroomGoodsInfoVO.setZgBid(list2.getLastBidAmount());
         }
         List<getHomeGoodsSkuXxiVO> homeGoodsSkuXxiVOS=new ArrayList<>();
        List<GoodsInfoTitleValueVO> goodsInfoTitleValueVOList = goodsSkuClient.getlistByGoodsId(goodsSku.getId(), SecurityConstants.INNER).getData();
-        Collections.sort(goodsInfoTitleValueVOList, Comparator.comparingInt(GoodsInfoTitleValueVO::getSortNum));
-        for (GoodsInfoTitleValueVO goodsInfoTitleValueVO:goodsInfoTitleValueVOList){
-            getHomeGoodsSkuXxiVO getHomeGoodsSkuXxiVOs=new getHomeGoodsSkuXxiVO();
-            getHomeGoodsSkuXxiVOs.setContent(goodsInfoTitleValueVO.getContent());
-            getHomeGoodsSkuXxiVOs.setTitleName(goodsInfoTitleValueVO.getTitleName());
-            homeGoodsSkuXxiVOS.add(getHomeGoodsSkuXxiVOs);
-        }
+       if (goodsInfoTitleValueVOList!=null){
+           Collections.sort(goodsInfoTitleValueVOList, Comparator.comparingInt(GoodsInfoTitleValueVO::getSortNum));
+           for (GoodsInfoTitleValueVO goodsInfoTitleValueVO:goodsInfoTitleValueVOList){
+               getHomeGoodsSkuXxiVO getHomeGoodsSkuXxiVOs=new getHomeGoodsSkuXxiVO();
+               getHomeGoodsSkuXxiVOs.setContent(goodsInfoTitleValueVO.getContent());
+               getHomeGoodsSkuXxiVOs.setTitleName(goodsInfoTitleValueVO.getTitleName());
+               homeGoodsSkuXxiVOS.add(getHomeGoodsSkuXxiVOs);
+           }
+       }
+
         AuctionSalesroomGoodsInfoVO.setXxiVOS(homeGoodsSkuXxiVOS);
 
         return AuctionSalesroomGoodsInfoVO;
@@ -614,29 +787,55 @@
     @Override
     public List<AuctionBidRecordVO> getAuctionBidRecord(AuctionSalesroomGoodsInfoDTO auctionSalesroomGoodsInfoDTO) {
         LambdaQueryWrapper<AuctionBidRecord> wrapper=Wrappers.lambdaQuery();
-        wrapper.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+
+        AuctionSalesroom byId = auctionSalesroomMapper.selectById(auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        if (byId==null){
+            LambdaQueryWrapper<AuctionSalesroom> wrapper1=Wrappers.lambdaQuery();
+            wrapper1.eq(AuctionSalesroom::getAuctionSalesroomNo,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+            wrapper1.eq(AuctionSalesroom::getDelFlag,0);
+            byId =auctionSalesroomMapper.selectOne(wrapper1);
+        }
+
+        if (auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId()!=null){
+            wrapper.eq(AuctionBidRecord::getAuctionSalesroomId,byId.getId());
+        }
         wrapper.eq(AuctionBidRecord::getDelFlag,0);
         wrapper.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
         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();
-        wrapper1.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        if (auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId()!=null){
+            wrapper1.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        }
         wrapper1.eq(AuctionBidRecord::getDelFlag,0);
         wrapper1.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
         wrapper1.eq(AuctionBidRecord::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
-        wrapper.last("limit 1");
-        AuctionBidRecord auctionBidRecord = auctionBidRecordMapper.selectOne(wrapper);
+        wrapper1.last("limit 1");
+        AuctionBidRecord auctionBidRecord = auctionBidRecordMapper.selectOne(wrapper1);
         if (auctionBidRecord!=null){
             LambdaQueryWrapper<AuctionBidRecord> wrapper3=Wrappers.lambdaQuery();
             wrapper3.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
@@ -650,11 +849,28 @@
                 auctionBidRecordVO.setSort(Integer.valueOf(count.intValue()));
                 auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount());
                 auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime());
-                Member data = emberClient.getMembeOne(auctionBidRecord.getMemberId(),
+                auctionBidRecordVO.setStatus(auctionBidRecord.getStatus());
+                Member data = memberClient.getMembeOne(auctionBidRecord.getMemberId(),
                         SecurityConstants.INNER).getData();
-                auctionBidRecordVO.setMemberName(data.getNickname());
-                auctionBidRecordVO.setMemberId(data.getId());
-                auctionBidRecordVOList.add(auctionBidRecordVO);
+                if (data!=null){
+                    auctionBidRecordVO.setMemberName(data.getNickname());
+                    auctionBidRecordVO.setMemberId(data.getId());
+                }
+                if (data!=null){
+                    Boolean b=false;
+                    for (AuctionBidRecordVO auctionBidRecordVOs:auctionBidRecordVOList){
+                        if (auctionBidRecordVOs.getMemberId().equals(data.getId())){
+                            b=true;
+                            break;
+                        }
+                    }
+                    if (!b){
+                        auctionBidRecordVOList.add(auctionBidRecordVO);
+                    }
+                }else{
+                    auctionBidRecordVOList.add(auctionBidRecordVO);
+                }
+
             }
         }
 
@@ -662,7 +878,8 @@
     }
 
 
-    public void AddOrder(Long goodsSkuId, Long memberId, BigDecimal lastBidAmount,BigDecimal bound) {
+    public Long AddOrder(Long goodsSkuId, Long memberId, BigDecimal lastBidAmount,
+            BigDecimal bound, Integer dealQuantity) {
         OrderDTO order=new OrderDTO();
         order.setGoodsSkuId(goodsSkuId);
         order.setOrderTime(LocalDateTime.now());
@@ -670,20 +887,27 @@
         order.setMemberId(memberId);
         AuctionSalesroomGoods auctionSalesroomGoods = this.getById(goodsSkuId);
 
-        order.setGoodsQuantity(1);
-        order.setTotalAmount(lastBidAmount);
+        order.setGoodsQuantity(dealQuantity);
+        order.setTotalAmount(lastBidAmount.multiply(new BigDecimal(dealQuantity)));
         order.setAuctionSalesroomId(auctionSalesroomGoods.getAuctionSalesroomId());
 
-        R<MemberAddress> memberAddressR = emberClient.getMemberAddressOne(memberId,
+        R<MemberAddress> memberAddressR = memberClient.getMemberAddressOne(memberId,
                 SecurityConstants.INNER);
         MemberAddress memberAddress=memberAddressR.getData();
 
-
         CustomConfig memberPointsMoney = sysUserClient.getconfig("MEMBER_POINTS_MONEY").getData();
         CustomConfig memberPointsPoints = sysUserClient.getconfig("MEMBER_POINTS_POINTS").getData();
-        Double aDouble= Double.valueOf(memberPointsMoney.getConfigValue()) * Double.valueOf(memberPointsPoints.getConfigValue());
-        BigDecimal pi=lastBidAmount.multiply(new BigDecimal(aDouble));
-        order.setPoints(pi.intValue());
+
+        if (lastBidAmount.compareTo(BigDecimal.ZERO) > 0) {
+            BigDecimal divide = lastBidAmount.divide(new BigDecimal(memberPointsMoney.getConfigValue()));
+            BigDecimal roundedDown = divide.setScale(0, RoundingMode.DOWN);
+            BigDecimal aDouble= roundedDown.multiply(new BigDecimal(memberPointsPoints.getConfigValue()));
+            order.setPoints(aDouble.intValue());
+        }else{
+            order.setPoints(0);
+        }
+
+
         if (memberAddress!=null){
             order.setReceiverCity(memberAddress.getCity());
             order.setReceiverDetailAddress(memberAddress.getDetailedAddress());
@@ -698,8 +922,8 @@
         order.setSkuName(goodsSku.getSkuName());
         order.setCoverPic(goodsSku.getCoverPic());
         order.setPrice(lastBidAmount);
-        orderClient.saveOrderOne(order,SecurityConstants.INNER);
+        order.setGoodsId(auctionSalesroomGoods.getGoodsSkuId());
+        return orderClient.saveOrderOne(order, SecurityConstants.INNER).getData();
     }
-
 
 }

--
Gitblit v1.7.1