From eea27b448ec2d289f5c9665bf4b3678d580457ee Mon Sep 17 00:00:00 2001
From: Lius <Lius2225@163.com>
Date: 星期二, 22 七月 2025 15:45:23 +0800
Subject: [PATCH] 三保变更基础代码,点检导出修改

---
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceOrderMapper.xml          |    2 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceChangeServiceImpl.java |  329 +++++++++++++++++++++++++
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/HfTemplateCategoryEnum.java            |    1 
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeStatusEnum.java  |   22 +
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java  |   19 +
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceChangeService.java         |   41 +++
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamThirdMaintenanceChangeController.java    |  140 +++++++---
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeRequest.java          |   36 ++
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceChange.java           |   22 +
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeReasonEnum.java  |   10 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeQuery.java            |   28 ++
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/BusinessCodeConst.java                 |    2 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceOrderService.java          |    8 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceChangeMapper.xml         |   12 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/EamThirdMaintenanceChangeMapper.java            |    6 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamInspectionOrderServiceImpl.java        |   30 +
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/request/EamWeekInsDetailUserResponse.java       |    2 
 lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceOrder.java            |    2 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/job/InspectionOrderGenerateJob.java                    |    1 
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamInspectionOrderController.java           |   25 -
 20 files changed, 650 insertions(+), 88 deletions(-)

diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/BusinessCodeConst.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/BusinessCodeConst.java
index bf95163..a2a8393 100644
--- a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/BusinessCodeConst.java
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/BusinessCodeConst.java
@@ -19,6 +19,8 @@
     String SECOND_MAINTENANCE_CODE_RULE = "SecondMaintenanceCodeRule";
     //涓変繚缂栫爜瑙勫垯
     String THIRD_MAINTENANCE_CODE_RULE = "ThirdMaintenanceCodeRule";
+    //涓変繚鍙樻洿缂栫爜瑙勫垯
+    String THIRD_MAINTENANCE_CHANGE_CODE_RULE = "ThirdMaintenanceChangeCodeRule";
     //璁惧鍊熷嚭褰掕繕
     String LEAN_OUT_CODE_RULE = "EquipmentLeanOutCodeRule";
     //璁惧灏佸瓨鍚皝
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/HfTemplateCategoryEnum.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/HfTemplateCategoryEnum.java
index 2870124..c3c0a07 100644
--- a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/HfTemplateCategoryEnum.java
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/HfTemplateCategoryEnum.java
@@ -5,6 +5,7 @@
     SECOND_MAINTENANCE, //浜屼繚
     THIRD_MAINTENANCE_HANDOVER, //涓変繚绉讳氦鍗�
     THIRD_MAINTENANCE_ACCEPTANCE, //涓変繚楠屾敹鍗�
+    THIRD_MAINTENANCE_CHANGE, //涓変繚鍙樻洿鍗�
     TECHNICAL_STATUS_EVALUATION, //鎶�鏈姸鎬侀壌瀹氳〃
     TECHNICAL_STATUS_EVALUATION_SAFETY_CHECK, //璁惧瀹夊叏瑁呯疆妫�鏌ュ崟
     TECHNICAL_STATUS_EVALUATION_OTHER_CHECK, //鍏朵粬妫�鏌ラ」鐩�
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeReasonEnum.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeReasonEnum.java
new file mode 100644
index 0000000..86bb535
--- /dev/null
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeReasonEnum.java
@@ -0,0 +1,10 @@
+package org.jeecg.modules.eam.constant;
+
+public enum ThirdMaintenanceChangeReasonEnum {
+    PRODUCTION_WORK_ORDER_EXPEDITED, //鐢熶骇浠诲姟鎬ユ棤娉曞仠鏈�
+    EQUIPMENT_BREAKDOWN_REPAIR, //璁惧鏁呴殰姝e浜庣淮淇姸鎬�
+    EQUIPMENT_SCRAPPED, //璁惧宸叉姤搴�
+    EQUIPMENT_MAJOR, //璁惧澶т慨銆侀」淇�
+    EQUIPMENT_RETROFITTING, //璁惧鏀归��
+    ;
+}
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeStatusEnum.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeStatusEnum.java
new file mode 100644
index 0000000..3b08d40
--- /dev/null
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/constant/ThirdMaintenanceChangeStatusEnum.java
@@ -0,0 +1,22 @@
+package org.jeecg.modules.eam.constant;
+
+public enum ThirdMaintenanceChangeStatusEnum {
+    WAIT_SUBMIT, //寰呮彁浜�
+    EQUIPMENT_MANAGER_SIGNING, //涓荤棰嗗绛惧瓧涓�
+    DEPART_MANAGER_SIGNING, //閮ㄩ棬棰嗗绛惧瓧涓�
+    PRODUCTION_SUPPORT_SIGNING, //淇濋殰閮ㄩ瀵肩瀛椾腑
+    ABOLISH, //宸蹭綔搴�
+    REJECTED, //宸查┏鍥�
+    COMPLETED, //宸插畬鎴�
+    ;
+
+    public static ThirdMaintenanceChangeStatusEnum getInstance(String code) {
+        ThirdMaintenanceChangeStatusEnum[] values = ThirdMaintenanceChangeStatusEnum.values();
+        for (ThirdMaintenanceChangeStatusEnum value : values) {
+            if (value.name().equals(code)) {
+                return value;
+            }
+        }
+        return null;
+    }
+}
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceChange.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceChange.java
index 06065f9..6636e22 100644
--- a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceChange.java
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceChange.java
@@ -1,5 +1,6 @@
 package org.jeecg.modules.eam.entity;
 
+import com.baomidou.mybatisplus.annotation.TableField;
 import com.baomidou.mybatisplus.annotation.TableName;
 import com.fasterxml.jackson.annotation.JsonFormat;
 import io.swagger.annotations.ApiModel;
@@ -41,6 +42,7 @@
      */
     @Excel(name = "涓変繚宸ュ崟ID", width = 15)
     @ApiModelProperty(value = "涓変繚宸ュ崟ID")
+    @Dict(dictTable = "eam_third_maintenance_order", dicCode = "id", dicText = "order_num")
     private String orderId;
     /**
      * 鍙樻洿鍗曞彿
@@ -53,13 +55,14 @@
      */
     @Excel(name = "鐢宠浜�", width = 15)
     @ApiModelProperty(value = "鐢宠浜�")
-    @Dict(dicCode = "sys_user, realname, username")
+    @Dict(dictTable = "sys_user", dicCode = "username", dicText = "realname")
     private String applicant;
     /**
      * 鐢宠閮ㄩ棬
      */
     @Excel(name = "鐢宠閮ㄩ棬", width = 15)
     @ApiModelProperty(value = "鐢宠閮ㄩ棬")
+    @Dict(dictTable = "eam_base_factory",dicText = "factory_name",dicCode = "org_code")
     private String factoryOrgCode;
     /**
      * 鐢宠鏃ユ湡
@@ -74,18 +77,21 @@
      */
     @Excel(name = "鐢宠绫诲瀷;鎶ュ簾銆佸欢淇�", width = 15)
     @ApiModelProperty(value = "鐢宠绫诲瀷;鎶ュ簾銆佸欢淇�")
