From 7ed6489395475fc41d33914dfcc940b75ff65101 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 18 五月 2023 16:35:29 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java |   77 +++++++++++++++++++++++++++++---------
 1 files changed, 59 insertions(+), 18 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 308b357..e966706 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
@@ -28,6 +28,7 @@
 import java.time.LocalDate;
 import java.time.Period;
 import java.util.*;
+import java.util.concurrent.atomic.AtomicInteger;
 import java.util.stream.Collectors;
 
 /**
@@ -130,7 +131,15 @@
         }
         model.addAttribute("allList",list);
         List<List<String>> list1 = new ArrayList<>();
+        AtomicInteger count = new AtomicInteger(0);
         for (TDriver tDriver : onLineDriver) {
+
+            String value1 = redisUtil.getValue("DRIVER_" + tDriver.getPhone());
+            String value2 = redisUtil.getValue(value1);
+            if(ToolUtil.isNotEmpty(value2)){
+                count.addAndGet(1);
+            }
+
             List<String> obj = new ArrayList<>(3);
             String value = redisUtil.getValue("DRIVER" + tDriver.getId());
             if(ToolUtil.isEmpty(value)){
@@ -141,7 +150,7 @@
             obj.add(String.valueOf(tDriver.getServerStatus()));// 服务状态
             list1.add(obj);
         }
-        model.addAttribute("onLineDriverCount",list1.size());
+        model.addAttribute("onLineDriverCount",count.get());
         // 拿到所有在线司机地址
         model.addAttribute("onLineDriver",list1);
         return PREFIX + "tHomePageMap.html";
@@ -150,7 +159,7 @@
     @RequestMapping("/getMap")
     @ResponseBody
     public Object getMap(Integer agentId,Integer type,Model model) {
-        Integer objectId = ShiroKit.getUser().getObjectId();
+        Integer objectId = Objects.requireNonNull(ShiroKit.getUser()).getObjectId();
         Integer roleType = ShiroKit.getUser().getRoleType();
         if(roleType == 3 && Objects.nonNull(objectId)){
             agentId = objectId;
@@ -183,8 +192,12 @@
                                 || order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode())
                                 || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList());
                 // 驾龄
-                Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
-                tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                if(Objects.nonNull(tDriver.getFirstCertificateTime())){
+                    Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
+                    tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                }else {
+                    tOrderServerResp.setDrivingExperience(0);
+                }
                 // 代驾次数
                 tOrderServerResp.setValetDrivingCount(collect.size());
                 // 行驶时间
@@ -199,8 +212,12 @@
                 }
                 tOrderServerResp.setGoTime(Long.valueOf(goTime).intValue());
                 // 行驶里程
-                int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
-                tOrderServerResp.setMileageTraveled(sum/1000);
+                if(CollectionUtils.isEmpty(collect)){
+                    tOrderServerResp.setMileageTraveled(0);
+                }else {
+                    int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
+                    tOrderServerResp.setMileageTraveled(sum/1000);
+                }
             }
             map.put("serverList",orderServerRespList);
             // 查询今天所有订单
@@ -254,8 +271,12 @@
                                 || order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode())
                                 || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList());
                 // 驾龄
-                Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
-                tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                if(Objects.nonNull(tDriver.getFirstCertificateTime())){
+                    Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
+                    tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                }else {
+                    tOrderServerResp.setDrivingExperience(0);
+                }
                 // 代驾次数
                 tOrderServerResp.setValetDrivingCount(collect.size());
                 // 行驶时间
@@ -270,8 +291,12 @@
                 }
                 tOrderServerResp.setGoTime(Long.valueOf(goTime).intValue());
                 // 行驶里程
-                int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
-                tOrderServerResp.setMileageTraveled(sum/1000);
+                if(CollectionUtils.isEmpty(collect)){
+                    tOrderServerResp.setMileageTraveled(0);
+                }else {
+                    int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
+                    tOrderServerResp.setMileageTraveled(sum/1000);
+                }
             }
             map.put("serverList",orderServerRespList);
 
@@ -330,8 +355,12 @@
                                 || order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode())
                                 || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList());
                 // 驾龄
-                Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
-                tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                if(Objects.nonNull(tDriver.getFirstCertificateTime())){
+                    Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
+                    tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                }else {
+                    tOrderServerResp.setDrivingExperience(0);
+                }
                 // 代驾次数
                 tOrderServerResp.setValetDrivingCount(collect.size());
                 // 行驶时间
@@ -346,8 +375,12 @@
                 }
                 tOrderServerResp.setGoTime(Long.valueOf(goTime).intValue());
                 // 行驶里程
-                int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
-                tOrderServerResp.setMileageTraveled(sum/1000);
+                if(CollectionUtils.isEmpty(collect)){
+                    tOrderServerResp.setMileageTraveled(0);
+                }else {
+                    int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
+                    tOrderServerResp.setMileageTraveled(sum/1000);
+                }
             }
             map.put("serverList",orderServerRespList);
         }else {
@@ -366,8 +399,12 @@
                                 || order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode())
                                 || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList());
                 // 驾龄
-                Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
-                tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                if(Objects.nonNull(tDriver.getFirstCertificateTime())){
+                    Period period = Period.between(LocalDate.now(), DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime()));
+                    tOrderServerResp.setDrivingExperience(Math.max(Math.abs(period.getYears()), 1));
+                }else {
+                    tOrderServerResp.setDrivingExperience(0);
+                }
                 // 代驾次数
                 tOrderServerResp.setValetDrivingCount(collect.size());
                 // 行驶时间
@@ -382,8 +419,12 @@
                 }
                 tOrderServerResp.setGoTime(Long.valueOf(goTime).intValue());
                 // 行驶里程
-                int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
-                tOrderServerResp.setMileageTraveled(sum/1000);
+                if(CollectionUtils.isEmpty(collect)){
+                    tOrderServerResp.setMileageTraveled(0);
+                }else {
+                    int sum = collect.stream().mapToInt(TOrder::getActualMileage).sum();
+                    tOrderServerResp.setMileageTraveled(sum/1000);
+                }
             }
             map.put("serverList",orderServerRespList);
         }

--
Gitblit v1.7.1