From cd55aff7eea06f77a8f712cef1ad2744c44d0f8a Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期四, 20 六月 2024 18:56:16 +0800
Subject: [PATCH] 1.修改bug

---
 ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java |  443 +++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 318 insertions(+), 125 deletions(-)

diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java
index ceca2e9..5d0f6ee 100644
--- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java
+++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java
@@ -12,6 +12,7 @@
 import com.ruoyi.common.core.enums.BondStatusEnum;
 import com.ruoyi.common.core.enums.OrderFromEnum;
 import com.ruoyi.common.core.enums.OrderStatusEnum;
+import com.ruoyi.common.core.enums.OrderTypeEnum;
 import com.ruoyi.common.core.enums.PaymentMethodEnum;
 import com.ruoyi.common.core.enums.RequestTypeEnum;
 import com.ruoyi.common.core.enums.ReturnRequestStatusEnum;
@@ -20,8 +21,8 @@
 import com.ruoyi.common.core.utils.page.BeanUtils;
 import com.ruoyi.common.core.utils.page.PageDTO;
 import com.ruoyi.common.redis.service.RedisService;
-import com.ruoyi.order.controller.management.dto.MgtMallOrderQuery;
 import com.ruoyi.order.controller.management.dto.MgtOrderConfirmShipmentDTO;
+import com.ruoyi.order.controller.management.dto.MgtOrderQuery;
 import com.ruoyi.order.controller.management.vo.MgtOrderReturnRequestVO;
 import com.ruoyi.order.controller.management.vo.MgtOrderVO;
 import com.ruoyi.order.domain.OrderReturnRequest;
@@ -51,10 +52,12 @@
 import com.ruoyi.system.api.domain.dto.MemberDTO;
 import com.ruoyi.system.api.domain.dto.MemberOrderDTO;
 import com.ruoyi.system.api.domain.dto.MemberOrderListDTO;
+import com.ruoyi.system.api.domain.dto.MgtAfterSaleSettingDTO;
 import com.ruoyi.system.api.domain.dto.OrderDTO;
 import com.ruoyi.system.api.domain.dto.updMembeOneDTO;
 import com.ruoyi.system.api.domain.vo.Express100VO;
 import com.ruoyi.system.api.domain.vo.MemberOrderListVO;
+import com.ruoyi.system.api.domain.vo.MemberOrderNumVO;
 import com.ruoyi.system.api.domain.vo.MemberTiOrderVO;
 import com.ruoyi.system.api.domain.vo.OrderVO;
 import com.ruoyi.system.api.feignClient.AuctionClient;
@@ -125,6 +128,10 @@
     @Resource
     private AuctionClient auctionClient;
 
+    @Resource
+    private  GoodsSkuClient GoodsSkuClient;
+
+
     @Override
     public void saveOrderOne(OrderDTO OrderDTO) {
         Order order=new Order();
@@ -145,7 +152,7 @@
         }
         order.setOrderTime(OrderDTO.getOrderTime());
         order.setOrderFrom(OrderDTO.getOrderFrom());
-        order.setAuctionType(OrderDTO.getAuctionType());
+        order.setAuctionOrderType(OrderDTO.getAuctionType());
         order.setGoodsSkuId(OrderDTO.getGoodsSkuId());
         order.setMemberId(OrderDTO.getMemberId());
         order.setTotalAmount(OrderDTO.getTotalAmount());
@@ -153,7 +160,7 @@
         order.setPoints(OrderDTO.getPoints());
         order.setGoodsQuantity(OrderDTO.getGoodsQuantity());
         order.setReceiverName(OrderDTO.getReceiverName());
-        order.setReceiverphone(OrderDTO.getReceiverphone());
+        order.setReceiverPhone(OrderDTO.getReceiverphone());
         order.setReceiverCity(OrderDTO.getReceiverCity());
         order.setReceiverDetailAddress(OrderDTO.getReceiverDetailAddress());
         order.setBound(OrderDTO.getBound());
@@ -244,6 +251,7 @@
         BigDecimal pice=new BigDecimal(0);
 
         Order order=new Order();
+        order.setMemberId(memberOrderDTO.getMemberId());
         if (memberOrderDTO.getOrderFrom()==1){
             order.setOrderFrom(OrderFromEnum.COMMODITY_ORDER);
             order.setOrderNo(OrderUtil.getOrderNoForPrefix("SP"));
@@ -302,7 +310,8 @@
 
             GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(data.getGoodsSkuId(), SecurityConstants.INNER).getData();
             memberOrderVO.setGoodsSkuId(memberOrderDTO.getGoodsSkuId());
-            memberOrderVO.setPrice(goodsSku.getPrice());
+            memberOrderVO.setPrice(data.getSeckillPrice());
+            memberOrderVO.setSjPrice(goodsSku.getPrice());
             memberOrderVO.setCoverPic(goodsSku.getCoverPic());
             memberOrderVO.setSkuName(goodsSku.getSkuName());
             memberOrderVO.setYouhiPrice(data.getSeckillPrice());
@@ -320,6 +329,7 @@
             order.setSkuName(goodsSku.getSkuName());
             order.setPrice(data.getSeckillPrice());
             order.setCoverPic(goodsSku.getCoverPic());
+            order.setSjPrice(goodsSku.getPrice());
             /*redisService.setCacheObject(CacheConstants.SECKILL_GOODS + data.getId(), surpNum - memberOrderDTO.getGoodsQuantity());*/
         }
         if (memberOrderDTO.getOrderFrom()==3){
@@ -327,7 +337,8 @@
             GoodsGroupPurchase data = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(memberOrderDTO.getGoodsSkuId(), SecurityConstants.INNER).getData();
             GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(data.getGoodsSkuId(), SecurityConstants.INNER).getData();
             memberOrderVO.setGoodsSkuId(memberOrderDTO.getGoodsSkuId());
-            memberOrderVO.setPrice(goodsSku.getPrice());
+            memberOrderVO.setPrice(data.getGroupPurchasePrice());
+            memberOrderVO.setSjPrice(goodsSku.getPrice());
             memberOrderVO.setCoverPic(goodsSku.getCoverPic());
             memberOrderVO.setSkuName(goodsSku.getSkuName());
             memberOrderVO.setYouhiPrice(data.getGroupPurchasePrice());
@@ -336,7 +347,9 @@
             order.setSkuName(goodsSku.getSkuName());
             order.setPrice(data.getGroupPurchasePrice());
             order.setCoverPic(goodsSku.getCoverPic());
+            order.setSjPrice(goodsSku.getPrice());
         }