+    @Dict(dicCode = "third_maintenance_change_category")
     private String applyCategory;
     /**
      * 鍙樻洿鐘舵��;寰呮彁浜ゃ�佸緟涓荤瀹℃牳銆佸緟閮ㄩ棬纭銆佸緟淇濋殰閮ㄧ‘璁ゃ�佸凡浣滃簾銆佸凡瀹屾垚
      */
     @Excel(name = "鍙樻洿鐘舵��;寰呮彁浜ゃ�佸緟涓荤瀹℃牳銆佸緟閮ㄩ棬纭銆佸緟淇濋殰閮ㄧ‘璁ゃ�佸凡浣滃簾銆佸凡瀹屾垚", width = 15)
     @ApiModelProperty(value = "鍙樻洿鐘舵��;寰呮彁浜ゃ�佸緟涓荤瀹℃牳銆佸緟閮ㄩ棬纭銆佸緟淇濋殰閮ㄧ‘璁ゃ�佸凡浣滃簾銆佸凡瀹屾垚")
+    @Dict(dicCode = "third_maintenance_change_status")
     private String changeStatus;
     /**
      * 寤朵繚鍘熷洜绫诲瀷;鐢熶骇浠诲姟銆佽澶囨晠闅溿�佹姤搴熴�佸ぇ淇」淇�佹惉杩�
      */
     @Excel(name = "寤朵繚鍘熷洜绫诲瀷;鐢熶骇浠诲姟銆佽澶囨晠闅溿�佹姤搴熴�佸ぇ淇」淇�佹惉杩�", width = 15)
     @ApiModelProperty(value = "寤朵繚鍘熷洜绫诲瀷;鐢熶骇浠诲姟銆佽澶囨晠闅溿�佹姤搴熴�佸ぇ淇」淇�佹惉杩�")
+    @Dict(dicCode = "third_maintenance_change_reason")
     private String applyReasonType;
     /**
      * 寤朵繚(鍙樻洿)鍘熷洜
@@ -106,7 +112,7 @@
      */
     @Excel(name = "涓荤棰嗗绛惧瓧", width = 15)
     @ApiModelProperty(value = "涓荤棰嗗绛惧瓧")
-    @Dict(dicCode = "sys_user, realname, username")
+    @Dict(dictTable = "sys_user", dicCode = "username", dicText = "realname")
     private String equipmentManagerSignature;
     /**
      * 涓荤棰嗗绛惧瓧鏃堕棿
@@ -121,7 +127,7 @@
      */
     @Excel(name = "閮ㄩ棬棰嗗绛惧瓧;鏍规嵁寤朵繚鍘熷洜绫诲瀷鍖哄垎涓嶅悓鐨勪汉瀹℃壒", width = 15)
     @ApiModelProperty(value = "閮ㄩ棬棰嗗绛惧瓧;鏍规嵁寤朵繚鍘熷洜绫诲瀷鍖哄垎涓嶅悓鐨勪汉瀹℃壒")
-    @Dict(dicCode = "sys_user, realname, username")
+    @Dict(dictTable = "sys_user", dicCode = "username", dicText = "realname")
     private String departManagerSignature;
     /**
      * 閮ㄩ棬棰嗗绛惧瓧鏃堕棿
@@ -142,7 +148,7 @@
      */
     @Excel(name = "鐢熶骇淇濋殰閮ㄩ瀵肩瀛�", width = 15)
     @ApiModelProperty(value = "鐢熶骇淇濋殰閮ㄩ瀵肩瀛�")
-    @Dict(dicCode = "sys_user, realname, username")
+    @Dict(dictTable = "sys_user", dicCode = "username", dicText = "realname")
     private String productionSupportSignature;
     /**
      * 鐢熶骇淇濋殰閮ㄩ瀵肩瀛楁椂闂�
@@ -164,4 +170,12 @@
     @Excel(name = "HF缂栫爜", width = 15)
     @ApiModelProperty(value = "HF缂栫爜")
     private String hfCode;
+
+    //鍒楄〃灞曠ず
+    @TableField(exist = false)
+    private String equipmentCode;
+    @TableField(exist = false)
+    private String equipmentName;
+    @TableField(exist = false)
+    private String equipmentModel;
 }
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceOrder.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceOrder.java
index 93562d0..6ac9ec8 100644
--- a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceOrder.java
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/entity/EamThirdMaintenanceOrder.java
@@ -243,4 +243,6 @@
     private String equipmentCode;
     @TableField(exist = false)
     private String equipmentName;
+    @TableField(exist = false)
+    private String equipmentModel;
 }
diff --git a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/request/EamWeekInsDetailUserResponse.java b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/request/EamWeekInsDetailUserResponse.java
index 9af0af0..02825b9 100644
--- a/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/request/EamWeekInsDetailUserResponse.java
+++ b/lxzn-module-eam-common/src/main/java/org/jeecg/modules/eam/request/EamWeekInsDetailUserResponse.java
@@ -28,7 +28,7 @@
     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd")
     @DateTimeFormat(pattern="yyyy-MM-dd")
     @ApiModelProperty(value = "鐐规鏃ユ湡")
-    private Date inspectionDate;
+    private Date planInspectionDate;
 
     /**鐐规浜�*/
     @ApiModelProperty(value = "鐐规浜�-鏄鍙栦汉")
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamInspectionOrderController.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamInspectionOrderController.java
index 7fd0901..958f9fc 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamInspectionOrderController.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamInspectionOrderController.java
@@ -305,31 +305,6 @@
     }
 
     /**
-     * 瀵煎嚭excel
-     *
-     * @param request
-     * @param eamInspectionOrder
-     */
-    //@RequiresPermissions("org.jeecg.modules:鐐规宸ュ崟:exportXls")
-    @RequestMapping(value = "/exportXls")
-    public ModelAndView exportXls(HttpServletRequest request, EamInspectionOrder eamInspectionOrder) {
-        return super.exportXls(request, eamInspectionOrder, EamInspectionOrder.class, "鐐规宸ュ崟");
-    }
-
-    /**
-     * 閫氳繃excel瀵煎叆鏁版嵁
-     *
-     * @param request
-     * @param response
-     * @return
-     */
-    //@RequiresPermissions("鐐规宸ュ崟:importExcel")
-    @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
-    public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
-        return super.importExcel(request, response, EamInspectionOrder.class);
-    }
-
-    /**
      * 瀵煎嚭鑾峰彇鍩烘湰淇℃伅
      * @param equipmentCode 缁熶竴缂栫爜
      * @param inspectionDate 鏃ユ湡
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamThirdMaintenanceChangeController.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamThirdMaintenanceChangeController.java
index 4e96dd1..6688ef7 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamThirdMaintenanceChangeController.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamThirdMaintenanceChangeController.java
@@ -1,23 +1,30 @@
 package org.jeecg.modules.eam.controller;
 
-import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.alibaba.fastjson.parser.Feature;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.ObjectMapper;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
 import org.jeecg.common.api.vo.Result;
 import org.jeecg.common.aspect.annotation.AutoLog;
 import org.jeecg.common.system.base.controller.JeecgController;
-import org.jeecg.common.system.query.QueryGenerator;
+import org.jeecg.common.util.TranslateDictTextUtils;
+import org.jeecg.modules.eam.constant.ThirdMaintenanceChangeStatusEnum;
+import org.jeecg.modules.eam.entity.EamTechnicalStatusEvaluationOrderChange;
 import org.jeecg.modules.eam.entity.EamThirdMaintenanceChange;
+import org.jeecg.modules.eam.request.EamTechnicalStatusEvaluationOrderChangeRequest;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeQuery;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeRequest;
 import org.jeecg.modules.eam.service.IEamThirdMaintenanceChangeService;
 import org.springframework.web.bind.annotation.*;
-import org.springframework.web.servlet.ModelAndView;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
 import java.util.Arrays;
 
 /**
@@ -34,11 +41,15 @@
 
     @Resource
     private IEamThirdMaintenanceChangeService eamThirdMaintenanceChangeService;
+    @Resource
+    private ObjectMapper objectMapper;
+    @Resource
+    private TranslateDictTextUtils translateDictTextUtils;
 
     /**
      * 鍒嗛〉鍒楄〃鏌ヨ
      *
-     * @param eamThirdMaintenanceChange
+     * @param query
      * @param pageNo
      * @param pageSize
      * @param req
@@ -47,41 +58,52 @@
     @AutoLog(value = "涓変繚鍙樻洿-鍒嗛〉鍒楄〃鏌ヨ")
     @ApiOperation(value = "涓変繚鍙樻洿-鍒嗛〉鍒楄〃鏌ヨ", notes = "涓変繚鍙樻洿-鍒嗛〉鍒楄〃鏌ヨ")
     @GetMapping(value = "/list")
-    public Result<?> queryPageList(EamThirdMaintenanceChange eamThirdMaintenanceChange,
+    public Result<?> queryPageList(EamThirdMaintenanceChangeQuery query,
                                    @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo,
                                    @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize,
                                    HttpServletRequest req) {
-        QueryWrapper<EamThirdMaintenanceChange> queryWrapper = QueryGenerator.initQueryWrapper(eamThirdMaintenanceChange, req.getParameterMap());
         Page<EamThirdMaintenanceChange> page = new Page<EamThirdMaintenanceChange>(pageNo, pageSize);
-        IPage<EamThirdMaintenanceChange> pageList = eamThirdMaintenanceChangeService.page(page, queryWrapper);
+        IPage<EamThirdMaintenanceChange> pageList = eamThirdMaintenanceChangeService.queryPageList(page, query);
         return Result.OK(pageList);
     }
 
     /**
      * 娣诲姞
      *
-     * @param eamThirdMaintenanceChange
+     * @param request
      * @return
      */
     @AutoLog(value = "涓変繚鍙樻洿-娣诲姞")
     @ApiOperation(value = "涓変繚鍙樻洿-娣诲姞", notes = "涓変繚鍙樻洿-娣诲姞")
     @PostMapping(value = "/add")
