From 46f06aa49b1fd284472ee13a1a8345d0046f33b8 Mon Sep 17 00:00:00 2001
From: zhibing.pu <393733352@qq.com>
Date: 星期四, 05 九月 2024 12:11:19 +0800
Subject: [PATCH] 完善功能

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java |  134 +++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 119 insertions(+), 15 deletions(-)

diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
index 92e56a0..ac3e50d 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
@@ -5,13 +5,18 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.ruoyi.account.api.feignClient.AppUserClient;
+import com.ruoyi.account.api.model.TAppUserAddress;
 import com.ruoyi.chargingPile.api.feignClient.ChargingPileClient;
 import com.ruoyi.chargingPile.api.model.TChargingPile;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.web.domain.AjaxResult;
+import com.ruoyi.common.core.web.page.PageInfo;
+import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.order.api.model.TExchangeOrder;
 import com.ruoyi.order.api.model.TShoppingOrder;
+import com.ruoyi.order.api.query.ShoppingOrderQuery;
 import com.ruoyi.order.api.query.TActivityStatisticsQuery;
+import com.ruoyi.order.api.vo.TActivityStatisticslVO;
 import com.ruoyi.order.api.vo.TActivityVO;
 import com.ruoyi.order.dto.ExchangeOrderGoodsInfo;
 import com.ruoyi.order.dto.GetMyExchangeOrder;
@@ -20,15 +25,20 @@
 import com.ruoyi.order.service.TShoppingOrderService;
 import com.ruoyi.common.core.dto.ExchangeDto;
 import com.ruoyi.common.core.utils.OrderCodeUtil;
+import com.ruoyi.other.api.feignClient.CouponClient;
+import com.ruoyi.other.api.feignClient.GoodsClient;
+import com.ruoyi.payment.api.feignClient.AliPaymentClient;
+import com.ruoyi.payment.api.feignClient.WxPaymentClient;
+import com.ruoyi.system.api.domain.SysUser;
+import com.ruoyi.system.api.feignClient.SysUserClient;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
@@ -52,6 +62,97 @@
     private AppUserClient appUserClient;
     @Resource
     private ChargingPileClient chargingPileClient;