+        order.setOrderRemark(memberOrderDTO.getOrderRemark());
         order.setMemberId(memberOrderDTO.getMemberId());
         order.setGoodsQuantity(memberOrderDTO.getGoodsQuantity());
         order.setOrderTime(LocalDateTime.now());
@@ -355,7 +368,7 @@
             order.setReceiverName(memberOrderDTO.getReceiverName());
             order.setReceiverCity(memberOrderDTO.getReceiverCity());
             order.setReceiverDetailAddress(memberOrderDTO.getReceiverDetailAddress());
-            order.setReceiverphone(memberOrderDTO.getReceiverphone());
+            order.setReceiverPhone(memberOrderDTO.getReceiverphone());
         }else{
             MemberAddress data = memberClient.getMemberAddressOne(
                     memberOrderDTO.getMemberId(), SecurityConstants.INNER).getData();
@@ -363,7 +376,7 @@
                 order.setReceiverName(data.getRecipientName());
                 order.setReceiverCity(data.getReceiverCity());
                 order.setReceiverDetailAddress(data.getDetailedAddress());
-                order.setReceiverphone(data.getRecipientPhone());
+                order.setReceiverPhone(data.getRecipientPhone());
             }
         }
 
@@ -384,7 +397,7 @@
         memberOrderVO.setReceiverName(order.getReceiverName());
         memberOrderVO.setReceiverCity(order.getReceiverCity());
         memberOrderVO.setReceiverDetailAddress(order.getReceiverDetailAddress());
-        memberOrderVO.setReceiverphone(order.getReceiverphone());
+        memberOrderVO.setReceiverphone(order.getReceiverPhone());
         Integer delayTime = 30;
         redisService.setCacheObject(CacheConstants.ORDER_AUTOMATIC_CANCEL + "-" + order.getId(), order.getId() , delayTime.longValue(), TimeUnit.MINUTES);
 
