From 9bcc40d213a44498c46dae5e678e592b918b40b0 Mon Sep 17 00:00:00 2001
From: rentaiming <806181062@qq.com>
Date: 星期四, 30 五月 2024 18:33:54 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java |   90 +++++++++++++++++++++++++++++++++++++++------
 1 files changed, 78 insertions(+), 12 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 a6141a7..19f8e55 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,12 +6,11 @@
 import com.ruoyi.auction.controller.forepart.dto.AuctionSalesroomGoodsDTO;
 import com.ruoyi.auction.controller.forepart.dto.AuctionSalesroomGoodsInfoDTO;
 import com.ruoyi.auction.controller.forepart.dto.OrderDTO;
+import com.ruoyi.auction.controller.forepart.vo.AuctionBidRecordVO;
 import com.ruoyi.auction.controller.forepart.vo.AuctionSalesroomGoodsInfoVO;
 import com.ruoyi.auction.controller.forepart.vo.AuctionSalesroomVO;
 import com.ruoyi.auction.controller.forepart.vo.ForepartAuctionSalesroomGoodsVO;
-import com.ruoyi.auction.controller.forepart.vo.MemberAuctionSalesroomInfoVO;
 import com.ruoyi.auction.domain.AuctionBidRecord;
-import com.ruoyi.auction.domain.AuctionSalesroom;
 import com.ruoyi.auction.domain.AuctionSalesroomGoods;
 import com.ruoyi.auction.mapper.AuctionSalesroomGoodsMapper;
 import com.ruoyi.auction.service.IAuctionBidRecordService;
@@ -23,7 +22,13 @@
 import com.ruoyi.common.core.enums.AuctionStartStatusEnum;
 import com.ruoyi.common.core.enums.BidStatusEnum;
 import com.ruoyi.common.core.enums.OrderFromEnum;
+import com.ruoyi.system.api.domain.AuctionSalesroom;
+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.dto.OrderAuctionBondDTO;
 import com.ruoyi.system.api.feignClient.GoodsSkuClient;
@@ -116,6 +121,8 @@
         forepartAuctionSalesroomGoodsVO.setCoverPic(goodsSku.getCoverPic());
         forepartAuctionSalesroomGoodsVO.setDescription(goodsSku.getDescription());
         forepartAuctionSalesroomGoodsVO.setUnit(goodsSku.getUnit());
+        forepartAuctionSalesroomGoodsVO.setSpec(goodsSku.getSpec());
+        forepartAuctionSalesroomGoodsVO.setSpecUnit(goodsSku.getSpecUnit());
         if (auctionSalesroomGoods.getStatus().getCode()==0 || auctionSalesroomGoods.getStatus().getCode()==2){
             LambdaQueryWrapper<AuctionSalesroomGoods> wrapper1=Wrappers.lambdaQuery();
             wrapper1.eq(AuctionSalesroomGoods::getDelFlag,0);
@@ -234,7 +241,6 @@
      */
     @Override
     public void auctionSalesroomStart(AuctionSalesroomGoodsDTO ationSalesroomGoodsDTO) {
-        ForepartAuctionSalesroomGoodsVO forepartAuctionSalesroomGoodsVO =new ForepartAuctionSalesroomGoodsVO();
         AuctionSalesroom auctionSalesroom=iAuctionSalesroomService.getById(ationSalesroomGoodsDTO.getAuctionSalesroomId());
         auctionSalesroom.setStatus(AuctionStartStatusEnum.IN_AUCTION);
         auctionSalesroom.setStartTime(LocalDateTime.now());
@@ -259,7 +265,6 @@
      */
     @Override
     public void auctionSalesroomEnd(AuctionSalesroomGoodsDTO ationSalesroomGoodsDTO) {
-        ForepartAuctionSalesroomGoodsVO forepartAuctionSalesroomGoodsVO =new ForepartAuctionSalesroomGoodsVO();
         AuctionSalesroom auctionSalesroom=iAuctionSalesroomService.getById(ationSalesroomGoodsDTO.getAuctionSalesroomId());
         auctionSalesroom.setStatus(AuctionStartStatusEnum.ENDED);
         auctionSalesroom.setEndTime(LocalDateTime.now());
@@ -347,7 +352,7 @@
 
         if (auctionSalesroomGoods.getStatus().getCode()==1) {
             LambdaQueryWrapper<AuctionBidRecord> wrapper = Wrappers.lambdaQuery();
-            wrapper.eq(AuctionBidRecord::getGoodsSkuId, auctionSalesroomGoodsDTO.getGoodsSkuId());
+            wrapper.eq(AuctionBidRecord::getTargetId, auctionSalesroomGoodsDTO.getGoodsSkuId());
             wrapper.eq(AuctionBidRecord::getDelFlag, 0);
             wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
             auctionBidRecordList = iAuctionBidRecordService.list(wrapper);
@@ -356,13 +361,15 @@
                 for (int i = 0; i <= auctionSalesroomGoods.getSalesroomStock(); i++) {
                     AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                     auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
-                    AddOrder(auctionBidRecord.getGoodsSkuId(),auctionBidRecord.getMemberId(),auctionBidRecord.getLastBidAmount(),auctionSalesroom.getBound());
+                    AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
+                            auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                 }
             } else {
                 for (int i = 0; i <= auctionBidRecordList.size(); i++) {
                     AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                     auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
-                    AddOrder(auctionBidRecord.getGoodsSkuId(),auctionBidRecord.getMemberId(),auctionBidRecord.getLastBidAmount(),auctionSalesroom.getBound());
+                    AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(),
+                            auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond());
                 }
             }
         }
@@ -391,16 +398,24 @@
         AuctionSalesroomGoodsInfoVO.setUnit(goodsSku.getUnit());
         AuctionSalesroomGoodsInfoVO.setDescription(goodsSku.getDescription());
         AuctionSalesroomGoodsInfoVO.setYears(goodsSku.getYears());
-
-
-
-
+        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());
+        AuctionSalesroomGoodsInfoVO.setCategory(data1.getCategoryName());
+        AuctionSalesroomGoodsInfoVO.setSeries(data2.getSeriesName());
+        AuctionSalesroomGoodsInfoVO.setFlavorType(data3.getFlavorTypeName());
         AuctionSalesroomGoodsInfoVO.setCoverPic(goodsSku.getCoverPic());
         AuctionSalesroomGoodsInfoVO.setAlbum(goodsSku.getAlbum());
