From 885a5836eb0fc1d7fcf54fbdb5f1969b9238a18c Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期四, 30 五月 2024 09:13:12 +0800
Subject: [PATCH] 解决冲突

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java |  121 +++++++++++++++++++++++++++++++++++++--
 1 files changed, 113 insertions(+), 8 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 6c10075..5ff06a1 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
@@ -4,11 +4,11 @@
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 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.AuctionSalesroomVO;
-import com.ruoyi.auction.controller.forepart.vo.ForepartAuctionSalesroomGoodsVO;
+import com.ruoyi.auction.controller.forepart.vo.*;
 import com.ruoyi.auction.domain.AuctionBidRecord;
-import com.ruoyi.auction.domain.AuctionSalesroom;
+import com.ruoyi.system.api.domain.AuctionSalesroom;
 import com.ruoyi.auction.domain.AuctionSalesroomGoods;
 import com.ruoyi.auction.mapper.AuctionSalesroomGoodsMapper;
 import com.ruoyi.auction.service.IAuctionBidRecordService;
@@ -20,8 +20,7 @@
 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.GoodsSku;
-import com.ruoyi.system.api.domain.MemberAddress;
+import com.ruoyi.system.api.domain.*;
 import com.ruoyi.system.api.domain.dto.OrderAuctionBondDTO;
 import com.ruoyi.system.api.feignClient.GoodsSkuClient;
 import com.ruoyi.system.api.feignClient.MemberClient;
@@ -60,6 +59,11 @@
 
     @Resource
     private OrderClient orderClient;
+
+    @Resource
+    private IAuctionBidRecordService auctionBidRecordService;
+
+
 
 
     /**
@@ -339,7 +343,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);
@@ -348,13 +352,13 @@
                 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.getBound());
                 }
             } 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.getBound());
                 }
             }
         }
@@ -364,6 +368,107 @@
 
     }
 
+    @Override
+    public AuctionSalesroomGoodsInfoVO getAuctionSalesroomGoodsInfo(AuctionSalesroomGoodsInfoDTO auctionSalesroomGoodsInfoDTO) {
+        AuctionSalesroom byId = iAuctionSalesroomService.getById(auctionSalesroomGoodsInfoDTO.getAuctionSalesroomId());
+        AuctionSalesroomGoods byId1 = iAuctionSalesroomGoodsService.getById(auctionSalesroomGoodsInfoDTO.getGoodsSkuId());
+        GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(byId1.getGoodsSkuId(), SecurityConstants.INNER).getData();
+        AuctionSalesroomGoodsInfoVO AuctionSalesroomGoodsInfoVO=new AuctionSalesroomGoodsInfoVO();
+        AuctionSalesroomGoodsInfoVO.setSalesroomId(byId.getId());
+        AuctionSalesroomGoodsInfoVO.setSalesroomName(byId.getSalesroomName());
+        AuctionSalesroomGoodsInfoVO.setGoodsSkuId(byId1.getId());
+        AuctionSalesroomGoodsInfoVO.setGoodsSkuName(goodsSku.getSkuName());
+        AuctionSalesroomGoodsInfoVO.setStartingPrice(byId1.getStartingPrice());
+        AuctionSalesroomGoodsInfoVO.setSalesroomStock(byId1.getSalesroomStock());
+        AuctionSalesroomGoodsInfoVO.setSalesroomType(byId.getType().getCode());
+        AuctionSalesroomGoodsInfoVO.setGoodsSkustatus(byId1.getStatus().getCode());
+        AuctionSalesroomGoodsInfoVO.setListingDuration(byId1.getListingDuration());
+        AuctionSalesroomGoodsInfoVO.setStartTime(byId1.getStartTime());
+        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.setMinimumMarkupAmount(byId1.getMinimumMarkupAmount());
+        LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery();
+        wrapper1.eq(AuctionBidRecord::getMemberId,auctionSalesroomGoodsInfoDTO.getMemberId());
+        wrapper1.eq(AuctionBidRecord::getAuctionSalesroomId,byId.getId());
+        wrapper1.eq(AuctionBidRecord::getTargetId,byId1.getId());
+        wrapper1.eq(AuctionBidRecord::getDelFlag,0);
+        AuctionBidRecord list1 = auctionBidRecordService.getOne(wrapper1);
+        if (list1!=null){
+            AuctionSalesroomGoodsInfoVO.setIsBond(2);
+            AuctionSalesroomGoodsInfoVO.setPresentBid(list1.getLastBidAmount());
+            if (list1.getStatus().getCode()==2){
+                AuctionSalesroomGoodsInfoVO.setIsStatus(2);
+            }else{
+                AuctionSalesroomGoodsInfoVO.setIsStatus(1);
+            }
+        }else{
+            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