From 779c235959bd1979381b07ffe561242c9cdd9ce2 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期一, 19 二月 2024 15:32:35 +0800
Subject: [PATCH] 指挥端查看权限下全部单兵端提交

---
 ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml |   93 +++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 79 insertions(+), 14 deletions(-)

diff --git a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
index 5f916c9..66aa0b8 100644
--- a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
+++ b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
@@ -24,6 +24,8 @@
         <result property="updateTime" column="update_time"/>
         <result property="cameraPriority" column="camera_priority"/>
         <result property="rongCloudToken" column="rong_cloud_token"/>
+        <result property="appUserType" column="app_user_type"/>
+        <result property="appOnlineState" column="app_online_state"/>
         <result property="remark" column="remark"/>
         <association property="dept" column="dept_id" javaType="SysDept" resultMap="deptResult"/>
         <collection property="roles" javaType="java.util.List" resultMap="RoleResult"/>
@@ -48,6 +50,31 @@
         <result property="status" column="role_status"/>
     </resultMap>
 
+    <resultMap type="SysUser" id="SysUserOnlyResult">
+        <id property="userId" column="user_id"/>
+        <result property="deptId" column="dept_id"/>
+        <result property="userName" column="user_name"/>
+        <result property="nickName" column="nick_name"/>
+        <result property="email" column="email"/>
+        <result property="phonenumber" column="phonenumber"/>
+        <result property="sex" column="sex"/>
+        <result property="avatar" column="avatar"/>
+        <result property="password" column="password"/>
+        <result property="status" column="status"/>
+        <result property="delFlag" column="del_flag"/>
+        <result property="loginIp" column="login_ip"/>
+        <result property="loginDate" column="login_date"/>
+        <result property="createBy" column="create_by"/>
+        <result property="createTime" column="create_time"/>
+        <result property="updateBy" column="update_by"/>
+        <result property="updateTime" column="update_time"/>
+        <result property="cameraPriority" column="camera_priority"/>
+        <result property="rongCloudToken" column="rong_cloud_token"/>
+        <result property="appUserType" column="app_user_type"/>
+        <result property="appOnlineState" column="app_online_state"/>
+        <result property="remark" column="remark"/>
+    </resultMap>
+
     <sql id="selectUserVo">
         select u.user_id,
                u.dept_id,
@@ -66,6 +93,8 @@
                u.create_time,
                u.camera_priority,
                u.rong_cloud_token,
+               u.app_user_type,
+               u.app_online_state,
                u.remark,
                d.dept_id,
                d.parent_id,
@@ -87,9 +116,6 @@
     </sql>
 
     <select id="selectUserList" parameterType="SysUser" resultMap="SysUserResult">
---         select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.sex, u.status,
---         u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark,u.camera_priority,u.rong_cloud_token, d.dept_name, d.leader from sys_user u
---         left join sys_dept d on u.dept_id = d.dept_id
         <include refid="selectUserVo"/>
         where u.del_flag = '0'
         <if test="userId != null and userId != ''">
