From fc8b51f40e71aa09bb49f407c1e9f68ac94ceb58 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 29 七月 2024 18:51:32 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java |  357 +++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 260 insertions(+), 97 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 fed4c43..c774148 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
@@ -6,16 +6,7 @@
 import com.fasterxml.jackson.core.JsonProcessingException;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.google.common.collect.Lists;
-import com.ruoyi.system.api.constants.NotificationTypeConstant;
-import com.ruoyi.system.api.domain.*;
-import com.ruoyi.system.api.domain.dto.AuctionSalesroomDTO;
-import com.ruoyi.system.api.domain.dto.AuctionSalesroomGoodsInfoDTO;
-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.auction.domain.AuctionBidRecord;
-import com.ruoyi.auction.domain.AuctionBrowseRecord;
 import com.ruoyi.auction.domain.AuctionSalesroomGoods;
 import com.ruoyi.auction.mapper.AuctionBidRecordMapper;
 import com.ruoyi.auction.mapper.AuctionSalesroomGoodsMapper;
@@ -30,23 +21,26 @@
 import com.ruoyi.common.core.enums.AuctionStartStatusEnum;
 import com.ruoyi.common.core.enums.BidStatusEnum;
 import com.ruoyi.common.core.enums.OrderFromEnum;
+import com.ruoyi.common.core.exception.ServiceException;
+import com.ruoyi.common.core.utils.DateUtils;
+import com.ruoyi.system.api.constants.NotificationTypeConstant;
+import com.ruoyi.system.api.domain.*;
+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.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.time.format.DateTimeFormatter;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.concurrent.ConcurrentHashMap;
 import javax.annotation.Resource;
-
-import com.ruoyi.system.api.feignClient.SysUserClient;
-import com.ruoyi.system.api.util.WebSocketUsers;
 import org.springframework.stereotype.Service;
 
 
@@ -113,7 +107,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){
@@ -130,7 +124,7 @@
                 .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.setListingDuration(auctionSalesroomGoods.getListingDuration());
@@ -182,6 +176,7 @@
             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);
             List<AuctionSalesroomGoods> auctionSalesroomGoods = this.list(wrapper);
@@ -199,42 +194,81 @@
             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.last("limit 1");
             AuctionSalesroomGoods auctionSalesroomGoods = this.getOne(wrapper);
             ForepartAuctionSalesroomGoodsVO currentAuctionSalesroomGoods=  new ForepartAuctionSalesroomGoodsVO();
-            R<GoodsSku> goodsSkuOne = goodsSkuClient.getGoodsSkuOne(
-                    auctionSalesroomGoods.getGoodsSkuId(), SecurityConstants.INNER);
-            GoodsSku goodsSku=goodsSkuOne.getData();
-            currentAuctionSalesroomGoods.setGoodsSkuName(goodsSku.getSkuName());
-            currentAuctionSalesroomGoods.setCoverPic(goodsSku.getCoverPic());
-            currentAuctionSalesroomGoods.setStartTime(auctionSalesroomGoods.getStartTime());
-            currentAuctionSalesroomGoods.setListingDuration(auctionSalesroomGoods.getListingDuration());
-            auctionSalesroomVO.setCurrentAuctionSalesroomGoods(currentAuctionSalesroomGoods);
-
-            list.add(auctionSalesroomGoods.getSortNum());
-
+            if (auctionSalesroomGoods!=null){
+                R<GoodsSku> goodsSkuOne = goodsSkuClient.getGoodsSkuOne(
+                        auctionSalesroomGoods.getGoodsSkuId(), SecurityConstants.INNER);
+                GoodsSku goodsSku=goodsSkuOne.getData();
+                currentAuctionSalesroomGoods.setGoodsSkuName(goodsSku.getSkuName());
+                currentAuctionSalesroomGoods.setGoodsSkuId(auctionSalesroomGoods.getId());
+                currentAuctionSalesroomGoods.setCoverPic(goodsSku.getCoverPic());
+                currentAuctionSalesroomGoods.setStartTime(auctionSalesroomGoods.getStartTime());
+                currentAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods.getStatus().getCode());
+                currentAuctionSalesroomGoods.setListingDuration(auctionSalesroomGoods.getListingDuration());
+                auctionSalesroomVO.setCurrentAuctionSalesroomGoods(currentAuctionSalesroomGoods);
+                list.add(auctionSalesroomGoods.getId());
+            }
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper1=Wrappers.lambdaQuery();
             wrapper1.eq(AuctionSalesroomGoods::getDelFlag,0);
