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; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * 维修工单表 新增 | ||||
|      * | ||||
| @ -167,16 +165,16 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     @DSTransactional | ||||
|     public DlRepairTicketsRespVO createTickets(DlRepairTicketsRespVO ticketsRespVO) { | ||||
|         // 验证 | ||||
|         if (ObjectUtil.isEmpty(ticketsRespVO.getCarId())) { | ||||
|         if (ObjectUtil.isEmpty(ticketsRespVO.getCarId())){ | ||||
|             throw exception0(500, "车辆信息为空"); | ||||
|         } | ||||
|         if (ObjectUtil.isEmpty(ticketsRespVO.getAdviserId())) { | ||||
|         if (ObjectUtil.isEmpty(ticketsRespVO.getAdviserId())){ | ||||
|             throw exception0(500, "服务顾问为空"); | ||||
|         } | ||||
|         ticketsRespVO.getItemList().forEach(item -> { | ||||
|             if (ObjectUtil.isEmpty(item.getRepairIds()) || ObjectUtil.isEmpty(item.getSaleId())) { | ||||
|             if (ObjectUtil.isEmpty(item.getRepairIds()) || ObjectUtil.isEmpty(item.getSaleId())){ | ||||
|                 String message = ""; | ||||
|                 switch (item.getItemType()) { | ||||
|                 switch (item.getItemType()){ | ||||
|                     case "01": | ||||
|                         message += "项目:"; | ||||
|                         break; | ||||
| @ -326,7 +324,7 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|         if (CollectionUtil.isNotEmpty(wares)) { | ||||
|             // 单位字典 | ||||
|             List<DictDataRespDTO> recordTypeList = dictDataApi.getDictDataList(DICT_REPAIR_UNIT); | ||||
|             Map<String, String> unitMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue, DictDataRespDTO::getLabel)); | ||||
|             Map<String,String> unitMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue,DictDataRespDTO::getLabel)); | ||||
| 
 | ||||
|             Set<String> ids = wares.stream().map(DlRepairTitemReqVO::getPartId).collect(Collectors.toSet()); | ||||
|             List<RepairWares> repairWares = waresService.listByIds(ids); | ||||
| @ -350,8 +348,8 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|         List<RepairRecordsRespVO> records = repairRecordsService.queryList(entity); | ||||
|         // 操作记录类型 | ||||
|         List<DictDataRespDTO> recordTypeList = dictDataApi.getDictDataList(DICT_REPAIR_RECORDS_TYPE); | ||||
|         Map<String, String> typeMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue, DictDataRespDTO::getLabel)); | ||||
|         result.setRecords(records.stream().peek(item -> item.setType(typeMap.get(item.getType()))).collect(Collectors.toList())); | ||||
|         Map<String,String> typeMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue,DictDataRespDTO::getLabel)); | ||||
|         result.setRecords(records.stream().peek(item->item.setType(typeMap.get(item.getType()))).collect(Collectors.toList())); | ||||
|         return result; | ||||
|     } | ||||
| 
 | ||||
| @ -379,7 +377,7 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     public void setTicketsPaid(DlRepairTicketsRespVO repairTicketsRespVO) { | ||||
|         // 更新订单状态 | ||||
|         RepairOrderInfo one = repairOrderInfoService.getOne(new LambdaQueryWrapper<RepairOrderInfo>().eq(RepairOrderInfo::getGoodsId, repairTicketsRespVO.getId())); | ||||
|         if (ObjectUtil.isEmpty(one)) { | ||||
|         if (ObjectUtil.isEmpty(one)){ | ||||
|             throw exception0(500, "系统异常"); | ||||
|         } | ||||
|         RepairOrderInfo repairOrderInfo = new RepairOrderInfo(); | ||||
| @ -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()); | ||||
| @ -685,7 +682,7 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
| 
 | ||||
|             // 因为目前的配件申请表在申请的时候就把配件加到工单中了,但后续的领取并没有同步到工单,所以如果这里是员工直接完成移交给服务顾问,就需要同步一下 | ||||
|             boolean flag = syncTicketWaresToTicket(respVO.getId()); | ||||
|             if (!flag) { | ||||
|             if (!flag){ | ||||
|                 throw exception0(500, "系统异常"); | ||||
|             } | ||||
|         } else { | ||||
| @ -816,7 +813,7 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|         ); | ||||
| 
 | ||||
|         boolean flag = syncTicketWaresToTicket(respVO.getId()); | ||||
|         if (!flag) { | ||||
|         if (!flag){ | ||||
|             throw exception0(500, "系统异常"); | ||||
|         } | ||||
| 
 | ||||
| @ -828,12 +825,12 @@ 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) { | ||||
|     public boolean syncTicketWaresToTicket(String id){ | ||||
|         // 先查满足条件的申请表 | ||||
|         ArrayList<String> status = new ArrayList<>(); | ||||
|         status.add("01"); // 待审核 | ||||
| @ -873,16 +870,16 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|             // 可能出现配件申请单审核通过了没有任何领取或全部退了的情况,所以如果itemCount等于0,直接把这个数据删掉 | ||||
|             // 过滤出需要删除的数据 | ||||
|             List<DlRepairTitem> delItems = AllItems.stream().filter(item -> item.getItemCount() == 0).collect(Collectors.toList()); | ||||
|             if (CollectionUtil.isNotEmpty(delItems)) { | ||||
|             if (CollectionUtil.isNotEmpty(delItems)){ | ||||
|                 // 删除需要删的 | ||||
|                 titemService.removeBatchByIds(delItems); | ||||
|                 Set<String> delIds = delItems.stream().map(DlRepairTitem::getId).collect(Collectors.toSet()); | ||||
|                 // 得到需要改的 | ||||
|                 List<DlRepairTitem> updateItems = AllItems.stream().filter(item -> delIds.contains(item.getId())).collect(Collectors.toList()); | ||||
|                 if (CollectionUtil.isNotEmpty(updateItems)) { | ||||
|                 if (CollectionUtil.isNotEmpty(updateItems)){ | ||||
|                     titemService.updateBatchById(updateItems); | ||||
|                 } | ||||
|             } else { | ||||
|             }else { | ||||
|                 // 没有需要删的就是全部都需要改 | ||||
|                 titemService.updateBatchById(AllItems); | ||||
|             } | ||||
| @ -922,21 +919,21 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|      **/ | ||||
|     @Override | ||||
|     public Map<String, Integer> getBossNum() { | ||||
|         Map<String, Integer> rtnMap = new HashMap<>(); | ||||
|         Map<String,Integer> rtnMap = new HashMap<>(); | ||||
|         int workingNum = 0; | ||||
|         int doneNum = 0; | ||||
|         List<DlRepairTickets> repairTickets = this.list(); | ||||
|         if (!repairTickets.isEmpty()) { | ||||
|             Map<String, List<DlRepairTickets>> ifFinishMap = repairTickets.stream().collect(Collectors.groupingBy(DlRepairTickets::getIsFinish)); | ||||
|             if (ifFinishMap.containsKey("0")) { | ||||
|         if(!repairTickets.isEmpty()){ | ||||
|             Map<String,List<DlRepairTickets>> ifFinishMap = repairTickets.stream().collect(Collectors.groupingBy(DlRepairTickets::getIsFinish)); | ||||
|             if(ifFinishMap.containsKey("0")){ | ||||
|                 workingNum = ifFinishMap.get("0").size(); | ||||
|             } | ||||
|             if (ifFinishMap.containsKey("1")) { | ||||
|             if(ifFinishMap.containsKey("1")){ | ||||
|                 doneNum = ifFinishMap.get("1").size(); | ||||
|             } | ||||
|         } | ||||
|         rtnMap.put("workingNum", workingNum); | ||||
|         rtnMap.put("doneNum", doneNum); | ||||
|         rtnMap.put("workingNum",workingNum); | ||||
|         rtnMap.put("doneNum",doneNum); | ||||
|         return rtnMap; | ||||
|     } | ||||
| 
 | ||||
| @ -975,13 +972,13 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|                 , tickets.getCarNo(), type, noticeCusVO.getName(), noticeCusVO.getMobile() | ||||
|         ); | ||||
|         // todo 小程序通知客户 | ||||
|         if (null != cus && StringUtils.isNotEmpty(cus.getPhoneNumber())) { | ||||
|         if(null!=cus && StringUtils.isNotEmpty(cus.getPhoneNumber())){ | ||||
|             // 短信通知客户 | ||||
|             SendSmsUtil.sendMsgCommon(new String[]{message}, cus.getPhoneNumber(), "1400852709", "蓝安汽车小程序", "2143603"); | ||||
|         } | ||||
|         // 记录日志 | ||||
|         String recordStr = noticeCusVO.getName() | ||||
|                 + "通知客户取车:" + message; | ||||
|                 + "通知客户取车:"+message; | ||||
|         repairRecordsService.saveRepairRecord(noticeCusVO.getId(), null, RecordTypeEnum.TZQC.getCode(), recordStr, null); | ||||
|     } | ||||
| 
 | ||||
| @ -1023,19 +1020,19 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
|     /** | ||||
|      * 新增工单子项 | ||||
|      * | ||||
|      * @param respVO 主要有两个参数,主表ID,itemList(这个需要前端处理成子表的对象能接收的数据) | ||||
|      * @author 小李 | ||||
|      * @date 19:59 2024/10/24 | ||||
|      * @param respVO 主要有两个参数,主表ID,itemList(这个需要前端处理成子表的对象能接收的数据) | ||||
|      **/ | ||||
|     @Override | ||||
|     @DSTransactional | ||||
|     public void addItems(DlRepairTicketsRespVO respVO) { | ||||
|     public void addItems(DlRepairTicketsRespVO respVO){ | ||||
|         // 先判断是否施工人员和销售人员是否都设置了 | ||||
|         respVO.getItemList().forEach(item -> { | ||||
|             if (ObjectUtil.isEmpty(item.getRepairIds())) { | ||||
|             if (ObjectUtil.isEmpty(item.getRepairIds())){ | ||||
|                 throw exception0(500, "施工人员尚未设置"); | ||||
|             } | ||||
|             if (ObjectUtil.isEmpty(item.getSaleId())) { | ||||
|             if (ObjectUtil.isEmpty(item.getSaleId())){ | ||||
|                 throw exception0(500, "销售人员尚未设置"); | ||||
|             } | ||||
|         }); | ||||
| @ -1046,93 +1043,10 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | ||||
| 
 | ||||
|         // 更新主表 | ||||
|         boolean flag = computeTicket(respVO.getId()); | ||||
|         if (!flag) { | ||||
|         if (!flag){ | ||||
|             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