From c9bcbceb7112358c780688ffbd0ebb3ef528e65e Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期五, 07 四月 2023 18:40:06 +0800
Subject: [PATCH] 首页管理

---
 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java |  385 ++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 364 insertions(+), 21 deletions(-)

diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java
index 982c9e1..99cbd75 100644
--- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java
+++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java
@@ -4,21 +4,28 @@
 import com.stylefeng.guns.core.base.controller.BaseController;
 import com.stylefeng.guns.core.common.constant.state.Order;
 import com.stylefeng.guns.core.shiro.ShiroKit;
+import com.stylefeng.guns.core.util.ToolUtil;
 import com.stylefeng.guns.modular.system.controller.resp.TOrderServerResp;
 import com.stylefeng.guns.modular.system.enums.OrderStateEnum;
+import com.stylefeng.guns.modular.system.enums.StatusEnum;
 import com.stylefeng.guns.modular.system.model.TAgent;
 import com.stylefeng.guns.modular.system.model.TDriver;
 import com.stylefeng.guns.modular.system.model.TOrder;
 import com.stylefeng.guns.modular.system.service.*;
 import com.stylefeng.guns.modular.system.util.DateUtil;
+import com.stylefeng.guns.modular.system.util.RedisUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Controller;
 import org.springframework.ui.Model;
+import org.springframework.util.CollectionUtils;
+import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.ResponseBody;
 
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
 import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 控制器
@@ -40,6 +47,10 @@
     private ITOrderService tOrderService;
     @Autowired
     private ITRevenueService tRevenueService;
+    @Autowired
+    private ITDriverWorkService tDriverWorkService;
+    @Autowired
+    private RedisUtil redisUtil;
 
     private String PREFIX = "/system/tHomePage/";
 
@@ -48,30 +59,188 @@
      */
     @RequestMapping("/map")
     public String map(Integer agentId,Integer type,Model model) {
+        // 查询所有代理商
+        List<TAgent> agentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                .ne("status", StatusEnum.DELETE.getCode())
+                .ne("principal",""));
+        model.addAttribute("agentList",agentList);
+        // 查询广东全区域数据 查询广东所有的代理商
+        List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                .eq("provinceCode", "440000"));
+        List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+        // 查询统计在线司机,待接单,服务中,已完成,已取消
+        List<TDriver> onLineDriver = tDriverService.selectList(new EntityWrapper<TDriver>()
+                .in("agentId", ids)
+                .eq("serverStatus", 2));
 