@@ -110,23 +136,19 @@
         <if test="params.endTime != null and params.endTime != ''"><!-- 缁撴潫鏃堕棿妫�绱� -->
             AND u.create_time &lt;= to_timestamp(#{params.endTime},'yyyy-MM-DD')
         </if>
-        <if test="deptId != null and deptId != 0">
-            AND (u.dept_id = #{deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE cast(#{deptId} as
-            varchar) = any(string_to_array(ancestors,',')) ))
+        <if test="appUserType!=null and appUserType!=''"> AND u.app_user_type = #{appUserType}</if>
+        <if test="deptId != null ">and (d.dept_id = #{deptId} OR d.dept_id IN ( SELECT t.dept_id FROM sys_dept t
+            WHERE cast(#{deptId} as varchar) = any(string_to_array(ancestors,',')) ))
         </if>
         <!-- 鏁版嵁鑼冨洿杩囨护 -->
         ${params.dataScope}
     </select>
-    <select id="selectAppUserList" parameterType="SysUser" resultMap="SysUserResult">
+    <select id="selectAllAppUserList" parameterType="SysUser" resultMap="SysUserResult">
         <include refid="selectUserVo"/>
-        where u.del_flag = '0'
-        and LOWER(r.role_name) like '%app%'
-        <if test="deptId != null and deptId != 0">
-            AND (u.dept_id = #{deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE cast(#{deptId} as
-            varchar) = any(string_to_array(ancestors,',')) ))
+        where u.del_flag = '0' and u.app_user_type in('0','1')
+        <if test="deptId != null ">and (d.dept_id = #{deptId} OR d.dept_id IN ( SELECT t.dept_id FROM sys_dept t
+            WHERE cast(#{deptId} as varchar) = any(string_to_array(ancestors,',')) ))
         </if>
-        <!-- 鏁版嵁鑼冨洿杩囨护 -->
-        ${params.dataScope}
     </select>
     <select id="selectAllocatedList" parameterType="SysUser" resultMap="SysUserResult">
         select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time
@@ -210,6 +232,7 @@
         <if test="createBy != null and createBy != ''">create_by,</if>
         <if test="remark != null and remark != ''">remark,</if>
         <if test="cameraPriority != null">camera_priority,</if>
+        <if test="appUserType != null and appUserType != ''">app_user_type,</if>
         create_time
         )values(
         <if test="userId != null and userId != ''">#{userId},</if>
@@ -225,6 +248,7 @@
         <if test="createBy != null and createBy != ''">#{createBy},</if>
         <if test="remark != null and remark != ''">#{remark},</if>
         <if test="cameraPriority != null">#{cameraPriority},</if>
+        <if test="appUserType != null">#{appUserType},</if>
         now()
         )
     </insert>
@@ -247,6 +271,8 @@
             <if test="remark != null">remark = #{remark},</if>
             <if test="cameraPriority != null">camera_priority = #{cameraPriority},</if>
             <if test="rongCloudToken != null">rong_cloud_token = #{rongCloudToken},</if>
+            <if test="appUserType != null">app_user_type = #{appUserType},</if>
+            <if test="appOnlineState != null">app_online_state = #{appOnlineState},</if>
             update_time = now()
         </set>
         where user_id = #{userId}
@@ -290,4 +316,43 @@
         inner join sys_dept sd on asy.dept_id = sd.dept_id
         where asy.car_id = #{carId})
     </select>
+
+    <select id="userByPlanId" parameterType="String" resultMap="SysUserResult">
+        select user_id,nick_name from sys_user where user_id in (select app_user_id from ard_app_patroluser where patrolplan_id = #{id})
+    </select>
+
+    <select id="getOnlineCommander" parameterType="String" resultMap="SysUserOnlyResult">
+        select distinct su0.* from sys_user su
+        inner join sys_user su0 on su.dept_id = su0.dept_id
+        inner join sys_user_role aur on su0.user_id = aur.user_id
+        inner join sys_role sr on aur.role_id = sr.role_id
+        where su.user_id = #{usersId} and su0.user_id != #{usersId}
+        and sr.role_key = 'appLeader' and su0.app_online_state = '1'
+    </select>
+
+    <select id="getOnlinePC" resultMap="SysUserOnlyResult">
+        select distinct su0.* from sys_user su
+        inner join sys_user su0 on su.dept_id = su0.dept_id
+        inner join sys_user_role aur on su0.user_id = aur.user_id
+        inner join sys_role sr on aur.role_id = sr.role_id
+        where su.user_id = #{usersId} and su0.user_id != #{usersId}
+        and sr.role_key != 'appLeader' and sr.role_key != 'appUser'
+        and su0.user_id in
+        <foreach collection="onLinePCIdList" item="userId" open="(" close=")" separator=",">
+            #{userId}
+        </foreach>
+    </select>
+
+    <select id="getOwnAndChildrenSoilderList" resultMap="SysUserOnlyResult">
+        select distinct su.user_id,su.dept_id,su.user_name,
+        concat(su.nick_name,'(',sd.dept_name,')') as nick_name from sys_user su
+        inner join sys_user_role sur on su.user_id = sur.user_id
+        inner join sys_role sr on sur.role_id = sr.role_id
+        inner join sys_dept sd on su.dept_id = sd.dept_id
+        where sr.role_key = 'appUser' and su.dept_id in
+        <foreach collection="deptIdList" item="deptId" open="(" close=")" separator=",">
+            #{deptId}
+        </foreach>
+        order by su.dept_id asc
+    </select>
 </mapper> 
\ No newline at end of file

--
Gitblit v1.9.3