-    public Result<?> add(@RequestBody EamThirdMaintenanceChange eamThirdMaintenanceChange) {
-        eamThirdMaintenanceChangeService.save(eamThirdMaintenanceChange);
-        return Result.OK("娣诲姞鎴愬姛锛�");
+    public Result<?> add(@RequestBody EamThirdMaintenanceChange request) {
+        if (request == null) {
+            return Result.error("娣诲姞鐨勫璞′笉鑳戒负绌猴紒");
+        }
+        boolean b = eamThirdMaintenanceChangeService.saveThirdMaintenanceChange(request);
+        if (!b) {
+            return Result.error("鍙樻洿澶辫触锛�");
+        }
+        return Result.OK("鍙樻洿鎴愬姛锛�");
     }
 
     /**
      * 缂栬緫
      *
-     * @param eamThirdMaintenanceChange
+     * @param request
      * @return
      */
     @AutoLog(value = "涓変繚鍙樻洿-缂栬緫")
     @ApiOperation(value = "涓変繚鍙樻洿-缂栬緫", notes = "涓変繚鍙樻洿-缂栬緫")
     @RequestMapping(value = "/edit", method = {RequestMethod.PUT, RequestMethod.POST})
-    public Result<?> edit(@RequestBody EamThirdMaintenanceChange eamThirdMaintenanceChange) {
-        eamThirdMaintenanceChangeService.updateById(eamThirdMaintenanceChange);
+    public Result<?> edit(@RequestBody EamThirdMaintenanceChange request) {
+        if (request == null) {
+            return Result.error("缂栬緫鐨勫璞′笉鑳戒负绌猴紒");
+        }
+        boolean b = eamThirdMaintenanceChangeService.editThirdMaintenanceChange(request);
+        if (!b) {
+            return Result.error("缂栬緫澶辫触锛�");
+        }
         return Result.OK("缂栬緫鎴愬姛!");
     }
 
@@ -113,6 +135,51 @@
         return Result.OK("鎵归噺鍒犻櫎鎴愬姛锛�");
     }
 
+    @AutoLog(value = "涓変繚鍙樻洿-鎻愪氦")
+    @ApiOperation(value = "涓変繚鍙樻洿-鎻愪氦", notes = "涓変繚鍙樻洿-鎻愪氦")
+    @GetMapping("/submit")
+    public Result<?> submit(@RequestParam(name = "id") String id) {
+        boolean b = eamThirdMaintenanceChangeService.submit(id);
+        if (!b) {
+            return Result.error("鎻愪氦澶辫触锛�");
+        }
+        return Result.OK("鎻愪氦鎴愬姛!");
+    }
+
+    @AutoLog(value = "涓変繚鍙樻洿-浣滃簾")
+    @ApiOperation(value = "涓変繚鍙樻洿-浣滃簾", notes = "涓変繚鍙樻洿-浣滃簾")
+    @GetMapping("/abolish")
+    public Result<?> abolish(@RequestParam(name = "id") String id) {
+        EamThirdMaintenanceChange entity = eamThirdMaintenanceChangeService.getById(id);
+        if (entity == null) {
+            return Result.error("瑕佷綔搴熺殑鏁版嵁涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        if (!ThirdMaintenanceChangeStatusEnum.WAIT_SUBMIT.name().equals(entity.getChangeStatus())) {
+            return Result.error("璇ョ姸鎬佺殑鏁版嵁涓嶅厑璁歌繘琛屼綔搴燂紒");
+        }
+        entity.setChangeStatus(ThirdMaintenanceChangeStatusEnum.ABOLISH.name());
+        eamThirdMaintenanceChangeService.updateById(entity);
+        return Result.OK("浣滃簾鎴愬姛!");
+    }
+
+    @AutoLog(value = "涓変繚鍙樻洿-瀹℃壒")
+    @ApiOperation(value = "涓変繚鍙樻洿-瀹℃壒", notes = "涓変繚鍙樻洿-瀹℃壒")
+    @PostMapping("/approval")
+    public Result<?> approval(@RequestBody EamThirdMaintenanceChangeRequest request) {
+        if (request == null) {
+            return Result.error("瀹℃壒鐨勫璞′笉鑳戒负绌猴紒");
+        }
+        // 妫�鏌ヨ姹傚弬鏁�
+        if (StrUtil.isBlank(request.getTaskId()) || StrUtil.isBlank(request.getDataId()) || StrUtil.isBlank(request.getInstanceId())) {
+            return Result.error("瀹℃壒浠诲姟閿欒鎴栦笉瀛樺湪锛�");
+        }
+        EamThirdMaintenanceChange b = eamThirdMaintenanceChangeService.approval(request);
+        if (b == null) {
+            return Result.error("鎿嶄綔澶辫触锛�");
+        }
+        return Result.ok("鎿嶄綔鎴愬姛锛�");
+    }
+
     /**
      * 閫氳繃id鏌ヨ
      *
@@ -123,31 +190,24 @@
     @ApiOperation(value = "涓変繚鍙樻洿-閫氳繃id鏌ヨ", notes = "涓変繚鍙樻洿-閫氳繃id鏌ヨ")
     @GetMapping(value = "/queryById")
     public Result<?> queryById(@RequestParam(name = "id", required = true) String id) {
-        EamThirdMaintenanceChange eamThirdMaintenanceChange = eamThirdMaintenanceChangeService.getById(id);
-        return Result.OK(eamThirdMaintenanceChange);
-    }
-
-    /**
-     * 瀵煎嚭excel
-     *
-     * @param request
-     * @param eamThirdMaintenanceChange
-     */
-    @RequestMapping(value = "/exportXls")
-    public ModelAndView exportXls(HttpServletRequest request, EamThirdMaintenanceChange eamThirdMaintenanceChange) {
-        return super.exportXls(request, eamThirdMaintenanceChange, EamThirdMaintenanceChange.class, "涓変繚鍙樻洿");
-    }
-
-    /**
-     * 閫氳繃excel瀵煎叆鏁版嵁
-     *
-     * @param request
-     * @param response
-     * @return
-     */
-    @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
-    public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
-        return super.importExcel(request, response, EamThirdMaintenanceChange.class);
+        EamThirdMaintenanceChange entity = eamThirdMaintenanceChangeService.getById(id);
+        if (entity == null) {
+            return Result.error("鏈壘鍒板搴旀暟鎹�");
+        }
+        try {
+            String json = objectMapper.writeValueAsString(entity);
+            JSONObject item = JSONObject.parseObject(json, Feature.OrderedField);
+            translateDictTextUtils.translateField("orderId", entity.getOrderId(), item, "eam_third_maintenance_order,order_num,id");
+            translateDictTextUtils.translateField("applicant", entity.getApplicant(), item, "sys_user,realname,username");
+            translateDictTextUtils.translateField("changeStatus", entity.getChangeStatus(), item, "third_maintenance_change_status");
+            translateDictTextUtils.translateField("applyReasonType", entity.getApplyReasonType(), item, "third_maintenance_change_reason");
+            translateDictTextUtils.translateField("equipmentManagerSignature", entity.getEquipmentManagerSignature(), item, "sys_user,realname,username");
+            translateDictTextUtils.translateField("departManagerSignature", entity.getDepartManagerSignature(), item, "sys_user,realname,username");
+            translateDictTextUtils.translateField("productionSupportSignature", entity.getProductionSupportSignature(), item, "sys_user,realname,username");
+            return Result.OK(item);
+        } catch (JsonProcessingException e) {
+            return Result.error("鏁版嵁杞瘧澶辫触锛�");
+        }
     }
 
 }
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/job/InspectionOrderGenerateJob.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/job/InspectionOrderGenerateJob.java
index b2f9d57..631bf9a 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/job/InspectionOrderGenerateJob.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/job/InspectionOrderGenerateJob.java
@@ -8,7 +8,6 @@
 import org.jeecg.modules.eam.constant.MaintenanceCategoryEnum;
 import org.jeecg.modules.eam.constant.OrderCreationMethodEnum;
 import org.jeecg.modules.eam.entity.EamInspectionOrder;