+        model.addAttribute("onLineDriverCount",onLineDriver.size());
+        tOrderService.getDataStatisticsCountByIds(ids,model);
+        // 查询服务中的订单列表
+        List<TOrderServerResp> orderServerRespList = tOrderService.getDataStatisticsServerListByIds(ids);
+        // 查询司机
+        for (TOrderServerResp tOrderServerResp : orderServerRespList) {
+            TDriver tDriver = tDriverService.selectById(tOrderServerResp.getDriverId());
+            tOrderServerResp.setAvatar(tDriver.getAvatar());
+            tOrderServerResp.setDriverName(tDriver.getName());
+        }
+        model.addAttribute("serverList",orderServerRespList);
+        // 查询今天所有订单
+        List<TOrder> allList = tOrderService.getDataStatisticsAllListByIds(ids,type);
+        List<List<String>> list = new ArrayList<>(allList.size());
+        for (TOrder tOrder : allList) {
+            List<String> obj = new ArrayList<>(3);
+            obj.add(tOrder.getStartLng());
+            obj.add(tOrder.getStartLat());
+            obj.add(String.valueOf(tOrder.getState()));
+            list.add(obj);
+        }
+        model.addAttribute("allList",list);
+        List<List<String>> list1 = new ArrayList<>(allList.size());
+        for (TDriver tDriver : onLineDriver) {
+            List<String> obj = new ArrayList<>(3);
+            String value = redisUtil.getValue("DRIVER" + tDriver.getId());
+            if(ToolUtil.isEmpty(value)){
+                continue;
+            }
+            obj.add(value.split(",")[0]);// 经度
+            obj.add(value.split(",")[1]);// 纬度
+            obj.add(String.valueOf(tDriver.getServerStatus()));// 服务状态
+            list1.add(obj);
+        }
+        // 拿到所有在线司机地址
+        model.addAttribute("onLineDriver",list1);
+        return PREFIX + "tHomePageMap.html";
+    }
+
+    @RequestMapping("/getMap")
+    @ResponseBody
+    public Object getMap(Integer agentId,Integer type,Model model) {
+        HashMap<String, Object> map = new HashMap<>();
+        // 查询所有代理商
+        List<TAgent> agentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                .ne("status", StatusEnum.DELETE.getCode())
+                .ne("principal",""));
+
+        map.put("agentList",agentList);
         if(Objects.nonNull(agentId)){
             // 查询统计在线司机,待接单,服务中,已完成,已取消
-            Map<String,Integer> map = new HashMap<>(4);
-            int serverCount = tDriverService.selectCount(new EntityWrapper<TDriver>()
+            List<TDriver> onLineDriver = tDriverService.selectList(new EntityWrapper<TDriver>()
                     .eq("agentId", agentId)
                     .eq("serverStatus", 2));
-            tOrderService.getDataStatisticsCount(agentId,map);
-            model.addAttribute("map",map);
-
+            map.put("onLineDriverCount",onLineDriver.size());
+            tOrderService.getDataStatisticsCountGetMap(agentId,map);
             // 查询服务中的订单列表
             List<TOrderServerResp> orderServerRespList = tOrderService.getDataStatisticsServerList(agentId);
-            model.addAttribute("serverList",orderServerRespList);
-
+            // 查询司机
+            for (TOrderServerResp tOrderServerResp : orderServerRespList) {
+                TDriver tDriver = tDriverService.selectById(tOrderServerResp.getDriverId());
+                tOrderServerResp.setAvatar(tDriver.getAvatar());
+                tOrderServerResp.setDriverName(tDriver.getName());
+            }
+            map.put("serverList",orderServerRespList);
             // 查询今天所有订单
-            List<TOrder> allList = tOrderService.getDataStatisticsAllList(agentId);
-
-            // TODO 拿到所有司机地址
-
+            List<TOrder> allList = tOrderService.getDataStatisticsAllList(agentId,type);
+            List<List<String>> list = new ArrayList<>(allList.size());
+            for (TOrder tOrder : allList) {
+                List<String> obj = new ArrayList<>(3);
+                obj.add(tOrder.getStartLng());
+                obj.add(tOrder.getStartLat());
+                obj.add(String.valueOf(tOrder.getState()));
+                list.add(obj);
+            }
+            map.put("allList",list);
+            List<List<String>> list1 = new ArrayList<>(allList.size());
+            for (TDriver tDriver : onLineDriver) {
+                List<String> obj = new ArrayList<>(3);
+                String value = redisUtil.getValue("DRIVER" + tDriver.getId());
+                if(ToolUtil.isEmpty(value)){
+                    continue;
+                }
+                obj.add(value.split(",")[0]);// 经度
+                obj.add(value.split(",")[1]);// 纬度
+                obj.add(String.valueOf(tDriver.getServerStatus()));// 服务状态
+                list1.add(obj);
+            }
+            // 拿到所有在线司机地址
+            map.put("onLineDriver",list1);
         }else {
-            // TODO 查询广东全区域数据
-        }
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            // 查询统计在线司机,待接单,服务中,已完成,已取消
+            List<TDriver> onLineDriver = tDriverService.selectList(new EntityWrapper<TDriver>()
+                    .in("agentId", ids)
+                    .eq("serverStatus", 2));
 
-        return PREFIX + "tHomePageMap.html";
+            map.put("onLineDriverCount",onLineDriver.size());
+            tOrderService.getDataStatisticsCountByIdsGetMap(ids,map);
+            // 查询服务中的订单列表
+            List<TOrderServerResp> orderServerRespList = tOrderService.getDataStatisticsServerListByIds(ids);
+            // 查询司机
+            for (TOrderServerResp tOrderServerResp : orderServerRespList) {
+                TDriver tDriver = tDriverService.selectById(tOrderServerResp.getDriverId());
+                tOrderServerResp.setAvatar(tDriver.getAvatar());
+                tOrderServerResp.setDriverName(tDriver.getName());
+            }
+            map.put("serverList",orderServerRespList);
+            // 查询今天所有订单
+            List<TOrder> allList = tOrderService.getDataStatisticsAllListByIds(ids,type);
+            List<List<String>> list = new ArrayList<>(allList.size());
+            for (TOrder tOrder : allList) {
+                List<String> obj = new ArrayList<>(3);
+                obj.add(tOrder.getStartLng());
+                obj.add(tOrder.getStartLat());
+                obj.add(String.valueOf(tOrder.getState()));
+                list.add(obj);
+            }
+            map.put("allList",list);
+            List<List<String>> list1 = new ArrayList<>(allList.size());
+            for (TDriver tDriver : onLineDriver) {
+                List<String> obj = new ArrayList<>(3);
+                String value = redisUtil.getValue("DRIVER" + tDriver.getId());
+                if(ToolUtil.isEmpty(value)){
+                    continue;
+                }
+                obj.add(value.split(",")[0]);// 经度
+                obj.add(value.split(",")[1]);// 纬度
+                obj.add(String.valueOf(tDriver.getServerStatus()));// 服务状态
+                list1.add(obj);
+            }
+            // 拿到所有在线司机地址
+            map.put("onLineDriver",list1);
+        }
+        return map;
+    }
+
+    @RequestMapping("/getServerOrder")
+    @ResponseBody
+    public Object getServerOrder(Integer agentId,Model model) {
+        HashMap<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 查询服务中的订单列表
+            List<TOrderServerResp> orderServerRespList = tOrderService.getDataStatisticsServerList(agentId);
+            // 查询司机
+            for (TOrderServerResp tOrderServerResp : orderServerRespList) {
+                TDriver tDriver = tDriverService.selectById(tOrderServerResp.getDriverId());
+                tOrderServerResp.setAvatar(tDriver.getAvatar());
+                tOrderServerResp.setDriverName(tDriver.getName());
+            }
+            map.put("serverList",orderServerRespList);
+        }else {
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            // 查询服务中的订单列表
+            List<TOrderServerResp> orderServerRespList = tOrderService.getDataStatisticsServerListByIds(ids);
+            // 查询司机
+            for (TOrderServerResp tOrderServerResp : orderServerRespList) {
+                TDriver tDriver = tDriverService.selectById(tOrderServerResp.getDriverId());
+                tOrderServerResp.setAvatar(tDriver.getAvatar());
+                tOrderServerResp.setDriverName(tDriver.getName());
+            }
+            map.put("serverList",orderServerRespList);
+        }
+        return map;
     }
 
     /**
@@ -79,33 +248,207 @@
      */
     @RequestMapping("/statistics")
     public String statistics(Integer agentId,String dayDate,String yearDate,String monthDate,Integer type,Model model) {
+        if(Objects.isNull(type)){
+            type = 1;
+        }
         model.addAttribute("txt",new SimpleDateFormat("yyyy年MM月dd日").format(new Date()) + DateUtil.getWeekDay(new Date()) + ",欢迎" +
                 Objects.requireNonNull(ShiroKit.getUser()).getName() + "登录");
+        // 查询所有代理商
+        List<TAgent> agentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                .ne("status", StatusEnum.DELETE.getCode())
+                .ne("principal",""));
+        model.addAttribute("agentList",agentList);
+        Map<String, Object> map = new HashMap<>();
         if(Objects.nonNull(agentId)){
             // 统计代理商
-            tAgentService.getDataStatistics(agentId,model);
+            tAgentService.getDataStatistics(agentId,model,map);
 
             // 统计司机数
-            tDriverService.getDataStatistics(agentId,model);
+            tDriverService.getDataStatistics(agentId,model,map);
 
-            // TODO 订单统计:按今天,昨天,本周,本月
+            // 订单统计本月
+            tOrderService.getStatisticsOrderByMonth(agentId,dayDate,model,map);
 
             // 订单统计,每年按月份
-            tOrderService.getDataStatisticsByYear(agentId,yearDate,model);
+            tOrderService.getDataStatisticsByYear(agentId,yearDate,model,map);
 
             // 业绩排名 performanceTable
             if (1 == type){
                 // 单量
-                tOrderService.getDataStatisticsOrderCount(agentId,monthDate,model);
+                tOrderService.getDataStatisticsOrderCount(agentId,monthDate,model,map);
             }else {
                 // 收入、佣金
-                tRevenueService.getDataStatisticsIncomeOrCommission(agentId,monthDate,type,model);
+                tRevenueService.getDataStatisticsIncomeOrCommission(agentId,monthDate,type,model,map);
             }
 
         }else {
-            // TODO 查询广东全区域数据
+            // 查询广东全区域数据 查询广东所有的代理商
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            // 统计代理商
+            tAgentService.getDataStatisticsByIds(ids,model,map);
+
+            // 统计司机数
+            tDriverService.getDataStatisticsByIds(ids,model,map);
+
+            // 订单统计本月
+            tOrderService.getStatisticsOrderByMonthIds(ids,dayDate,model,map);
+
+            // 订单统计,每年按月份
+            tOrderService.getDataStatisticsByYearByIds(ids,yearDate,model,map);
+
+            // 业绩排名 performanceTable
+            if (1 == type){
+                // 单量
+                tOrderService.getDataStatisticsOrderCountByIds(ids,monthDate,model,map);
+            }else {
+                // 收入、佣金
+                tRevenueService.getDataStatisticsIncomeOrCommissionByIds(ids,monthDate,type,model,map);
+            }
         }
         return PREFIX + "tHomePageStatistics.html";
     }
 