-            wrapper1.eq(AuctionSalesroomGoods::getSortNum,auctionSalesroomGoods.getSortNum()+1);
+            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);
+
+            }else{
+                LambdaQueryWrapper<AuctionSalesroomGoods> wrappers=Wrappers.lambdaQuery();
+                wrappers.eq(AuctionSalesroomGoods::getStatus,0);
+                wrappers.eq(AuctionSalesroomGoods::getDelFlag,0);
+                wrappers.eq(AuctionSalesroomGoods::getBackupStatus,false);
+                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().getCode());
+                    currentAuctionSalesroomGoods.setListingDuration(auctionSalesroomGoodss.getListingDuration());
+                    auctionSalesroomVO.setCurrentAuctionSalesroomGoods(currentAuctionSalesroomGoods);
+                    wrappers.eq(AuctionSalesroomGoods::getSortNum, auctionSalesroomGoodss.getSortNum());
+                    list.add(auctionSalesroomGoodss.getId());
+                }
+
+
+            }
             wrapper1.last("limit 1");
             AuctionSalesroomGoods auctionSalesroomGoods1 = this.getOne(wrapper1);
             ForepartAuctionSalesroomGoodsVO nextAuctionSalesroomGoods=  new ForepartAuctionSalesroomGoodsVO();
             if (auctionSalesroomGoods1!=null){
-                list.add(auctionSalesroomGoods.getSortNum()+1);
+
                 R<GoodsSku> goodsSkuOne1 = goodsSkuClient.getGoodsSkuOne(
-                        auctionSalesroomGoods.getGoodsSkuId(), SecurityConstants.INNER);
+                        auctionSalesroomGoods1.getGoodsSkuId(), SecurityConstants.INNER);
                 GoodsSku goodsSku1=goodsSkuOne1.getData();
                 nextAuctionSalesroomGoods.setNextGoodsSkuName(goodsSku1.getSkuName());
                 nextAuctionSalesroomGoods.setCoverPic(goodsSku1.getCoverPic());
+                nextAuctionSalesroomGoods.setGoodsSkustatus(auctionSalesroomGoods1.getStatus().getCode());
+                nextAuctionSalesroomGoods.setGoodsSkuId(auctionSalesroomGoods1.getId());
                 auctionSalesroomVO.setNextAuctionSalesroomGoods(nextAuctionSalesroomGoods);
+                list.add(auctionSalesroomGoods1.getId());
             }
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
-            wrapper2.notIn(AuctionSalesroomGoods::getSortNum,list);
-            wrapper2.eq(AuctionSalesroomGoods::getDelFlag,0);
+            if(list.size()>0){
+                wrapper2.notIn(AuctionSalesroomGoods::getId,list);
+            }
             wrapper2.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
-            wrapper2.orderByAsc(AuctionSalesroomGoods::getSortNum);
             wrapper2.orderByAsc(AuctionSalesroomGoods::getStatus);
+            wrapper2.orderByAsc(AuctionSalesroomGoods::getSortNum);
+            wrapper2.eq(AuctionSalesroomGoods::getBackupStatus,false);
             List<AuctionSalesroomGoods> auctionSalesroomGoods2 = this.list(wrapper2);
             for (AuctionSalesroomGoods salesroomGoods:auctionSalesroomGoods2){
                 ForepartAuctionSalesroomGoodsVO forepartAuctionSalesroomGoodsVO1=new ForepartAuctionSalesroomGoodsVO();
@@ -243,13 +277,16 @@
                 GoodsSku goodsSku2=goodsSkuOne2.getData();
                 forepartAuctionSalesroomGoodsVO1.setGoodsSkuName(goodsSku2.getSkuName());
                 forepartAuctionSalesroomGoodsVO1.setCoverPic(goodsSku2.getCoverPic());
-                forepartAuctionSalesroomGoodsVO1.setGoodsSkustatus(salesroomGoods.getStatus());
+                forepartAuctionSalesroomGoodsVO1.setGoodsSkuId(salesroomGoods.getId());
+                forepartAuctionSalesroomGoodsVO1.setGoodsSkustatus(salesroomGoods.getStatus().getCode());
                 auctionSalesroomGoodsVOS.add(forepartAuctionSalesroomGoodsVO1);
             }
 
 
         }
         auctionSalesroomVO.setElseAuctionSalesroomGoods(auctionSalesroomGoodsVOS);