-import org.jeecg.modules.eam.entity.EamInspectionOrderDetail;
 import org.jeecg.modules.eam.entity.EamMaintenanceStandard;
 import org.jeecg.modules.eam.entity.EamMaintenanceStandardDetail;
 import org.jeecg.modules.eam.request.EamInspectionOrderRequest;
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/EamThirdMaintenanceChangeMapper.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/EamThirdMaintenanceChangeMapper.java
index 35587e9..718ee26 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/EamThirdMaintenanceChangeMapper.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/EamThirdMaintenanceChangeMapper.java
@@ -1,6 +1,11 @@
 package org.jeecg.modules.eam.mapper;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Constants;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import org.apache.ibatis.annotations.Param;
 import org.jeecg.modules.eam.entity.EamThirdMaintenanceChange;
 
 /**
@@ -11,4 +16,5 @@
  */
 public interface EamThirdMaintenanceChangeMapper extends BaseMapper<EamThirdMaintenanceChange> {
 
+    IPage<EamThirdMaintenanceChange> queryPageList(Page<EamThirdMaintenanceChange> page, @Param(Constants.WRAPPER) QueryWrapper<EamThirdMaintenanceChange> queryWrapper);
 }
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceChangeMapper.xml b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceChangeMapper.xml
index 5da01a2..5d97e01 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceChangeMapper.xml
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceChangeMapper.xml
@@ -2,4 +2,16 @@
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 <mapper namespace="org.jeecg.modules.eam.mapper.EamThirdMaintenanceChangeMapper">
 
+    <select id="queryPageList" resultType="org.jeecg.modules.eam.entity.EamThirdMaintenanceChange">
+        SELECT
+            tmc.*,
+            e.equipment_code,
+            e.equipment_name,
+            e.equipment_model
+        FROM
+            eam_third_maintenance_change tmc
+                INNER JOIN eam_third_maintenance_order tmo ON tmc.order_id = tmo.id
+                INNER JOIN eam_equipment e ON tmo.equipment_id = e.id
+            ${ew.customSqlSegment}
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceOrderMapper.xml b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceOrderMapper.xml
index abcb111..e75d5da 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceOrderMapper.xml
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/mapper/xml/EamThirdMaintenanceOrderMapper.xml
@@ -3,7 +3,7 @@
 <mapper namespace="org.jeecg.modules.eam.mapper.EamThirdMaintenanceOrderMapper">
 
     <select id="queryPageList" resultType="org.jeecg.modules.eam.entity.EamThirdMaintenanceOrder">
