From 7f6033c2b60979a9566b33440b716d17803e18aa Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期六, 20 一月 2024 14:28:38 +0800
Subject: [PATCH] 查询本部门在线PC端及指挥端修改提交

---
 ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java |   29 +++++++++++++++++++++++------
 1 files changed, 23 insertions(+), 6 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
index 5c227bb..141edd6 100644
--- a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
@@ -14,6 +14,7 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.scheduling.domian.SchedulingParam;
+import com.ruoyi.system.mapper.SysUserMapper;
 import com.ruoyi.system.service.ISysUserService;
 import com.ruoyi.utils.gis.GisUtil;
 import com.ruoyi.utils.gis.Point;
@@ -24,6 +25,8 @@
 import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.stream.Collectors;
+
+import static com.ruoyi.utils.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS;
 
 
 /**
@@ -45,6 +48,8 @@
     ArdWallMapper ardWallMapper;
     @Resource
     IArdAlarmWallService ardAlarmWallService;
+    @Resource
+    private SysUserMapper sysUserMapper;
 
     Map<String, String> firstAlarmMap = new HashMap<>();//棣栨鎶ヨ缂撳瓨key:鐢ㄦ埛id_鍥存爮id value: 鎶ヨid
     /**
@@ -238,12 +243,8 @@
         List<ArdAlarmWall> ardAlarmWalls = new ArrayList<>();
         //鑾峰彇褰撳墠鐢ㄦ埛鐨勯儴闂�
         String userId = ardAppPosition.getUserId();
-        SysUser sysUser = redisCache.getCacheObject("user_list:" + userId);
-        Long deptId = sysUser.getDeptId();
-        //鑾峰彇褰撳墠閮ㄩ棬鍙婂瓙閮ㄩ棬涓嬬殑鎵�鏈夌數瀛愬洿鏍�
-        ArdWall ardWall = new ArdWall();
-        ardWall.setDeptId(deptId);
-        List<ArdWall> ardWalls = ardWallMapper.selectArdWallList(ardWall);
+        //鑾峰彇鐢ㄦ埛鍏宠仈鐨勬墍鏈夌數瀛愬洿鏍�
+        List<ArdWall> ardWalls = ardWallMapper.selectArdWallListByUserId(userId);
         if (ardWalls.size() > 0) {
             //閬嶅巻鎵�鏈夌數瀛愬洿鏍�
             for (ArdWall wall : ardWalls) {
@@ -325,4 +326,20 @@
         }
         return ardAlarmWalls;
     }
+
+    @Override
+    public Map<String, List<SysUser>> getOnlinePCOrCommander(String usersId) {
+        Map<String, List<SysUser>> result = new HashMap();
+        List<SysUser> commanderList = sysUserMapper.getOnlineCommander(usersId);
+        result.put("commander",commanderList);
+        try{
+            List<String> onLinePCIdList = new ArrayList();
+            onLinePCIdList.addAll(ONLINE_USER_SESSIONS.keySet());
+            List<SysUser> pcList = sysUserMapper.getOnlinePC(usersId,onLinePCIdList);
+            result.put("pc",pcList);
+        }catch(Exception e){
+            result.put("pc",new ArrayList());
+        }
+        return result;
+    }
 }

--
Gitblit v1.9.3