+
+
 
 
         return auctionSalesroomVO;
@@ -268,9 +305,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);
@@ -279,20 +322,28 @@
         wrapper2.orderByAsc(AuctionSalesroomGoods::getSortNum);
         wrapper2.last("limit 1");
         AuctionSalesroomGoods auctionSalesroomGoods = this.getOne(wrapper2);
-        auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.IN_PROGRESS);
-        auctionSalesroomGoods.setStartTime(LocalDateTime.now());
-        this.updateById(auctionSalesroomGoods);
 
+        if (auctionSalesroomGoods==null){
+            throw new ServiceException("以没有待拍卖商品");
+        }
+
+        if(auctionSalesroomGoods!=null){
+            auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.IN_PROGRESS);
+            auctionSalesroomGoods.setStartTime(LocalDateTime.now());
+            this.updateById(auctionSalesroomGoods);
+        }
         Map<String, Object> map = new ConcurrentHashMap<>();
         map.put("notification_type", NotificationTypeConstant.AUCTION_SALESROOM);
         map.put("auctionSalesroomId", auctionSalesroom.getId());
+        map.put("AuctionTypeEnum",auctionSalesroom.getStatus());
         map.put("message_type", "start");
+        map.put("type", "1");
         String msg = null;
         try {
             msg = objectMapper.writeValueAsString(map);
         } catch (JsonProcessingException e) {
         }
-        WebSocketUsers.sendMessageToUsersByText(msg);
+        sysUserClient.pushAll(msg, SecurityConstants.INNER);
 
     }
 
@@ -328,11 +379,11 @@
             }
 
         }
-        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());
@@ -343,18 +394,26 @@
             orderAuctionBondDTO.setUserList(list);
             orderClient.getOrderAuctionBond(orderAuctionBondDTO,
                     SecurityConstants.INNER);
+        }else{
+            OrderAuctionBondDTO orderAuctionBondDTO=new OrderAuctionBondDTO();
+            orderAuctionBondDTO.setAuctionSalesroomId(auctionSalesroom.getId());
+            orderAuctionBondDTO.setUserList(list);
+            orderClient.getOrderAuctionBond(orderAuctionBondDTO,
+                    SecurityConstants.INNER);
         }
 
         Map<String, Object> map = new ConcurrentHashMap<>();
         map.put("notification_type", NotificationTypeConstant.AUCTION_SALESROOM);
+        map.put("AuctionTypeEnum",auctionSalesroom.getStatus());
         map.put("auctionSalesroomId", auctionSalesroom.getId());
         map.put("message_type", "end");
+        map.put("type", "1");
         String msg = null;
         try {
             msg = objectMapper.writeValueAsString(map);
         } catch (JsonProcessingException e) {
         }
-        WebSocketUsers.sendMessageToUsersByText(msg);
+        sysUserClient.pushAll(msg, SecurityConstants.INNER);
     }
 
 
