From 3e9bc147f05ab3ce8db0afcf6272b95b543eb89a Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 16 八月 2024 13:40:26 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/mx_charging_pile

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java |  104 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 93 insertions(+), 11 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 446c350..0208eb3 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
@@ -2,20 +2,32 @@
 
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.ruoyi.account.api.feignClient.AppUserClient;
+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.page.PageInfo;
+import com.ruoyi.order.api.model.TChargingOrder;
 import com.ruoyi.order.api.model.TExchangeOrder;
 import com.ruoyi.order.api.model.TShoppingOrder;
+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.service.TChargingOrderService;
 import com.ruoyi.order.service.TExchangeOrderService;
 import com.ruoyi.order.service.TShoppingOrderService;
+import com.ruoyi.order.service.TVipOrderService;
+import com.ruoyi.order.service.impl.TChargingOrderServiceImpl;
 import io.swagger.annotations.Api;
 import io.swagger.models.auth.In;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.util.StringUtils;
+import org.springframework.web.bind.annotation.*;
 
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -33,12 +45,46 @@
     private TShoppingOrderService tShoppingOrderService;
     @Autowired
     private TExchangeOrderService exchangeOrderService;
+    @Autowired
+    private TChargingOrderService chargingOrderService;
+    @Autowired
+    private TVipOrderService vipOrderService;
+    @Autowired
+    private AppUserClient appUserClient;
+    @Autowired
+    private ChargingPileClient chargingPileClient;
     /**
-     * 管理后台 根据商品ids 查询对应的销量
-     * @param goodsIds
+     * 管理后台 活动费用统计
+     * @param
      * @return
      */
-    @PostMapping("/t-exchange-order/getSalesCountByGoodsIds")
+    @PostMapping(value = "/activityStatistics")
+    public R<TActivityVO> activityStatistics(@RequestBody TActivityStatisticsQuery dto) {
+        if (StringUtils.hasLength(dto.getPhone())){
+            // 远程调用查询出符合条件的用户ids
+            List<Long> data = appUserClient.getUserIdsByPhone(dto.getPhone()).getData();
+            dto.setUserIds(data);
+        }
+        if (dto.getSiteId()!=null){
+            // 远程调用查询出符合条件的充电桩ids
+            List<TChargingPile> data = chargingPileClient.getChargingPileBySiteId(dto.getSiteId()).getData();
+            dto.setChargingPileIds(data.stream().map(TChargingPile::getId).collect(Collectors.toList()));
+        }
+        return R.ok(tShoppingOrderService.activityStatistics(dto));
+    }
+
+    //订单详情
+    @PostMapping(value = "/detail")
+    public R<TExchangeOrder> detail(@RequestParam("orderId") Long orderId) {
+        return R.ok(exchangeOrderService.getById(orderId));
+    }
+
+    /**
+     * 管理后台 根据商品ids 查询对应的销量
+     * @param goodsIds  订单号-商品类型
+     * @return
+     */
+    @PostMapping("/getSalesCountByGoodsIds")
     public R<List<Integer>> getSalesCountByGoodsId(String goodsIds){
         String[] split = goodsIds.split("-");
         // 取出最后一位字符 类型1查询现金购买 类型2查询积分兑换
@@ -47,13 +93,11 @@
         switch (Integer.parseInt(s)){
             case 1:
                 for (int i = 0; i < split.length-1; i++) {
-
                     Integer reduce = tShoppingOrderService.list(new QueryWrapper<TShoppingOrder>()
                                     .eq("goods_id", split[i])
                                     .eq("payment_status", 2)
                                     .ne("refund_status", 2))
                             .stream().map(TShoppingOrder::getPurchaseQuantity).reduce(0, Integer::sum);
-
                     res.add(reduce);
                 }
                 break;
@@ -63,14 +107,52 @@
                                     .eq("goods_id", split[i])
                                     )
                             .stream().map(TExchangeOrder::getPurchaseQuantity).reduce(0, Integer::sum);
-
                     res.add(reduce);
                 }
                 break;
         }
-
-
         return R.ok(res);
     }
+    /**
+     * 管理后台 根据t_app_coupon订单ids查询优惠券的订单编号
+     * @param goodsIds  订单号-商品类型
+     * @return
+     */
+    @PostMapping("/getCodeByOrderId")
+    public R<List<String>> getCodeByOrderId(String goodsIds){
+        String[] split = goodsIds.split("-");
+        List<String> strings = new ArrayList<>();
+        for (String s : split) {
+            if (s.contains("-")){
+                // 带有负号的是积分兑换的订单
+                TExchangeOrder one = exchangeOrderService.getOne(new QueryWrapper<TExchangeOrder>()
+                        .eq("order_type", 2)
+                        .eq("id", s.replace("-","")));
+                if (one != null){
+                    strings.add(one.getCode());
+                }else{
+                    strings.add("");
+                }
+            }else{
+                TShoppingOrder one = tShoppingOrderService.getOne(new QueryWrapper<TShoppingOrder>()
+                        .eq("order_type", 2)
+                        .eq("id", s));
+                if (one != null){
+                    strings.add(one.getCode());
+                }else{
+                    strings.add("");
+                }
+            }
+
+        }
+
+        return R.ok(strings);
+    }
+    /**
+     * 管理后台 根据t_app_coupon订单ids查询积分兑换优惠券的订单编号
+     * @param goodsIds  订单号-商品类型
+     * @return
+     */
+
 }
 

--
Gitblit v1.7.1