From 2c08bfb96d6523dfbf5ae543e94495c151aadbf1 Mon Sep 17 00:00:00 2001 From: ZengTao <2773468879@qq.com> Date: 星期五, 14 三月 2025 17:53:18 +0800 Subject: [PATCH] 大屏嵌入历史任务,生产统计显示 --- hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/opctask/service/impl/EdgStorageDeviceTaskServiceImpl.java | 48 +++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 45 insertions(+), 3 deletions(-) diff --git a/hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/opctask/service/impl/EdgStorageDeviceTaskServiceImpl.java b/hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/opctask/service/impl/EdgStorageDeviceTaskServiceImpl.java index 4e13ea7..d4d3e3f 100644 --- a/hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/opctask/service/impl/EdgStorageDeviceTaskServiceImpl.java +++ b/hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/opctask/service/impl/EdgStorageDeviceTaskServiceImpl.java @@ -2,18 +2,24 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; +import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.mes.common.config.Const; +import com.mes.edgstoragecage.entity.EdgStorageCage; import com.mes.edgstoragecage.entity.EdgStorageCageDetails; +import com.mes.edgstoragecage.entity.vo.EdgSlotRemainVO; import com.mes.edgstoragecage.service.EdgStorageCageDetailsService; +import com.mes.edgstoragecage.service.EdgStorageCageService; import com.mes.job.OpcCacheGlassTask; import com.mes.opctask.entity.EdgStorageDeviceTask; import com.mes.opctask.entity.EdgStorageDeviceTaskHistory; import com.mes.opctask.mapper.EdgStorageDeviceTaskMapper; import com.mes.opctask.service.EdgStorageDeviceTaskHistoryService; import com.mes.opctask.service.EdgStorageDeviceTaskService; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import javax.annotation.Resource; +import java.util.List; /** * @Author : zhoush @@ -33,9 +39,14 @@ @Resource private EdgStorageCageDetailsService edgStorageCageDetailsService; @Resource - EdgStorageDeviceTaskMapper edgStorageDeviceTaskMapper; + private EdgStorageCageService edgStorageCageService; @Resource - OpcCacheGlassTask opcCacheGlassTask; + EdgStorageDeviceTaskMapper edgStorageDeviceTaskMapper; + + @Value("${mes.glassGap}") + private int glassGap; + @Value("${mes.cellLength}") + private int cellLength; @Override public EdgStorageDeviceTask queryTaskMessage(String tableName) { @@ -75,12 +86,13 @@ .eq(EdgStorageCageDetails::getGlassId, glassId)); } - opcCacheGlassTask.updateCellRemainWidth(cell, deviceId, taskHistory); edgStorageDeviceTaskHistoryService.update(new LambdaUpdateWrapper<EdgStorageDeviceTaskHistory>() .eq(EdgStorageDeviceTaskHistory::getTaskState, Const.RAW_GLASS_TASK_NEW) .eq(EdgStorageDeviceTaskHistory::getDeviceId, deviceId) .set(EdgStorageDeviceTaskHistory::getTaskState, Const.RAW_GLASS_TASK_FAILURE) ); + //璁$畻姣忎釜鍚勮嚜鐨勫墿浣欏昂瀵镐俊鎭� + resetSlotRemainWidth(); //鏈�鍚庢洿鏂颁换鍔★紝淇濊瘉浠诲姟鍓嶇殑鍔ㄤ綔閮藉仛瀹� EdgStorageDeviceTask task = new EdgStorageDeviceTask(); task.setTaskRunning(Const.GLASS_CACHE_TYPE_EMPTY); @@ -89,4 +101,34 @@ this.updateTaskMessage(tableName, task); return Boolean.TRUE; } + + @Override + public Boolean taskSuccess(Integer deviceId) { + String tableName = deviceId == 1 ? EDG_STORAGE_DEVICE_ONE_TASK : EDG_STORAGE_DEVICE_TWO_TASK; + edgStorageDeviceTaskHistoryService.update(new LambdaUpdateWrapper<EdgStorageDeviceTaskHistory>() + .set(EdgStorageDeviceTaskHistory::getTaskState, Const.RAW_GLASS_TASK_SUCCESS) + .eq(EdgStorageDeviceTaskHistory::getTaskState, Const.RAW_GLASS_TASK_NEW) + .eq(EdgStorageDeviceTaskHistory::getDeviceId, deviceId)); + //璁$畻姣忎釜鍚勮嚜鐨勫墿浣欏昂瀵镐俊鎭� + resetSlotRemainWidth(); + //鏈�鍚庢洿鏂颁换鍔★紝淇濊瘉浠诲姟鍓嶇殑鍔ㄤ綔閮藉仛瀹� + EdgStorageDeviceTask task = new EdgStorageDeviceTask(); + task.setTaskRunning(Const.GLASS_CACHE_TYPE_EMPTY); + task.setGlassIdOut(""); + task.setStartCell(0); + this.updateTaskMessage(tableName, task); + return Boolean.TRUE; + } + + private boolean resetSlotRemainWidth() { + //灏嗗昂瀵搁噸缃负鍘熷灏哄 + edgStorageCageService.update(new LambdaUpdateWrapper<EdgStorageCage>().set(EdgStorageCage::getRemainWidth, cellLength)); + //鑾峰彇绗煎唴鐨勮鎯呮暟鎹� + List<EdgSlotRemainVO> edgSlotRemainVOS = edgStorageCageDetailsService.querySlotRemainWidth(cellLength, glassGap); + //鎸夌収鏌ヨ缁撴灉瀵圭鍐呯幇鏈夌幓鐠冪殑鏍煎瓙灏哄杩涜鏇存柊 + if(CollectionUtils.isNotEmpty(edgSlotRemainVOS)){ + edgStorageCageService.resetSlotRemainWidth(edgSlotRemainVOS); + } + return Boolean.TRUE; + } } -- Gitblit v1.8.0