@@ -365,7 +424,7 @@
     @Override
     public List<AuctionSalesroomGoods> isAuctionSalesroom(AuctionSalesroomDTO ationSalesroomGoodsDTO) {
         LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
-        wrapper2.eq(AuctionSalesroomGoods::getStatus,0);
+        wrapper2.eq(AuctionSalesroomGoods::getStatus,1);
         wrapper2.eq(AuctionSalesroomGoods::getDelFlag,0);
         wrapper2.eq(AuctionSalesroomGoods::getAuctionSalesroomId,ationSalesroomGoodsDTO.getAuctionSalesroomId());
         List<AuctionSalesroomGoods> auctionSalesroomGoods = this.list(wrapper2);
@@ -382,23 +441,33 @@
         LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
         wrapper2.eq(AuctionSalesroomGoods::getAuctionSalesroomId,auctionSalesroomGoodsDTO.getAuctionSalesroomId());
         wrapper2.eq(AuctionSalesroomGoods::getDelFlag,0);
-        wrapper2.eq(AuctionSalesroomGoods::getGoodsSkuId,auctionSalesroomGoodsDTO.getGoodsSkuId());
+        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<>();
+       Map<String, Object> map = new ConcurrentHashMap<>();
         map.put("notification_type", NotificationTypeConstant.AUCTION_SALESROOM_GOODS);
-        map.put("notification_time", LocalDateTime.now());
-        map.put("goodsSkuId", auctionSalesroomGoods.getId());
+        map.put("notification_time", DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:ss"));
+        map.put("goodsSkuId", auctionSalesroomGoods.getId().toString());
+        map.put("auctionSalesroomId", auctionSalesroomGoods.getAuctionSalesroomId().toString());
         map.put("message_type", "start");
+        map.put("type",2);
+        map.put("AuctionGoodsStatusEnum",auctionSalesroomGoods.getStatus());
         String msg = null;
         try {
             msg = objectMapper.writeValueAsString(map);
         } catch (JsonProcessingException e) {
             throw new RuntimeException(e);
         }
-        WebSocketUsers.sendMessageToUsersByText(msg);
+        sysUserClient.pushAll(msg, SecurityConstants.INNER);
     }
 
 
@@ -412,11 +481,10 @@
         LambdaQueryWrapper<AuctionSalesroomGoods> wrapper2=Wrappers.lambdaQuery();
         wrapper2.eq(AuctionSalesroomGoods::getAuctionSalesroomId,auctionSalesroomGoodsDTO.getAuctionSalesroomId());
         wrapper2.eq(AuctionSalesroomGoods::getDelFlag,0);
-        wrapper2.eq(AuctionSalesroomGoods::getGoodsSkuId,auctionSalesroomGoodsDTO.getGoodsSkuId());
-        AuctionSalesroomGoods auctionSalesroomGood=this.getOne(wrapper2);
-        AuctionSalesroom auctionSalesroom=iAuctionSalesroomService.getById(auctionSalesroomGood.getAuctionSalesroomId());
+        wrapper2.eq(AuctionSalesroomGoods::getId,auctionSalesroomGoodsDTO.getGoodsSkuId());
+        AuctionSalesroomGoods auctionSalesroomGoods=this.getOne(wrapper2);
+        AuctionSalesroom auctionSalesroom=iAuctionSalesroomService.getById(auctionSalesroomGoodsDTO.getAuctionSalesroomId());
 
-        AuctionSalesroomGoods auctionSalesroomGoods=this.getById(auctionSalesroomGoodsDTO.getGoodsSkuId());
         List<AuctionBidRecord> auctionBidRecordList=new ArrayList<>();
 
         if (auctionSalesroomGoods.getStatus().getCode()==1) {
@@ -429,9 +497,10 @@
             if(auctionBidRecordList.size()>0){
                 //判断
                 if (auctionBidRecordList.size() >= auctionSalesroomGoods.getSalesroomStock()) {
-                    for (int i = 0; i <= auctionSalesroomGoods.getSalesroomStock(); i++) {
+                    for (int i = 0; i < auctionSalesroomGoods.getSalesroomStock(); i++) {
                         AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
+                        auctionBidRecordMapper.updateById(auctionBidRecord);
                         AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
                                 auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                     }
@@ -443,37 +512,47 @@
                             SecurityConstants.INNER);
 
 
-                    for (int i = 0; i <= auctionBidRecordList.size(); i++) {
+                    for (int i = 0; i < auctionBidRecordList.size(); i++) {
                         AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                         auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
+                        auctionBidRecordMapper.updateById(auctionBidRecord);
                         AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
                                 auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                     }
                 }
             }
         }
+        auctionSalesroomGoods.setEndTime(LocalDateTime.now());
+        auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.ENDED);
+        this.updateById(auctionSalesroomGoods);
 
-        auctionSalesroomGood.setStatus(AuctionGoodsStatusEnum.ENDED);
-        this.updateById(auctionSalesroomGood);
-
-        Map<String, Object> map = new ConcurrentHashMap<>();
+       Map<String, Object> map = new ConcurrentHashMap<>();
         map.put("notification_type", NotificationTypeConstant.AUCTION_SALESROOM_GOODS);
-        map.put("notification_time", LocalDateTime.now());
-        map.put("goodsSkuId", auctionSalesroomGoods.getId());
+        map.put("notification_time", DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:ss"));
+        map.put("goodsSkuId", auctionSalesroomGoods.getId().toString());
+        map.put("auctionSalesroomId", auctionSalesroomGoods.getAuctionSalesroomId().toString());
         map.put("message_type", "end");
+        map.put("type",2);
+        map.put("AuctionGoodsStatusEnum",auctionSalesroomGoods.getStatus());
         String msg = null;
         try {
             msg = objectMapper.writeValueAsString(map);
         } catch (JsonProcessingException e) {
             throw new RuntimeException(e);
         }
-        WebSocketUsers.sendMessageToUsersByText(msg);
+        sysUserClient.pushAll(msg, SecurityConstants.INNER);
 
     }
 
     @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();
@@ -490,25 +569,38 @@
         AuctionSalesroomGoodsInfoVO.setUnit(goodsSku.getUnit());
         AuctionSalesroomGoodsInfoVO.setDescription(goodsSku.getDescription());
         AuctionSalesroomGoodsInfoVO.setDetail(goodsSku.getDetail());
+        AuctionSalesroomGoodsInfoVO.setSharePic(goodsSku.getSharePic());
+        AuctionSalesroomGoodsInfoVO.setShareTitle(goodsSku.getShareTitle());
         AuctionSalesroomGoodsInfoVO.setYears(String.valueOf(goodsSku.getYears().getYear()));
         GoodsBrand data = goodsSkuClient.getBrandOne(goodsSku.getBrandId(), SecurityConstants.INNER).getData();
         GoodsCategory data1 = goodsSkuClient.getCategoryOne(goodsSku.getCategoryId(), SecurityConstants.INNER).getData();
         GoodsSeries data2 = goodsSkuClient.getSeriesOne(goodsSku.getSeriesId(), SecurityConstants.INNER).getData();
         GoodsFlavorType data3 = goodsSkuClient.getFlavorTypeOne(goodsSku.getFlavorTypeId(), SecurityConstants.INNER).getData();
-        AuctionSalesroomGoodsInfoVO.setBrand(data.getBrandName());
+        if(data!=null){
+            AuctionSalesroomGoodsInfoVO.setBrand(data.getBrandName());
+        }
+        if(data1!=null){
         AuctionSalesroomGoodsInfoVO.setCategory(data1.getCategoryName());
+        }
+            if(data2!=null){
         AuctionSalesroomGoodsInfoVO.setSeries(data2.getSeriesName());
+            }
+                if(data3!=null){
         AuctionSalesroomGoodsInfoVO.setFlavorType(data3.getFlavorTypeName());
+                }
         AuctionSalesroomGoodsInfoVO.setCoverPic(goodsSku.getCoverPic());
         AuctionSalesroomGoodsInfoVO.setAlbum(goodsSku.getAlbum());
         AuctionSalesroomGoodsInfoVO.setSpec(goodsSku.getSpec());
         AuctionSalesroomGoodsInfoVO.setSpecUnit(goodsSku.getSpecUnit());
+
+        CustomConfig returnAddressUserName = sysUserClient.getconfig("MALL_ORDER_DESCRIPTION").getData();
+        AuctionSalesroomGoodsInfoVO.setExplain(returnAddressUserName.getConfigValue());
         AuctionSalesroomGoodsInfoVO.setMinimumMarkupAmount(byId1.getMinimumMarkupAmount());
         LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery();
-        wrapper1.eq(AuctionBidRecord::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
         wrapper1.eq(AuctionBidRecord::getAuctionSalesroomId,byId.getId());
         wrapper1.eq(AuctionBidRecord::getAuctionType,2);
         wrapper1.eq(AuctionBidRecord::getTargetId,byId1.getId());
+        wrapper1.eq(AuctionBidRecord::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
         wrapper1.eq(AuctionBidRecord::getDelFlag,0);
         AuctionBidRecord list1 = auctionBidRecordMapper.selectOne(wrapper1);
         if (list1!=null){
@@ -516,6 +608,15 @@
             AuctionSalesroomGoodsInfoVO.setPresentBid(list1.getLastBidAmount());
             if (list1.getStatus().getCode()==2){
                 AuctionSalesroomGoodsInfoVO.setIsStatus(2);
+                OrderDTO orderDTO =new OrderDTO();
+                orderDTO.setMemberId(auctionSalesroomGoodsInfoDTO.getMemberId());
+                orderDTO.setGoodsSkuId(byId1.getId());
+                Order data4 = orderClient.getOrderOne(orderDTO, SecurityConstants.INNER).getData();
+                if (data4!=null){
+                    AuctionSalesroomGoodsInfoVO.setOrderId(data4.getId());
+                    AuctionSalesroomGoodsInfoVO.setOrderNo(data4.getOrderNo());
+                }
+
             }else{
                 AuctionSalesroomGoodsInfoVO.setIsStatus(1);
             }
@@ -524,13 +625,49 @@
             AuctionSalesroomGoodsInfoVO.setIsStatus(1);
         }
 
+        LambdaQueryWrapper<AuctionBidRecord> wrapper2=Wrappers.lambdaQuery();
+        wrapper2.eq(AuctionBidRecord::getAuctionSalesroomId,byId.getId());
+        wrapper2.eq(AuctionBidRecord::getAuctionType,2);
+        wrapper2.eq(AuctionBidRecord::getTargetId,byId1.getId());
+        wrapper2.eq(AuctionBidRecord::getDelFlag,0);
+        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();
+       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;
     }
 
     @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);
@@ -542,38 +679,56 @@
             auctionBidRecordVO.setSort(i+1);
             auctionBidRecordVO.setLastBidAmount(auctionBidRecordList.get(i).getLastBidAmount());
             auctionBidRecordVO.setLastBidTime(auctionBidRecordList.get(i).getLastBidTime());
-            Member data = emberClient.getMembeOne(auctionBidRecordList.get(i).getMemberId(),
-                    SecurityConstants.INNER).getData();
-            auctionBidRecordVO.setMemberName(data.getNickname());
-            auctionBidRecordVO.setMemberId(data.getId());
+            auctionBidRecordVO.setMemberName(auctionBidRecordList.get(i).getNickname());
+            auctionBidRecordVO.setMemberId(auctionBidRecordList.get(i).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());
+            wrapper3.eq(AuctionBidRecord::getDelFlag,0);
+            wrapper3.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
+            wrapper3.le(AuctionBidRecord::getId,auctionBidRecord.getId());
+            wrapper3.orderByDesc(AuctionBidRecord::getLastBidAmount);
+            Long count = auctionBidRecordMapper.selectCount(wrapper);
+            if (count>0){
+                AuctionBidRecordVO auctionBidRecordVO=new AuctionBidRecordVO();
+                auctionBidRecordVO.setSort(Integer.valueOf(count.intValue()));
+                auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount());
+                auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime());
+                Member data = emberClient.getMembeOne(auctionBidRecord.getMemberId(),
+                        SecurityConstants.INNER).getData();
+                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);
+                }
 