-        select wmo.*, e.equipment_code, e.equipment_name
+        select wmo.*, e.equipment_code, e.equipment_name, e.equipment_model
         from eam_third_maintenance_order wmo
         inner join eam_equipment e
         on wmo.equipment_id = e.id
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeQuery.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeQuery.java
new file mode 100644
index 0000000..4ab0dc7
--- /dev/null
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeQuery.java
@@ -0,0 +1,28 @@
+package org.jeecg.modules.eam.request;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.util.Date;
+
+/**
+ * @Author: Lius
+ * @CreateTime: 2025-07-21
+ * @Description:
+ */
+@Data
+public class EamThirdMaintenanceChangeQuery {
+    private String equipmentId;
+    private String changeOrderNum;
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private Date applyDateBegin;
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private Date applyDateEnd;
+
+    private String changeStatus;
+    private String column;
+    private String order;
+}
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeRequest.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeRequest.java
new file mode 100644
index 0000000..06bcb5e
--- /dev/null
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/request/EamThirdMaintenanceChangeRequest.java
@@ -0,0 +1,36 @@
+package org.jeecg.modules.eam.request;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+import org.jeecg.modules.flowable.domain.vo.FlowTaskVo;
+
+import java.io.Serializable;
+
+/**
+ * @Author: Lius
+ * @CreateTime: 2025-07-21
+ * @Description:
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+@Accessors(chain = true)
+@ApiModel(value = "涓変繚鍙樻洿瀵硅薄", description = "涓変繚鍙樻洿")
+public class EamThirdMaintenanceChangeRequest extends FlowTaskVo implements Serializable {
+
+    private static final long serialVersionUID = 80020193253190375L;
+
+    /**
+     * 涓婚敭
+     */
+    @ApiModelProperty(value = "涓婚敭")
+    private String id;
+
+    /**
+     * 宸ュ崟鍙�
+     */
+    @ApiModelProperty(value = "宸ュ崟鍙�")
+    private String orderNum;
+}
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceChangeService.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceChangeService.java
index a14ddaa..a606fce 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceChangeService.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceChangeService.java
@@ -1,7 +1,12 @@
 package org.jeecg.modules.eam.service;
 
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.IService;
+import org.jeecg.common.api.vo.Result;
 import org.jeecg.modules.eam.entity.EamThirdMaintenanceChange;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeQuery;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeRequest;
 
 /**
  * @Description: 涓変繚鍙樻洿
@@ -11,4 +16,40 @@
  */
 public interface IEamThirdMaintenanceChangeService extends IService<EamThirdMaintenanceChange> {
 
+    /**
+     * 鍒嗛〉鏌ヨ
+     * @param page
+     * @param query
+     * @return
+     */
+    IPage<EamThirdMaintenanceChange> queryPageList(Page<EamThirdMaintenanceChange> page, EamThirdMaintenanceChangeQuery query);
+
+    /**
+     * 娣诲姞
+     * @param request
+     * @return
+     */
+    boolean saveThirdMaintenanceChange(EamThirdMaintenanceChange request);
+
+    /**
+     * 缂栬緫
+     * @param request
+     * @return
+     */
+    boolean editThirdMaintenanceChange(EamThirdMaintenanceChange request);
+
+    /**
+     * 鎻愪氦 寮�鍚祦绋嬪鎵�
+     * @param id
+     * @return
+     */
+    boolean submit(String id);
+
+    /**
+     * 娴佺▼瀹℃壒
+     * @param request
+     * @return
+     */
+    EamThirdMaintenanceChange approval(EamThirdMaintenanceChangeRequest request);
+
 }
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceOrderService.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceOrderService.java
index d214a27..23870f9 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceOrderService.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/IEamThirdMaintenanceOrderService.java
@@ -58,4 +58,12 @@
      * @return
      */
     Result<?> selectVoById(String id);
+
+    /**
+     * 鏇存柊涓変繚宸ュ崟鐘舵��
+     * @param orderId
+     * @param maintenanceStatus
+     * @return
+     */
+    boolean updateMaintenanceStatus(String orderId, String maintenanceStatus);
 }
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamInspectionOrderServiceImpl.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamInspectionOrderServiceImpl.java
index bd393ff..fb90334 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamInspectionOrderServiceImpl.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamInspectionOrderServiceImpl.java
@@ -371,17 +371,19 @@
             resultMap.put("itemCode", weekInsDetailResultResponse.getItemCode());
             resultMap.put("itemName", weekInsDetailResultResponse.getItemName());
             resultMap.put("itemDemand", weekInsDetailResultResponse.getItemDemand());
-            // 浣跨敤AtomicInteger浣滀负璁℃暟鍣紝浠�1寮�濮�
-            AtomicInteger counter = new AtomicInteger(1);
             Map<Integer, EamWeekInsDetailResultResponse> collect = weekInsDetailResultResponseList
                     .stream()
                     .collect(Collectors.toMap(
-                            // 鍒嗙粍閿細浣跨敤鑷搴忓彿锛堜粠1寮�濮嬶級
-                            item -> counter.getAndIncrement(),
+                            // 鍒嗙粍閿細浣跨敤planInspectionDate瀛楁钀藉湪鏈湀鐨勫懆鏁�
+                            item -> {
+                                Calendar calendar = Calendar.getInstance();
+                                calendar.setTime(item.getPlanInspectionDate());
+                                return calendar.get(Calendar.WEEK_OF_MONTH);
+                            },
                             // 鍊硷細鐩存帴浣跨敤褰撳墠瀵硅薄
                             item -> item,
-                            // 鍚堝苟鍑芥暟锛氬綋鍚屼竴搴忓彿鏈夊涓璞℃椂锛堢悊璁轰笂涓嶄細鍙戠敓锛夛紝濡備綍澶勭悊
-                            (existing, replacement) -> existing, // 鑻ユ湁閲嶅閿紝淇濈暀宸插瓨鍦ㄧ殑瀵硅薄
+                            // 鍚堝苟鍑芥暟锛氬綋鍚屼竴鍛ㄦ湁澶氫釜瀵硅薄鏃讹紙鏍规嵁闇�姹備笉浼氬彂鐢燂紝浣嗕粛闇�鎻愪緵锛�
+                            (existing, replacement) -> existing,
                             // 鎸囧畾Map鐨勫叿浣撳疄鐜帮紙鍙�夛級
                             LinkedHashMap::new // 淇濇寔鎻掑叆椤哄簭
                     ));