+        AuctionSalesroomGoodsInfoVO.setSpec(goodsSku.getSpec());
+        AuctionSalesroomGoodsInfoVO.setSpecUnit(goodsSku.getSpecUnit());
+        AuctionSalesroomGoodsInfoVO.setMinimumMarkupAmount(byId1.getMinimumMarkupAmount());
         LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery();
         wrapper1.eq(AuctionBidRecord::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
         wrapper1.eq(AuctionBidRecord::getAuctionSalesroomId,byId.getId());
-        wrapper1.eq(AuctionBidRecord::getGoodsSkuId,byId1.getId());
+        wrapper1.eq(AuctionBidRecord::getAuctionType,2);
+        wrapper1.eq(AuctionBidRecord::getTargetId,byId1.getId());
         wrapper1.eq(AuctionBidRecord::getDelFlag,0);
         AuctionBidRecord list1 = auctionBidRecordService.getOne(wrapper1);
         if (list1!=null){
@@ -415,9 +430,60 @@
             AuctionSalesroomGoodsInfoVO.setIsBond(1);
             AuctionSalesroomGoodsInfoVO.setIsStatus(1);
         }
+
         return AuctionSalesroomGoodsInfoVO;
     }
 
+    @Override
+    public List<AuctionBidRecordVO> getAuctionBidRecord(AuctionSalesroomGoodsInfoDTO auctionSalesroomGoodsInfoDTO) {
+        LambdaQueryWrapper<AuctionBidRecord> wrapper=Wrappers.lambdaQuery();
+        wrapper.eq(AuctionBidRecord::getAuctionSalesroomId,auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        wrapper.eq(AuctionBidRecord::getDelFlag,0);
+        wrapper.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
+        wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
+        wrapper.last("limit 10");
+        List<AuctionBidRecord> auctionBidRecordList=auctionBidRecordService.list(wrapper);
+        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());
+            Member data = emberClient.getMembeOne(auctionBidRecordList.get(i).getMemberId(),
+                    SecurityConstants.INNER).getData();
+            auctionBidRecordVO.setMemberName(data.getNickname());
+            auctionBidRecordVO.setMemberId(data.getId());
+            auctionBidRecordVOList.add(auctionBidRecordVO);
+        }
+        LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery();
+        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=auctionBidRecordService.getOne(wrapper);
+
+        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=auctionBidRecordService.count(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;
+    }
+
 
     public void AddOrder(Long goodsSkuId, Long memberId, BigDecimal lastBidAmount,BigDecimal bound) {
         OrderDTO order=new OrderDTO();

--
Gitblit v1.7.1