|
|
|
@ -46,6 +46,8 @@ import cn.dev33.satoken.stp.StpUtil;
|
|
|
|
|
|
|
|
|
|
import java.util.*;
|
|
|
|
|
import java.util.concurrent.CompletableFuture;
|
|
|
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
|
|
|
import org.dromara.dms.mapper.DmsFaultComponentsPartsMapper;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 故障报修工单Service业务层处理
|
|
|
|
@ -75,6 +77,8 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
@DubboReference(timeout = 15000, retries = 1)
|
|
|
|
|
private final RemoteFileService remoteFileService;
|
|
|
|
|
|
|
|
|
|
private final DmsFaultComponentsPartsMapper dmsFaultComponentsPartsMapper;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 查询故障报修工单
|
|
|
|
|
*
|
|
|
|
@ -176,6 +180,12 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
@GlobalTransactional(rollbackFor = Exception.class)
|
|
|
|
|
public Boolean insertByBo(DmsBillsFaultInstanceBo bo) {
|
|
|
|
|
bo.setMachineId((long) bo.getDeviceId());
|
|
|
|
|
|
|
|
|
|
// 【关键修复】处理PDA端outsrcId到outsourcingId的转换
|
|
|
|
|
if (bo.getOutsrcId() != null && bo.getOutsrcId() > 0) {
|
|
|
|
|
bo.setOutsourcingId(Long.valueOf(bo.getOutsrcId()));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DmsBillsFaultInstance add = MapstructUtils.convert(bo, DmsBillsFaultInstance.class);
|
|
|
|
|
validEntityBeforeSave(add);
|
|
|
|
|
// 获取当前日期时间
|
|
|
|
@ -253,7 +263,7 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
}
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
// 创建故障实例活动对象
|
|
|
|
|
// 【重要修改】创建故障实例活动对象 - 只有PDA创建工单时才生成
|
|
|
|
|
DmsFaultInstanceActivity dmsFaultInstanceActivity = new DmsFaultInstanceActivity();
|
|
|
|
|
// 设置维修实例ID
|
|
|
|
|
dmsFaultInstanceActivity.setRepairInstanceId(add.getRepairInstanceId());
|
|
|
|
@ -269,9 +279,9 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
dmsFaultInstanceActivity.setMachineId(add.getMachineId());
|
|
|
|
|
// 设置维修类型
|
|
|
|
|
dmsFaultInstanceActivity.setRepairType(add.getRepairType());
|
|
|
|
|
// 如果外部资源ID不为空,则设置外部资源ID
|
|
|
|
|
if (add.getOutsourcingId() != null) {
|
|
|
|
|
dmsFaultInstanceActivity.setOutsourcingId(add.getOutsourcingId());
|
|
|
|
|
// 【关键修复】如果外部资源ID不为空,则设置外部资源ID
|
|
|
|
|
if (bo.getOutsourcingId() != null) {
|
|
|
|
|
dmsFaultInstanceActivity.setOutsourcingId(bo.getOutsourcingId());
|
|
|
|
|
}
|
|
|
|
|
// 设置处理状态为待审批
|
|
|
|
|
dmsFaultInstanceActivity.setProcessHandleStatus(DmsConstants.DMS_BILLS_FAULT_INSTANCE_ACTIVITY_HANDLE_STATUS_TO_PICK);
|
|
|
|
@ -281,7 +291,7 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
dmsFaultInstanceActivityMapper.insert(dmsFaultInstanceActivity);
|
|
|
|
|
//存储图片
|
|
|
|
|
// 获取文件URL列表
|
|
|
|
|
List<String> fileUrls = add.getFileUrls();
|
|
|
|
|
List<String> fileUrls = bo.getFileUrls();
|
|
|
|
|
// 批量插入实例文件记录
|
|
|
|
|
batchInsertInstanceFiles(fileUrls, dmsFaultInstanceActivity.getInstanceActivityId());
|
|
|
|
|
return flag;
|
|
|
|
@ -443,6 +453,14 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
dmsFaultInstanceActivity.setHandleBy(userName);
|
|
|
|
|
dmsFaultInstanceActivity.setHandleTime(currentDate);
|
|
|
|
|
|
|
|
|
|
// 【调试日志】打印传入的活动ID,以确认问题根源
|
|
|
|
|
log.info("调用startRepair时,从控制器传入的instanceActivityId为: {}", dmsFaultInstanceActivity.getInstanceActivityId());
|
|
|
|
|
|
|
|
|
|
// 【关键修复】在插入新的活动记录前,必须将ID设置为空。
|
|
|
|
|
// 这是因为传入的dmsFaultInstanceActivity对象可能包含了由PDA端getBillsFaultInstance4Repair接口返回的
|
|
|
|
|
// 第一个活动节点(process_step_order=1)的ID。如果不清空,MyBatis会尝试使用这个旧ID插入新记录,
|
|
|
|
|
// 如果instance_activity_id不是主键或唯一键,就会导致数据重复;如果是,则会抛出主键冲突异常。
|
|
|
|
|
dmsFaultInstanceActivity.setInstanceActivityId(null);
|
|
|
|
|
// 插入新的故障实例活动记录
|
|
|
|
|
boolean result = dmsFaultInstanceActivityService.insertByBo(dmsFaultInstanceActivity);
|
|
|
|
|
|
|
|
|
@ -457,43 +475,55 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
*/
|
|
|
|
|
@Override
|
|
|
|
|
@GlobalTransactional(rollbackFor = Exception.class)
|
|
|
|
|
public int completeRepair(DmsFaultInstanceActivityBo dmsFaultInstanceActivity) {
|
|
|
|
|
// 批量插入实例的附件文件信息
|
|
|
|
|
batchInsertInstanceAfterFiles(dmsFaultInstanceActivity.getFileUrls(), dmsFaultInstanceActivity.getInstanceActivityId());
|
|
|
|
|
public int completeRepair(DmsFaultInstanceActivityBo dmsFaultInstanceActivity, List<MultipartFile> files) {
|
|
|
|
|
// 更新 dms_fault_instance_activity 表
|
|
|
|
|
DmsFaultInstanceActivity activity = new DmsFaultInstanceActivity();
|
|
|
|
|
activity.setInstanceActivityId(dmsFaultInstanceActivity.getInstanceActivityId());
|
|
|
|
|
activity.setProcessHandleStatus(DmsConstants.DMS_BILLS_FAULT_INSTANCE_ACTIVITY_HANDLE_STATUS_FINISH);
|
|
|
|
|
activity.setEndTime(new Date());
|
|
|
|
|
activity.setRepairer(LoginHelper.getLoginUser() == null ? LoginHelper.getUsername() : LoginHelper.getLoginUser().getNickname());
|
|
|
|
|
dmsFaultInstanceActivityMapper.updateById(activity);
|
|
|
|
|
|
|
|
|
|
// 获取需要插入的备件列表
|
|
|
|
|
// 批量保存处理的零部件
|
|
|
|
|
List<DmsFaultComponentsParts> parts = dmsFaultInstanceActivity.getParts();
|
|
|
|
|
if (!CollectionUtils.isEmpty(parts)) {
|
|
|
|
|
for (DmsFaultComponentsParts part : parts) {
|
|
|
|
|
part.setFaultId(dmsFaultInstanceActivity.getRepairInstanceId());
|
|
|
|
|
}
|
|
|
|
|
dmsFaultInstanceActivityMapper.insertParts(parts);
|
|
|
|
|
if (parts != null && !parts.isEmpty()) {
|
|
|
|
|
parts.forEach(part -> {
|
|
|
|
|
part.setRepairInstanceId(dmsFaultInstanceActivity.getRepairInstanceId());
|
|
|
|
|
dmsFaultComponentsPartsMapper.insert(part);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 根据维修实例ID查询对应的工单实例
|
|
|
|
|
DmsBillsFaultInstance dmsBillsFaultInstance = baseMapper.selectById(dmsFaultInstanceActivity.getRepairInstanceId());
|
|
|
|
|
if (dmsBillsFaultInstance == null) {
|
|
|
|
|
throw new ServiceException("工单不存在");
|
|
|
|
|
// 处理文件上传
|
|
|
|
|
if (files != null && !files.isEmpty()) {
|
|
|
|
|
List<DmsInstanceFile> fileList = new ArrayList<>();
|
|
|
|
|
for (MultipartFile file : files) {
|
|
|
|
|
try {
|
|
|
|
|
RemoteFile remoteFile = remoteFileService.upload(file.getName(), file.getOriginalFilename(), file.getContentType(), file.getBytes());
|
|
|
|
|
DmsInstanceFile instanceFile = new DmsInstanceFile();
|
|
|
|
|
instanceFile.setTargetId(dmsFaultInstanceActivity.getInstanceActivityId());
|
|
|
|
|
instanceFile.setFilePath(remoteFile.getUrl());
|
|
|
|
|
instanceFile.setTargetType("1"); // 维修完成图片
|
|
|
|
|
fileList.add(instanceFile);
|
|
|
|
|
dmsInstanceFileMapper.insert(instanceFile);
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
throw new ServiceException("文件上传失败");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 检查工单状态
|
|
|
|
|
String dmsBillsStatus = dmsBillsFaultInstance.getBillsStatus();
|
|
|
|
|
if (!dmsBillsStatus.equals(DmsConstants.DMS_BILLS_FAULT_INSTANCE_STATUS_REPAIRING)) {
|
|
|
|
|
throw new ServiceException("工单状态不允许完成维修,请先开始维修");
|
|
|
|
|
// 更新 dms_bills_fault_instance 表
|
|
|
|
|
DmsBillsFaultInstance instance = baseMapper.selectById(dmsFaultInstanceActivity.getRepairInstanceId());
|
|
|
|
|
if (instance == null) {
|
|
|
|
|
throw new ServiceException("工单不存在: " + dmsFaultInstanceActivity.getRepairInstanceId());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 获取当前日期和时间
|
|
|
|
|
Date currentDate = new Date();
|
|
|
|
|
String userName = LoginHelper.getLoginUser() == null ? LoginHelper.getUsername() : LoginHelper.getLoginUser().getNickname();
|
|
|
|
|
|
|
|
|
|
// 设置工单状态为维修完成,确认状态为待确认
|
|
|
|
|
dmsBillsFaultInstance.setBillsStatus(DmsConstants.DMS_BILLS_FAULT_INSTANCE_STATUS_FINISH);
|
|
|
|
|
dmsBillsFaultInstance.setRealEndTime(currentDate);
|
|
|
|
|
dmsBillsFaultInstance.setRepairConfirm("0"); // 设置为待确认状态
|
|
|
|
|
instance.setBillsStatus(DmsConstants.DMS_BILLS_FAULT_INSTANCE_STATUS_FINISH);
|
|
|
|
|
instance.setRealEndTime(new Date());
|
|
|
|
|
instance.setRepairConfirm("0"); // 设置为待确认状态
|
|
|
|
|
baseMapper.updateById(instance);
|
|
|
|
|
|
|
|
|
|
// 推进工作流
|
|
|
|
|
if (dmsBillsFaultInstance.getWfDefinitionId() != null) {
|
|
|
|
|
Long currentTaskId = remoteWorkflowService.getCurrentTaskIdByInstanceId(dmsBillsFaultInstance.getWfDefinitionId());
|
|
|
|
|
if (instance.getWfDefinitionId() != null) {
|
|
|
|
|
Long currentTaskId = remoteWorkflowService.getCurrentTaskIdByInstanceId(instance.getWfDefinitionId());
|
|
|
|
|
if (currentTaskId != null) {
|
|
|
|
|
RemoteCompleteTask remoteCompleteTask = new RemoteCompleteTask();
|
|
|
|
|
remoteCompleteTask.setTaskId(currentTaskId);
|
|
|
|
@ -501,7 +531,7 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
List<String> messageTypes = new ArrayList<>();
|
|
|
|
|
messageTypes.add("1"); // 站内信
|
|
|
|
|
remoteCompleteTask.setMessageType(messageTypes);
|
|
|
|
|
remoteCompleteTask.setNotice("故障报修工单维修完成,待主管确认,工单编号:" + dmsBillsFaultInstance.getBillsFaultCode());
|
|
|
|
|
remoteCompleteTask.setNotice("故障报修工单维修完成,待主管确认,工单编号:" + instance.getBillsFaultCode());
|
|
|
|
|
boolean b = remoteWorkflowService.completeTask(remoteCompleteTask);
|
|
|
|
|
if (!b) {
|
|
|
|
|
throw new ServiceException("工作流推进失败");
|
|
|
|
@ -509,19 +539,7 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 更新工单状态
|
|
|
|
|
baseMapper.updateById(dmsBillsFaultInstance);
|
|
|
|
|
|
|
|
|
|
// 设置工单活动状态为已完成,并记录结束时间和维修人员
|
|
|
|
|
dmsFaultInstanceActivity.setProcessHandleStatus(DmsConstants.DMS_BILLS_FAULT_INSTANCE_ACTIVITY_HANDLE_STATUS_FINISH);
|
|
|
|
|
dmsFaultInstanceActivity.setEndTime(currentDate);
|
|
|
|
|
dmsFaultInstanceActivity.setRepairer(userName);
|
|
|
|
|
|
|
|
|
|
// 更新故障实例活动记录
|
|
|
|
|
DmsFaultInstanceActivity faultInstanceActivity = MapstructUtils.convert(dmsFaultInstanceActivity, DmsFaultInstanceActivity.class);
|
|
|
|
|
int i = dmsFaultInstanceActivityMapper.updateById(faultInstanceActivity);
|
|
|
|
|
|
|
|
|
|
return i;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
@ -754,9 +772,18 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
*/
|
|
|
|
|
@Override
|
|
|
|
|
public DmsBillsFaultInstanceVo selectDmsBillsFaultInstanceByRepairInstanceId(Long repairInstanceId) {
|
|
|
|
|
try {
|
|
|
|
|
// 根据repairInstanceId查询故障实例及其关联的设备和第一条活动记录
|
|
|
|
|
DmsBillsFaultInstanceVo dmsBillsFaultInstance = baseMapper.selectFaultInstanceJoinFirstAndDeviceById(repairInstanceId);
|
|
|
|
|
|
|
|
|
|
if (dmsBillsFaultInstance == null) {
|
|
|
|
|
throw new ServiceException("工单不存在,repairInstanceId: " + repairInstanceId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 【调试日志】输出查询结果,确认outsourcingId是否正确获取
|
|
|
|
|
log.info("查询工单详情,repairInstanceId: {}, outsourcingId: {}, instanceActivityId: {}",
|
|
|
|
|
repairInstanceId, dmsBillsFaultInstance.getOutsourcingId(), dmsBillsFaultInstance.getInstanceActivityId());
|
|
|
|
|
|
|
|
|
|
// 【关键修复】查询零部件信息,确保PDA端兼容性
|
|
|
|
|
List<DmsFaultComponentsPartsVo> partsVoList = baseMapper.selectParts(repairInstanceId);
|
|
|
|
|
if (partsVoList == null) {
|
|
|
|
@ -802,6 +829,44 @@ public class DmsBillsFaultInstanceServiceImpl implements IDmsBillsFaultInstanceS
|
|
|
|
|
|
|
|
|
|
// 返回故障实例对象
|
|
|
|
|
return dmsBillsFaultInstance;
|
|
|
|
|
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
log.error("查询工单详情异常,repairInstanceId: {}", repairInstanceId, e);
|
|
|
|
|
|
|
|
|
|
// 如果是查询返回多条记录的异常,尝试备用查询方案
|
|
|
|
|
if (e.getMessage() != null && e.getMessage().contains("Expected one result")) {
|
|
|
|
|
log.warn("检测到查询返回多条记录异常,尝试备用查询方案,repairInstanceId: {}", repairInstanceId);
|
|
|
|
|
|
|
|
|
|
// 备用方案:查询工单基本信息和最新的活动记录
|
|
|
|
|
DmsBillsFaultInstanceVo workOrder = baseMapper.selectVoById(repairInstanceId);
|
|
|
|
|
if (workOrder != null) {
|
|
|
|
|
// 查询最新的活动记录
|
|
|
|
|
MPJLambdaWrapper<DmsFaultInstanceActivity> wrapper = JoinWrappers.lambda(DmsFaultInstanceActivity.class)
|
|
|
|
|
.eq(DmsFaultInstanceActivity::getRepairInstanceId, repairInstanceId)
|
|
|
|
|
.orderByDesc(DmsFaultInstanceActivity::getProcessStepOrder)
|
|
|
|
|
.orderByDesc(DmsFaultInstanceActivity::getInstanceActivityId)
|
|
|
|
|
.last("LIMIT 1");
|
|
|
|
|
DmsFaultInstanceActivity latestActivity = dmsFaultInstanceActivityMapper.selectOne(wrapper);
|
|
|
|
|
|
|
|
|
|
if (latestActivity != null) {
|
|
|
|
|
// 设置活动相关信息
|
|
|
|
|
workOrder.setInstanceActivityId(latestActivity.getInstanceActivityId());
|
|
|
|
|
workOrder.setFaultType(latestActivity.getFaultType());
|
|
|
|
|
workOrder.setFaultDescription(latestActivity.getFaultDescription());
|
|
|
|
|
workOrder.setDesignOperations(latestActivity.getDesignOperations());
|
|
|
|
|
workOrder.setRepairType(latestActivity.getRepairType());
|
|
|
|
|
workOrder.setOutsourcingId(latestActivity.getOutsourcingId());
|
|
|
|
|
workOrder.setProcessHandleResolution(latestActivity.getProcessHandleResolution());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
log.info("备用查询方案成功,repairInstanceId: {}, instanceActivityId: {}",
|
|
|
|
|
repairInstanceId, workOrder.getInstanceActivityId());
|
|
|
|
|
return workOrder;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw new ServiceException("查询工单详情失败:" + e.getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|