فهرست منبع

我发起的工单

ouyj 5 ماه پیش
والد
کامیت
dc4613cf09

+ 87 - 0
ygtx-gxt/src/main/java/com/ygtx/gxt/controller/GxtOrderMineController.java

@@ -0,0 +1,87 @@
+package com.ygtx.gxt.controller;
+
+import com.ygtx.common.annotation.Log;
+import com.ygtx.common.core.controller.BaseController;
+import com.ygtx.common.core.domain.AjaxResult;
+import com.ygtx.common.core.page.TableDataInfo;
+import com.ygtx.common.enums.BusinessType;
+import com.ygtx.gxt.domain.GxtRepairOrder;
+import com.ygtx.gxt.domain.GxtWorkOrder;
+import com.ygtx.gxt.domain.OrderScoreInfo;
+import com.ygtx.gxt.service.IGxtOrderMineService;
+import com.ygtx.gxt.service.IGxtOrderScoreService;
+import com.ygtx.gxt.service.IGxtRepairOrderService;
+import com.ygtx.gxt.service.IGxtWorkOrderService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 我的工单Controller
+ * 
+ * @author ouyj
+ * @date 2025-11-27
+ */
+@RestController
+@RequestMapping("/gxt/orderMine")
+public class GxtOrderMineController extends BaseController
+{
+    @Autowired
+    private IGxtRepairOrderService gxtRepairOrderService;
+
+    @Autowired
+    private IGxtWorkOrderService gxtWorkOrderService;
+    
+    @Autowired
+    private IGxtOrderMineService gxtOrderMineService;
+
+    /**
+     * 查询我创建的工单列表(合并维修工单和维保工单)
+     */
+    @PreAuthorize("@ss.hasPermi('gxt:orderMine:listMyCreate')")
+    @GetMapping("/listMyCreate")
+    public TableDataInfo listMyCreate(GxtRepairOrder repairOrder, GxtWorkOrder workOrder)
+    {
+        // 开启分页插件自动分页
+        startPage();
+        // 查询合并的工单列表
+        List<OrderScoreInfo> list = gxtOrderMineService.selectUnionOrderListMyCreate(repairOrder, workOrder);
+        return getDataTable(list);
+    }
+
+    /**
+     * 查询我处理的工单列表(合并维修工单和维保工单)
+     */
+    @PreAuthorize("@ss.hasPermi('gxt:orderMine:listMyDone')")
+    @GetMapping("/listMyDone")
+    public TableDataInfo listMyDone(GxtRepairOrder repairOrder, GxtWorkOrder workOrder)
+    {
+        // 开启分页插件自动分页
+        startPage();
+        // 查询合并的工单列表
+        List<OrderScoreInfo> list = gxtOrderMineService.selectUnionOrderListMyDone(repairOrder, workOrder);
+        return getDataTable(list);
+    }
+
+    /**
+     * 获取工单详细信息
+     */
+    @PreAuthorize("@ss.hasPermi('gxt:orderMine:query')")
+    @GetMapping(value = "/{orderType}/{orderId}")
+    public AjaxResult getInfo(@PathVariable("orderType") Integer orderType, @PathVariable("orderId") Long orderId)
+    {
+        if (orderType == 1) {
+            // 维修工单
+            GxtRepairOrder order = gxtRepairOrderService.selectGxtRepairOrderById(orderId);
+            return success(order);
+        } else if (orderType == 2) {
+            // 维保工单
+            GxtWorkOrder order = gxtWorkOrderService.selectGxtWorkOrderById(orderId);
+            return success(order);
+        }
+        return AjaxResult.error("无效的工单类型");
+    }
+}

+ 30 - 0
ygtx-gxt/src/main/java/com/ygtx/gxt/mapper/GxtOrderMineMapper.java

@@ -0,0 +1,30 @@
+package com.ygtx.gxt.mapper;
+
+import com.ygtx.gxt.domain.GxtRepairOrder;
+import com.ygtx.gxt.domain.GxtWorkOrder;
+import com.ygtx.gxt.domain.OrderScoreInfo;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 工单评分Mapper接口
+ * 
+ * @author lingming
+ * @date 2025-11-12
+ */
+public interface GxtOrderMineMapper {
+
+    /**
+     * 查询我创建的工单列表(维修工单和维保工单)
+     * 
+     * @param repairOrder 维修工单查询条件
+     * @param workOrder 维保工单查询条件
+     * @return 合并的工单列表
+     */
+    public List<OrderScoreInfo> selectUnionOrderList(@Param("repairOrder") GxtRepairOrder repairOrder,
+                                                     @Param("workOrder") GxtWorkOrder workOrder);
+
+
+}

+ 35 - 0
ygtx-gxt/src/main/java/com/ygtx/gxt/service/IGxtOrderMineService.java

@@ -0,0 +1,35 @@
+package com.ygtx.gxt.service;
+
+import com.ygtx.gxt.domain.GxtRepairOrder;
+import com.ygtx.gxt.domain.GxtWorkOrder;
+import com.ygtx.gxt.domain.OrderScoreInfo;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 我的工单Service接口
+ * 
+ * @author ouyj
+ * @date 2025-11-27
+ */
+public interface IGxtOrderMineService {
+
+    /**
+     * 查询我创建的工单列表(合并维修工单和维保工单)
+     * 
+     * @param repairOrder 维修工单查询条件
+     * @param workOrder 维保工单查询条件
+     * @return 合并的工单列表
+     */
+    public List<OrderScoreInfo> selectUnionOrderListMyCreate(GxtRepairOrder repairOrder, GxtWorkOrder workOrder);
+
+    /**
+     * 查询我处理的工单列表(合并维修工单和维保工单)
+     *
+     * @param repairOrder 维修工单查询条件
+     * @param workOrder 维保工单查询条件
+     * @return 合并的工单列表
+     */
+    List<OrderScoreInfo> selectUnionOrderListMyDone(GxtRepairOrder repairOrder, GxtWorkOrder workOrder);
+}

+ 356 - 0
ygtx-gxt/src/main/java/com/ygtx/gxt/service/impl/GxtOrderMineServiceImpl.java