+
+    /**
+     * 首页统计通过代理商查询
+     */
+    @RequestMapping("/statisticsByAgentId")
+    @ResponseBody
+    public Map<String, Object> statisticsByAgentId(Integer agentId, String dayDate, String yearDate, String monthDate, Integer type, Model model) {
+        Map<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 统计代理商
+            tAgentService.getDataStatistics(agentId,model,map);
+
+            // 统计司机数
+            tDriverService.getDataStatistics(agentId,model,map);
+
+            // 订单统计本月
+            tOrderService.getStatisticsOrderByMonth(agentId,dayDate,model,map);
+
+            // 订单统计,每年按月份
+            tOrderService.getDataStatisticsByYear(agentId,yearDate,model,map);
+
+            // 业绩排名 performanceTable
+            if (1 == type){
+                // 单量
+                tOrderService.getDataStatisticsOrderCount(agentId,monthDate,model,map);
+            }else {
+                // 收入、佣金
+                tRevenueService.getDataStatisticsIncomeOrCommission(agentId,monthDate,type,model,map);
+            }
+
+        }
+        return map;
+    }
+
+    /**
+     * 首页统计通过代理商查询订单量 今天,昨天,本周,本月
+     */
+    @RequestMapping("/statisticsMonthByAgentId")
+    @ResponseBody
+    public Map<String, Object> statisticsMonthByAgentId(Integer agentId, String dayDate,Model model) {
+        dayDate = new SimpleDateFormat("yyyy-MM").format(new Date());
+        Map<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 订单统计本月
+            tOrderService.getStatisticsOrderByMonth(agentId,dayDate,model,map);
+        }else {
+            // 查询广东全区域数据 查询广东所有的代理商
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            // 订单统计本月
+            tOrderService.getStatisticsOrderByMonthIds(ids,dayDate,model,map);
+        }
+        return map;
+    }
+
+    /**
+     * 首页统计通过代理商查询订单量 按年
+     */
+    @RequestMapping("/statisticsYearByAgentId")
+    @ResponseBody
+    public Map<String, Object> statisticsYearByAgentId(Integer agentId, String yearDate,Model model) {
+        if(!StringUtils.hasLength(yearDate)){
+            yearDate = new SimpleDateFormat("yyyy").format(new Date());
+        }
+        Map<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 订单统计,每年按月份
+            tOrderService.getDataStatisticsByYear(agentId,yearDate,model,map);
+        }else {
+            // 查询广东全区域数据 查询广东所有的代理商
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            tOrderService.getDataStatisticsByYearByIds(ids,yearDate,model,map);
+        }
+        return map;
+    }
+
+    /**
+     * 首页统计通过代理商查询订单量,收入,佣金 按年
+     */
+    @RequestMapping("/statisticsOrderByAgentId")
+    @ResponseBody
+    public Map<String, Object> statisticsOrderByAgentId(Integer agentId, String monthDate,Integer type,Model model) {
+        if(Objects.isNull(type)){
+            type = 1;
+        }
+        if(!StringUtils.hasLength(monthDate)){
+            monthDate = new SimpleDateFormat("yyyy-MM").format(new Date());
+        }
+        Map<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 业绩排名 performanceTable
+            if (1 == type){
+                // 单量
+                tOrderService.getDataStatisticsOrderCount(agentId,monthDate,model,map);
+            }else {
+                // 收入、佣金
+                tRevenueService.getDataStatisticsIncomeOrCommission(agentId,monthDate,type,model,map);
+            }
+        }else {
+            // 业绩排名 performanceTable
+            // 查询广东全区域数据 查询广东所有的代理商
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            if (1 == type){
+                // 单量
+                tOrderService.getDataStatisticsOrderCountByIds(ids,monthDate,model,map);
+            }else {
+                // 收入、佣金
+                tRevenueService.getDataStatisticsIncomeOrCommissionByIds(ids,monthDate,type,model,map);
+            }
+        }
+        return map;
+    }
+
+    /**
+     * 首页统计通过代理商查询司机数量
+     */
+    @RequestMapping("/statisticsDriverByAgentId")
+    @ResponseBody
+    public Map<String, Object> statisticsDriverByAgentId(Integer agentId,Model model) {
+        Map<String, Object> map = new HashMap<>();
+        if(Objects.nonNull(agentId)){
+            // 统计司机数
+            tDriverService.getDataStatistics(agentId,model,map);
+            tAgentService.getDataStatistics(agentId,model,map);
+        }else {
+            // 统计司机数
+            // 查询广东全区域数据 查询广东所有的代理商
+            List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>()
+                    .eq("provinceCode", "440000"));
+            List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList());
+            tDriverService.getDataStatisticsByIds(ids,model,map);
+            tAgentService.getDataStatisticsByIds(ids,model,map);
+        }
+        return map;
+    }
+
 }

--
Gitblit v1.7.1