From 392b42c4891cf2e6beda57ab32c51598f290f4b7 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期五, 14 三月 2025 20:56:27 +0800 Subject: [PATCH] bug修改 --- ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionSalesroomGoodsServiceImpl.java | 76 ++++++++++++++++++++++++-------------- 1 files changed, 48 insertions(+), 28 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 44cb11b..ffc0100 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 @@ -21,6 +21,7 @@ import com.ruoyi.common.core.enums.AuctionOrderTypeEnum; import com.ruoyi.common.core.enums.AuctionStartStatusEnum; import com.ruoyi.common.core.enums.BidStatusEnum; +import com.ruoyi.common.core.enums.ClientTypeEnum; import com.ruoyi.common.core.enums.OrderFromEnum; import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.DateUtils; @@ -163,7 +164,10 @@ forepartAuctionSalesroomGoodsVO.setGoodsSkuName(goodsSku.getSkuName()); forepartAuctionSalesroomGoodsVO.setGoodsSkustatus(auctionSalesroomGoods.getStatus().getCode()); forepartAuctionSalesroomGoodsVO.setStartingPrice(auctionSalesroomGoods.getStartingPrice()); - forepartAuctionSalesroomGoodsVO.setSalesroomStock(auctionSalesroomGoods.getSalesroomStock()); + // forepartAuctionSalesroomGoodsVO.setSalesroomStock(auctionSalesroomGoods.getSalesroomStock()); + forepartAuctionSalesroomGoodsVO.setBidNum(auctionSalesroomGoods.getBidNum()); + forepartAuctionSalesroomGoodsVO.setDealQuantity(auctionSalesroomGoods.getDealQuantity()); + forepartAuctionSalesroomGoodsVO.setMaxAmount(auctionSalesroomGoods.getMaxAmount()); forepartAuctionSalesroomGoodsVO.setListingDuration(auctionSalesroomGoods.getListingDuration()); forepartAuctionSalesroomGoodsVO.setStartTime(auctionSalesroomGoods.getStartTime()); forepartAuctionSalesroomGoodsVO.setCoverPic(goodsSku.getScreenCoverPic()); @@ -392,7 +396,8 @@ GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO(); goodsStockUpdDTO.setGoodsSkuId(salesroomGoods.getGoodsSkuId()); - goodsStockUpdDTO.setAuctionStock(salesroomGoods.getSalesroomStock()); + goodsStockUpdDTO.setAuctionStock( + salesroomGoods.getBidNum() * salesroomGoods.getDealQuantity()); goodsSkuClient.updGoodsStock(Lists.newArrayList(goodsStockUpdDTO), SecurityConstants.INNER); @@ -519,7 +524,7 @@ if (auctionBidRecordList.size() > 0) { //判断 if (auctionBidRecordList.size() >= auctionSalesroomGoods.getBidNum()) { - for (int i = 0; i < auctionSalesroomGoods.getSalesroomStock(); i++) { + for (int i = 0; i < auctionSalesroomGoods.getBidNum(); i++) { AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i); auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL); Long orderId = AddOrder(auctionBidRecord.getTargetId(), @@ -538,7 +543,9 @@ } else { GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO(); goodsStockUpdDTO.setGoodsSkuId(auctionSalesroomGoods.getGoodsSkuId()); - goodsStockUpdDTO.setAuctionStock(auctionSalesroomGoods.getSalesroomStock()- auctionBidRecordList.size()); + goodsStockUpdDTO.setAuctionStock(auctionSalesroomGoods.getBidNum() + * auctionSalesroomGoods.getDealQuantity() - auctionBidRecordList.size() + * auctionSalesroomGoods.getDealQuantity()); goodsSkuClient.updGoodsStock(Lists.newArrayList(goodsStockUpdDTO), SecurityConstants.INNER); @@ -548,7 +555,8 @@ auctionBidRecord.setStatus(BidStatusEnum.SUCCESSFUL); Long orderId = AddOrder(auctionBidRecord.getTargetId(), auctionBidRecord.getMemberId(), - auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond(), 1); + auctionBidRecord.getLastBidAmount(), auctionSalesroom.getBond(), + auctionSalesroomGoods.getDealQuantity()); if (Objects.nonNull(orderId)) { orderIdMap.put(auctionBidRecord.getMemberId(), orderId.toString()); auctionBidRecord.setOrderId(orderId); @@ -569,8 +577,9 @@ .equals(BidStatusEnum.SUCCESSFUL)) .map(AuctionBidRecord::getMemberId) .collect(Collectors.toList()); - Map<Long, Long> bidMap = auctionBidRecordList.stream().collect( - Collectors.toMap(AuctionBidRecord::getMemberId, AuctionBidRecord::getId)); + Map<Long, String> bidMap = auctionBidRecordList.stream().collect( + Collectors.toMap(AuctionBidRecord::getMemberId, + item -> item.getId().toString())); if (CollUtils.isNotEmpty(successMemberIdList)) { List<Member> successMemberList = memberClient.getMemberListByIds( successMemberIdList, SecurityConstants.INNER).getData(); @@ -606,7 +615,7 @@ auctionSalesroomGoods.setStatus(AuctionGoodsStatusEnum.ENDED); 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", DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:ss")); map.put("goodsSkuId", auctionSalesroomGoods.getId().toString()); @@ -632,7 +641,7 @@ * @param successFlag // 中标状态 1:中标 0:未中标 */ private void sendWebsocketMsg(Long id, List<Member> memberList, GoodsSku goodsSku, - Integer successFlag, Map<Long, String> userIdMap, Map<Long, Long> bidMap) { + Integer successFlag, Map<Long, String> userIdMap, Map<Long, String> bidMap) { for (Member member : memberList) { Map<String, Object> map = new ConcurrentHashMap<>(); map.put("notification_type", NotificationTypeConstant.AUCTION_POPUP); @@ -641,10 +650,12 @@ map.put("goods_name", Objects.nonNull(goodsSku) ? goodsSku.getSkuName() : ""); map.put("success_flag", successFlag); map.put("order_id", successFlag == 1 ? userIdMap.getOrDefault(member.getId(), "") : ""); - map.put("auction_bid_record_id", bidMap.getOrDefault(member.getId(), 0L)); + map.put("auction_bid_record_id", bidMap.getOrDefault(member.getId(), "0")); + map.put("member_id", member.getId().toString()); String msg = JSONObject.toJSONString(map); - sysUserClient.pushBatch( - WebsocketMessageDTO.builder().message(msg).userId(member.getUserId()).build(), + sysUserClient.pushByClientType( + WebsocketMessageDTO.builder().message(msg).clientType(ClientTypeEnum.MEMBER) + .userId(member.getUserId()).build(), SecurityConstants.INNER); log.info("===================>发送websocket通知,消息体{}", msg); } @@ -666,7 +677,10 @@ AuctionSalesroomGoodsInfoVO.setGoodsSkuId(byId1.getId()); AuctionSalesroomGoodsInfoVO.setGoodsSkuName(goodsSku.getSkuName()); AuctionSalesroomGoodsInfoVO.setStartingPrice(byId1.getStartingPrice()); - AuctionSalesroomGoodsInfoVO.setSalesroomStock(byId1.getSalesroomStock()); + // AuctionSalesroomGoodsInfoVO.setSalesroomStock(byId1.getSalesroomStock()); + AuctionSalesroomGoodsInfoVO.setBidNum(byId1.getBidNum()); + AuctionSalesroomGoodsInfoVO.setMaxAmount(byId1.getMaxAmount()); + AuctionSalesroomGoodsInfoVO.setDealQuantity(byId1.getDealQuantity()); AuctionSalesroomGoodsInfoVO.setSalesroomType(byId.getType().getCode()); AuctionSalesroomGoodsInfoVO.setGoodsSkustatus(byId1.getStatus().getCode()); AuctionSalesroomGoodsInfoVO.setListingDuration(byId1.getListingDuration()); @@ -790,14 +804,27 @@ wrapper.orderByDesc(AuctionBidRecord::getLastBidAmount); wrapper.last("limit 10"); List<AuctionBidRecord> auctionBidRecordList = auctionBidRecordMapper.selectList(wrapper); + Set<Long> memberIdSet = auctionBidRecordList.stream().map(AuctionBidRecord::getMemberId) + .collect(Collectors.toSet()); + R<List<Member>> memberListByIds = memberClient.getMemberListByIds(memberIdSet, + SecurityConstants.INNER); + Map<Long, String> memberMap = new HashMap<>(); + if (CollUtils.isNotEmpty(memberListByIds.getData())) { + memberMap = memberListByIds.getData().stream() + .collect(Collectors.toMap(Member::getId, item -> item.getAvatar())); + } 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()); - auctionBidRecordVO.setMemberName(auctionBidRecordList.get(i).getNickname()); - auctionBidRecordVO.setMemberId(auctionBidRecordList.get(i).getMemberId()); + AuctionBidRecord auctionBidRecord = auctionBidRecordList.get(i); + auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount()); + auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime()); + auctionBidRecordVO.setMemberName(auctionBidRecord.getNickname()); + auctionBidRecordVO.setMemberId(auctionBidRecord.getMemberId()); + auctionBidRecordVO.setStatus(auctionBidRecord.getStatus()); + auctionBidRecordVO.setAvatar( + memberMap.getOrDefault(auctionBidRecord.getMemberId(), "")); auctionBidRecordVOList.add(auctionBidRecordVO); } LambdaQueryWrapper<AuctionBidRecord> wrapper1=Wrappers.lambdaQuery(); @@ -822,6 +849,7 @@ auctionBidRecordVO.setSort(Integer.valueOf(count.intValue())); auctionBidRecordVO.setLastBidAmount(auctionBidRecord.getLastBidAmount()); auctionBidRecordVO.setLastBidTime(auctionBidRecord.getLastBidTime()); + auctionBidRecordVO.setStatus(auctionBidRecord.getStatus()); Member data = memberClient.getMembeOne(auctionBidRecord.getMemberId(), SecurityConstants.INNER).getData(); if (data!=null){ @@ -851,7 +879,7 @@ public Long AddOrder(Long goodsSkuId, Long memberId, BigDecimal lastBidAmount, - BigDecimal bound, Integer goodsQuantity) { + BigDecimal bound, Integer dealQuantity) { OrderDTO order=new OrderDTO(); order.setGoodsSkuId(goodsSkuId); order.setOrderTime(LocalDateTime.now()); @@ -859,8 +887,8 @@ order.setMemberId(memberId); AuctionSalesroomGoods auctionSalesroomGoods = this.getById(goodsSkuId); - order.setGoodsQuantity(goodsQuantity); - order.setTotalAmount(lastBidAmount); + order.setGoodsQuantity(dealQuantity); + order.setTotalAmount(lastBidAmount.multiply(new BigDecimal(dealQuantity))); order.setAuctionSalesroomId(auctionSalesroomGoods.getAuctionSalesroomId()); R<MemberAddress> memberAddressR = memberClient.getMemberAddressOne(memberId, @@ -898,12 +926,4 @@ return orderClient.saveOrderOne(order, SecurityConstants.INNER).getData(); } - /** - * 设置弹窗状态已弹出 - * @param id - */ - @Override - public void setPopup(Long id) { - - } } -- Gitblit v1.7.1