-        LambdaQueryWrapper<AuctionBidRecord> wrapper3=Wrappers.lambdaQuery();
-        wrapper3.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
-        wrapper3.eq(AuctionBidRecord::getDelFlag,0);
-        wrapper3.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
-        wrapper3.le(AuctionBidRecord::getId,auctionBidRecord.getId());
-        wrapper3.orderByDesc(AuctionBidRecord::getLastBidAmount);
-        Long count = auctionBidRecordMapper.selectCount(wrapper);
-        if (count>0){
-            AuctionBidRecordVO auctionBidRecordVO=new AuctionBidRecordVO();
-            auctionBidRecordVO.setSort(Integer.valueOf(count.intValue()));
-            auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount());
-            auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime());
-            Member data = emberClient.getMembeOne(auctionBidRecord.getMemberId(),
-                    SecurityConstants.INNER).getData();
-            auctionBidRecordVO.setMemberName(data.getNickname());
-            auctionBidRecordVO.setMemberId(data.getId());
-            auctionBidRecordVOList.add(auctionBidRecordVO);
+            }
         }
+
         return auctionBidRecordVOList;
     }
 
@@ -594,18 +749,26 @@
                 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.intValue()>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);
+        }
 
 
-        order.setReceiverCity(memberAddress.getCity());
-        order.setReceiverDetailAddress(memberAddress.getDetailedAddress());
-        order.setReceiverphone(memberAddress.getRecipientPhone());
-        order.setReceiverName(memberAddress.getRecipientName());
+        if (memberAddress!=null){
+            order.setReceiverCity(memberAddress.getCity());
+            order.setReceiverDetailAddress(memberAddress.getDetailedAddress());
+            order.setReceiverphone(memberAddress.getRecipientPhone());
+            order.setReceiverName(memberAddress.getRecipientName());
+        }
+
         order.setBound(bound);
         order.setAuctionType(AuctionOrderTypeEnum.AUCTION_ITEMS);
         GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(auctionSalesroomGoods.getGoodsSkuId(), SecurityConstants.INNER)

--
Gitblit v1.7.1