@@ -394,18 +407,22 @@
     @Override
     public MemberTiOrderVO updMemberOrder(MemberOrderDTO memberOrderDTO) {
         Order order = baseMapper.selectById(memberOrderDTO.getId());
+        if(memberOrderDTO.getOrderRemark()!=null){
+            order.setOrderRemark(memberOrderDTO.getOrderRemark());
+        }
+
         MemberTiOrderVO memberOrderVO=new MemberTiOrderVO();
         if (memberOrderDTO.getReceiverDetailAddress()!=null){
             order.setReceiverName(memberOrderDTO.getReceiverName());
             order.setReceiverCity(memberOrderDTO.getReceiverCity());
             order.setReceiverDetailAddress(memberOrderDTO.getReceiverDetailAddress());
-            order.setReceiverphone(memberOrderDTO.getReceiverphone());
+            order.setReceiverPhone(memberOrderDTO.getReceiverphone());
         }
         if (memberOrderDTO.getOrderRemark()!=null){
             order.setOrderRemark(memberOrderDTO.getOrderRemark());
         }if (memberOrderDTO.getGoodsQuantity()!=null){
             if (order.getOrderFrom().getCode()==1){
-                GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(memberOrderDTO.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(order.getGoodsSkuId(), SecurityConstants.INNER).getData();
                 if (goodsSku.getStock()<memberOrderDTO.getGoodsQuantity()){
                     throw new ServiceException("对不起,购买数大于库存");
                 }else{
@@ -422,6 +439,7 @@
                             SecurityConstants.INNER);
 
                     order.setTotalAmount(goodsSku.getPrice().multiply(new BigDecimal(memberOrderDTO.getGoodsQuantity())));
+                    order.setGoodsQuantity(memberOrderDTO.getGoodsQuantity());
                     memberOrderVO.setGoodsSkuId(memberOrderDTO.getGoodsSkuId());
                     memberOrderVO.setPrice(goodsSku.getPrice());
                     memberOrderVO.setCoverPic(goodsSku.getCoverPic());
@@ -431,17 +449,19 @@
             }
             if (order.getOrderFrom().getCode()==2){
                 MemberOrderDTO memberOrderDTO1=new MemberOrderDTO();
-                memberOrderDTO1.setMemberId(memberOrderDTO.getMemberId());
-                memberOrderDTO1.setGoodsSkuId(memberOrderDTO.getGoodsSkuId());
+                memberOrderDTO1.setMemberId(order.getMemberId());
+                memberOrderDTO1.setGoodsSkuId(order.getGoodsSkuId());
                 Integer num=baseMapper.getSeckillMembers1(memberOrderDTO1);
-                GoodsSeckill data = goodsSkuClient.getGoodsSeckillOne(memberOrderDTO.getGoodsSkuId(), SecurityConstants.INNER).getData();
-                GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(memberOrderDTO.getGoodsSkuId(), SecurityConstants.INNER).getData();
-                if (data.getLimitNumber()<=num){
+                Integer num1=num+order.getGoodsQuantity();
+                GoodsSeckill data = goodsSkuClient.getGoodsSeckillOne(order.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(data.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                if (data.getLimitNumber()<=num1){
                     throw new ServiceException("对不起,大于商品购买数");
                 }else{
                     if (data.getSeckillStock()<memberOrderDTO.getGoodsQuantity()){
                         throw new ServiceException("对不起,购买数大于库存");
                     }else{
+                        order.setGoodsQuantity(memberOrderDTO.getGoodsQuantity());
                     GoodsStockUpdDTO goodsStockUpdDTO = new GoodsStockUpdDTO();
                     goodsStockUpdDTO.setGoodsSkuId(data.getId());
                     goodsStockUpdDTO.setAuctionStock(data.getSeckillStock()+order.getGoodsQuantity());
@@ -452,7 +472,12 @@
                     goodsStockUpdDTO1.setAuctionStock(data.getSeckillStock()-memberOrderDTO.getGoodsQuantity());
                     goodsSkuClient.updGoodsSeckill(goodsStockUpdDTO,SecurityConstants.INNER);
 
-                    order.setTotalAmount(data.getSeckillPrice().multiply(new BigDecimal(memberOrderDTO.getGoodsQuantity())));
+                        order.setTotalAmount(data.getSeckillPrice().multiply(new BigDecimal(memberOrderDTO.getGoodsQuantity())));
+                        order.setGoodsQuantity(memberOrderDTO.getGoodsQuantity());
+                        order.setSkuName(goodsSku.getSkuName());
+                        order.setPrice(data.getSeckillPrice());
+                        order.setCoverPic(goodsSku.getCoverPic());
+                        order.setSjPrice(goodsSku.getPrice());
 
                 }
             }
@@ -461,69 +486,106 @@
                 memberOrderVO.setCoverPic(goodsSku.getCoverPic());
                 memberOrderVO.setSkuName(goodsSku.getSkuName());
                 memberOrderVO.setYouhiPrice(data.getSeckillPrice());
-        }
-        }
-
-        if (memberOrderDTO.getCouponId()!=null){
-            CouponMemberDTO couponMemberDTO=new CouponMemberDTO();
-            couponMemberDTO.setId(memberOrderDTO.getCouponId());
-            CouponMember data = promotionClient.getCouponMember(couponMemberDTO, SecurityConstants.INNER).getData();
-
-
-            if (order.getCouponId()!=null){
-                CouponMemberDTO couponMemberDTO1=new CouponMemberDTO();
-                couponMemberDTO1.setId(memberOrderDTO.getCouponId());
-                couponMemberDTO1.setCouponStatus(1);
-                promotionClient.updCouponMember(couponMemberDTO1, SecurityConstants.INNER);
-            }
-
-            BigDecimal pice=new BigDecimal(0);
-            if (data.getCouponType().getCode()==1){
-                pice= order.getTotalAmount();
-                if (pice.doubleValue()>=data.getFullReductionAmount().doubleValue()){
-                    pice.subtract(data.getReductionAmount());
-                    order.setDiscountMoney(data.getReductionAmount());
+        }  if (order.getOrderFrom().getCode()==3){
+                order.setOrderFrom(OrderFromEnum.GROUP_PURCHASE_ORDERS);
+                GoodsGroupPurchase data = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(order.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(data.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                MemberOrderDTO memberOrderDTO1=new MemberOrderDTO();
+                memberOrderDTO1.setMemberId(order.getMemberId());
+                memberOrderDTO1.setGoodsSkuId(order.getGoodsSkuId());
+                Integer num=baseMapper.getGoodsGroupPurchase(memberOrderDTO1);
+                Integer num1=num+order.getGoodsQuantity();
+                if (data.getLimitNumber()<=num1){
+                    throw new ServiceException("对不起,大于商品购买数");
+                }else{
+                    if (data.getLimitNumber()<memberOrderDTO.getGoodsQuantity()){
+                        throw new ServiceException("对不起,购买数大于库存");
+                    }else{
+                        memberOrderVO.setGoodsSkuId(memberOrderDTO.getGoodsSkuId());
+                        memberOrderVO.setPrice(data.getGroupPurchasePrice());
+                        memberOrderVO.setSjPrice(goodsSku.getPrice());
+                        memberOrderVO.setCoverPic(goodsSku.getCoverPic());
+                        memberOrderVO.setSkuName(goodsSku.getSkuName());
+                        memberOrderVO.setYouhiPrice(data.getGroupPurchasePrice());
+                        order.setGoodsQuantity(memberOrderDTO.getGoodsQuantity());
+                        order.setSkuName(goodsSku.getSkuName());
+                        order.setPrice(data.getGroupPurchasePrice());
+                        order.setCoverPic(goodsSku.getCoverPic());
+                        order.setSjPrice(goodsSku.getPrice());
+                    }
                 }
-            }
-            if (data.getCouponType().getCode()==2){
-                pice= order.getTotalAmount();
-                pice.subtract(data.getVoucherAmount());
-                order.setDiscountMoney(data.getVoucherAmount());
-            }
-            if (data.getCouponType().getCode()==3){
-                pice= order.getTotalAmount();
-                BigDecimal pice1=new BigDecimal(data.getDiscountRate());
-                BigDecimal pice2=new BigDecimal(0.1);
-                BigDecimal pice3=pice.multiply(pice1.multiply(pice2));
-                BigDecimal pice4= pice.subtract(pice3);
-               if (pice4.doubleValue()>data.getMaxDiscount().doubleValue()){
-                   pice=pice.subtract(data.getMaxDiscount());
-                   order.setDiscountMoney(data.getMaxDiscount());
-               }else{
-                   order.setDiscountMoney(pice4);
-                   pice=pice3;
-               }
+
+
 
             }
-            order.setCouponId(memberOrderDTO.getCouponId());
-            CouponMemberDTO couponMemberDTO2=new CouponMemberDTO();
-            couponMemberDTO2.setId(memberOrderDTO.getCouponId());
-            couponMemberDTO2.setCouponStatus(2);
-            promotionClient.updCouponMember(couponMemberDTO2, SecurityConstants.INNER);
+        }
+        if (memberOrderDTO.getGoodsQuantity()!=null){
+            BigDecimal pice=order.getPrice().multiply(new BigDecimal(memberOrderDTO.getGoodsQuantity()));
+            if (memberOrderDTO.getCouponId()!=null){
+                CouponMemberDTO couponMemberDTO=new CouponMemberDTO();
+                couponMemberDTO.setId(memberOrderDTO.getCouponId());
+                CouponMember data = promotionClient.getCouponMember(couponMemberDTO, SecurityConstants.INNER).getData();
+                if (order.getCouponId()!=0){
+                    CouponMemberDTO couponMemberDTO1=new CouponMemberDTO();
+                    couponMemberDTO1.setId(memberOrderDTO.getCouponId());
+                    couponMemberDTO1.setCouponStatus(0);
+                    promotionClient.updCouponMember(couponMemberDTO1, SecurityConstants.INNER);
+                }
 
+                order.setCouponId(data.getId());
+
+                if (data.getCouponType().getCode()==1){
+                    if (pice.doubleValue()>=data.getFullReductionAmount().doubleValue()){
+                        pice=pice.subtract(data.getReductionAmount());
+                        order.setDiscountMoney(data.getReductionAmount());
+                    }
+                }
+                if (data.getCouponType().getCode()==2){
+                    pice= order.getTotalAmount();
+                    pice=pice.subtract(data.getVoucherAmount());
+                    order.setDiscountMoney(data.getVoucherAmount());
+                }
+                if (data.getCouponType().getCode()==3){
+                    pice= order.getTotalAmount();
+                    BigDecimal pice1=new BigDecimal(data.getDiscountRate());
+                    BigDecimal pice2=new BigDecimal(0.1);
+                    BigDecimal pice3=pice.multiply(pice1.multiply(pice2));
+                    BigDecimal pice4= pice.subtract(pice3);
+                    if (pice4.doubleValue()>data.getMaxDiscount().doubleValue()){
+                        pice=pice.subtract(data.getMaxDiscount());
+                        order.setDiscountMoney(data.getMaxDiscount());
+                    }else{
+                        order.setDiscountMoney(pice4);
+                        pice=pice3;
+                    }
+
+                }
+                order.setCouponId(memberOrderDTO.getCouponId());
+                CouponMemberDTO couponMemberDTO2=new CouponMemberDTO();
+                couponMemberDTO2.setId(memberOrderDTO.getCouponId());
+                couponMemberDTO2.setCouponStatus(1);
+                promotionClient.updCouponMember(couponMemberDTO2, SecurityConstants.INNER);
+            }else{
+                if (order.getCouponId()!=null&&order.getCouponId()!=0){
+                    CouponMemberDTO couponMemberDTO1=new CouponMemberDTO();
+                    couponMemberDTO1.setCouponStatus(0);
+                    couponMemberDTO1.setId(order.getCouponId());
+                    promotionClient.updCouponMember(couponMemberDTO1, SecurityConstants.INNER);
+                }
+                order.setCouponId(0L);
+                order.setDiscountMoney(new BigDecimal(0));
+            }
             order.setTotalAmount(pice);
 
             CustomConfig memberPointsMoney = sysUserClient.getconfig("MEMBER_POINTS_MONEY").getData();
             CustomConfig memberPointsPoints = sysUserClient.getconfig("MEMBER_POINTS_POINTS").getData();
 
-            BigDecimal pic=pice.multiply(new BigDecimal(memberOrderDTO.getGoodsQuantity()));
             Double aDouble= Double.valueOf(memberPointsMoney.getConfigValue()) * Double.valueOf(memberPointsPoints.getConfigValue());
-            BigDecimal pi=pic.multiply(new BigDecimal(aDouble));
+            BigDecimal pi=pice.multiply(new BigDecimal(aDouble));
             order.setPoints(pi.intValue());
-
+            baseMapper.updateById(order);
         }
 
-        baseMapper.updateById(order);
 
         memberOrderVO.setId(order.getId());
         memberOrderVO.setOrderStatus(OrderStatusEnum.TO_PLAY);
@@ -539,8 +601,8 @@
         memberOrderVO.setReceiverName(order.getReceiverName());
         memberOrderVO.setReceiverCity(order.getReceiverCity());
         memberOrderVO.setReceiverDetailAddress(order.getReceiverDetailAddress());
-        memberOrderVO.setReceiverphone(order.getReceiverphone());
-        memberOrderVO.setYouhiPrice(order.getDiscountMoney());
+        memberOrderVO.setReceiverphone(order.getReceiverPhone());
+        memberOrderVO.setDiscountMoney(order.getDiscountMoney());
 
         return memberOrderVO;
     }
@@ -550,14 +612,48 @@
         Page<Order> page = new Page<>(memberOrderListDTO.getPageCurr(), memberOrderListDTO.getPageSize());
         LambdaQueryWrapper<Order> wrapper= Wrappers.lambdaQuery();
         wrapper.eq(Order::getMemberId,memberOrderListDTO.getMemberId());
-        wrapper.like(Order::getSkuName,memberOrderListDTO.getGoodsSkuName());
-        wrapper.like(Order::getOrderNo,memberOrderListDTO.getOrderNo());
-        wrapper.eq(Order::getOrderStatus,memberOrderListDTO.getOrderStatus());
+        if(memberOrderListDTO.getGoodsSkuName()!=null){
+            wrapper.like(Order::getSkuName,memberOrderListDTO.getGoodsSkuName());
+        }
+        if(memberOrderListDTO.getOrderNo()!=null){
+            wrapper.like(Order::getOrderNo,memberOrderListDTO.getOrderNo());
+        }
+        if(memberOrderListDTO.getOrderStatus()!=null){
+            wrapper.eq(Order::getOrderStatus,memberOrderListDTO.getOrderStatus().getCode()-1);
+        }
         wrapper.eq(Order::getDelFlag,0);
         wrapper.orderByDesc(Order::getCancelTime);
         Page<Order> page1 = this.page(page, wrapper);
 
         PageDTO<MemberOrderListVO> memberOrderListVOPageDTO = PageDTO.of(page1, MemberOrderListVO.class);
+        List<MemberOrderListVO> list = memberOrderListVOPageDTO.getList();
+        for (MemberOrderListVO MemberOrderList:list){
+            OrderReturnRequest orderReturnRequest = orderReturnRequestService.getOne(
+                    Wrappers.lambdaQuery(OrderReturnRequest.class)
+                            .eq(OrderReturnRequest::getOrderId,
+                                    MemberOrderList.getId()).last("limit 1"));
+            if (StringUtils.isNotNull(orderReturnRequest)&&orderReturnRequest!=null) {
+                MemberOrderList.setStatus(orderReturnRequest.getStatus());
+                MemberOrderList.setRequestId(orderReturnRequest.getId());
+                MemberOrderList.setIsRequest(2);
+            }else{
+                MemberOrderList.setIsRequest(1);
+            }
+            LambdaQueryWrapper<OrderAuctionBond> wrapper3= Wrappers.lambdaQuery();
+            wrapper3.eq(OrderAuctionBond::getOrderId,MemberOrderList.getId());
+            OrderAuctionBond orderAuctionBond = orderAuctionBondMapper.selectOne(wrapper3);
+            if (orderAuctionBond!=null){
+                if (orderAuctionBond.getBoundStatus().getCode()==1||orderAuctionBond.getBoundStatus().getCode()==2){
+                    MemberOrderList.setIsAuctionBond(1);
+                }else{
+                    MemberOrderList.setIsAuctionBond(2);
+                }
+            }else {
+                MemberOrderList.setIsAuctionBond(1);
+            }
+        }
+
+
         return memberOrderListVOPageDTO;
     }
 
@@ -567,6 +663,36 @@
         OrderVO orderVO=new OrderVO();
         try {
             orderVO = BeanUtils.copyBean(order, OrderVO.class);
+            if (orderVO.getOrderFrom().getCode()==3){
+                GoodsGroupPurchase data = GoodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(order.getGoodsSkuId(), SecurityConstants.INNER).getData();
+                orderVO.setGroupTime(data.getGroupTime());
+            }
+
+            OrderReturnRequest orderReturnRequest = orderReturnRequestService.getOne(
+                    Wrappers.lambdaQuery(OrderReturnRequest.class)
+                            .eq(OrderReturnRequest::getOrderId,
+                                    orderVO.getId()).last("limit 1"));
+            if (StringUtils.isNotNull(orderReturnRequest)&&orderReturnRequest!=null) {
+                orderVO.setStatus(orderReturnRequest.getStatus());
+                orderVO.setRequestId(orderReturnRequest.getId());
+                orderVO.setIsRequest(2);
+            }else{
+                orderVO.setIsRequest(1);
+            }
+
+            LambdaQueryWrapper<OrderAuctionBond> wrapper3= Wrappers.lambdaQuery();
+            wrapper3.eq(OrderAuctionBond::getOrderId,order.getId());
+            OrderAuctionBond orderAuctionBond = orderAuctionBondMapper.selectOne(wrapper3);
+            if (orderAuctionBond!=null){
+                if (orderAuctionBond.getBoundStatus().getCode()==1||orderAuctionBond.getBoundStatus().getCode()==2){
+                    orderVO.setIsAuctionBond(1);
+                }else{
+                    orderVO.setIsAuctionBond(2);
+                }
+            }else {
+                orderVO.setIsAuctionBond(1);
+            }
+
         } catch (Exception e) {
             throw new RuntimeException(e);
         }
@@ -576,17 +702,17 @@
     @Override
     public void CancelOrderOne(MemberOrderListDTO memberOrderListDTO) {
         Order order = baseMapper.selectById(memberOrderListDTO.getId());
-        if (order.getOrderStatus().getCode()==1){
+        if (order.getOrderStatus().getCode() == 1) {
             order.setOrderStatus(OrderStatusEnum.CANCELED);
             order.setCancelTime(LocalDateTime.now());
             baseMapper.updateById(order);
         }
-        if (order.getOrderStatus().getCode()==2) {
+        if (order.getOrderStatus().getCode() == 2) {
             order.setOrderStatus(OrderStatusEnum.CANCELED);
             order.setCancelTime(LocalDateTime.now());
             baseMapper.updateById(order);
 
-            updMembeOneDTO MembeOneDTO=new updMembeOneDTO();
+            updMembeOneDTO MembeOneDTO = new updMembeOneDTO();
             MembeOneDTO.setType(2);
             MembeOneDTO.setMemberId(order.getMemberId());
             MembeOneDTO.setMoney(order.getTotalAmount());
@@ -599,33 +725,38 @@
                 LambdaQueryWrapper<Paylog> paylogEntityWrapper = Wrappers.lambdaQuery();
                 paylogEntityWrapper.eq(Paylog::getOutTradeNo, order.getOrderNo());
                 Paylog paylog = iPaylogService.getOne(paylogEntityWrapper);
-                boolean bo = paylogService.refundForAlipay(paylog.getOutTradeNo(), paylog.getTradeNo(), paylog.getPayMoney());
-                if (!bo) {
-                    System.out.println("支付宝退款失败");
+                if (paylog != null) {
+                    boolean bo = paylogService.refundForAlipay(paylog.getOutTradeNo(), paylog.getTradeNo(), paylog.getPayMoney());
+                    if (!bo) {
+                        System.out.println("支付宝退款失败");
+                    }
                 }
+
             } else if (order.getPaymentMethod() != null && order.getPaymentMethod().getCode() == 2) {//微信
                 //获取支付信息
                 LambdaQueryWrapper<Paylog> paylogEntityWrapper = Wrappers.lambdaQuery();
                 paylogEntityWrapper.eq(Paylog::getOutTradeNo, order.getOrderNo());
                 Paylog paylog = iPaylogService.getOne(paylogEntityWrapper);
+                if (paylog != null) {
+                    String refundMoney = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d);
+                    Integer refundFee = Integer.parseInt(refundMoney.substring(0, refundMoney.length() - 3));
+                    String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d);
+                    Integer totalFee = Integer.parseInt(money.substring(0, money.length() - 3));
+                    refundFee = 1;
 
-                String refundMoney = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d);
-                Integer refundFee = Integer.parseInt(refundMoney.substring(0, refundMoney.length() - 3));
-                String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d);
-                Integer totalFee = Integer.parseInt(money.substring(0, money.length() - 3));
-                refundFee = 1;
+                    String regEx = "[^0-9]";
+                    Pattern p = Pattern.compile(regEx);
+                    Matcher m = p.matcher(order.getOrderNo());
+                    String ma = m.replaceAll("").trim();
+                    boolean bo = paylogService.refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2");
+                    if (!bo) {
+                        System.out.println("微信退款失败");
+                    }
 
-                String regEx = "[^0-9]";
-                Pattern p = Pattern.compile(regEx);
-                Matcher m = p.matcher(order.getOrderNo());
-                String ma = m.replaceAll("").trim();
-                boolean bo = paylogService.refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2");
-                if (!bo) {
-                    System.out.println("微信退款失败");
                 }
             }
-        }}
-
+        }
+    }
     @Override
     public void AffirmOrderOne(MemberOrderListDTO memberOrderListDTO) {
         Order order = baseMapper.selectById(memberOrderListDTO.getId());
@@ -659,20 +790,46 @@
                 Integer totalFee = Integer.parseInt(money.substring(0, money.length() - 3));
                 refundFee = 1;
 
-                String regEx = "[^0-9]";
-                Pattern p = Pattern.compile(regEx);
-                Matcher m = p.matcher(order.getOrderNo());
-                String ma = m.replaceAll("").trim();
-                boolean bo = paylogService.refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2");
-                if (!bo) {
-                    System.out.println("微信退款失败");
+                    String regEx = "[^0-9]";
+                    Pattern p = Pattern.compile(regEx);
+                    Matcher m = p.matcher(order.getOrderNo());
+                    String ma = m.replaceAll("").trim();
+                    boolean bo = paylogService.refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2");
+                    if (!bo) {
+                        System.out.println("微信退款失败");
+                    }
                 }
-            }
+
         }else{
             order.setOrderStatus(OrderStatusEnum.FINISHED);
             order.setReceiveTime(LocalDateTime.now());
             baseMapper.updateById(order);
         }
+    }
+
+    @Override
+    public MemberOrderNumVO MemberOrderNum(MemberOrderListDTO memberOrderListDTO) {
+        MemberOrderNumVO vo=new MemberOrderNumVO();
+
+        LambdaQueryWrapper<Order> paylogEntityWrapper = Wrappers.lambdaQuery();
+        paylogEntityWrapper.eq(Order::getMemberId, memberOrderListDTO.getMemberId());
+        paylogEntityWrapper.eq(Order::getOrderStatus,1);
+        List<Order> list = this.list(paylogEntityWrapper);
+        vo.setDzforderNo(list.size());
+
+        LambdaQueryWrapper<Order> paylogEntityWrapper1 = Wrappers.lambdaQuery();
+        paylogEntityWrapper1.eq(Order::getMemberId, memberOrderListDTO.getMemberId());
+        paylogEntityWrapper1.eq(Order::getOrderStatus,2);
+        List<Order> list1 = this.list(paylogEntityWrapper1);
+        vo.setDfhorderNo(list1.size());
+
+        LambdaQueryWrapper<Order> paylogEntityWrapper2 = Wrappers.lambdaQuery();
+        paylogEntityWrapper2.eq(Order::getMemberId, memberOrderListDTO.getMemberId());
+        paylogEntityWrapper2.eq(Order::getOrderStatus,3);
+        List<Order> list2 = this.list(paylogEntityWrapper2);
+        vo.setDshorderNo(list2.size());
+
+        return vo;
     }
 
     /**
@@ -694,7 +851,7 @@
      * @return PageDTO<MgtMallOrderVO>
      */
     @Override
-    public PageDTO<MgtOrderVO> getOrderPage(MgtMallOrderQuery query) {
+    public PageDTO<MgtOrderVO> getOrderPage(MgtOrderQuery query) {
         PageDTO<MgtOrderVO> pageVO;
         // 封装会员条件查询对象
         MemberDTO memberDTO = null;
@@ -718,14 +875,20 @@
         }
         page = this.lambdaQuery()
                 .in(StringUtils.isNotEmpty(memberIdSet), Order::getMemberId, memberIdSet)
+                .ne(query.getQueryType().equals(OrderTypeEnum.MALL_ODER), Order::getOrderFrom,
+                        OrderFromEnum.AUCTION_ORDERS)
+                .eq(query.getQueryType().equals(OrderTypeEnum.AUCTION_ORDER), Order::getOrderFrom,
+                        OrderFromEnum.AUCTION_ORDERS)
                 .like(StringUtils.isNotBlank(query.getOrderNo()), Order::getOrderNo,
                         query.getOrderNo())
-                .eq(StringUtils.isNotNull(query.getOrderFrom()), Order::getOrderFrom,
+                .eq(StringUtils.isNotNull(query.getOrderFrom()) && query.getQueryType()
+                                .equals(OrderTypeEnum.MALL_ODER), Order::getOrderFrom,
                         query.getOrderFrom())
                 .like(StringUtils.isNotBlank(query.getSkuName()), Order::getSkuName,
                         query.getSkuName())
                 .eq(StringUtils.isNotNull(query.getOrderStatus()), Order::getOrderStatus,
                         query.getOrderStatus())
+                .orderByDesc(Order::getCreateTime)
                 .page(new Page<>(query.getPageCurr(), query.getPageSize()));
         if (StringUtils.isEmpty(page.getRecords())) {
             pageVO = PageDTO.empty(page);
@@ -733,12 +896,30 @@
         pageVO = PageDTO.of(page, MgtOrderVO.class);
         if (query.getOrderFrom() == OrderFromEnum.AUCTION_ORDERS) {
             List<MgtOrderVO> list = pageVO.getList();
+            // 封装参数查询拍卖会
+            Set<Long> auctionSalesroomGoodsIdSet = list.stream()
+                    .filter(order -> order.getAuctionType() == AuctionOrderTypeEnum.AUCTION_ITEMS)
+                    .map(MgtOrderVO::getGoodsSkuId).collect(Collectors.toSet());
+            List<AuctionSalesroom> auctionSalesroomList = auctionClient.getAuctionSalesroomByIds(
+                            auctionSalesroomGoodsIdSet, SecurityConstants.INNER)
+                    .getData();
+            Map<Long, String> salesroomMap = auctionSalesroomList.stream()
+                    .collect(Collectors.toMap(AuctionSalesroom::getId,
+                            AuctionSalesroom::getSalesroomName));
             // 封装参数查询拍卖订单保证金
-            Set<Long> orderIdSet = list.stream().map(MgtOrderVO::getId)
+            Set<Long> auctionGoodsIdSet = list.stream()
+                    .filter(order -> order.getAuctionType() == AuctionOrderTypeEnum.REGULAR_ITEMS)
+                    .map(MgtOrderVO::getGoodsSkuId)
                     .collect(Collectors.toSet());
+
+            Set<Long> auctionSalesroomSet = auctionSalesroomList.stream()
+                    .map(AuctionSalesroom::getId)
+                    .collect(Collectors.toSet());
+
             List<OrderAuctionBond> auctionBondList = orderAuctionBondMapper.selectList(
                     Wrappers.lambdaQuery(OrderAuctionBond.class)
-                            .in(OrderAuctionBond::getOrderId, orderIdSet)
+                            .in(OrderAuctionBond::getAuctionGoodsId, auctionGoodsIdSet)
+                            .in(OrderAuctionBond::getAuctionSalesroomId, auctionSalesroomSet)
                             .eq(OrderAuctionBond::getBoundStatus,
                                     BondStatusEnum.PAID));
             Map<String, OrderAuctionBond> auctionSalesroomBondMap = auctionBondList.stream()
@@ -751,27 +932,18 @@
                     .collect(Collectors.toMap(
                             bond -> bond.getAuctionGoodsId() + "-" + bond.getMemberId(),
                             Function.identity()));
-            // 封装参数查询拍卖会
-            Set<Long> auctionSalesroomGoodsIdSet = list.stream()
-                    .filter(order -> order.getAuctionType() == AuctionOrderTypeEnum.AUCTION_ITEMS)
-                    .map(MgtOrderVO::getGoodsSkuId).collect(Collectors.toSet());
-            List<AuctionSalesroom> auctionSalesroomList = auctionClient.getAuctionSalesroomByIds(
-                            auctionSalesroomGoodsIdSet, SecurityConstants.INNER)
-                    .getData();
-            Map<Long, String> salesroomMap = auctionSalesroomList.stream()
-                    .collect(Collectors.toMap(AuctionSalesroom::getId,
-                            AuctionSalesroom::getSalesroomName));
+
             list.forEach(order -> {
                 if (order.getAuctionType() == AuctionOrderTypeEnum.AUCTION_ITEMS) {
                     order.setSalesroomName(
                             StringUtils.isNotBlank(salesroomMap.get(order.getGoodsSkuId()))
-                                    ? salesroomMap.get(order.getGoodsSkuId()) : "无");
+                                    ? salesroomMap.get(order.getAuctionSalesroomId()) : "无");
                     order.setBoundStatus(
                             StringUtils.isNotNull(auctionSalesroomBondMap.get(
-                                            order.getGoodsSkuId() + "-" + order.getMemberId())
+                                            order.getAuctionSalesroomId() + "-" + order.getMemberId())
                                     .getBoundStatus())
                                     ? auctionSalesroomBondMap.get(
-                                            order.getGoodsSkuId() + "-" + order.getMemberId())
+                                            order.getAuctionSalesroomId() + "-" + order.getMemberId())
                                     .getBoundStatus()
                                     : null);
                 }
@@ -809,7 +981,7 @@
             mgtOrderVO.setPhone(member.getPhone());
         }
         // 拍卖订单查询拍卖会信息
-        if (order.getOrderFrom() == OrderFromEnum.AUCTION_ORDERS && (order.getAuctionType()
+        if (order.getOrderFrom() == OrderFromEnum.AUCTION_ORDERS && (order.getAuctionOrderType()
                 == AuctionOrderTypeEnum.AUCTION_ITEMS)) {
             List<AuctionSalesroom> auctionSalesroom = auctionClient.getAuctionSalesroomByIds(
                     Lists.newArrayList(order.getGoodsSkuId())
@@ -901,9 +1073,7 @@
             boolean result = handleRefund(paymentMethod, paylog, orderNo);
             if (result) {
                 paylog.setState(3);// 已退款
-                order.setOrderStatus(OrderStatusEnum.REFUNDED);
                 iPaylogService.updateById(paylog);
-                this.updateById(order);
             }
             OrderReturnRequest orderReturnRequest = new OrderReturnRequest();
             orderReturnRequest.setOrderId(id);
@@ -946,12 +1116,17 @@
     @Override
     public void refundReturn(Long id) {
         Order order = getOrder(id);
-        if (order.getOrderStatus() == OrderStatusEnum.TO_BE_SHIPPED
-                || order.getOrderStatus() == OrderStatusEnum.GOODS_TO_BE_RECEIVED
-                || order.getOrderStatus() == OrderStatusEnum.FINISHED) {
+        if (order.getOrderStatus() == OrderStatusEnum.FINISHED) {
             OrderReturnRequest orderReturnRequest = new OrderReturnRequest();
             order.setOrderStatus(OrderStatusEnum.AFTER_SALE);
             this.updateById(order);
+            MgtAfterSaleSettingDTO data = sysUserClient.getAfterSaleSetting().getData();
+            if (StringUtils.isNull(data)) {
+                throw new ServiceException("获取售后退货信息失败");
+            }
+            orderReturnRequest.setRecipientName(data.getReceiverName());
+            orderReturnRequest.setRecipientPhone(data.getReceiverPhone());
+            orderReturnRequest.setDetailedAddress(data.getReceiverAddress());
             orderReturnRequest.setOrderId(id);
             orderReturnRequest.setRequestTime(LocalDateTime.now());
             orderReturnRequest.setRequestType(RequestTypeEnum.REFUNDS_AND_RETURNS);
@@ -979,12 +1154,30 @@
     @Override
     public void refundBond(Long id) {
         Order order = getOrder(id);
-        OrderAuctionBond orderAuctionBond = orderAuctionBondMapper.selectOne(
-                Wrappers.lambdaQuery(OrderAuctionBond.class)
-                        .eq(OrderAuctionBond::getOrderId, id));
+        OrderAuctionBond orderAuctionBond;
+        if (order.getAuctionOrderType() == AuctionOrderTypeEnum.AUCTION_ITEMS) {
+            orderAuctionBond = orderAuctionBondMapper.selectOne(
+                    Wrappers.lambdaQuery(OrderAuctionBond.class)
+                            .eq(OrderAuctionBond::getAuctionSalesroomId,
+                                    order.getAuctionSalesroomId())
+                            .eq(OrderAuctionBond::getBoundStatus, BondStatusEnum.PAID));
+            if (StringUtils.isNotNull(orderAuctionBond)
+                    && orderAuctionBond.getBoundStatus() == BondStatusEnum.REFUNDED) {
+                throw new ServiceException("改拍卖会已退保证金");
+            }
+        } else {
+            orderAuctionBond = orderAuctionBondMapper.selectOne(
+                    Wrappers.lambdaQuery(OrderAuctionBond.class)
+                            .eq(OrderAuctionBond::getAuctionGoodsId,
+                                    order.getGoodsSkuId())
+                            .eq(OrderAuctionBond::getBoundStatus, BondStatusEnum.PAID));
+        }
         Paylog paylog = iPaylogService.lambdaQuery()
                 .eq(Paylog::getOutTradeNo, orderAuctionBond.getOrderNo())
                 .last("limit 1").one();
+        if (StringUtils.isNull(paylog)) {
+            throw new ServiceException("支付记录不存在");
+        }
         PaymentMethodEnum paymentMethod = orderAuctionBond.getPaymentMethod();
         if (orderAuctionBond.getBoundStatus() == BondStatusEnum.PAID) {
             boolean result = handleRefund(paymentMethod, paylog, orderAuctionBond.getOrderNo());

--
Gitblit v1.7.1