+    @Resource
+    private GoodsClient goodsClient;
+    @Resource
+    private CouponClient couponClient;
+
+
+    @PostMapping("/getExchangeOrderList")
+    @ApiOperation(value = "列表查询", tags = {"管理后台-兑换订单"})
+    public AjaxResult<PageInfo<TExchangeOrder>> getExchangeOrderList(@RequestBody ShoppingOrderQuery query) {
+        if (StringUtils.hasLength(query.getPhone())) {
+            List<Long> data = appUserClient.getUserIdsByPhone(query.getPhone()).getData();
+            if (data.isEmpty()){
+                return AjaxResult.success(new PageInfo<TShoppingOrder>());
+            }
+            query.setUserIds(data);
+        }
+        if (StringUtils.hasLength(query.getName())) {
+            List<Integer> data = goodsClient.getGoodsIdsByName(query.getName()).getData();
+            query.setGoodsIds(data);
+            List<Integer> data1 = couponClient.getCouponIdsByName(query.getName()).getData();
+            query.setCouponIds(data1);
+            if (data.isEmpty() && data1.isEmpty()){
+                return AjaxResult.success(new PageInfo<TShoppingOrder>());
+            }
+        }
+
+        PageInfo<TExchangeOrder> res = exchangeOrderService.pageList(query);
+        return AjaxResult.success(res);
+    }
+    @Resource
+    private SysUserClient sysUserClient;
+    @GetMapping("/getShoppingOrderInfoById")
+    @ApiOperation(value = "根据订单id查看订单详情", tags = {"管理后台-兑换订单"})
+    public AjaxResult<TExchangeOrder> getShoppingOrderList(String id) {
+        TExchangeOrder byId = exchangeOrderService.getById(id);
+        if (byId.getConsignerId()!=null){
+            SysUser data = sysUserClient.getSysUser(byId.getConsignerId()).getData();
+            if (data!=null){
+                byId.setConsignerName(data.getUserName());
+            }
+        }
+        if (byId.getCancellationId()!=null){
+            SysUser data = sysUserClient.getSysUser(byId.getCancellationId()).getData();
+            if (data!=null){
+                byId.setCancellationName(data.getUserName());
+            }
+        }
+        if (byId.getAppUserAddressId()!=null){
+            TAppUserAddress data = appUserClient.getAddressById(byId.getAppUserAddressId()).getData();
+            if (data!=null){
+                byId.setReceivingName(data.getName()+"-"+data.getPhone());
+                byId.setReceivingAddress(data.getAddress());
+            }
+        }
+        return AjaxResult.success(byId);
+    }
+    @Resource
+    private TokenService tokenService;
+    @GetMapping("/deleteShoppingOrder")
+    @ApiOperation(value = "批量删除订单", tags = {"管理后台-兑换订单"})
+    public AjaxResult<TExchangeOrder> deleteShoppingOrder(String ids) {
+        exchangeOrderService.removeBatchByIds(Arrays.asList(ids.split(",")));
+        return AjaxResult.success();
+    }
+    @GetMapping("/cancelShoppingOrder")
+    @ApiOperation(value = "取消订单", tags = {"管理后台-兑换订单"})
+    public AjaxResult cancelShoppingOrder(String id) {
+        TExchangeOrder byId = exchangeOrderService.getById(id);
+        Long userid = tokenService.getLoginUser().getUserid();
+        byId.setCancellationId(userid);
+        byId.setCancellationTime(LocalDateTime.now());
+        byId.setStatus(4);
+        exchangeOrderService.updateById(byId);
+        // 回退积分
+        Integer points = byId.getPoints();
+        appUserClient.refundPoints(byId.getAppUserId()+"-"+points);
+        return AjaxResult.success();
+    }
+    @GetMapping("/consignerShoppingOrder")
+    @ApiOperation(value = "发货", tags = {"管理后台-兑换订单"})
+    public AjaxResult consignerShoppingOrder(String id,String companyName,String code) {
+        TExchangeOrder byId = exchangeOrderService.getById(id);
+        byId.setExpressCompany(companyName);
+        byId.setExpressNumber(code);
+        Long userid = tokenService.getLoginUser().getUserid();
+        byId.setConsignerId(userid);
+        byId.setConsignerTime(LocalDateTime.now());
+        byId.setStatus(2);
+        exchangeOrderService.updateById(byId);
+        return AjaxResult.success();
+    }
     /**
      * 管理后台 活动费用统计
      * @param
@@ -62,6 +163,11 @@
         if (StringUtils.hasLength(dto.getPhone())){
             // 远程调用查询出符合条件的用户ids
             List<Long> data = appUserClient.getUserIdsByPhone(dto.getPhone()).getData();
+            if (data.isEmpty()){
+                TActivityVO res = new TActivityVO();
+                res.setList(new PageInfo<TActivityStatisticslVO>());
+                return R.ok(res);
+            }
             dto.setUserIds(data);
         }
         if (dto.getSiteId()!=null){
@@ -88,23 +194,21 @@
         String[] split = goodsIds.split("-");
         // 取出最后一位字符 类型1查询现金购买 类型2查询积分兑换
         String s = split[split.length - 1];
+        String[] split1 = split[0].split(",");
         List<Integer> res = new ArrayList<>();
         switch (Integer.parseInt(s)){
             case 1:
-                for (int i = 0; i < split.length-1; i++) {
+                for (int i = 0; i < split1.length; i++) {
                     Integer reduce = tShoppingOrderService.list(new QueryWrapper<TShoppingOrder>()
-                                    .eq("goods_id", split[i])
-                                    .eq("payment_status", 2)
+                                    .eq("order_type",1)
                                     .ne("refund_status", 2))
                             .stream().map(TShoppingOrder::getPurchaseQuantity).reduce(0, Integer::sum);
                     res.add(reduce);
                 }
                 break;
             case 2:
-                for (int i = 0; i < split.length-1; i++) {
-                    Integer reduce = exchangeOrderService.list(new QueryWrapper<TExchangeOrder>()
-                                    .eq("goods_id", split[i])
-                                    )
+                for (int i = 0; i < split1.length; i++) {
+                    Integer reduce = exchangeOrderService.list(new QueryWrapper<TExchangeOrder>().eq("order_type",1).ne("status",4).eq("goods_id", split1[i]))
                             .stream().map(TExchangeOrder::getPurchaseQuantity).reduce(0, Integer::sum);
                     res.add(reduce);
                 }
@@ -172,18 +276,18 @@
             tExchangeOrder.setCouponId(exchangeDto.getGoodId());
         }
         tExchangeOrder.setPurchaseQuantity(1);
-        tExchangeOrder.setAppUserAddressId(Long.valueOf(exchangeDto.getAddressId()));
+        tExchangeOrder.setAppUserAddressId(exchangeDto.getAddressId()==null?null:Long.valueOf(exchangeDto.getAddressId()));
         tExchangeOrder.setPoints(exchangeDto.getPoint());
         tExchangeOrder.setRemark("");
         if (exchangeDto.getGoodType()==1){
-            tExchangeOrder.setStatus(0);
+            tExchangeOrder.setStatus(1);
         }else {
             tExchangeOrder.setStatus(3);
         }
         tExchangeOrder.setCreateTime(LocalDateTime.now());
         tExchangeOrder.setDelFlag(false);
         exchangeOrderService.save(tExchangeOrder);
-        return R.ok();
+        return R.ok(tExchangeOrder.getId());
 
     }
     
@@ -191,8 +295,8 @@
     
     @GetMapping("/getMyExchangeOrder")
     @ApiOperation(value = "获取兑换记录列表", tags = {"小程序-兑换记录"})
-    public AjaxResult<List<MyExchangeOrderList>> getMyExchangeOrder(GetMyExchangeOrder query){
-        List<MyExchangeOrderList> list = exchangeOrderService.getMyExchangeOrder(query);
+    public AjaxResult<Map<String, Object>> getMyExchangeOrder(GetMyExchangeOrder query){
+        Map<String, Object> list = exchangeOrderService.getMyExchangeOrder(query);
         return AjaxResult.success(list);
     }
     

--
Gitblit v1.7.1