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/AuctionBidRecordServiceImpl.java |   65 +++++++++++++++++++++++++++++++-
 1 files changed, 62 insertions(+), 3 deletions(-)

diff --git a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionBidRecordServiceImpl.java b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionBidRecordServiceImpl.java
index 84cbbb9..012b9fe 100644
--- a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionBidRecordServiceImpl.java
+++ b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionBidRecordServiceImpl.java
@@ -1,9 +1,19 @@
 package com.ruoyi.auction.service.impl;
 
-import com.ruoyi.auction.domain.pojo.AuctionBidRecord;
-import com.ruoyi.auction.mapper.AuctionBidRecordMapper;
-import com.ruoyi.auction.service.IAuctionBidRecordService;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.system.api.domain.dto.AuctionSalesroomDTO;
+import com.ruoyi.auction.domain.AuctionBidRecord;
+import com.ruoyi.auction.domain.AuctionSalesroomGoods;
+import com.ruoyi.auction.mapper.AuctionBidRecordMapper;
+import com.ruoyi.auction.mapper.AuctionSalesroomGoodsMapper;
+import com.ruoyi.auction.service.IAuctionBidRecordService;
+import com.ruoyi.common.core.enums.AuctionOrderTypeEnum;
+import com.ruoyi.common.core.enums.BidStatusEnum;
+import java.util.ArrayList;
+import java.util.List;
+import javax.annotation.Resource;
 import org.springframework.stereotype.Service;
 
 /**
@@ -17,4 +27,53 @@
 @Service
 public class AuctionBidRecordServiceImpl extends ServiceImpl<AuctionBidRecordMapper, AuctionBidRecord> implements IAuctionBidRecordService {
 
+    @Resource
+    private AuctionSalesroomGoodsMapper auctionSalesroomGoodsMapper;
+
+    @Override
+    public List<AuctionBidRecord> getAuctionBidRecordList(AuctionSalesroomDTO auctionSalesroomGoodsDTO) {
+        AuctionSalesroomGoods auctionSalesroomGoods = auctionSalesroomGoodsMapper.selectById(
+                auctionSalesroomGoodsDTO.getGoodsSkuId());
+            List<AuctionBidRecord> auctionBidRecordList=new ArrayList<>();
+            if (auctionSalesroomGoods.getStatus().getCode()==1){
+                LambdaQueryWrapper<AuctionBidRecord> wrapper=Wrappers.lambdaQuery();
+                wrapper.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsDTO.getGoodsSkuId());
+                wrapper.eq(AuctionBidRecord::getDelFlag,0);
+                wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
+                auctionBidRecordList = this.list(wrapper);
+                //判断
+                if (auctionBidRecordList.size()>=auctionSalesroomGoods.getSalesroomStock()){
+                    for (int i=0;i<auctionSalesroomGoods.getSalesroomStock();i++){
+                        AuctionBidRecord auctionBidRecord= auctionBidRecordList.get(i);
+                        auctionBidRecord.setStatus(BidStatusEnum.LEAD);
+                    }
+                }else{
+                    if (auctionBidRecordList.size()>0){
+                        for (int i=0;i<auctionBidRecordList.size();i++){
+                            AuctionBidRecord auctionBidRecord= auctionBidRecordList.get(i);
+                            auctionBidRecord.setStatus(BidStatusEnum.LEAD);
+                        }
+                    }
+
+                }
+            }if (auctionSalesroomGoods.getStatus().getCode()==2){
+                LambdaQueryWrapper<AuctionBidRecord> wrapper=Wrappers.lambdaQuery();
+                wrapper.eq(AuctionBidRecord::getTargetId,auctionSalesroomGoodsDTO.getGoodsSkuId());
+                wrapper.eq(AuctionBidRecord::getStatus,2);
+                wrapper.eq(AuctionBidRecord::getDelFlag,0);
+                wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount);
+                auctionBidRecordList = this.list(wrapper);
+            }
+            return auctionBidRecordList;
+
+
+    }
+
+    @Override
+    public List<AuctionBidRecord> getBidRecordByGoodsId(Long id) {
+        return this.lambdaQuery().eq(AuctionBidRecord::getTargetId, id)
+                .eq(AuctionBidRecord::getAuctionType,
+                        AuctionOrderTypeEnum.REGULAR_ITEMS)
+                .orderByDesc(AuctionBidRecord::getLastBidAmount).list();
+    }
 }

--
Gitblit v1.7.1