Compare commits
	
		
			No commits in common. "32015dd9db1e9726ac994dbef3a1382f90157757" and "65410b9f3893e595ee670d8d87d0eab0a4353217" have entirely different histories.
		
	
	
		
			32015dd9db
			...
			65410b9f38
		
	
		
| @ -126,7 +126,5 @@ public class BaseConstants { | ||||
|     /** 施工中 */ | ||||
|     public static final String REPAIR_RECORD_TYPE_SGZ = "sgz"; | ||||
| 
 | ||||
|     /** 字典:超时自动总检配置 */ | ||||
|     public static final String AUTO_INSPECTION = "auto_inspection"; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -1,30 +0,0 @@ | ||||
| package cn.iocoder.yudao.job; | ||||
| 
 | ||||
| import cn.iocoder.yudao.framework.quartz.core.handler.JobHandler; | ||||
| import cn.iocoder.yudao.framework.tenant.core.job.TenantJob; | ||||
| import cn.iocoder.yudao.module.tickets.service.DlRepairTicketsService; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| import org.springframework.stereotype.Component; | ||||
| 
 | ||||
| import javax.annotation.Resource; | ||||
| 
 | ||||
| /** | ||||
|  * 超时自动总检的定时任务 | ||||
|  * | ||||
|  * @author 小李 | ||||
|  * @date 16:32 2024/10/26 | ||||
| **/ | ||||
| @Component | ||||
| @TenantJob | ||||
| @Slf4j | ||||
| public class AutoInspectionJob implements JobHandler { | ||||
| 
 | ||||
|     @Resource | ||||
|     private DlRepairTicketsService repairTicketsService; | ||||
| 
 | ||||
|     @Override | ||||
|     public String execute(String param) throws Exception { | ||||
|         repairTicketsService.autoInspection(); | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
| @ -46,7 +46,6 @@ import java.util.function.Function; | ||||
| import java.util.stream.Collectors; | ||||
| 
 | ||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; | ||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; | ||||
| 
 | ||||
| /** | ||||
|  * 针对表【dl_repair_so(采购单领料单)】的数据库操作Service实现 | ||||
| @ -110,14 +109,6 @@ public class DlRepairSoServiceImpl extends ServiceImpl<DlRepairSoMapper, DlRepai | ||||
|     @Override | ||||
|     public void createRepairSo(DlRepairSoRespVO repairSoRespVO) { | ||||
|         repairSoRespVO.setSoTime(new Date()); | ||||
|         // 加个判断,可能出现没有设置价格的情况 | ||||
|         if (repairSoRespVO.getGoodsList() != null){ | ||||
|             repairSoRespVO.getGoodsList().forEach(item -> { | ||||
|                 if (item.getGoodsPrice() == null){ | ||||
|                     throw exception0(500, "有配件未设置进价"); | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
|         //保存供应商 | ||||
|         if (StringUtils.isEmpty(repairSoRespVO.getSupplierId())){ | ||||
|             //采购单中录入供应商或无供应商情况 | ||||
| @ -509,8 +500,8 @@ public class DlRepairSoServiceImpl extends ServiceImpl<DlRepairSoMapper, DlRepai | ||||
|         List<DlRepairSoi> pmsWaresList = repairSoiService.listByIds(filterWare.stream().map(DlRepairSoi::getId).collect(Collectors.toList())); | ||||
|         //初始化本次入库采购品 | ||||
|         List<DlRepairSoi> inWaresList = new ArrayList<>(); | ||||
|         //原始配件库相关配件---不是用wareId,是用GoodsId,wareId是仓库 | ||||
|         List<RepairWares> waresList = waresService.listByIds(pmsWaresList.stream().map(DlRepairSoi::getGoodsId).collect(Collectors.toList())); | ||||
|         //原始配件库相关配件 | ||||
|         List<RepairWares> waresList = waresService.listByIds(pmsWaresList.stream().map(DlRepairSoi::getWareId).collect(Collectors.toList())); | ||||
| 
 | ||||
|         /*2、采购单转入库单*/ | ||||
|         //入库单关联采购单 | ||||
| @ -551,10 +542,10 @@ public class DlRepairSoServiceImpl extends ServiceImpl<DlRepairSoMapper, DlRepai | ||||
|         repairSoiService.saveBatch(inWaresList); | ||||
| 
 | ||||
|         /*4、原始配件库处理*/ | ||||
|         //入库配件按照原始配件库id分组,目的取出数量---不是用wareId,是用GoodsId,wareId是仓库 | ||||
|         Map<String, DlRepairSoi> wareMap = filterWare.stream().collect(Collectors.toMap(DlRepairSoi::getGoodsId, soi -> soi)); | ||||
|         //采购配件按照按照原始配件库id分组,目的取出价格---不是用wareId,是用GoodsId,wareId是仓库 | ||||
|         Map<String, DlRepairSoi> itemsMap = pmsWaresList.stream().collect(Collectors.toMap(DlRepairSoi::getGoodsId,soi -> soi)); | ||||
|         //入库配件按照原始配件库id分组,目的取出数量 | ||||
|         Map<String, DlRepairSoi> wareMap = filterWare.stream().collect(Collectors.toMap(DlRepairSoi::getWareId, soi -> soi)); | ||||
|         //采购配件按照按照原始配件库id分组,目的取出价格 | ||||
|         Map<String, DlRepairSoi> itemsMap = pmsWaresList.stream().collect(Collectors.toMap(DlRepairSoi::getWareId,soi -> soi)); | ||||
|         waresList.forEach(item -> { | ||||
|             DlRepairSoi filterSoi = wareMap.get(item.getId()); | ||||
|             DlRepairSoi itemSoi = itemsMap.get(item.getId()); | ||||
|  | ||||
| @ -209,12 +209,4 @@ public interface DlRepairTicketsService extends IService<DlRepairTickets> { | ||||
|      * @param id 维修工单ID | ||||
|      **/ | ||||
|     boolean syncTicketWaresToTicket(String id); | ||||
| 
 | ||||
|     /** | ||||
|      * 超时自动总检 | ||||
|      * | ||||
|      * @author 小李 | ||||
|      * @date 16:35 2024/10/26 | ||||
|     **/ | ||||
|     void autoInspection(); | ||||
| } | ||||
|  | ||||
| @ -66,9 +66,6 @@ import javax.servlet.http.HttpServletResponse; | ||||
| import java.io.FileOutputStream; | ||||
| import java.io.InputStream; | ||||
| import java.math.BigDecimal; | ||||
| import java.time.LocalDateTime; | ||||
| import java.time.format.DateTimeFormatter; | ||||
| import java.time.temporal.ChronoUnit; | ||||
| import java.util.*; | ||||
| import java.util.stream.Collectors; | ||||
| 
 | ||||
| @ -156,6 +153,7 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     private DlTwItemService twItemService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * 维修工单表 新增 | ||||
|      * | ||||
| @ -424,7 +422,6 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|         // 新增车辆信息 | ||||
|         if (ObjectUtil.isNotEmpty(customerAndCarVO.getCarInfo())) { | ||||
|             if (ObjectUtil.isEmpty(customerAndCarVO.getCarInfo().getId())) { | ||||
|                 customerAndCarVO.getCarInfo().setUserId(Long.valueOf(customerAndCarVO.getUserInfo().getId())); | ||||
|                 carMainService.createCarMain(customerAndCarVO.getCarInfo()); | ||||
|             } else { | ||||
|                 carMainService.updateCarMain(customerAndCarVO.getCarInfo()); | ||||
| @ -828,9 +825,9 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     /** | ||||
|      * 用于同步一个工单的所有配件申请表的数据到维修工单,主要针对已领取数量小于申请数量的情况 | ||||
|      * | ||||
|      * @param id 维修工单ID | ||||
|      * @author 小李 | ||||
|      * @date 9:52 2024/10/26 | ||||
|      * @param id 维修工单ID | ||||
|     **/ | ||||
|     @Override | ||||
|     public boolean syncTicketWaresToTicket(String id){ | ||||
| @ -1023,9 +1020,9 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     /** | ||||
|      * 新增工单子项 | ||||
|      * | ||||
|      * @param respVO 主要有两个参数,主表ID,itemList(这个需要前端处理成子表的对象能接收的数据) | ||||
|      * @author 小李 | ||||
|      * @date 19:59 2024/10/24 | ||||
|      * @param respVO 主要有两个参数,主表ID,itemList(这个需要前端处理成子表的对象能接收的数据) | ||||
|      **/ | ||||
|     @Override | ||||
|     @DSTransactional | ||||
| @ -1050,89 +1047,6 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|             throw exception0(500, "系统错误"); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * 超时自动总检 | ||||
|      * | ||||
|      * @author 小李 | ||||
|      * @date 16:35 2024/10/26 | ||||
|      **/ | ||||
|     @Override | ||||
|     @DSTransactional | ||||
|     public void autoInspection() { | ||||
|         // 查所有需要总检但还没总检的工单 | ||||
|         List<DlRepairTickets> tickets = baseMapper.selectList(new LambdaQueryWrapper<DlRepairTickets>().eq(DlRepairTickets::getTicketsWorkStatus, "05")); | ||||
|         // 如果没有,直接退出 | ||||
|         if (CollectionUtil.isEmpty(tickets)) { | ||||
|             return; | ||||
|         } | ||||
|         // 获取超时自动总检配置的时间 | ||||
|         List<DictDataRespDTO> dataList = dictDataApi.getDictDataList(BaseConstants.AUTO_INSPECTION); | ||||
|         // 理论上是只有一个的,但防止被删了或者别的什么原因,直接报错 | ||||
|         DictDataRespDTO dictDataRespDTO = dataList.stream().findFirst().orElse(null); | ||||
|         if (ObjectUtil.isEmpty(dictDataRespDTO)) { | ||||
|             log.error("超时自动总检时间没有配置"); | ||||
|             return; | ||||
|         } | ||||
|         // 计算超时的工单 | ||||
|         // 超时时间 | ||||
|         int time = Integer.parseInt(dictDataRespDTO.getValue()); | ||||
| 
 | ||||
|         List<DlRepairTickets> list = tickets.stream().filter(item -> { | ||||
|             // 当前时间---放到里面是因为如果数据量多,动态获取当前时间更能满足需求 | ||||
|             LocalDateTime now = LocalDateTime.now(); | ||||
|             return ChronoUnit.MINUTES.between(item.getUpdateTime(), now) > time; | ||||
|         }).collect(Collectors.toList()); | ||||
| 
 | ||||
|         // 同步工单的配件申请表到工单,如果都没超时,退出 | ||||
|         if (CollectionUtil.isEmpty(list)) { | ||||
|             return; | ||||
|         } | ||||
|         // 先取总检们 | ||||
|         // 取这个角色的角色信息 | ||||
|         RoleReqDTO roleInfo = roleApi.getRoleInfo(RepairRoleEnum.INSPECTION.getCode()); | ||||
|         // 通过角色信息查有这个角色的人 | ||||
|         List<Long> ids = permissionApi.getUserIdByRoleId(roleInfo.getId()); | ||||
|         // 如果没有总检,直接报错退出 | ||||
|         if (CollectionUtil.isEmpty(ids)) { | ||||
|             log.error("系统中没有总检"); | ||||
|             return; | ||||
|         } | ||||
|         // 在过滤一次,主要是过滤掉没法同步申请表到工单的数据 | ||||
|         List<DlRepairTickets> result = list.stream().filter(item -> { | ||||
|             boolean flag = syncTicketWaresToTicket(item.getId()); | ||||
|             // 如果出现更新不到的情况 | ||||
|             if (!flag) { | ||||
|                 // 通知总检,让其手动操作 | ||||
|                 ids.forEach(id -> { | ||||
|                     repairWorkerService.sentMessage(id, "待总检工单:" + item.getTicketNo() + "已经超时,但无法自动总检,请手动处理"); | ||||
|                 }); | ||||
|             } | ||||
|             return flag; | ||||
|         }).collect(Collectors.toList()); | ||||
|         // 如果没有记录同步成功,报错并退出 | ||||
|         if (CollectionUtil.isEmpty(result)) { | ||||
|             log.error("自动总检失败,原因可能是无法同步申请表到工单"); | ||||
|         } | ||||
|         // 移交服务顾问 | ||||
|         List<DlRepairTickets> updateTickets = result.stream().map(item -> { | ||||
|             DlRepairTickets ticket = new DlRepairTickets(); | ||||
|             ticket.setId(item.getId()); | ||||
|             ticket.setNowRepairId(Long.valueOf(item.getAdviserId())); | ||||
|             ticket.setNowRepairName(item.getAdviserName()); | ||||
|             return ticket; | ||||
|         }).collect(Collectors.toList()); | ||||
|         baseMapper.updateById(updateTickets); | ||||
|         // 通知总检和服务顾问 | ||||
|         result.forEach(item -> { | ||||
|             repairWorkerService.sentMessage(Long.valueOf(item.getAdviserId()), "您有新的工单可以出厂检验"); | ||||
|             ids.forEach(id -> { | ||||
|                 repairWorkerService.sentMessage(id, "工单:" + item.getTicketNo() + "已由系统自动总检并移交服务顾问"); | ||||
|             }); | ||||
|             // 记录日志 | ||||
|             repairRecordsService.saveRepairRecord(item.getId(), null, RecordTypeEnum.ZJ.getCode(), "该工单由系统自动总检完成", null); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user