From 1a677d2b4a4bc615602f8c2a22bc07ec1356e5be Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期四, 16 十月 2025 17:39:06 +0800
Subject: [PATCH] 2025.10.16 1. 根据全局响应增强器GlobalResponseAdvice,将原先的BaseResPack接口包装函数统一去除; 2. 新增三种类型的数据产品数据库实体 3. 新增典型问题场景清单中间数据产品接口
---
src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/UserMapServiceImpl.kt | 54 +++++++++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 51 insertions(+), 3 deletions(-)
diff --git a/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/UserMapServiceImpl.kt b/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/UserMapServiceImpl.kt
index 234838d..5f4a5fb 100644
--- a/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/UserMapServiceImpl.kt
+++ b/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/UserMapServiceImpl.kt
@@ -17,7 +17,9 @@
import cn.flightfeather.supervision.domain.ds2.repository.UserMapRep
import cn.flightfeather.supervision.lightshare.service.UserMapService
import cn.flightfeather.supervision.lightshare.vo.AreaVo
+import cn.flightfeather.supervision.lightshare.vo.DataHead
import cn.flightfeather.supervision.lightshare.vo.DeviceMapVo
+import cn.flightfeather.supervision.lightshare.vo.DeviceSiteVo
import org.springframework.stereotype.Service
import tk.mybatis.mapper.entity.Example
import java.util.*
@@ -102,18 +104,64 @@
//浠ラ缇界幆澧冪郴缁熶腑鐨勭敤鎴蜂负涓讳綋
1 -> {
val u = userInfoTZRep.findEnterpriseUser(areaVo.districtname, areaVo.scensetypeid?.toInt())
- u.map { it?.guid }
+ u.map { it?.guid to it?.realname }
}
//浠ラ缇界洃绠$郴缁熶腑鐨勭敤鎴蜂负涓讳綋
2 -> {
val task = taskRep.findOneTask(areaVo) ?: throw BizException("褰撳墠鏌ヨ鏉′欢涓嬫湭鎵惧埌瀵瑰簲椤跺眰浠诲姟")
val scenes = sceneRep.findSceneList(task.tguid!!, areaVo.scensetypeid?.toInt(), areaVo.towncode)
.map { it?.guid }
- userInfoSVRep.findUser(scenes).map { it?.guid }
+ userInfoSVRep.findUser(scenes).map { it?.guid to it?.realname }
}
else -> emptyList()
}
// 2.閫氳繃鍖哄煙鏉′欢鍐冲畾鍖归厤鐨勬暟鎹潵婧�
- return aopDataDeviceMap.findMapSet(areaVo, userIdList)
+ val mapSet = aopDataDeviceMap.findMapSet(areaVo, userIdList.map { it.first })
+ val result = mutableListOf<DeviceMapVo>()
+ // 灏嗕笉鍦╩apSet涓殑鐢ㄦ埛锛屾坊鍔犲埌缁撴灉闆嗕腑
+ userIdList.forEach {u ->
+ val ddm = mapSet.find { m->
+ when (areaVo.sourceType) {
+ //浠ラ缇界幆澧冪郴缁熶腑鐨勭敤鎴蜂负涓讳綋
+ 1 -> m.tzUserId == u.first
+ //浠ラ缇界洃绠$郴缁熶腑鐨勭敤鎴蜂负涓讳綋
+ 2 -> m.svUserId == u.first
+ else -> false
+ }
+ }
+ if (ddm == null) {
+ result.add(DeviceMapVo().apply {
+ when (areaVo.sourceType) {
+ //浠ラ缇界幆澧冪郴缁熶腑鐨勭敤鎴蜂负涓讳綋
+ 1 -> {
+ tzUserId = u.first
+ tzUserName = u.second
+ }
+ //浠ラ缇界洃绠$郴缁熶腑鐨勭敤鎴蜂负涓讳綋
+ 2 -> {
+ svUserId = u.first
+ svUserName = u.second
+
+ }
+ }
+ })
+ }
+ }
+ // 灏唌apSet涓殑鏁版嵁娣诲姞鍒扮粨鏋滈泦涓�
+ result.addAll(mapSet)
+ return result.sortedBy { it.svUserId }
+ }
+
+ override fun insertOrUpdate(param: Pair<AreaVo, DeviceMapVo>): Int {
+ return aopDataDeviceMap.insertOrUpdate(param.first, listOf(param.second))
+ }
+
+ override fun searchThirdPartyDevice(
+ areaVo: AreaVo,
+ keyword: String,
+ page: Int?,
+ perPage: Int?,
+ ): Pair<DataHead, List<DeviceSiteVo>> {
+ return aopDataDeviceMap.searchDevice(areaVo, keyword, page ?: 1, perPage ?: 30)
}
}
\ No newline at end of file
--
Gitblit v1.9.3