From 69cd43d9303ed7cd985bd64379b4cc5b0aecef14 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期三, 15 一月 2025 17:01:26 +0800
Subject: [PATCH] 离线工单审核通过修改状态

---
 ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml |   36 ++++++++++++++++++++++++++----------
 1 files changed, 26 insertions(+), 10 deletions(-)

diff --git a/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml b/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml
index 3a71794..d0ecfcf 100644
--- a/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml
+++ b/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml
@@ -68,12 +68,15 @@
         <if test="query.unitId != null">
             AND wo.unit_id = #{query.unitId}
         </if>
-        <if test="query.errorType != null and query.errorType != ''">
+        <if test="query.errorTypeList != null and query.errorTypeList.size>0">
             AND (EXISTS (
             SELECT 1
             FROM t_work_order_error_type twoet
             WHERE twoet.work_order_no = wo.work_order_no
-            AND twoet.error_name = #{query.errorType}
+            AND twoet.error_name in
+            <foreach collection="query.errorTypeList" open="(" close=")" separator="," item="errorType">
+                        #{errorType}
+            </foreach>
             ))
         </if>
         <if test="query.keyword != null and query.keyword != ''">
@@ -92,7 +95,7 @@
         ORDER BY wo.work_order_no DESC
     </select>
 
-    <select id="export" resultMap="BaseResultMap">
+    <select id="export" resultType = "com.ycl.platform.domain.vo.WorkOrderVO">
         SELECT
         wo.id,wo.status,
         wo.work_order_no,
@@ -111,11 +114,18 @@
         p.yw_person_name,
         tm.name as source,
         tm.ip as ip,
+        yp.province_tag_video,
+        yp.province_tag_car,
+        yp.province_tag_face,
+        yp.important_tag,
+        yp.important_command_image_tag,
+        yp.dept_tag,
         GROUP_CONCAT(DISTINCT da.dict_label ORDER BY da.dict_label SEPARATOR ',') AS errorType,
         GROUP_CONCAT(DISTINCT ci.img_url ORDER BY ci.create_time DESC SEPARATOR ',') AS imgListStr
         FROM
         t_work_order wo
         INNER JOIN t_monitor tm ON wo.serial_number = tm.serial_number
+        INNER JOIN t_yw_point yp ON wo.serial_number = yp.serial_number
         INNER JOIN t_work_order_error_type et ON wo.work_order_no = et.work_order_no
         INNER JOIN sys_dict_data da ON da.dict_value = et.error_name AND da.dict_type = 'error_type'
         INNER JOIN t_yw_unit u ON wo.unit_id = u.id AND u.deleted = 0
@@ -135,12 +145,15 @@
         <if test="query.start != null and query.end != null">
             AND wo.create_time BETWEEN #{query.start} AND #{query.end}
         </if>
-        <if test="query.errorType != null and query.errorType !='' ">
+        <if test="query.errorTypeList != null and query.errorTypeList.size>0">
             AND (EXISTS (
             SELECT 1
             FROM t_work_order_error_type twoet
             WHERE twoet.work_order_no = wo.work_order_no
-            AND twoet.error_name = #{query.errorType}
+            AND twoet.error_name in
+            <foreach collection="query.errorTypeList" open="(" close=")" separator="," item="errorType">
+                #{errorType}
+            </foreach>
             ))
         </if>
         GROUP BY
@@ -211,10 +224,10 @@
     </select>
     <select id="getOfflineWorkOrder" resultType="java.lang.String">
         select tm.ip
-        FROM
-            t_work_order wo
+        FROM t_work_order wo
         INNER JOIN t_monitor tm ON wo.serial_number = tm.serial_number
-        where (EXISTS (
+        where wo.status != 'AUDITING_SUCCESS' and wo.deleted = 0
+        AND (EXISTS (
                 SELECT 1
                 FROM t_work_order_error_type twoet
                 WHERE twoet.work_order_no = wo.work_order_no
@@ -258,6 +271,7 @@
             WHERE DATE_FORMAT(w.create_time, '%Y') = DATE_FORMAT(NOW(), '%Y')
                 AND w.deleted = 0 AND unit_id = #{unitId}
             GROUP BY dateType
+            ORDER BY dateType
         </if>
 
         <if test="dateType == 'week'">
@@ -274,6 +288,7 @@
             w.create_time BETWEEN DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE()) DAY) AND DATE_ADD(CURDATE(), INTERVAL (6 - WEEKDAY(CURDATE())) DAY)
                AND w.deleted = 0 AND unit_id = #{unitId}
             GROUP BY dateType
+            ORDER BY dateType
         </if>
 
         <if test="dateType == 'day'">
@@ -290,6 +305,7 @@
                 DATE_FORMAT(w.create_time, '%Y-%m-%d') BETWEEN DATE_FORMAT(CURDATE(), '%Y-%m-01') AND LAST_DAY(CURDATE())
               AND w.deleted = 0 AND unit_id = #{unitId}
             GROUP BY dateType
+            ORDER BY dateType
         </if>
     </select>
 
@@ -331,7 +347,7 @@
         FROM
              t_work_order wo
         WHERE
-            wo.status = 'YW_HANDLE'
+            (wo.status = 'YW_HANDLE' or wo.status ='DISTRIBUTED' )
             AND wo.deleted = 0
     </select>
 
@@ -343,7 +359,7 @@
     </insert>
 
     <select id="selectPassOrder" resultType="com.ycl.platform.domain.vo.WorkOrderVO">
-        SELECT wo.id,wo.work_order_no,wo.unit_id,woet.error_name as errorType,woet.distribute_time,woar.create_time as auditTime
+        SELECT wo.id,wo.work_order_no,wo.unit_id,woet.error_name as errorType,woet.create_time as distributeTime,woar.create_time as auditTime
         FROM t_work_order wo
         LEFT JOIN t_work_order_error_type woet ON woet.work_order_no = wo.work_order_no
         LEFT JOIN t_work_order_auditing_record woar ON woar.work_order_no = wo.work_order_no

--
Gitblit v1.8.0