From baf2cc2ce3dfd1235c012a3750132769fcd9ad2f Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期四, 18 九月 2025 17:02:05 +0800
Subject: [PATCH] 2025.9.18 1. 联合前端调试数据产品接口(待完成)

---
 src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/DataProdBaseServiceImpl.kt |   36 ++++++++++++++++++++++++++++++------
 1 files changed, 30 insertions(+), 6 deletions(-)

diff --git a/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/DataProdBaseServiceImpl.kt b/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/DataProdBaseServiceImpl.kt
index 4fd0203..0cd663b 100644
--- a/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/DataProdBaseServiceImpl.kt
+++ b/src/main/kotlin/cn/flightfeather/supervision/lightshare/service/impl/DataProdBaseServiceImpl.kt
@@ -120,11 +120,23 @@
                 })
                 if (subtaskList.isEmpty()) return@queryCache emptyList<DPEvaluateInfo>()
 
+                val sceneList = aopDbMapper.scenseMapper.selectByExample(Example(Scense::class.java).apply {
+                    createCriteria().andIn("guid", subtaskList.map { it.scenseid })
+                        .andEqualTo("typeid", queryOpt.sceneTypeId)
+                })
+
+                val validSubtaskList = subtaskList.filter { sceneList.find { scene -> scene.guid == it.scenseid } != null }
+
                 aopDbMapper.evaluationMapper.selectByExample(Example(Evaluation::class.java).apply {
-                    createCriteria().andIn("stguid", subtaskList.map { it.stguid })
+                    createCriteria().andIn("stguid", validSubtaskList.map { it.stguid })
                 }).forEach {
                     res.add(DPEvaluateInfo().apply {
-                        subTask = subtaskList.find { sub-> sub.stguid == it.stguid }
+                        val scene = sceneList.find { sce-> sce.guid == it.sguid }
+                        index = scene?.index
+                        subTask = validSubtaskList.find { sub-> sub.stguid == it.stguid }?.apply {
+                            towncode = scene?.towncode
+                            townname = scene?.townname
+                        }
                         evaluate = it
                         val score = it.resultscorebef?.toIntOrNull() ?: -1
                         scoreLevel = when {
@@ -136,6 +148,7 @@
                         }
                     })
                 }
+                res.sortBy { it.index }
                 return@queryCache res
             },
             save = {  }
@@ -152,16 +165,27 @@
                 })
                 if (subtaskList.isEmpty()) return@queryCache emptyList<DPInspectionInfo>()
 
+                val sceneList = aopDbMapper.scenseMapper.selectByExample(Example(Scense::class.java).apply {
+                    createCriteria().andIn("guid", subtaskList.map { it.scenseid })
+                        .andEqualTo("typeid", queryOpt.sceneTypeId)
+                })
+                val validSubtaskList = subtaskList.filter { sceneList.find { scene -> scene.guid == it.scenseid } != null }
+
                 val problemList = aopDbMapper.problemlistMapper.selectByExample(Example(Problemlist::class.java).apply {
-                    createCriteria().andIn("stguid", subtaskList.map { it.stguid })
+                    createCriteria().andIn("stguid", validSubtaskList.map { it.stguid })
                 })
 
                 val problemTypeList = aopDbMapper.problemtypeMapper.selectByExample(Example(Problemtype::class.java)
                     .apply { createCriteria().andIn("guid", problemList.map { it.ptguid }) })
 
-                subtaskList.forEach {
+                validSubtaskList.forEach {
                     res.add(DPInspectionInfo().apply {
-                        subTask = it
+                        val scene = sceneList.find { sce-> sce.guid == it.scenseid }
+                        index = scene?.index
+                        subTask = it.apply {
+                            towncode = scene?.towncode
+                            townname = scene?.townname
+                        }
                         problems = problemList.filter { problem-> problem.stguid == it.stguid }.map { problem->
                             val problemListVo = ProblemListVo()
                             BeanUtils.copyProperties(problem, problemListVo)
@@ -175,7 +199,7 @@
                         }
                     })
                 }
-
+                res.sortBy { it.index }
                 return@queryCache res
             },
             save = {  }

--
Gitblit v1.9.3