|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | private LocService locService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ConfigService configService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | * @description 完成入库,更新库存 | 
|---|
|  |  |  | * @param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @time 2025/4/2 12:37 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | * @param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | * @description 完成入库,更新库存 | 
|---|
|  |  |  | * @time 2025/4/2 12:37 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ?") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | //    @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void completeInStock() throws Exception { | 
|---|
|  |  |  | List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getTaskStatus, TaskStsType.COMPLETE_IN.id)); | 
|---|
|  |  |  | if (tasks.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | taskService.completeTask(tasks); | 
|---|
|  |  |  | taskService.complateInTask(tasks); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @description: 完成出库任务,更新库存 | 
|---|
|  |  |  | * @version 1.0 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0/5 * * * * ?") | 
|---|
|  |  |  | @Scheduled(cron = "0/30 * * * * ?  ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void complateOutStock() throws Exception { | 
|---|
|  |  |  | List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getTaskStatus, TaskStsType.COMPLETE_OUT.id)); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | * @description 已完成任务加入历史档 | 
|---|
|  |  |  | * @param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @time 2025/4/3 12:54 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | * @param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | * @description 已完成任务加入历史档 | 
|---|
|  |  |  | * @time 2025/4/3 12:54 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0 0/05 * * * ?  ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void taskLogUpdate() { | 
|---|
|  |  |  | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<TaskLog> taskLogs = new ArrayList<>(); | 
|---|
|  |  |  | Map<Long, List<TaskItem>> listMap = taskItems.stream().collect(Collectors.groupingBy(TaskItem::getTaskId)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tasks.forEach(task -> { | 
|---|
|  |  |  | TaskLog taskLog = new TaskLog(); | 
|---|
|  |  |  | BeanUtils.copyProperties(task, taskLog); | 
|---|
|  |  |  | taskLog.setTaskId(task.getId()).setId(null); | 
|---|
|  |  |  | taskLogs.add(taskLog); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | if (!taskLogService.saveBatch(taskLogs)) { | 
|---|
|  |  |  | throw new CoolException("任务历史档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TaskItemLog >itemLogs = new ArrayList<>(); | 
|---|
|  |  |  | taskLog.setTaskId(task.getId()) | 
|---|
|  |  |  | .setId(null); | 
|---|
|  |  |  | if (!taskLogService.save(taskLog)) { | 
|---|
|  |  |  | throw new CoolException("任务历史档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | taskItems.forEach(item -> { | 
|---|
|  |  |  | TaskItemLog itemLog = new TaskItemLog(); | 
|---|
|  |  |  | BeanUtils.copyProperties(item, itemLog); | 
|---|
|  |  |  | itemLog.setId(null).setTaskItemId(item.getId()); | 
|---|
|  |  |  | itemLogs.add(itemLog); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | List<TaskItemLog> itemLogs = new ArrayList<>(); | 
|---|
|  |  |  | for (TaskItem item : listMap.get(task.getId())) { | 
|---|
|  |  |  | TaskItemLog itemLog = new TaskItemLog(); | 
|---|
|  |  |  | BeanUtils.copyProperties(item, itemLog); | 
|---|
|  |  |  | itemLog.setId(null) | 
|---|
|  |  |  | .setTaskId(task.getId()) | 
|---|
|  |  |  | .setLogId(taskLog.getId()) | 
|---|
|  |  |  | .setTaskItemId(item.getId()); | 
|---|
|  |  |  | itemLogs.add(itemLog); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!taskItemLogService.saveBatch(itemLogs)) { | 
|---|
|  |  |  | throw new CoolException("任务明细历史档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!taskItemLogService.saveBatch(itemLogs)) { | 
|---|
|  |  |  | throw new CoolException("任务明细历史档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!taskService.removeByIds(list)) { | 
|---|
|  |  |  | throw new CoolException("原始任务删除失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Long> itemIds = taskItems.stream().map(TaskItem::getId).collect(Collectors.toList()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!taskItemService.removeByIds(itemIds)) { | 
|---|
|  |  |  | throw new CoolException("原始任务明细删除失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|