@@ -0,0 +1,356 @@
+package com.ygtx.gxt.service.impl;
+
+import com.ygtx.common.constant.Constants;
+import com.ygtx.common.core.domain.entity.SysRole;
+import com.ygtx.common.core.domain.entity.SysUser;
+import com.ygtx.common.core.domain.model.LoginUser;
+import com.ygtx.common.utils.SecurityUtils;
+import com.ygtx.common.utils.StringUtils;
+import com.ygtx.framework.aspectj.DataScopeAspect;
+import com.ygtx.gxt.domain.*;
+import com.ygtx.gxt.mapper.GxtOrderMineMapper;
+import com.ygtx.gxt.mapper.GxtOrderScoreMapper;
+import com.ygtx.gxt.service.IGxtOrderMineService;
+import com.ygtx.gxt.service.IGxtOrderScoreService;
+import com.ygtx.gxt.service.IGxtRepairOrderService;
+import com.ygtx.gxt.service.IGxtWorkOrderService;
+import com.ygtx.system.mapper.SysUserMapper;
+import com.ygtx.system.service.ISysConfigService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.math.BigDecimal;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 我的工单Service业务层处理
+ *
+ * @author ouyj
+ * @date 2025-11-27
+ */
+@Service
+public class GxtOrderMineServiceImpl implements IGxtOrderMineService {
+
+    @Autowired
+    private GxtOrderMineMapper gxtOrderMineMapper;
+    
+    @Autowired
+    private IGxtRepairOrderService gxtRepairOrderService;
+    
+    @Autowired
+    private IGxtWorkOrderService gxtWorkOrderService;
+    
+    @Autowired
+    private SysUserMapper userMapper;
+
+    @Autowired
+    private ISysConfigService configService;
+
+    /**
+     * 查询我创建的工单列表(维修工单和维保工单)
+     *
+     * @param repairOrder 维修工单查询条件
+     * @param workOrder 维保工单查询条件
+     * @return 合并的工单列表
+     */
+    @Override
+    public List<OrderScoreInfo> selectUnionOrderListMyCreate(GxtRepairOrder repairOrder, GxtWorkOrder workOrder) {
+        if (repairOrder.getCreateBy() == null || repairOrder.getCreateBy().isEmpty()) {
+            repairOrder.setCreateBy(SecurityUtils.getUsername());
+        }
+
+        if (workOrder.getCreateBy() == null || workOrder.getCreateBy().isEmpty()) {
+            workOrder.setCreateBy(SecurityUtils.getUsername());
+        }
+        // 查询工单列表
+        List<OrderScoreInfo> orderList = gxtOrderMineMapper.selectUnionOrderList(repairOrder, workOrder);
+
+        return orderList;
+    }
+
+    @Override
+    public List<OrderScoreInfo> selectUnionOrderListMyDone(GxtRepairOrder repairOrder, GxtWorkOrder workOrder) {
+        // 添加业务特定的数据权限过滤
+        addBusinessDataScopeFilter(repairOrder, workOrder);
+
+        // 设置创建人,用于数据权限过滤
+        if(!Constants.SUPER_ADMIN.equals(SecurityUtils.getUsername())){
+            if (repairOrder.getCreateBy() == null || repairOrder.getCreateBy().isEmpty()) {
+                repairOrder.setCreateBy(SecurityUtils.getUsername());
+            }
+
+            if (workOrder.getCreateBy() == null || workOrder.getCreateBy().isEmpty()) {
+                workOrder.setCreateBy(SecurityUtils.getUsername());
+            }
+        }
+        // 查询工单列表
+        List<OrderScoreInfo> orderList = gxtOrderMineMapper.selectUnionOrderList(repairOrder, workOrder);
+
+        return orderList;
+    }
+
+    /**
+     * 添加业务特定的数据权限过滤条件
+     * 基于角色的数据范围进行自定义权限控制
+     *
+     * @param repairOrder 维修工单查询条件
+     * @param workOrder 维保工单查询条件
+     */
+    private void addBusinessDataScopeFilter(GxtRepairOrder repairOrder, GxtWorkOrder workOrder) {
+        // 获取当前登录用户
+        LoginUser loginUser = SecurityUtils.getLoginUser();
+        if (loginUser == null) {
+            return;
+        }
+
+        SysUser currentUser = loginUser.getUser();
+        if (currentUser == null) {
+            return;
+        }
+
+        // 如果是超级管理员,不过滤数据
+        if (currentUser.isAdmin()) {
+            return;
+        }
+
+        // 获取用户角色
+        List<SysRole> roles = currentUser.getRoles();
+        if (roles == null || roles.isEmpty()) {
+            return;
+        }
+
+        // 构建业务特定的数据权限SQL
+        StringBuilder orderBusinessSql = new StringBuilder();
+        StringBuilder repairBusinessSql = new StringBuilder();
+
+        // 遍历用户角色,根据角色的数据范围添加业务特定的权限控制
+        for (SysRole role : roles) {
+            String dataScope = role.getDataScope();
+
+            // 如果是全部数据权限,则不过滤
+            if (DataScopeAspect.DATA_SCOPE_ALL.equals(dataScope)) {
+                orderBusinessSql.setLength(0); // 清空之前的条件
+                repairBusinessSql.setLength(0); // 清空之前的条件
+                break; // 全部数据权限,跳出循环
+            }
+
+            // 自定义数据权限 - 根据角色的数据范围值来控制查询条件
+            if (DataScopeAspect.DATA_SCOPE_CUSTOM.equals(dataScope)) {
+                // 获取具有自定义数据权限的角色ID列表
+                List<String> customRoleIds = new ArrayList<>();
+                for (SysRole r : roles) {
+                    if (DataScopeAspect.DATA_SCOPE_CUSTOM.equals(r.getDataScope())) {
+                        customRoleIds.add(String.valueOf(r.getRoleId()));
+                    }
+                }
+
+                // 构建自定义数据权限查询条件
+                if (orderBusinessSql.length() > 0) {
+                    orderBusinessSql.append(" OR ");
+                }
+                // 构建自定义数据权限查询条件
+                if (repairBusinessSql.length() > 0) {
+                    repairBusinessSql.append(" OR ");
+                }
+
+                if (customRoleIds.size() > 1) {
+                    // 多个自定义数据权限角色使用IN查询
+                    orderBusinessSql.append("(t.pcs_station_pid IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append("))")
+                            .append(" OR t.pcs_station_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append("))")
+                            .append(" OR t.gxt_center_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append(")))");
+                    repairBusinessSql.append("(t.pcs_station_pid IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append("))")
+                            .append(" OR t.pcs_station_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append("))")
+                            .append(" OR t.gxt_center_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id IN (")
+                            .append(String.join(",", customRoleIds))
+                            .append(")))");
+                } else {
+                    // 单个自定义数据权限角色查询
+                    orderBusinessSql.append("(t.pcs_station_pid IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append(")")
+                            .append(" OR t.pcs_station_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append(")")
+                            .append(" OR t.gxt_center_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append("))");
+                    repairBusinessSql.append("(t.pcs_station_pid IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append(")")
+                            .append(" OR t.pcs_station_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append(")")
+                            .append(" OR t.gxt_center_id IN (SELECT dept_id FROM sys_role_dept WHERE role_id = ")
+                            .append(role.getRoleId())
+                            .append("))");
+                }
+                continue;
+            }
+
+            // 部门数据权限 - 适用于部门负责人角色
+            if (DataScopeAspect.DATA_SCOPE_DEPT.equals(dataScope)) {
+                if (orderBusinessSql.length() > 0) {
+                    orderBusinessSql.append(" OR ");
+                }
+                if (repairBusinessSql.length() > 0) {
+                    repairBusinessSql.append(" OR ");
+                }
+                orderBusinessSql.append("(t.pcs_station_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR t.pcs_station_pid = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR t.gxt_center_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(")");
+                repairBusinessSql.append("(t.pcs_station_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR t.pcs_station_pid = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR t.gxt_center_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(")");
+                continue;
+            }
+
+            // 部门及以下数据权限
+            if (DataScopeAspect.DATA_SCOPE_DEPT_AND_CHILD.equals(dataScope)) {
+                if (orderBusinessSql.length() > 0) {
+                    orderBusinessSql.append(" OR ");
+                }
+                if (repairBusinessSql.length() > 0) {
+                    repairBusinessSql.append(" OR ");
+                }
+                orderBusinessSql.append("(t.pcs_station_id IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors))")
+                        .append(" OR t.pcs_station_pid IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors))")
+                        .append(" OR t.gxt_center_id IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors)))");
+                repairBusinessSql.append("(t.pcs_station_id IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors))")
+                        .append(" OR t.pcs_station_pid IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors))")
+                        .append(" OR t.gxt_center_id IN ")
+                        .append("(SELECT dept_id FROM sys_dept WHERE dept_id = ")
+                        .append(currentUser.getDeptId())
+                        .append(" OR FIND_IN_SET(")
+                        .append(currentUser.getDeptId())
+                        .append(", ancestors)))");
+                continue;
+            }
+
+            // 仅本人数据权限 - 适用于主检修员角色
+            if (DataScopeAspect.DATA_SCOPE_SELF.equals(dataScope)) {
+                if (orderBusinessSql.length() > 0) {
+                    orderBusinessSql.append(" OR ");
+                }
+                if (repairBusinessSql.length() > 0) {
+                    repairBusinessSql.append(" OR ");
+                }
+                orderBusinessSql.append("(t.team_leader_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.assign_user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.accept_user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.id IN (SELECT order_id FROM gxt_work_order_person WHERE user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(") ")
+                        .append(" OR t.create_by = '")
+                        .append(currentUser.getUserName())
+                        .append("')");
+                repairBusinessSql.append("(t.team_leader_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.assign_user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.accept_user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(" OR t.id IN (SELECT order_id FROM gxt_repair_order_person WHERE user_id = ")
+                        .append(currentUser.getUserId())
+                        .append(") ")
+                        .append(" OR t.create_by = '")
+                        .append(currentUser.getUserName())
+                        .append("')");
+                continue;
+            }
+        }
+        String selfData = configService.selectConfigByKey("gxt.oder.selfData");
+        if (StringUtils.isNotEmpty(selfData) && "1".equals(selfData)) {
+            if (orderBusinessSql.length() > 0) {
+                orderBusinessSql.append(" OR ");
+            }
+            if (repairBusinessSql.length() > 0) {
+                repairBusinessSql.append(" OR ");
+            }
+            orderBusinessSql.append("(t.team_leader_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.assign_user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.accept_user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.id IN (SELECT order_id FROM gxt_work_order_person WHERE user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(") ")
+                    .append(" OR t.create_by = '")
+                    .append(currentUser.getUserName())
+                    .append("')");
+            repairBusinessSql.append("(t.team_leader_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.assign_user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.accept_user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(" OR t.id IN (SELECT order_id FROM gxt_repair_order_person WHERE user_id = ")
+                    .append(currentUser.getUserId())
+                    .append(") ")
+                    .append(" OR t.create_by = '")
+                    .append(currentUser.getUserName())
+                    .append("')");
+        }
+        // 如果构建了业务特定的过滤条件,则添加到查询参数中
+        if (orderBusinessSql.length() > 0) {
+            String businessDataScopeSql = " AND (" + orderBusinessSql.toString() + ")";
+            workOrder.getParams().put("businessDataScope", businessDataScopeSql);
+        }
+        if (repairBusinessSql.length() > 0) {
+            String businessDataScopeSql = " AND (" + repairBusinessSql.toString() + ")";
+            repairOrder.getParams().put("businessDataScope", businessDataScopeSql);
+        }
+    }
+    
+
+}

+ 217 - 0
ygtx-gxt/src/main/resources/mapper/gxt/GxtOrderMineMapper.xml

@@ -0,0 +1,217 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.ygtx.gxt.mapper.GxtOrderMineMapper">
+
+    <resultMap type="com.ygtx.gxt.domain.OrderScoreInfo" id="OrderScoreInfoResult">
+        <result property="orderType"    column="order_type"    />
+        <result property="id"    column="id"    />
+        <result property="workOrderProjectNo"    column="work_order_project_no"    />
+        <result property="workOrderStatus"    column="work_order_status"    />
+        <result property="gxtCenterId"    column="gxt_center_id"    />
+        <result property="gxtCenter"    column="gxt_center"    />
+        <result property="pcsStationId"    column="pcs_station_id"    />
+        <result property="pcsStationPid"    column="pcs_station_pid"    />
+        <result property="pcsStationName"    column="pcs_station_name"    />
+        <result property="pcsDeviceId"    column="pcs_device_id"    />
+        <result property="pcsDeviceName"    column="pcs_device_name"    />
+        <result property="brand"    column="brand"    />
+        <result property="model"    column="model"    />
+        <result property="assignTime"    column="assign_time"    />
+        <result property="assignUserId"    column="assign_user_id"    />
+        <result property="assignUserName"    column="assign_user_name"    />
+        <result property="acceptTime"    column="accept_time"    />
+        <result property="acceptUserId"    column="accept_user_id"    />
+        <result property="acceptUserName"    column="accept_user_name"    />
+        <result property="realStartTime"    column="real_start_time"    />
+        <result property="realEndTime"    column="real_end_time"    />
+        <result property="teamLeaderId"    column="team_leader_id"    />
+        <result property="teamLeaderName"    column="team_leader_name"    />
+        <result property="workGroupMemberId"    column="work_group_member_id"    />
+        <result property="workGroupMemberName"    column="work_group_member_name"    />
+        <result property="score"    column="score"    />
+        <result property="reviewContent"    column="review_content"    />
+        <result property="suspendReason"    column="suspend_reason"    />
+        <result property="restartTime"    column="restart_time"    />
+        <result property="priorityType"    column="priority_type"    />
+        <result property="workEndTime"    column="work_end_time"    />
+        <result property="scoringStatus"    column="scoring_status"    />
+        <result property="workSummary"    column="work_summary"    />
+        <result property="maintenanceType"    column="maintenance_type"    />
+        <result property="inspectionType"    column="inspection_type"    />
+        <!-- 新增字段映射 -->
+        <result property="planHour"    column="plan_hour"    />
+        <result property="faultCode"    column="fault_code"    />
+        <result property="faultDesc"    column="fault_desc"    />
+        <result property="occurTime"    column="occur_time"    />
+        <result property="suspendTime"    column="suspend_time"    />
+        <result property="pauseReason"    column="pause_reason"    />
+        <result property="pauseTime"    column="pause_time"    />
+        <result property="completeTime"    column="complete_time"    />
+        <result property="status"    column="status"    />
+        <result property="reviewScoreNum"    column="review_score_num"    />
+        <result property="finalCoefficient"    column="final_coefficient"    />
+        <result property="planStartTime" column="plan_start_time" />
+        <result property="planEndTime" column="plan_end_time" />
+        <result property="createTime"    column="create_time"    />
+        <result property="updateTime"    column="update_time"    />
+    </resultMap>
+
+    <select id="selectUnionOrderList" resultMap="OrderScoreInfoResult">
+        SELECT * FROM (
+            SELECT
+                1 as order_type,
+                id as id,
+                work_order_project_no as work_order_project_no,
+                work_order_status as work_order_status,
+                gxt_center_id as gxt_center_id,
+                gxt_center as gxt_center,
+                pcs_station_id as pcs_station_id,
+                pcs_station_pid as pcs_station_pid,
+                pcs_station_name as pcs_station_name,
+                pcs_device_id as pcs_device_id,
+                pcs_device_name as pcs_device_name,
+                brand as brand,
+                model as model,
+                assign_time as assign_time,
+                assign_user_id as assign_user_id,
+                assign_user_name as assign_user_name,
+                accept_time as accept_time,
+                accept_user_id as accept_user_id,
+                accept_user_name as accept_user_name,
+                real_start_time as real_start_time,
+                real_end_time as real_end_time,
+                team_leader_id as team_leader_id,
+                team_leader_name as team_leader_name,
+                work_group_member_id as work_group_member_id,
+                work_group_member_name as work_group_member_name,
+                score as score,
+                review_content as review_content,
+                suspend_reason as suspend_reason,
+                restart_time as restart_time,
+                priority_type as priority_type,
+                real_end_time as work_end_time,
+                scoring_status as scoring_status,
+                content as work_summary,
+                maintenance_type as maintenance_type,
+                null as inspection_type,
+                null as plan_start_time,
+                null as plan_end_time,
+                plan_hour as plan_hour,
+                fault_code as fault_code,
+                fault_desc as fault_desc,
+                occur_time as occur_time,
+                null as suspend_time,
+                null as pause_reason,
+                null as pause_time,
+                null as complete_time,
+                review_score_num as review_score_num,
+                final_coefficient as final_coefficient,
+                create_time as create_time,
+                update_time as update_time
+            FROM gxt_repair_order t
+            <where>
+                <if test="repairOrder.workOrderProjectNo != null and repairOrder.workOrderProjectNo != ''"> and work_order_project_no like concat('%', #{repairOrder.workOrderProjectNo}, '%')</if>
+                <if test="repairOrder.workOrderStatus != null and repairOrder.workOrderStatus != ''"> and work_order_status = #{repairOrder.workOrderStatus}</if>
+                <if test="repairOrder.gxtCenterId != null"> and gxt_center_id = #{repairOrder.gxtCenterId}</if>
+                <if test="repairOrder.gxtCenter != null and repairOrder.gxtCenter != ''"> and gxt_center = #{repairOrder.gxtCenter}</if>
+                <if test="repairOrder.pcsStationId != null"> and pcs_station_id = #{repairOrder.pcsStationId}</if>
+                <if test="repairOrder.pcsStationName != null and repairOrder.pcsStationName != ''"> and pcs_station_name = #{repairOrder.pcsStationName}</if>
+                <if test="repairOrder.pcsDeviceId != null"> and pcs_device_id = #{repairOrder.pcsDeviceId}</if>
+                <if test="repairOrder.pcsDeviceName != null and repairOrder.pcsDeviceName != ''"> and pcs_device_name like concat('%', #{repairOrder.pcsDeviceName}, '%')</if>
+                <if test="repairOrder.teamLeaderName != null and repairOrder.teamLeaderName != ''"> and team_leader_name like concat('%', #{repairOrder.teamLeaderName}, '%')</if>
+                <if test="repairOrder.scoringStatus != null and repairOrder.scoringStatus != ''"> and scoring_status in
+                    <foreach collection="repairOrder.scoringStatus.split(',')" item="status" open="(" close=")" separator=",">
+                        #{status}
+                    </foreach>
+                </if>
+
+                <if test="repairOrder.orderType != null and repairOrder.orderType != ''"> and 1 = #{repairOrder.orderType}</if>
+                <if test="repairOrder.createBy != null and repairOrder.createBy != ''"> and create_by = #{repairOrder.createBy}</if>
+                <!-- 业务特定数据权限过滤条件 -->
+                <if test="repairOrder.params.businessDataScope != null and repairOrder.params.businessDataScope != ''">
+                    ${repairOrder.params.businessDataScope}
+                </if>
+            </where>
+
+            UNION ALL
+
+            SELECT
+                2 as order_type,
+                id as id,
+                work_order_project_no as work_order_project_no,
+                work_order_status as work_order_status,
+                gxt_center_id as gxt_center_id,
+                gxt_center as gxt_center,
+                pcs_station_id as pcs_station_id,
+                pcs_station_pid as pcs_station_pid,
+                pcs_station_name as pcs_station_name,
+                pcs_device_id as pcs_device_id,
+                pcs_device_name as pcs_device_name,
+                brand as brand,
+                model as model,
+                assign_time as assign_time,
+                assign_user_id as assign_user_id,
+                assign_user_name as assign_user_name,
+                accept_time as accept_time,
+                accept_user_id as accept_user_id,
+                accept_user_name as accept_user_name,
+                real_start_time as real_start_time,
+                real_end_time as real_end_time,
+                team_leader_id as team_leader_id,
+                team_leader_name as team_leader_name,
+                work_group_member_id as work_group_member_id,
+                work_group_member_name as work_group_member_name,
+                score as score,
+                review_content as review_content,
+                suspend_reason as suspend_reason,
+                restart_time as restart_time,
+                priority_type as priority_type,
+                real_end_time as work_end_time,
+                scoring_status as scoring_status,
+                real_content as work_summary,
+                null as maintenance_type,
+                inspection_type as inspection_type,
+                plan_start_time as plan_start_time,
+                plan_end_time as plan_end_time,
+                plan_hour as plan_hour,
+                fault_code as fault_code,
+                fault_desc as fault_desc,
+                null as occur_time,
+                suspend_time as suspend_time,
+                pause_reason as pause_reason,
+                pause_time as pause_time,
+                complete_time as complete_time,
+                review_score_num as review_score_num,
+                final_coefficient as final_coefficient,
+                create_time as create_time,
+                update_time as update_time
+            FROM gxt_work_order t
+            <where>
+                <if test="workOrder.workOrderProjectNo != null and workOrder.workOrderProjectNo != ''"> and work_order_project_no like concat('%', #{workOrder.workOrderProjectNo}, '%')</if>
+                <if test="workOrder.workOrderStatus != null and workOrder.workOrderStatus != ''"> and work_order_status = #{workOrder.workOrderStatus}</if>
+                <if test="workOrder.gxtCenterId != null"> and gxt_center_id = #{workOrder.gxtCenterId}</if>
+                <if test="workOrder.gxtCenter != null and workOrder.gxtCenter != ''"> and gxt_center = #{workOrder.gxtCenter}</if>
+                <if test="workOrder.pcsStationId != null"> and pcs_station_id = #{workOrder.pcsStationId}</if>
+                <if test="workOrder.pcsStationName != null and workOrder.pcsStationName != ''"> and pcs_station_name = #{workOrder.pcsStationName}</if>
+                <if test="workOrder.pcsDeviceId != null"> and pcs_device_id = #{workOrder.pcsDeviceId}</if>
+                <if test="workOrder.pcsDeviceName != null and workOrder.pcsDeviceName != ''"> and pcs_device_name like concat('%', #{workOrder.pcsDeviceName}, '%')</if>
+                <if test="workOrder.teamLeaderName != null and workOrder.teamLeaderName != ''"> and team_leader_name like concat('%', #{workOrder.teamLeaderName}, '%')</if>
+                <if test="workOrder.scoringStatus != null and workOrder.scoringStatus != ''"> and scoring_status in
+                    <foreach collection="workOrder.scoringStatus.split(',')" item="status" open="(" close=")" separator=",">
+                        #{status}
+                    </foreach>
+                </if>
+                <if test="workOrder.orderType != null and workOrder.orderType != ''"> and 2 = #{workOrder.orderType}</if>
+                <if test="workOrder.createBy != null and workOrder.createBy != ''"> and create_by = #{workOrder.createBy}</if>
+                <!-- 业务特定数据权限过滤条件 -->
+                <if test="workOrder.params.businessDataScope != null and workOrder.params.businessDataScope != ''">
+                    ${workOrder.params.businessDataScope}
+                </if>
+            </where>
+        ) t
+        ORDER BY create_time DESC
+    </select>
+
+</mapper>

+ 27 - 0
ygtx-ui/src/api/gxt/orderMine.js

@@ -0,0 +1,27 @@
+import request from '@/utils/request'
+
+// 查询我的创建工单列表(合并维修工单和维保工单)
+export function listMyCreate(query) {
+  return request({
+    url: '/gxt/orderMine/listMyCreate',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询我处理的工单列表(合并维修工单和维保工单)
+export function listMyDone(query) {
+  return request({
+    url: '/gxt/orderMine/listMyDone',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询工单详细信息
+export function getOrderInfo(orderType, orderId) {
+  return request({
+    url: '/gxt/orderMine/' + orderType + '/' + orderId,
+    method: 'get'
+  })
+}

+ 704 - 0
ygtx-ui/src/views/gxt/orderMyCreate/index.vue

@@ -0,0 +1,704 @@
+<template>
+  <div class="app-container">
+    <!-- 查询条件区域 -->
+    <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="100px" label-position="top">
+      <el-form-item label="工单编码" prop="workOrderProjectNo" label-position="top">
+        <el-input
+            v-model="queryParams.workOrderProjectNo"
+            placeholder="请输入工单编码"
+            clearable
+            @keyup.enter="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="风机编号" prop="pcsDeviceName" label-position="top">
+        <el-input
+            v-model="queryParams.pcsDeviceName"
+            placeholder="请输入风机编号"
+            clearable
+            @keyup.enter="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="维保中心" prop="gxtCenter" label-position="top">
+        <el-select
+            v-model="queryParams.gxtCenter"
+            placeholder="请选择维保中心"
+            clearable
+            @change="handleMaintenanceCenterChange"
+        >
+          <el-option
+              v-for="item in maintenanceCenterOptions"
+              :key="item.deptId"
+              :label="item.deptName"
+              :value="item.deptName">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="场站" prop="pcsStationName" label-position="top">
+        <el-select
+            v-model="queryParams.pcsStationName"
+            placeholder="请选择场站"
+            clearable
+            :disabled="!queryParams.gxtCenter"
+        >
+          <el-option
+              v-for="item in stationOptions"
+              :key="item.deptId"
+              :label="item.deptName"
+              :value="item.deptName">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="工单状态" prop="workOrderStatus" label-position="top">
+        <el-select v-model="queryParams.workOrderStatus" placeholder="请选择工单状态" clearable>
+          <el-option
+              v-for="dict in gxt_work_order_status"
+              :key="dict.value"
+              :label="dict.label"
+              :value="dict.value"
+          />
+        </el-select>
+      </el-form-item>
+    </el-form>
+    <div style="float: right;margin-bottom: 10px;">
+      <el-button icon="Refresh" @click="resetQuery">重置</el-button>
+      <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
+    </div>
+
+    <!-- 操作按钮区域 -->
+    <el-row :gutter="10" class="mb8">
+      <!-- 空的按钮区域,保持与其他页面一致的间距 -->
+    </el-row>
+
+    <!-- 工单列表 -->
+    <el-table
+        v-loading="loading"
+        :data="orderList"
+        style="width: 100%"
+        :max-height="tableHeight"
+    >
+      <el-table-column label="工单类型" align="center" prop="orderType" width="100">
+        <template #default="scope">
+          <el-tag v-if="scope.row.orderType === 1" type="danger">维修工单</el-tag>
+          <el-tag v-else type="success">维保工单</el-tag>
+        </template>
+      </el-table-column>
+      <el-table-column label="工单编码" align="center" prop="workOrderProjectNo" width="160" fixed>
+        <template #default="scope">
+          <el-button link type="primary" @click="handleView(scope.row)">
+            {{ scope.row.workOrderProjectNo }}
+          </el-button>
+        </template>
+      </el-table-column>
+      <el-table-column label="风机编号" align="center" prop="pcsDeviceName" width="120" :show-overflow-tooltip="true">
+        <template #default="scope">
+          {{ scope.row.pcsDeviceName || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="工单状态" align="center" prop="workOrderStatus" min-width="100">
+        <template #default="scope">
+          <dict-tag :options="gxt_work_order_status" :value="scope.row.workOrderStatus" />
+        </template>
+      </el-table-column>
+      <el-table-column label="维保中心" align="center" prop="gxtCenter"  width="150" :show-overflow-tooltip="true">
+        <template #default="scope">
+          {{ scope.row.gxtCenter || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="场站" align="center" prop="pcsStationName" width="150" :show-overflow-tooltip="true">
+        <template #default="scope">
+          {{ scope.row.pcsStationName || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="品牌" align="center" prop="brand" width="120" :show-overflow-tooltip="true">
+        <template #default="scope">
+          {{ scope.row.brand || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="机型" align="center" prop="model" width="120" :show-overflow-tooltip="true">
+        <template #default="scope">
+          {{ scope.row.model || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="接单人" align="center" prop="acceptUserName" width="100" >
+        <template #default="scope">
+          {{ scope.row.acceptUserName || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="接单时间" align="center" prop="acceptTime" width="150">
+        <template #default="scope">
+          <span>{{ scope.row.acceptTime ? parseTime(scope.row.acceptTime, '{y}-{m}-{d} {h}:{i}') : '-' }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="工作负责人" align="center" prop="teamLeaderName" width="100" >
+        <template #default="scope">
+          {{ scope.row.teamLeaderName || '-' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="开始时间" align="center" prop="realStartTime" width="150">
+        <template #default="scope">
+          <span>{{ scope.row.realStartTime ? parseTime(scope.row.realStartTime, '{y}-{m}-{d} {h}:{i}') : '-' }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="结束时间" align="center" prop="realEndTime" width="150">
+        <template #default="scope">
+          <span>{{ scope.row.realEndTime ? parseTime(scope.row.realEndTime, '{y}-{m}-{d} {h}:{i}') : '-' }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" min-width="150" fixed="right">
+        <template #default="scope">
+          <el-button
+              type="info"
+              link
+              @click="handleView(scope.row)"
+              v-hasPermi="['gxt:orderMine:query']"
+          ><i class="fa fa-eye"></i>查看</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+
+    <pagination
+        v-show="total>0"
+        :total="total"
+        v-model:page="queryParams.pageNum"
+        v-model:limit="queryParams.pageSize"
+        @pagination="getList"
+    />
+
+    <!-- 维修工单详情对话框 -->
+    <el-dialog title="维修工单详情" v-model="repairDetailDialogVisible" width="1000px" append-to-body>
+      <el-row :gutter="20">
+        <!-- 工单信息 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">工单信息</h3>
+            <div class="info-content">
+              <el-form label-width="100px" label-position="top">
+                <el-row :gutter="20">
+                  <el-col :span="24">
+                    <el-form-item label="工单编码">{{ detailData.workOrderProjectNo }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="工单状态">
+                      <dict-tag :options="gxt_work_order_status" :value="detailData.workOrderStatus" />
+                    </el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="风机编号">{{ detailData.pcsDeviceName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="维保中心">{{ detailData.gxtCenter || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="场站">{{ detailData.pcsStationName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="品牌">{{ detailData.brand || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="机型">{{ detailData.model || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="发生时间">{{ parseTime(detailData.occurTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="故障代码">{{ detailData.faultCode || '-' }}</el-form-item>
+                  </el-col>
+                </el-row>
+              </el-form>
+            </div>
+          </div>
+        </el-col>
+
+        <!-- 处理信息 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">处理信息</h3>
+            <div class="info-content">
+              <el-form label-width="100px" label-position="top">
+                <el-row :gutter="20">
+                  <el-col :span="24">
+                    <el-form-item label="下发人">{{ detailData.assignUserName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="下发时间">{{ parseTime(detailData.assignTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="接单人">{{ detailData.acceptUserName || '-'}}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="接单时间">{{ parseTime(detailData.acceptTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="工作负责人">{{ detailData.teamLeaderName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="检修人员">{{ detailData.workGroupMemberName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="MIS工单编码">{{ detailData.misOrderNo || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="开始时间">{{ parseTime(detailData.realStartTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="结束时间">{{ parseTime(detailData.realEndTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="恢复运行时间">{{ parseTime(detailData.restartTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                </el-row>
+              </el-form>
+            </div>
+          </div>
+        </el-col>
+
+        <!-- 工单流转记录 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">工单流转</h3>
+            <div class="flow-history">
+              <el-timeline>
+                <el-timeline-item type="primary"
+                                  v-for="(flow, index) in flowList"
+                                  :key="index"
+                                  :timestamp="parseTime(flow.actionTime, '{y}-{m}-{d} {h}:{i}')"
+                >
+                  <div class="flow-item">
+                    <h4><dict-tag :options="gxt_repair_order_flow_action_type" :value="flow.actionType" /></h4>
+                    <p>
+                      {{ flow.operatorName }}
+                    </p>
+                  </div>
+                </el-timeline-item>
+              </el-timeline>
+            </div>
+          </div>
+        </el-col>
+      </el-row>
+      <el-form label-position="top">
+        <el-row>
+          <el-col :span="24">
+            <el-form-item label="故障信息">
+              <div class="content-text">{{ detailData.faultBarcode || '-' }}</div>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+      <!-- 附件信息 -->
+      <div class="info-section" v-if="detailData.attachmentUrls">
+        <h3 class="section-title">结单附件</h3>
+        <el-row>
+          <el-col :span="24">
+            <el-form-item label="附件">
+              <preview :limit="8" v-model="detailData.attachmentUrls" :filesize="5" disabled></preview>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </div>
+      <template #footer>
+        <div class="dialog-footer">
+          <el-button @click="repairDetailDialogVisible = false">关 闭</el-button>
+        </div>
+      </template>
+    </el-dialog>
+
+    <!-- 维保工单详情对话框 -->
+    <el-dialog title="维保工单详情" v-model="workDetailDialogVisible" width="1000px" append-to-body>
+      <el-row :gutter="20">
+        <!-- 工单信息 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">工单信息</h3>
+            <div class="info-content">
+              <el-form label-width="100px" label-position="top">
+                <el-row :gutter="20">
+                  <el-col :span="24">
+                    <el-form-item label="工单编码">{{ detailData.workOrderProjectNo }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="工单状态">
+                      <dict-tag :options="gxt_work_order_status" :value="detailData.workOrderStatus" />
+                    </el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="风机编号">{{ detailData.pcsDeviceName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="维保中心">{{ detailData.gxtCenter || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="场站">{{ detailData.pcsStationName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="品牌">{{ detailData.brand || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="机型">{{ detailData.model || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="维保类型">
+                      <dict-tag :options="gxt_inspection_type" :value="detailData.inspectionType" />
+                    </el-form-item>
+                  </el-col>
+                </el-row>
+              </el-form>
+            </div>
+          </div>
+        </el-col>
+
+        <!-- 处理信息 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">处理信息</h3>
+            <div class="info-content">
+              <el-form label-width="100px" label-position="top">
+                <el-row :gutter="20">
+                  <el-col :span="24">
+                    <el-form-item label="下发人">{{ detailData.assignUserName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="下发时间">{{ parseTime(detailData.assignTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="接单人">{{ detailData.acceptUserName || '-'}}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="接单时间">{{ parseTime(detailData.acceptTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="工作负责人">{{ detailData.teamLeaderName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="检修人员">{{ detailData.workGroupMemberName || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="MIS工单编码">{{ detailData.misNo || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="开始时间">{{ parseTime(detailData.realStartTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="结束时间">{{ parseTime(detailData.realEndTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                  <el-col :span="24">
+                    <el-form-item label="恢复运行时间">{{ parseTime(detailData.restartTime, '{y}-{m}-{d} {h}:{i}') || '-' }}</el-form-item>
+                  </el-col>
+                </el-row>
+              </el-form>
+            </div>
+          </div>
+        </el-col>
+
+        <!-- 工单流转记录 -->
+        <el-col :span="8">
+          <div class="info-section">
+            <h3 class="section-title">工单流转</h3>
+            <div class="flow-history">
+              <el-timeline>
+                <el-timeline-item type="primary"
+                                  v-for="(flow, index) in flowList"
+                                  :key="index"
+                                  :timestamp="parseTime(flow.actionTime, '{y}-{m}-{d} {h}:{i}')"
+                >
+                  <div class="flow-item">
+                    <h4><dict-tag :options="gxt_repair_order_flow_action_type" :value="flow.actionType" /></h4>
+                    <p>
+                      {{ flow.operatorName }}
+                    </p>
+                  </div>
+                </el-timeline-item>
+              </el-timeline>
+            </div>
+          </div>
+        </el-col>
+      </el-row>
+      <el-form label-position="top">
+        <el-row>
+          <el-col :span="24">
+            <el-form-item label="维保内容">
+              <div class="content-text">{{ detailData.content || '-' }}</div>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+      <!-- 附件信息 -->
+      <div class="info-section" v-if="detailData.attachmentUrls">
+        <h3 class="section-title">结单附件</h3>
+        <el-row>
+          <el-col :span="24">
+            <el-form-item label="附件">
+              <preview :limit="8" v-model="detailData.attachmentUrls" :filesize="5" disabled></preview>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </div>
+      <template #footer>
+        <div class="dialog-footer">
+          <el-button @click="workDetailDialogVisible = false">关 闭</el-button>
+        </div>
+      </template>
+    </el-dialog>
+  </div>
+</template>
+
+<script setup>
+import { getCurrentInstance, reactive, ref, toRefs, onMounted } from "vue";
+import { listMyCreate, getOrderInfo } from "@/api/gxt/orderMine.js";
+import { listMaintenanceCenters, listStationsByMaintenanceCenter } from "@/api/gxt/equipment.js";
+import preview from '@/components/FileUpload/preview.vue'
+
+const { proxy } = getCurrentInstance();
+
+// 显示搜索栏
+const showSearch = ref(true);
+
+// 加载状态
+const loading = ref(false);
+
+// 表格高度
+const tableHeight = ref(window.innerHeight - 300);
+
+// 数据总数
+const total = ref(0);
+
+// 维修工单详情对话框可见性
+const repairDetailDialogVisible = ref(false);
+
+// 维保工单详情对话框可见性
+const workDetailDialogVisible = ref(false);
+
+// 维保中心选项
+const maintenanceCenterOptions = ref([]);
+
+// 场站选项
+const stationOptions = ref([]);
+
+// 工单列表
+const orderList = ref([]);
+
+// 详情数据
+const detailData = ref({});
+
+// 工单流转记录
+const flowList = ref([]);
+
+// 查询参数
+const data = reactive({
+  queryParams: {
+    pageNum: 1,
+    pageSize: 10,
+    workOrderProjectNo: undefined,
+    workOrderStatus: undefined,
+    gxtCenter: undefined,
+    pcsStationName: undefined,
+    pcsDeviceName: undefined
+  }
+});
+
+const { queryParams } = toRefs(data);
+
+// 获取字典数据
+const { gxt_maintenance_type, gxt_work_order_status, gxt_order_priority_type,gxt_repair_order_flow_action_type,gxt_order_suspend_reason,gxt_inspection_type,gxt_pause_reasons } = proxy.useDict("gxt_maintenance_type", "gxt_work_order_status", "gxt_order_priority_type","gxt_repair_order_flow_action_type","gxt_order_suspend_reason","gxt_inspection_type","gxt_pause_reasons")
+
+// 页面加载时执行
+onMounted(() => {
+  getList();
+  getMaintenanceCenterAndStationList();
+  window.addEventListener('resize', handleResize);
+});
+
+// 获取列表数据
+function getList() {
+  loading.value = true;
+  listMyCreate(queryParams.value).then(response => {
+    orderList.value = response.rows;
+    total.value = response.total;
+    loading.value = false;
+  });
+}
+
+// 获取维保中心和场站列表
+function getMaintenanceCenterAndStationList() {
+  listMaintenanceCenters().then(response => {
+    maintenanceCenterOptions.value = response.data.map(item => {
+      return { deptName: item, deptId: item };
+    });
+
+    // 如果已选择维保中心,则筛选出该维保中心下的场站
+    if (queryParams.value.gxtCenter) {
+      listStationsByMaintenanceCenter(queryParams.value.gxtCenter).then(res => {
+        stationOptions.value = res.data.map(item => {
+          return { deptName: item, deptId: item };
+        });
+      });
+    } else {
+      // 如果未选择维保中心,则清空场站选项
+      stationOptions.value = [];
+    }
+  });
+}
+
+// 处理维保中心变更
+function handleMaintenanceCenterChange(selectedCenter) {
+  // 清空场站选择
+  queryParams.value.pcsStationName = null;
+
+  // 如果选择了维保中心,则加载对应的场站
+  if (selectedCenter) {
+    listStationsByMaintenanceCenter(selectedCenter).then(response => {
+      stationOptions.value = response.data.map(item => {
+        return { deptName: item, deptId: item };
+      });
+    });
+  } else {
+    // 如果未选择维保中心,则清空场站选项
+    stationOptions.value = [];
+  }
+}
+
+// 搜索按钮操作
+function handleQuery() {
+  queryParams.value.pageNum = 1;
+  getList();
+}
+
+// 重置按钮操作
+function resetQuery() {
+  proxy.resetForm("queryRef");
+  handleQuery();
+}
+
+// 查看详情
+function handleView(row) {
+  // 调用后端接口获取详细信息
+  getOrderInfo(row.orderType, row.id).then(response => {
+    detailData.value = response.data;
+    // 从工单详情中获取流转记录
+    flowList.value = response.data.workOrderFlowList || response.data.repairOrderFlowList || [];
+    
+    if (row.orderType === 1) {
+      // 维修工单
+      repairDetailDialogVisible.value = true;
+    } else {
+      // 维保工单
+      workDetailDialogVisible.value = true;
+    }
+  }).catch(error => {
+    proxy.$modal.msgError("获取工单详情失败:" + error.message);
+  });
+}
+
+// 处理窗口大小变化
+function handleResize() {
+  tableHeight.value = window.innerHeight - 300;
+}
+</script>
+
+<style scoped>
+/* 表单字段间距调整 */
+.el-form-item {
+  margin-bottom: 18px;
+}
+
+.text-gray-500 {
+  color: #6b7280;
+}
+
+.card-header {
+  font-weight: bold;
+  font-size: 16px;
+}
+
+.info-section {
+  padding: 16px 0;
+  height: 100%;
+  box-sizing: border-box;
+}
+
+.section-title {
+  font-weight: bold;
+  font-size: 16px;
+  margin-bottom: 15px;
+  padding-bottom: 10px;
+  border-bottom: 1px solid #ebeef5;
+}
+
+.info-content {
+  height: calc(100% - 30px);
+  overflow-y: auto;
+  overflow-x: hidden; /* 防止横向滚动 */
+  padding: 0 10px; /* 添加内边距防止内容贴边 */
+}
+
+.info-item {
+  margin-bottom: 12px;
+}
+
+.info-item label {
+  display: block;
+  font-size: 12px;
+  color: #999;
+  margin-bottom: 4px;
+}
+
+.info-item p {
+  font-size: 14px;
+  color: #333;
+  margin: 0;
+  line-height: 1.4;
+}
+
+.flow-history {
+  height: 100%;
+  padding: 0 10px; /* 添加内边距防止内容贴边 */
+}
+
+.flow-history .el-timeline {
+  margin-left: 0;
+  padding-left: 0;
+}
+
+.flow-item {
+  /*padding: 10px;
+  border-radius: 4px;*/
+}
+
+.flow-item h4 {
+  margin: 0 0 5px 0;
+  font-size: 14px;
+  font-weight: bold;
+}
+
+.flow-item p {
+  margin: 0;
+  font-size: 12px;
+  line-height: 1.4;
+  color: #606266;
+}
+
+/* 修复对话框底部按钮点击区域问题 */
+:deep(.el-dialog__footer) {
+  padding: 20px !important;
+  position: relative;
+  z-index: 10;
+}
+
+/* 确保关闭按钮有完整的点击区域 */
+.dialog-footer :deep(.el-button) {
+  padding: 12px 20px;
+  min-width: 80px;
+  z-index: 20;
+  position: relative;
+}
+
+/* 表单字段间距调整 */
+:deep(.el-form-item) {
+  margin-bottom: 18px;
+}
+
+.content-text {
+  white-space: pre-wrap;
+  word-break: break-word;
+  line-height: 1.5;
+}
+</style>