From 20b8e50ddb2daf21d65a43ec363e5925edb5b10e Mon Sep 17 00:00:00 2001
From: rentaiming <806181062@qq.com>
Date: 星期三, 31 七月 2024 18:40:34 +0800
Subject: [PATCH] 修改bug

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomServiceImpl.java |  112 +++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 79 insertions(+), 33 deletions(-)

diff --git a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomServiceImpl.java b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomServiceImpl.java
index a51b10a..236c277 100644
--- a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomServiceImpl.java
+++ b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomServiceImpl.java
@@ -25,10 +25,11 @@
 import com.ruoyi.auction.controller.management.vo.MgtAuctionSalesroomScreenVO;
 import com.ruoyi.auction.controller.management.vo.MgtAuctionSalesroomVO;
 import com.ruoyi.auction.domain.AuctionBidRecord;
+import com.ruoyi.auction.domain.AuctionBondJl;
 import com.ruoyi.auction.domain.AuctionBrowseRecord;
-import com.ruoyi.auction.domain.AuctionSalesroomGoods;
 import com.ruoyi.auction.domain.AuctionVideo;
 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.IAuctionBidRecordService;
@@ -62,6 +63,7 @@
 import com.ruoyi.system.api.domain.AppMiniLoginVO;
 import com.ruoyi.system.api.domain.AuctionGoods;
 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.GoodsSku;
 import com.ruoyi.system.api.domain.Member;
@@ -168,6 +170,9 @@
     private AuctionBidRecordMapper auctionBidRecordMapper;
 
     @Resource
+    private AuctionBondJlMapper auctionBondJlMapper;
+
+    @Resource
     private RemoteFileService remoteFileService;
     public static RequestConfig config = RequestConfig.custom().setConnectTimeout(5000).setSocketTimeout(5000).build();
     // 配置您申请的KEY,在个人中心->我的数据,接口名称上方查看
