From cab87dcfaa7b1e2bc1298572b775026bb17ef38b Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期四, 17 十月 2024 13:54:41 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java | 104 ++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 81 insertions(+), 23 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java index 29197d3..66c59da 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java @@ -5,6 +5,7 @@ import com.zy.asrs.framework.common.Cools; import com.zy.asrs.framework.exception.CoolException; import com.zy.asrs.wcs.common.domain.enums.DictType; +import com.zy.asrs.wcs.core.entity.BasShuttle; import com.zy.asrs.wcs.core.entity.Loc; import com.zy.asrs.wcs.core.map.controller.param.MapDataParam; import com.zy.asrs.wcs.core.map.controller.param.MapQueryParam; @@ -12,27 +13,30 @@ import com.zy.asrs.wcs.core.map.controller.result.LocVo; import com.zy.asrs.wcs.core.map.controller.result.ShuttleVo; import com.zy.asrs.wcs.core.map.entity.MapItem; +import com.zy.asrs.wcs.core.model.enums.DeviceCtgType; import com.zy.asrs.wcs.core.model.enums.LocStsType; +import com.zy.asrs.wcs.core.service.BasShuttleService; import com.zy.asrs.wcs.core.service.LocService; import com.zy.asrs.wcs.core.service.LocStsService; import com.zy.asrs.wcs.core.utils.Utils; -import com.zy.asrs.wcs.rcs.cache.SlaveConnection; import com.zy.asrs.wcs.rcs.entity.Device; -import com.zy.asrs.wcs.rcs.entity.DeviceType; -import com.zy.asrs.wcs.rcs.model.enums.SlaveType; import com.zy.asrs.wcs.rcs.model.protocol.LiftProtocol; import com.zy.asrs.wcs.rcs.model.protocol.ShuttleProtocol; import com.zy.asrs.wcs.rcs.service.DeviceService; import com.zy.asrs.wcs.rcs.service.DeviceTypeService; -import com.zy.asrs.wcs.rcs.thread.ShuttleThread; import com.zy.asrs.wcs.system.entity.Dict; import com.zy.asrs.wcs.system.service.DictService; import com.zy.asrs.wcs.system.service.UserService; +import com.zy.asrs.wcs.utils.CommonUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import java.util.*; +import java.util.ArrayList; +import java.util.Date; +import java.util.List; +import java.util.Optional; +import java.util.stream.Collectors; /** * Created by vincent on 3/15/2024 @@ -52,6 +56,8 @@ private LocService locService; @Autowired private LocStsService locStsService; + @Autowired + private BasShuttleService basShuttleService; public String getMapFloorList(Long userId) { String floorKey = "floor-list"; @@ -103,18 +109,32 @@ } } // loc - locService.remove(new LambdaQueryWrapper<Loc>().eq(Loc::getLev, param.getFloor())); + List<String> newLocList = new ArrayList<>(); for (MapItem item : param.getItemList()) { + int row = Integer.parseInt(String.valueOf(item.getProperty().get("row"))); + int bay = Integer.parseInt(String.valueOf(item.getProperty().get("bay"))); + String locNo = Utils.getLocNo(row, bay, param.getFloor()); + newLocList.add(locNo); + } + + List<String> existLocList = locService.list(new LambdaQueryWrapper<Loc>().eq(Loc::getLev, param.getFloor())) + .stream().map(Loc::getLocNo).collect(Collectors.toList()); + + + List<String> locListToSave = newLocList.stream().filter(locNo -> !existLocList.contains(locNo)).collect(Collectors.toList()); + + List<String> locListToRemove = existLocList.stream().filter(locNo -> !newLocList.contains(locNo)).collect(Collectors.toList()); + + List<String> locListInBoth = newLocList.stream().filter(existLocList::contains).collect(Collectors.toList()); + + for (String locNo : locListToSave) { Loc loc = new Loc(); - loc.setRow(Integer.parseInt(String.valueOf(item.getProperty().get("row")))); - loc.setBay(Integer.parseInt(String.valueOf(item.getProperty().get("bay")))); - loc.setLev(param.getFloor()); - String locNo = Utils.getLocNo(loc.getRow(), loc.getBay(), loc.getLev()); loc.setLocNo(locNo); loc.setName(locNo); - + loc.setRow(Utils.getRow(locNo)); + loc.setBay(Utils.getBay(locNo)); + loc.setLev(Utils.getLev(locNo)); loc.setLocSts(LocStsType.O.val()); - loc.setCreateBy(userId); loc.setCreateTime(now); loc.setUpdateBy(userId); @@ -123,41 +143,77 @@ throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�"); } } + + for (String locNo : locListToRemove) { + if (!locService.remove(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, locNo))) { + throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�"); + } + } + + for (String locNo : locListInBoth) { + + } } - - public List<LocVo> getShelfLocNoList(String locNo) { + public List<LocVo> getShelfLocNoGroup(String locNo) { List<LocVo> locVos = new ArrayList<>(); int row = Utils.getRow(locNo); int bay = Utils.getBay(locNo); List<Loc> locList = locService.list(new LambdaQueryWrapper<Loc>().eq(Loc::getRow, row).eq(Loc::getBay, bay).orderByAsc(Loc::getLev)); for (Loc loc : locList) { - locVos.add(new LocVo(loc.getLocNo(), loc.getLocStsFlag())); + LocVo locVo = new LocVo(); + locVo.setLocNo(loc.getLocNo()); + locVo.setLocSts(loc.getLocStsFlag()); + locVo.setZpallet(loc.getZpallet()); + locVo.setEnable(CommonUtils.getStatusBool(loc.getStatus())); + locVos.add(locVo); } return locVos; + } + + public LocVo getShelfLocNoInfo(String locNo) { + LocVo locVo = new LocVo(); + locVo.setLocNo(locNo); + Loc loc = locService.selectByLocNo(locNo); + if (null == loc) { + return locVo; + } + locVo.setLocSts(loc.getLocStsFlag()); + locVo.setZpallet(loc.getZpallet()); + locVo.setEnable(CommonUtils.getStatusBool(loc.getStatus())); + return locVo; } public ShuttleVo getShuttleInfo(String shuttleNo) { ShuttleVo vo = new ShuttleVo(); vo.setShuttleNo(shuttleNo); - DeviceType deviceType = deviceTypeService.getOne(new LambdaQueryWrapper<DeviceType>().eq(DeviceType::getFlag, SlaveType.Shuttle.toString())); - Device device = deviceService.getOne(new LambdaQueryWrapper<Device>().eq(Device::getDeviceType, deviceType.getId()).eq(Device::getDeviceNo, shuttleNo)); + Device device = deviceService.getOne(new LambdaQueryWrapper<Device>() + .eq(Device::getDeviceType, DeviceCtgType.SHUTTLE.val()) + .eq(Device::getDeviceNo, shuttleNo) + .eq(Device::getStatus, 1) + ); if (null == device) { return vo; } - ShuttleThread thread = (ShuttleThread)SlaveConnection.get(SlaveType.Shuttle, device.getId().intValue()); - if (null == thread) { + BasShuttle basShuttle = basShuttleService.getOne(new LambdaQueryWrapper<BasShuttle>().eq(BasShuttle::getDeviceId, device.getId())); + if (null == basShuttle || Cools.isEmpty(basShuttle.getProtocol())) { return vo; } - ShuttleProtocol protocol = thread.getStatus(); - if (null == protocol) { - return vo; - } + ShuttleProtocol protocol = JSON.parseObject(basShuttle.getProtocol(), ShuttleProtocol.class); +// ShuttleThread thread = (ShuttleThread)SlaveConnection.get(SlaveType.Shuttle, device.getId().intValue()); +// if (null == thread) { +// return vo; +// } +// ShuttleProtocol protocol = thread.getStatus(); +// if (null == protocol) { +// return vo; +// } vo.setTaskNo(String.valueOf(protocol.getTaskNo())); vo.setStatus(protocol.getProtocolStatusType().desc); vo.setOriginLocNo(protocol.getSourceLocNo()); vo.setDestLocNo(protocol.getLocNo()); vo.setCurrentCode(protocol.getCurrentCode()); + vo.setCurrentLocNo(protocol.getCurrentLocNo()); vo.setBatteryPower(protocol.getBatteryPower()); vo.setErrorCode(protocol.getErrorCode()); vo.setBatteryTemp(protocol.getBatteryTemp()); @@ -165,7 +221,9 @@ vo.setHasPallet(protocol.getHasPallet()); vo.setHasCharge(protocol.getHasCharge()); vo.setBatteryVoltage(String.valueOf(protocol.getBatteryVoltage())); +// vo.setZpallet(); vo.setPakMk(protocol.getPakMk()); + vo.setEnable(CommonUtils.getStatusBool(basShuttle.getStatus())); return vo; } -- Gitblit v1.9.1