@@ -442,12 +444,18 @@
         Map<Integer, EamWeekInsDetailUserResponse> groupMap = eamWeekInsDetailUserResponseList
                 .stream()
                 .collect(Collectors.toMap(
-                        // 鍒嗙粍閿細浣跨敤鑷搴忓彿锛堜粠1寮�濮嬶級
-                        item -> counter.getAndIncrement(),
-                        // 鍊硷細鐩存帴浣跨敤褰撳墠瀵硅薄锛堜綔涓哄垵濮嬪�硷級
+                        // 鍒嗙粍閿細浣跨敤 planInspectionDate 瀛楁钀藉湪鏈湀鐨勫懆鏁�
+                        item -> {
+                            Calendar calendar = Calendar.getInstance();
+                            calendar.setTime(item.getPlanInspectionDate());
+                            return calendar.get(Calendar.WEEK_OF_MONTH);
+                        },
+                        // 鍊硷細鐩存帴浣跨敤褰撳墠瀵硅薄
                         item -> item,
-                        // 鍚堝苟鍑芥暟锛氬綋鍚屼竴鈥滃ぉ鈥濇湁澶氫釜瀵硅薄鏃讹紝濡備綍澶勭悊锛堣繖閲岀ず渚嬪彇绗竴涓級
-                        (existing, replacement) -> existing // 鑻ユ湁閲嶅閿紝淇濈暀宸插瓨鍦ㄧ殑瀵硅薄
+                        // 鍚堝苟鍑芥暟锛氬綋鍚屼竴鍛ㄦ湁澶氫釜瀵硅薄鏃讹紙鏍规嵁闇�姹備笉浼氬彂鐢燂級
+                        (existing, replacement) -> existing,
+                        // 浣跨敤 LinkedHashMap 淇濇寔鎻掑叆椤哄簭
+                        LinkedHashMap::new
                 ));
         Map<String, Object> resultMap = new LinkedHashMap<>();
         for (int i = 1; i <= 5; i++) {
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceChangeServiceImpl.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceChangeServiceImpl.java
index 11c5a5e..f70581a 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceChangeServiceImpl.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceChangeServiceImpl.java
@@ -1,10 +1,56 @@
 package org.jeecg.modules.eam.service.impl;
 
+import cn.hutool.core.collection.CollectionUtil;
+import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.shiro.SecurityUtils;
+import org.flowable.engine.TaskService;
+import org.flowable.task.api.Task;
+import org.jeecg.common.api.vo.Result;
+import org.jeecg.common.constant.CommonConstant;
+import org.jeecg.common.constant.DataBaseConstant;
+import org.jeecg.common.exception.JeecgBootException;
+import org.jeecg.common.system.vo.LoginUser;
+import org.jeecg.common.util.TranslateDictTextUtils;
+import org.jeecg.common.util.oConvertUtils;
+import org.jeecg.modules.eam.constant.*;
+import org.jeecg.modules.eam.entity.EamBaseHFCode;
+import org.jeecg.modules.eam.entity.EamEquipment;
 import org.jeecg.modules.eam.entity.EamThirdMaintenanceChange;
+import org.jeecg.modules.eam.entity.EamThirdMaintenanceOrder;
 import org.jeecg.modules.eam.mapper.EamThirdMaintenanceChangeMapper;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeQuery;
+import org.jeecg.modules.eam.request.EamThirdMaintenanceChangeRequest;
+import org.jeecg.modules.eam.service.IEamBaseHFCodeService;
+import org.jeecg.modules.eam.service.IEamEquipmentService;
 import org.jeecg.modules.eam.service.IEamThirdMaintenanceChangeService;
+import org.jeecg.modules.eam.service.IEamThirdMaintenanceOrderService;
+import org.jeecg.modules.flowable.apithird.business.entity.FlowMyBusiness;
+import org.jeecg.modules.flowable.apithird.business.service.IFlowMyBusinessService;
+import org.jeecg.modules.flowable.apithird.service.FlowCommonService;
+import org.jeecg.modules.flowable.service.IFlowDefinitionService;
+import org.jeecg.modules.flowable.service.IFlowTaskService;
+import org.jeecg.modules.system.entity.BaseFactory;
+import org.jeecg.modules.system.entity.BaseFactoryUser;
+import org.jeecg.modules.system.service.IBaseFactoryService;
+import org.jeecg.modules.system.service.IBaseFactoryUserService;
+import org.jeecg.modules.system.service.ISysBusinessCodeRuleService;
+import org.jeecg.modules.system.service.ISysUserService;
+import org.jeecg.modules.system.vo.UserSelector;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import javax.annotation.Resource;
+import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * @Description: 涓変繚鍙樻洿
@@ -15,4 +61,287 @@
 @Service
 public class EamThirdMaintenanceChangeServiceImpl extends ServiceImpl<EamThirdMaintenanceChangeMapper, EamThirdMaintenanceChange> implements IEamThirdMaintenanceChangeService {
 
+    @Resource
+    private EamThirdMaintenanceChangeMapper eamThirdMaintenanceChangeMapper;
+    @Resource
+    private IBaseFactoryUserService baseFactoryUserService;
+    @Resource
+    private IBaseFactoryService baseFactoryService;
+    @Resource
+    private IEamThirdMaintenanceOrderService thirdMaintenanceOrderService;
+    @Resource
+    private IEamEquipmentService equipmentService;
+    @Resource
+    private ISysBusinessCodeRuleService businessCodeRuleService;
+    @Resource
+    private IEamBaseHFCodeService hfCodeService;
+    @Resource
+    private ISysUserService sysUserService;
+    @Resource
+    private FlowCommonService flowCommonService;
+    @Resource
+    private TranslateDictTextUtils translateDictTextUtils;
+    @Resource
+    private IFlowDefinitionService flowDefinitionService;
+    @Resource
+    private IFlowMyBusinessService flowMyBusinessService;
+    @Resource
+    private TaskService taskService;
+    @Resource
+    private IEamEquipmentService eamEquipmentService;
+    @Resource
+    private IFlowTaskService flowTaskService;
+
+    @Override
+    public IPage<EamThirdMaintenanceChange> queryPageList(Page<EamThirdMaintenanceChange> page, EamThirdMaintenanceChangeQuery query) {
+        QueryWrapper<EamThirdMaintenanceChange> queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("tmc.del_flag", CommonConstant.DEL_FLAG_0);
+        //鐢ㄦ埛鏁版嵁鏉冮檺
+        LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
+        if (sysUser == null) {
+            return page;
+        }
+        if (StringUtils.isNotBlank(sysUser.getEquipmentIds())) {
+            //閫夋嫨浜嗚澶囷紝鏍规嵁璁惧id杩囨护璁惧
+            List<String> equipArr = Arrays.asList(sysUser.getEquipmentIds().split(","));
+            queryWrapper.in("e.equipment_code", equipArr);
+        } else {
+            //娌℃湁閫夋嫨璁惧锛屾牴鎹腑蹇冭繃婊よ澶�
+            List<BaseFactoryUser> baseFactoryUserList = baseFactoryUserService.
+                    list(new LambdaQueryWrapper<BaseFactoryUser>().eq(BaseFactoryUser::getUserId, sysUser.getId()));
+            if (!CollectionUtils.isEmpty(baseFactoryUserList)) {
+                Set<String> factoryIds = baseFactoryUserList.stream().map(BaseFactoryUser::getFactoryId).collect(Collectors.toSet());
+                Set<String> factoryCode = baseFactoryService.listByIds(factoryIds).stream().map(BaseFactory::getOrgCode).collect(Collectors.toSet());
+                queryWrapper.in("e.factory_org_code", factoryCode);
+            } else {
+                return page;
+            }
+        }
+        //鏌ヨ鏉′欢杩囨护
+        if (query != null) {
+            if (StringUtils.isNotBlank(query.getEquipmentId())) {
+                queryWrapper.eq("tmc.equipment_id", query.getEquipmentId());
+            }
+            if (StringUtils.isNotBlank(query.getChangeOrderNum())) {
+                queryWrapper.like("tmc.order_num", query.getChangeOrderNum());
+            }
+            if (StringUtils.isNotBlank(query.getChangeStatus())) {
+                queryWrapper.eq("tmc.change_status", query.getChangeStatus());
+            }
+            if (query.getApplyDateBegin() != null && query.getApplyDateEnd() != null) {
+                queryWrapper.between("tmc.apply_date", query.getApplyDateBegin(), query.getApplyDateEnd());
+            }
+            //鎺掑簭
+            if (StringUtils.isNotBlank(query.getColumn()) && StringUtils.isNotBlank(query.getOrder())) {
+                String column = query.getColumn();
+                if (column.endsWith(CommonConstant.DICT_TEXT_SUFFIX)) {
+                    column = column.substring(0, column.lastIndexOf(CommonConstant.DICT_TEXT_SUFFIX));
+                }
+                if (DataBaseConstant.SQL_ASC.equalsIgnoreCase(query.getOrder())) {
+                    queryWrapper.orderByAsc("tmc." + oConvertUtils.camelToUnderline(column));
+                } else {
+                    queryWrapper.orderByDesc("tmc." + oConvertUtils.camelToUnderline(column));
+                }
+            } else {
+                queryWrapper.orderByDesc("tmc.create_time");
+            }
+        } else {
+            queryWrapper.orderByDesc("tmc.create_time");
+        }
+        return eamThirdMaintenanceChangeMapper.queryPageList(page, queryWrapper);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean saveThirdMaintenanceChange(EamThirdMaintenanceChange request) {
+        //鏌ヨ宸ュ崟
+        EamThirdMaintenanceOrder order = thirdMaintenanceOrderService.getById(request.getOrderId());
+        if (order == null) {
+            throw new JeecgBootException("涓変繚宸ュ崟涓嶅瓨鍦紝鎿嶄綔澶辫触锛�");
+        }
+        //鏌ヨ璁惧
+        EamEquipment equipment = equipmentService.getById(order.getEquipmentId());
+        if (equipment == null) {
+            throw new JeecgBootException("璁惧淇℃伅涓嶅瓨鍦紝鎿嶄綔澶辫触锛�");
+        }
+        //鐢ㄦ埛鏁版嵁鏉冮檺
+        LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
+        if (sysUser == null) {
+            throw new JeecgBootException("鐧诲綍鐢ㄦ埛淇℃伅涓虹┖锛屾搷浣滃け璐ワ紒");
+        }
+        String codeSeq = businessCodeRuleService.generateBusinessCodeSeq(BusinessCodeConst.THIRD_MAINTENANCE_CHANGE_CODE_RULE);
+        request.setChangeOrderNum(codeSeq);
+        request.setId(null);
+        request.setChangeStatus(ThirdMaintenanceChangeStatusEnum.WAIT_SUBMIT.name());
+        request.setDelFlag(CommonConstant.DEL_FLAG_0);
+        request.setApplicant(sysUser.getUsername());
+        request.setApplyDate(new Date());
+        request.setFactoryOrgCode(equipment.getFactoryOrgCode());
+        // 涓変繚鍙樻洿宸ュ崟HF
+        EamBaseHFCode eamBaseHFCode = hfCodeService.selectByCategory(HfTemplateCategoryEnum.THIRD_MAINTENANCE_CHANGE.name());
+        if (eamBaseHFCode == null) {
+            throw new JeecgBootException("鏈厤缃妧鏈姸鎬侀壌瀹氬彉鏇寸殑HF缂栫爜锛屾坊鍔犲け璐ワ紒");
+        }
+        request.setHfCode(eamBaseHFCode.getHfCode());
+        this.getBaseMapper().insert(request);
+        boolean b = thirdMaintenanceOrderService.updateMaintenanceStatus(request.getOrderId(), ThirdMaintenanceStatusEnum.CHANGE.name());
+        if (!b) {
+            throw new JeecgBootException("涓変繚宸ュ崟鐘舵�佸彉鏇村け璐ワ紝鏃犳硶鍙樻洿锛�");
+        }
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean editThirdMaintenanceChange(EamThirdMaintenanceChange request) {
+        EamThirdMaintenanceChange entity = this.getBaseMapper().selectById(request);
+        if(entity == null) {
+            throw new JeecgBootException("缂栬緫鐨勬暟鎹凡鍒犻櫎锛岃鍒锋柊閲嶈瘯锛�");
+        }
+        if(!ThirdMaintenanceChangeStatusEnum.WAIT_SUBMIT.name().equals(entity.getChangeStatus())) {
+            throw new JeecgBootException("鍙湁寰呮彁浜ょ姸鎬佹墠鍙紪杈戯紒");
+        }
+        entity.setApplyReasonType(request.getApplyReasonType());
+        entity.setApplyReason(request.getApplyReason());
+        this.getBaseMapper().updateById(entity);
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean submit(String id) {
+        EamThirdMaintenanceChange entity = this.getBaseMapper().selectById(id);
+        if (entity == null) {
+            throw new JeecgBootException("瑕佹彁浜ょ殑宸ュ崟涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        if (!ThirdMaintenanceChangeStatusEnum.WAIT_SUBMIT.name().equals(entity.getChangeStatus())) {
+            throw new JeecgBootException("璇ュ伐鍗曞凡杩涜杩囨彁浜わ紒");
+        }
+        EamThirdMaintenanceOrder order = thirdMaintenanceOrderService.getById(entity.getOrderId());
+        if(order == null) {
+            throw new JeecgBootException("瑕佸彉鏇寸殑涓変繚宸ュ崟涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        EamEquipment equipment = equipmentService.getById(order.getEquipmentId());
+        if (equipment == null) {
+            throw new JeecgBootException("璁惧涓嶅瓨鍦紝鎻愪氦澶辫触锛�");
+        }
+        LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
+        if(sysUser == null || !sysUser.getUsername().equals(entity.getApplicant())) {
+            throw new JeecgBootException("涓嶆槸鏈汉锛屼笉鑳芥彁浜ゆ宸ュ崟锛�");
+        }
+        entity.setChangeStatus(ThirdMaintenanceChangeStatusEnum.EQUIPMENT_MANAGER_SIGNING.name());
+        //鏌ヨ涓嬬骇瀹℃壒浜哄憳
+        List<UserSelector> userSelectors = sysUserService.selectOperatorList(equipment.getEquipmentCode(), equipment.getFactoryOrgCode(), BusinessCodeConst.PCR0011);
+        if (CollectionUtil.isEmpty(userSelectors)) {
+            throw new JeecgBootException("璁惧鏈垎閰嶇粰浣跨敤鍗曚綅涓荤瀹ょ骇棰嗗锛屾棤娉曟彁浜わ紒");
+        }
+        List<String> userApprovalList = userSelectors.stream().map(UserSelector::getUsername).collect(Collectors.toList());
+        //鏇存柊瀹炰綋
+        this.getBaseMapper().updateById(entity);
+        //鍚姩娴佺▼
+        flowCommonService.initActBusiness("宸ュ崟鍙�: " + entity.getChangeOrderNum() + ";璁惧缂栧彿: " + equipment.getEquipmentCode(),
+                entity.getId(), "IEamThirdMaintenanceChangeService", "third_maintenance_change", null);
+        Map<String, Object> variables = new HashMap<>();
+        variables.put("dataId", entity.getId());
+        String applyReasonTypeText = translateDictTextUtils.translateField("applyReasonType", entity.getApplyReasonType(), "third_maintenance_change_reason");
+        if (StrUtil.isEmpty(applyReasonTypeText)) {
+            variables.put("organization", "鏂板涓変繚宸ュ崟鍙樻洿榛樿鍚姩娴佺▼");
+            variables.put("comment", "鏂板涓変繚宸ュ崟鍙樻洿榛樿鍚姩娴佺▼");
+        } else {
+            variables.put("organization", applyReasonTypeText);
+            variables.put("comment", applyReasonTypeText);
+        }
+        Result<?> result = flowDefinitionService.startProcessInstanceByKey("third_maintenance_change", variables);
+        if(result == null || !result.isSuccess()) {
+            throw new JeecgBootException("鍚姩娴佺▼澶辫触锛�");
+        }
+        //鏇存柊宸ュ崟鐘舵�佷负鍙樻洿涓�
+        order.setMaintenanceStatus(ThirdMaintenanceStatusEnum.CHANGE.name());
+        boolean b = thirdMaintenanceOrderService.updateById(order);
+        if(!b) {
+            throw new JeecgBootException("涓変繚宸ュ崟鐘舵�佹洿鏂板け璐ワ紒");
+        }
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public EamThirdMaintenanceChange approval(EamThirdMaintenanceChangeRequest request) {
+        EamThirdMaintenanceChange entity = this.getBaseMapper().selectById(request.getId());
+        if (entity == null) {
+            throw new JeecgBootException("瀹℃壒鐨勬暟鎹凡鍒犻櫎锛岃鍒锋柊閲嶈瘯锛�");
+        }
+        EamThirdMaintenanceOrder order = thirdMaintenanceOrderService.getById(entity.getOrderId());
+        if(order == null) {
+            throw new JeecgBootException("瑕佸彉鏇寸殑涓変繚宸ュ崟涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        // 鑾峰彇褰撳墠鐧诲綍鐢ㄦ埛
+        LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal();
+        if (user == null || StrUtil.isBlank(user.getId())) {
+            throw new JeecgBootException("鏈幏鍙栧埌鐧诲綍鐢ㄦ埛锛岃閲嶆柊鐧诲綍鍚庡啀璇曪紒");
+        }
+        request.setAssignee(user.getUsername());
+        // 鑾峰彇娴佺▼涓氬姟璁板綍
+        FlowMyBusiness flowMyBusiness = flowMyBusinessService.getFlowMyBusiness(request.getInstanceId(), request.getTaskId());
+        if (flowMyBusiness == null) {
+            throw new JeecgBootException("娴佺▼瀹炰緥涓嶅瓨鍦紝璇峰埛鏂板悗閲嶈瘯锛�");
+        }
+
+        if (!isUserAuthorized(flowMyBusiness, user)) {
+            throw new JeecgBootException("鐢ㄦ埛鏃犳潈鎿嶄綔姝や换鍔★紝璇峰埛鏂板悗閲嶈瘯锛�");
+        }
+        // 璁ら浠诲姟
+        if (!claimTask(flowMyBusiness.getTaskId(), user)) {
+            throw new JeecgBootException("浠诲姟涓嶅瓨鍦ㄣ�佸凡瀹屾垚鎴栧凡琚粬浜鸿棰嗭紒");
+        }
+        EamEquipment equipment = eamEquipmentService.getById(order.getEquipmentId());
+        if (equipment == null) {
+            throw new JeecgBootException("璁惧涓嶅瓨鍦紝璇锋鏌ワ紒");
+        }
+
+        // 璁剧疆娴佺▼鍙橀噺
+        setupProcessVariables(request, order, user, equipment);
+
+        // 瀹屾垚娴佺▼浠诲姟
+        Result result = flowTaskService.complete(request);
+
+        // 鏍规嵁浠诲姟瀹屾垚缁撴灉鏇存柊宸ュ崟鐘舵��
+        updateOrderStatus(result, request, order, user);
+
+        //鏇存柊宸ュ崟淇℃伅
+        this.getBaseMapper().updateById(entity);
+        return entity;
+    }
+
+    /**
+     * 璁剧疆娴佺▼鍙橀噺
+     */
+    private void setupProcessVariables(EamThirdMaintenanceChangeRequest request, EamThirdMaintenanceOrder order, LoginUser user, EamEquipment equipment) {
+
+    }
+
+    /**
+     * 鏇存柊宸ュ崟鐘舵��
+     */
+    private void updateOrderStatus(Result result, EamThirdMaintenanceChangeRequest request, EamThirdMaintenanceOrder order, LoginUser user) {
+
+    }
+
+    private boolean isUserAuthorized(FlowMyBusiness flowMyBusiness, LoginUser user) {
+        List<String> todoUsers = JSON.parseArray(flowMyBusiness.getTodoUsers(), String.class);
+        return todoUsers != null && todoUsers.contains(user.getUsername());
+    }
+
+    private boolean claimTask(String taskId, LoginUser user) {
+        Task task = taskService.createTaskQuery().taskId(taskId).singleResult();
+        if (task == null) {
+            return false;
+        }
+        if (task.getAssignee() != null && !task.getAssignee().equals(user.getUsername())) {
+            return false;
+        }
+        taskService.claim(taskId, user.getUsername());
+        return true;
+    }
+
 }
diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
index 18c3350..ef15217 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
@@ -5,6 +5,7 @@
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -22,12 +23,8 @@
 import org.jeecg.common.util.oConvertUtils;
 import org.jeecg.modules.eam.aspect.annotation.EquipmentHistoryLog;
 import org.jeecg.modules.eam.constant.*;
-import org.jeecg.modules.eam.entity.EamBaseHFCode;
-import org.jeecg.modules.eam.entity.EamEquipment;
-import org.jeecg.modules.eam.entity.EamThirdMaintenanceOrder;
-import org.jeecg.modules.eam.entity.EamThirdMaintenanceOrderDetail;
+import org.jeecg.modules.eam.entity.*;
 import org.jeecg.modules.eam.mapper.EamThirdMaintenanceOrderMapper;
-import org.jeecg.modules.eam.request.EamInspectionOrderRequest;
 import org.jeecg.modules.eam.request.EamThirdMaintenanceQuery;
 import org.jeecg.modules.eam.request.EamThirdMaintenanceRequest;
 import org.jeecg.modules.eam.service.*;
@@ -360,6 +357,18 @@
         return Result.ok(eamThirdMaintenanceRequestList);
     }
 
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean updateMaintenanceStatus(String orderId, String maintenanceStatus) {
+        LambdaUpdateWrapper<EamThirdMaintenanceOrder> updateWrapper = new LambdaUpdateWrapper<>();
+        updateWrapper.eq(EamThirdMaintenanceOrder::getId, orderId);
+        updateWrapper.set(EamThirdMaintenanceOrder::getMaintenanceStatus, maintenanceStatus);
+        updateWrapper.eq(EamThirdMaintenanceOrder::getDelFlag, CommonConstant.DEL_FLAG_0);
+        updateWrapper.in(EamThirdMaintenanceOrder::getMaintenanceStatus, Arrays.asList(ThirdMaintenanceStatusEnum.WAIT_MAINTENANCE.name(), ThirdMaintenanceStatusEnum.FREEZE.name()));
+        int update = this.getBaseMapper().update(null, updateWrapper);
+        return update > 0;
+    }
+
     /**
      * 璁剧疆娴佺▼鍙橀噺
      */

--
Gitblit v1.9.3