@@ -243,12 +248,12 @@
 
     @Override
     public AuctionSalesroom getAuctionBidRecordOne(ForepartAuctionBidRecordDTO arepartAuctionBidRecordDTO) {
-        R<SysUser> r=sysUserClient.queryUserByPhone(arepartAuctionBidRecordDTO.getPhone());
+        R<SysUser> r=sysUserClient.queryUserByPhone1(arepartAuctionBidRecordDTO.getPhone());
         SysUser sysUser=r.getData();
         if (sysUser==null){
             throw new ServiceException("手机号未注册");
         }
-        if (sysUser.getStatus().equals(1)){
+        if (sysUser.getStatus().equals("1")){
             throw new ServiceException("该拍卖师账号停用");
         }
 
@@ -401,17 +406,25 @@
             memberAuctionSalesroomVO.setBond(auctionSalesroom.getBond());
             memberAuctionSalesroomVO.setAuthentication(auctionSalesroom.getAuthentication());
             memberAuctionSalesroomDTO.setAuctionSalesroomId(auctionSalesroom.getId());
-            List<OrderAuctionBond> data = orderClient.getOrderAuctionBondList1(memberAuctionSalesroomDTO, SecurityConstants.INNER).getData();
-            if (data!=null&&data.size()>0){
+
+            LambdaQueryWrapper<AuctionBondJl> wrapper=Wrappers.lambdaQuery();
+            wrapper.eq(AuctionBondJl::getAuctionSalesroomId,auctionSalesroom.getId());
+            wrapper.eq(AuctionBondJl::getMemberId,memberAuctionSalesroomDTO.getMemberId());
+            wrapper.eq(AuctionBondJl::getIsState,0);
+            AuctionBondJl auctionBondJl = auctionBondJlMapper.selectOne(wrapper);
+
+            if (auctionBondJl!=null){
                memberAuctionSalesroomVO.setIsApply(2);
            }else{
                memberAuctionSalesroomVO.setIsApply(1);
            }
-            MemberAuctionSalesroomDTO memberAuctionSalesroomDTO1=new MemberAuctionSalesroomDTO();
-            memberAuctionSalesroomDTO1.setAuctionSalesroomId(auctionSalesroom.getId());
-            List<OrderAuctionBond> data1 = orderClient.getOrderAuctionBondList1(memberAuctionSalesroomDTO1, SecurityConstants.INNER).getData();
-            if(data1!=null){
-                memberAuctionSalesroomVO.setApplyNum(data1.size());
+            LambdaQueryWrapper<AuctionBondJl> wrapper1=Wrappers.lambdaQuery();
+            wrapper1.eq(AuctionBondJl::getAuctionSalesroomId,auctionSalesroom.getId());
+            wrapper1.eq(AuctionBondJl::getBondType,2);
+            wrapper1.eq(AuctionBondJl::getIsState,0);
+            java.util.List<AuctionBondJl> auctionBondJls = auctionBondJlMapper.selectList(wrapper1);
+            if(auctionBondJls!=null){
+                memberAuctionSalesroomVO.setApplyNum(auctionBondJls.size());
 
             }else{
                 memberAuctionSalesroomVO.setApplyNum(0);
@@ -452,8 +465,12 @@
         memberAuctionSalesroomInfoVO.setStatus(byId.getStatus());
         memberAuctionSalesroomInfoVO.setCoverPic(byId.getCoverPic());
 
-        List<OrderAuctionBond> data = orderClient.getOrderAuctionBondList1(memberAuctionSalesroomDTO, SecurityConstants.INNER).getData();
-        if (data.size()>0){
+        LambdaQueryWrapper<AuctionBondJl> wrapper=Wrappers.lambdaQuery();
+        wrapper.eq(AuctionBondJl::getAuctionSalesroomId,byId.getId());
+        wrapper.eq(AuctionBondJl::getMemberId,memberAuctionSalesroomDTO.getMemberId());
+        wrapper.eq(AuctionBondJl::getIsState,0);
+        AuctionBondJl auctionBondJl = auctionBondJlMapper.selectOne(wrapper);
+        if (auctionBondJl!=null){
             memberAuctionSalesroomInfoVO.setIsApply(2);
         }else{
             memberAuctionSalesroomInfoVO.setIsApply(1);
@@ -533,14 +550,15 @@
         wrapper3.eq(AuctionBrowseRecord::getTargetId,memberAuctionSalesroomDTO.getAuctionSalesroomId());
         wrapper3.eq(AuctionBrowseRecord::getBrowseType,AuctionOrderTypeEnum.AUCTION_ITEMS);
         wrapper3.eq(AuctionBrowseRecord::getMemberId,memberAuctionSalesroomDTO.getMemberId());
-        wrapper3.ge(AuctionBrowseRecord::getCreateTime, now)
-                .le(AuctionBrowseRecord::getCreateTime, newTime7);
+        wrapper3.ge(AuctionBrowseRecord::getCreateTime, newTime7)
+                .le(AuctionBrowseRecord::getCreateTime, now);
         List<AuctionBrowseRecord> list = iAuctionBrowseRecordService.list(wrapper3);
         if (list.size()==0){
             AuctionBrowseRecord auctionBrowseRecord=new AuctionBrowseRecord();
             auctionBrowseRecord.setBrowseType(AuctionOrderTypeEnum.AUCTION_ITEMS);
             auctionBrowseRecord.setMemberId(memberAuctionSalesroomDTO.getMemberId());
             auctionBrowseRecord.setTargetId(memberAuctionSalesroomDTO.getAuctionSalesroomId());
+            auctionBrowseRecord.setSkuName(byId.getSalesroomName());
             iAuctionBrowseRecordService.save(auctionBrowseRecord);
         }
 
@@ -1027,9 +1045,7 @@
         Set<Long> goodsSkuIdList = null;
         goodsSkuIdList = data.stream().map(OrderAuctionBond::getAuctionSalesroomId)
                     .collect(Collectors.toSet());
-        Page<AuctionSalesroom> page = new Page<>();
-        page.setSize(memberAuctionSalesroomDTO.getPageSize());
-        page.setCurrent(memberAuctionSalesroomDTO.getPageCurr());
+
        /* MemberAuctionSalesroomWdDTO memberAuctionSalesroomWdDTO=new MemberAuctionSalesroomWdDTO();
         if (goodsSkuIdList.size()>0){
             memberAuctionSalesroomWdDTO.setGoodsSkuIdList(goodsSkuIdList);
@@ -1048,6 +1064,9 @@
 
         }*/
 
+        Page<AuctionSalesroom> page = new Page<>();
+        page.setSize(memberAuctionSalesroomDTO.getPageSize());
+        page.setCurrent(memberAuctionSalesroomDTO.getPageCurr());
         LambdaQueryWrapper<AuctionSalesroom> wrapper1=Wrappers.lambdaQuery();
         if (goodsSkuIdList.size()>0){
             wrapper1.in(AuctionSalesroom::getId,goodsSkuIdList);
@@ -1068,7 +1087,7 @@
                 "        WHEN status = 0 THEN 2\n" +
                 "        WHEN status = 1 THEN 1\n" +
                 "        WHEN status = 2 THEN 3\n" +
-                "        END,status");
+                "        END,status asc ");
 
         Page<AuctionSalesroom> auctionSalesroomList=this.page(page,wrapper1);
         PageDTO<WdMemberAuctionSalesroomVO> wdMemberAuctionSalesroomVOPageDTO = PageDTO.of(auctionSalesroomList, WdMemberAuctionSalesroomVO.class);
@@ -1078,6 +1097,7 @@
             MemberAuctionSalesroomDTO memberAuctionSalesroomDTO1=new MemberAuctionSalesroomDTO();
             memberAuctionSalesroomDTO1.setAuctionSalesroomId(auctionSalesroom.getId());
             memberAuctionSalesroomDTO1.setMemberId(MemberAuctionSalesroomDTO.getMemberId());
+            auctionSalesroom.setIsBond(2);
             List<OrderAuctionBond> data1 = orderClient.getOrderAuctionBondList1(memberAuctionSalesroomDTO1, SecurityConstants.INNER).getData();
             if (data1.size()>0){
                 auctionSalesroom.setBondTime(data1.get(0).getCreateTime());
@@ -1209,7 +1229,7 @@
                 .between(StringUtils.isNotNull(query.getStartTime()) && StringUtils.isNotNull(
                                 query.getEndTime()), AuctionSalesroom::getStartTime, query.getStartTime(),
                         query.getEndTime())
-                .orderByAsc(AuctionSalesroom::getCreateTime)
+                .orderByDesc(AuctionSalesroom::getCreateTime)
                 .page(new Page<>(query.getPageCurr(), query.getPageSize()));
         List<AuctionSalesroom> records = page.getRecords();
         if (StringUtils.isNull(records)) {
@@ -1255,7 +1275,7 @@
                 vo.setAuctionSalesroomGoodsVOS(collect);
                 if (StringUtils.isNotNull(vo.getCurrentAuctionSalesroomGoods())) {
                     int index = collect.indexOf(vo.getCurrentAuctionSalesroomGoods());
-                    if (collect.size() > 1) {
+                    if (collect.size() > 1 && index < collect.size() - 1) {
                         vo.setNextAuctionSalesroomGoods(collect.get(index + 1));
                     }
                     // 分页查询当前拍品出价信息
@@ -1370,8 +1390,8 @@
     public PageDTO<MgtAuctionSalesroomGoodsVO> backupGoods(MgtAuctionSalesroomGoodsQuery query) {
         Page<AuctionSalesroomGoods> page = new Page<>(query.getPageCurr(), query.getPageSize());
         Set<Long> goodsSkuIdSet = null;
-        if (StringUtils.isNotBlank(query.getGoodsName())) {
-            List<GoodsSku> data = goodsSkuClient.getGoodsByName(query.getGoodsName(),
+        if (StringUtils.isNotBlank(query.getGoodsSkuName())) {
+            List<GoodsSku> data = goodsSkuClient.getGoodsByName(query.getGoodsSkuName(),
                     SecurityConstants.INNER).getData();
             if (StringUtils.isNotEmpty(data)) {
                 goodsSkuIdSet = data.stream().map(GoodsSku::getId)
@@ -1446,7 +1466,7 @@
                 Wrappers.lambdaQuery(AuctionBidRecord.class)
                         .eq(AuctionBidRecord::getAuctionSalesroomId,
                                 auctionSalesroomGoods.getAuctionSalesroomId())
-                        .eq(AuctionBidRecord::getTargetId, auctionSalesroomGoods.getGoodsSkuId())
+                        .eq(AuctionBidRecord::getTargetId, auctionSalesroomGoods.getId())
                         .eq(AuctionBidRecord::getAuctionType, AuctionOrderTypeEnum.AUCTION_ITEMS)
                         .orderByDesc(AuctionBidRecord::getLastBidAmount));
         if (CollUtils.isNotEmpty(auctionBidRecordList)) {
@@ -1459,7 +1479,7 @@
                     auctionBidRecords.add(auctionBidRecord);
                 }
             } else {
-                for (int i = 0; i < auctionSalesroomGoods.getSalesroomStock(); i++) {
+                for (int i = 0; i < auctionBidRecordList.size(); i++) {
                     AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i);
                     auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL);
                     auctionBidRecordMapper.updateById(auctionBidRecord);
@@ -1649,7 +1669,6 @@
     public void stopCurrentAuctionSalesroom(Long auctionSalesroomId)
             throws JsonProcessingException {
         LambdaQueryWrapper<AuctionSalesroomGoods> wrapper = Wrappers.lambdaQuery();
-        wrapper.eq(AuctionSalesroomGoods::getStatus, AuctionGoodsStatusEnum.WAITING);
         wrapper.eq(AuctionSalesroomGoods::getAuctionSalesroomId, auctionSalesroomId);
         wrapper.orderByDesc(AuctionSalesroomGoods::getSortNum);
         List<AuctionSalesroomGoods> auctionSalesroomGoods = auctionSalesroomGoodsMapper.selectList(
@@ -1665,19 +1684,18 @@
         auctionSalesroom.setStatus(AuctionStartStatusEnum.ENDED);
         auctionSalesroom.setEndTime(LocalDateTime.now());
         auctionSalesroomMapper.updateById(auctionSalesroom);
-
+        auctionSalesroomGoods = auctionSalesroomGoods.stream()
+                .filter(goods -> goods.getStatus().equals(AuctionGoodsStatusEnum.WAITING)).collect(
+                        Collectors.toList());
         if (StringUtils.isNotEmpty(auctionSalesroomGoods)) {
             List<GoodsStockUpdDTO> dtoList = new ArrayList<>();
             for (AuctionSalesroomGoods salesroomGoods : auctionSalesroomGoods) {
                 salesroomGoods.setStatus(AuctionGoodsStatusEnum.ENDED);
                 // 等待中的商品退库存
-                if (salesroomGoods.getStatus().equals(AuctionGoodsStatusEnum.WAITING)) {
-                    GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO();
-                    goodsStockUpdDTO.setGoodsSkuId(salesroomGoods.getGoodsSkuId());
-                    goodsStockUpdDTO.setAuctionStock(salesroomGoods.getSalesroomStock());
-                    dtoList.add(goodsStockUpdDTO);
-                }
-
+                GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO();
+                goodsStockUpdDTO.setGoodsSkuId(salesroomGoods.getGoodsSkuId());
+                goodsStockUpdDTO.setAuctionStock(salesroomGoods.getSalesroomStock());
+                dtoList.add(goodsStockUpdDTO);
             }
             // 批量更新商品库存
             auctionSalesroomGoodsMapper.updateBatchById(auctionSalesroomGoods);
@@ -1719,4 +1737,32 @@
                         Collectors.toSet());
         return this.listByIds(auctionSalesroomIdSet);
     }
+
+    /**
+     * 根据商品id获取正在进行的拍卖会
+     *
+     * @param id 商品id
+     * @return
+     */
+    @Override
+    public List<AuctionSalesroom> getAuctionSalesroomBySkuId(Long id) {
+        List<AuctionSalesroomGoods> auctionSalesroomGoods = auctionSalesroomGoodsMapper.selectList(
+                new LambdaQueryWrapper<AuctionSalesroomGoods>().eq(
+                                AuctionSalesroomGoods::getGoodsSkuId, id)
+                        .groupBy(AuctionSalesroomGoods::getAuctionSalesroomId));
+        if (CollUtils.isNotEmpty(auctionSalesroomGoods)) {
+            Set<Long> auctionSalesroomIdSet = auctionSalesroomGoods.stream()
+                    .map(AuctionSalesroomGoods::getAuctionSalesroomId).collect(
+                            Collectors.toSet());
+            return this.lambdaQuery()
+                    .eq(AuctionSalesroom::getStatus, AuctionStartStatusEnum.IN_AUCTION).in(
+                            AuctionSalesroom::getId, auctionSalesroomGoods).list();
+        }
+        return CollUtils.emptyList();
+    }
+
+    @Override
+    public AuctionSalesroomGoods getAuctionSalesroomGoodsById(Long goodsSkuId) {
+        return auctionSalesroomGoodsMapper.selectById(goodsSkuId);
+    }
 }

--
Gitblit v1.7.1