|
|
|
@ -32,6 +32,8 @@ import org.springframework.transaction.annotation.Transactional; |
|
|
|
|
|
|
|
|
|
import javax.annotation.Resource; |
|
|
|
|
import java.time.LocalDate; |
|
|
|
|
import java.time.LocalDateTime; |
|
|
|
|
import java.time.format.DateTimeFormatter; |
|
|
|
|
import java.util.ArrayList; |
|
|
|
|
import java.util.List; |
|
|
|
|
import java.util.Map; |
|
|
|
@ -201,21 +203,49 @@ public class EntrustAlterApplyServiceImpl extends ServiceImpl<EntrustAlterApplyM |
|
|
|
|
@Override |
|
|
|
|
@Transactional(rollbackFor = Exception.class) |
|
|
|
|
public Boolean updateEntrust(ApprovedUpdateEntrustDTO dto) { |
|
|
|
|
Entrustment entrustment = validUpdateInfoAndGetEntrustInfo(dto); |
|
|
|
|
StringBuilder updateRecordBuilder = new StringBuilder(); // 更新记录
|
|
|
|
|
Entrustment entrustment = validUpdateInfoAndGetEntrustInfo(dto, updateRecordBuilder); |
|
|
|
|
// 提取委托id
|
|
|
|
|
StringBuilder updateRecordBuilder = new StringBuilder(); |
|
|
|
|
String entrustmentId = entrustment.getId(); |
|
|
|
|
String entrustId = entrustment.getId(); |
|
|
|
|
CaseEvent oldCaseInfo = caseEventService.getById(entrustment.getCaseId()); |
|
|
|
|
caseEventService.update(Wrappers.<CaseEvent>lambdaUpdate().eq(CaseEvent::getId, entrustment.getCaseId()).set(CaseEvent::getCaseBrief, dto.getCaseBrief())); |
|
|
|
|
// 添加更新记录 | <br> 代表换行
|
|
|
|
|
updateRecordBuilder.append("操作记录:").append("<br>该委托案件的案件简要由 [").append(oldCaseInfo.getCaseBrief()).append("] 更改为 [").append(dto.getCaseBrief()).append("] 。"); |
|
|
|
|
updateRecordBuilder.append(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))); |
|
|
|
|
updateRecordBuilder.append("<br>案件更新记录:").append("<br>该委托案件的案件简要由 [").append(oldCaseInfo.getCaseBrief()).append("] 更改为 [").append(dto.getCaseBrief()).append("] 。"); |
|
|
|
|
// 2.修改检材 信息
|
|
|
|
|
// 这里之所以要取未更新前的信息是为了留痕
|
|
|
|
|
Map<String, EntrustmentIdentificationMaterial> oldInfoMap = entrustmentIdentificationMaterialService.list(Wrappers.<EntrustmentIdentificationMaterial>lambdaQuery() |
|
|
|
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustmentId) |
|
|
|
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustId) |
|
|
|
|
.orderByAsc(EntrustmentIdentificationMaterial::getOrderNo)) |
|
|
|
|
.stream().collect(Collectors.toMap(EntrustmentIdentificationMaterial::getId, Function.identity())); |
|
|
|
|
List<MaterialDTO> materialList = dto.getMaterialList(); |
|
|
|
|
|
|
|
|
|
List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList = processUpdateEntrustMaterialInfo( |
|
|
|
|
dto.getMaterialList(), |
|
|
|
|
oldInfoMap, |
|
|
|
|
updateRecordBuilder |
|
|
|
|
); |
|
|
|
|
entrustmentIdentificationMaterialService.updateBatchById(entrustmentIdentificationMaterialList); |
|
|
|
|
// 3. 更新委托鉴定要求
|
|
|
|
|
updateEntrustmentRequirement(entrustment, dto.getEntrustRequirement(), updateRecordBuilder); |
|
|
|
|
// 如果确认完成,则删除鉴定事项确认书和委托书,并更新申请状态为已完成
|
|
|
|
|
if (dto.getFinished()) { |
|
|
|
|
// 4.删除鉴定事项确认书和委托书
|
|
|
|
|
deleteConfirmEntrustLetter(entrustment.getEntrustmentNo(), entrustId); |
|
|
|
|
} |
|
|
|
|
return super.update(Wrappers.<EntrustAlterApply>lambdaUpdate().eq(EntrustAlterApply::getId, dto.getId()) |
|
|
|
|
.set(EntrustAlterApply::getUpdateRecord, updateRecordBuilder.toString()) |
|
|
|
|
.set(dto.getFinished(), EntrustAlterApply::getStatus, EntrustAlterApplyStatus.FINISHED.getStatus())); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 处理更新委托鉴定检材信息 |
|
|
|
|
* |
|
|
|
|
* @param materialList 待更新的材料DTO列表 |
|
|
|
|
* @param oldInfoMap 旧的委托鉴定材料信息映射表,key为材料ID,value为对应的委托鉴定材料对象 |
|
|
|
|
* @param updateRecordBuilder 更新记录构建器,用于构建更新记录 |
|
|
|
|
* @return 更新后的委托鉴定材料对象列表 |
|
|
|
|
*/ |
|
|
|
|
private List<EntrustmentIdentificationMaterial> processUpdateEntrustMaterialInfo(List<MaterialDTO> materialList, Map<String, EntrustmentIdentificationMaterial> oldInfoMap, StringBuilder updateRecordBuilder) { |
|
|
|
|
Integer index = 1; |
|
|
|
|
List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList = new ArrayList<>(); |
|
|
|
|
for (MaterialDTO item : materialList) { |
|
|
|
@ -273,17 +303,7 @@ public class EntrustAlterApplyServiceImpl extends ServiceImpl<EntrustAlterApplyM |
|
|
|
|
entrustmentIdentificationMaterial.setAnalysisOption(analysisOption); |
|
|
|
|
entrustmentIdentificationMaterialList.add(entrustmentIdentificationMaterial); |
|
|
|
|
} |
|
|
|
|
entrustmentIdentificationMaterialService.updateBatchById(entrustmentIdentificationMaterialList); |
|
|
|
|
// 3. 更新委托鉴定要求
|
|
|
|
|
updateEntrustmentRequirement(entrustmentId, entrustment, dto.getEntrustRequirement()); |
|
|
|
|
// 如果确认完成,则删除鉴定事项确认书和委托书,并更新申请状态为已完成
|
|
|
|
|
if (dto.getFinished()) { |
|
|
|
|
// 4.删除鉴定事项确认书和委托书
|
|
|
|
|
deleteConfirmEntrustLetter(entrustment.getEntrustmentNo(), entrustmentId); |
|
|
|
|
} |
|
|
|
|
return super.update(Wrappers.<EntrustAlterApply>lambdaUpdate().eq(EntrustAlterApply::getId, dto.getId()) |
|
|
|
|
.set(EntrustAlterApply::getUpdateRecord, updateRecordBuilder.toString()) |
|
|
|
|
.set(dto.getFinished(), EntrustAlterApply::getStatus, EntrustAlterApplyStatus.FINISHED.getStatus())); |
|
|
|
|
return entrustmentIdentificationMaterialList; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
@ -306,16 +326,17 @@ public class EntrustAlterApplyServiceImpl extends ServiceImpl<EntrustAlterApplyM |
|
|
|
|
/** |
|
|
|
|
* 更新鉴定要求 |
|
|
|
|
* |
|
|
|
|
* @param entrustmentId |
|
|
|
|
* @param entrustment |
|
|
|
|
* @param entrustRequirement |
|
|
|
|
* @param updateRecordBuilder |
|
|
|
|
*/ |
|
|
|
|
public void updateEntrustmentRequirement(String entrustmentId, Entrustment entrustment, String entrustRequirement) { |
|
|
|
|
if (StrUtil.isNotBlank(entrustRequirement)) { |
|
|
|
|
public void updateEntrustmentRequirement(Entrustment entrustment, String entrustRequirement, StringBuilder updateRecordBuilder) { |
|
|
|
|
if (StrUtil.isNotBlank(entrustRequirement) && !entrustment.getEntrustRequirement().equals(entrustRequirement)) { |
|
|
|
|
entrustment.setEntrustRequirement(entrustRequirement); |
|
|
|
|
updateRecordBuilder.append("<br>鉴定要求更新记录:").append("<br>原鉴定要求 [").append(entrustment.getEntrustRequirement()).append("] 修改为 [").append(entrustRequirement).append("]。"); |
|
|
|
|
} else { |
|
|
|
|
List<EntrustmentIdentificationMaterial> renewList = entrustmentIdentificationMaterialService.list(Wrappers.<EntrustmentIdentificationMaterial>lambdaQuery() |
|
|
|
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustmentId) |
|
|
|
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustment.getId()) |
|
|
|
|
.orderByAsc(EntrustmentIdentificationMaterial::getOrderNo)); |
|
|
|
|
entrustment.setEntrustRequirement(entrustmentService.buildEntrustReq(renewList)); |
|
|
|
|
} |
|
|
|
@ -348,10 +369,12 @@ public class EntrustAlterApplyServiceImpl extends ServiceImpl<EntrustAlterApplyM |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 校验更新数据是否合法,并且返回委托信息 |
|
|
|
|
* |
|
|
|
|
* @param dto |
|
|
|
|
* @param updateRecordBuilder 初始化 |
|
|
|
|
* @return |
|
|
|
|
*/ |
|
|
|
|
private Entrustment validUpdateInfoAndGetEntrustInfo(ApprovedUpdateEntrustDTO dto) { |
|
|
|
|
private Entrustment validUpdateInfoAndGetEntrustInfo(ApprovedUpdateEntrustDTO dto, StringBuilder updateRecordBuilder) { |
|
|
|
|
// 判断当前申请状态是否审核通过
|
|
|
|
|
EntrustAlterApply entrustAlterApply = super.getById(dto.getId()); |
|
|
|
|
if (entrustAlterApply == null) { |
|
|
|
@ -370,6 +393,9 @@ public class EntrustAlterApplyServiceImpl extends ServiceImpl<EntrustAlterApplyM |
|
|
|
|
if (entrustment == null) { |
|
|
|
|
throw new ValidateCodeException("修改的委托记录不存在!"); |
|
|
|
|
} |
|
|
|
|
if (StrUtil.isNotBlank(entrustAlterApply.getUpdateRecord())) { |
|
|
|
|
updateRecordBuilder.append(entrustAlterApply.getUpdateRecord()).append("<br>"); |
|
|
|
|
} |
|
|
|
|
return entrustment; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|