|
@@ -1,6 +1,8 @@
|
|
|
package com.ruoyi.ams.nieyan.service.impl;
|
|
|
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
+import com.ruoyi.ams.agv.car.domain.CarInfo;
|
|
|
+import com.ruoyi.ams.agv.car.mapper.CarInfoMapper;
|
|
|
import com.ruoyi.ams.asn.domain.WmsDocAsnDetails;
|
|
|
import com.ruoyi.ams.asn.domain.WmsDocAsnHeader;
|
|
|
import com.ruoyi.ams.asn.service.IWmsDocAsnDetailsService;
|
|
@@ -8,10 +10,14 @@ import com.ruoyi.ams.asn.service.IWmsDocAsnHeaderService;
|
|
|
import com.ruoyi.ams.business.IBusinessService;
|
|
|
import com.ruoyi.ams.config.domain.dto.AgvCallDTO;
|
|
|
import com.ruoyi.ams.config.domain.dto.AgvCallItemDTO;
|
|
|
+import com.ruoyi.ams.config.mapper.AsnSoStrategyMapper;
|
|
|
import com.ruoyi.ams.inv.domain.vo.InvLotLocIdLotattVO;
|
|
|
import com.ruoyi.ams.inv.service.IInvLotAttService;
|
|
|
import com.ruoyi.ams.inv.service.IInvLotLocIdService;
|
|
|
+import com.ruoyi.ams.task.domain.WcsTask;
|
|
|
+import com.ruoyi.ams.task.mapper.WcsTaskMapper;
|
|
|
import com.ruoyi.base.constant.Constant;
|
|
|
+import com.ruoyi.base.domain.BaseLocationInfo;
|
|
|
import com.ruoyi.base.service.IBaseLocationInfoService;
|
|
|
import com.ruoyi.base.utils.IdSequenceUtils;
|
|
|
import com.ruoyi.common.core.domain.AjaxResult;
|
|
@@ -44,7 +50,12 @@ public class AgvCallProxyService {
|
|
|
private IBaseLocationInfoService baseLocationInfoService;
|
|
|
@Autowired
|
|
|
private IInvLotAttService iInvLotAttService;
|
|
|
-
|
|
|
+ @Autowired
|
|
|
+ private CarInfoMapper carInfoMapper;
|
|
|
+ @Autowired
|
|
|
+ private WcsTaskMapper wcsTaskMapper;
|
|
|
+ @Autowired
|
|
|
+ private AsnSoStrategyMapper asnSoStrategyMapper;
|
|
|
@Autowired
|
|
|
private IdSequenceUtils idSequenceUtils;
|
|
|
|
|
@@ -217,55 +228,6 @@ public class AgvCallProxyService {
|
|
|
return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.SEVEN.getValue(), agvCallDTO);
|
|
|
}
|
|
|
|
|
|
- /**
|
|
|
- * 成品下线(硫酸镍)->裹膜|成品暂存区
|
|
|
- *
|
|
|
- * @param locationFrom
|
|
|
- * @param locationTo
|
|
|
- * @param createUser
|
|
|
- * @param theWeighing
|
|
|
- * @param agvCallItemDTOList
|
|
|
- * @return
|
|
|
- */
|
|
|
- public AjaxResult productsDownLineLSN(String locationFrom, String locationTo, String createUser
|
|
|
- , Boolean theWeighing
|
|
|
- , List<AgvCallItemDTO> agvCallItemDTOList) {
|
|
|
- AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
|
- agvCallDTO.setLocationFrom(locationFrom);
|
|
|
- agvCallDTO.setLocationTo(locationTo);
|
|
|
- agvCallDTO.setCreateUser(createUser);
|
|
|
- agvCallDTO.setTheWeighing(theWeighing);
|
|
|
- agvCallDTO.setAgvCallItemDTOList(agvCallItemDTOList);
|
|
|
- // 增加硫酸镍标识
|
|
|
- for (AgvCallItemDTO agvCallItemDTO : agvCallItemDTOList) {
|
|
|
- agvCallItemDTO.getLotattDTO().setLotatt18("Y"); //是否硫酸镍,Y代表否
|
|
|
- }
|
|
|
- createWmsDoc(createUser, agvCallItemDTOList);
|
|
|
- return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.EIGHT.getValue(), agvCallDTO);
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * 成品下线(硫酸镍)->仓储区
|
|
|
- *
|
|
|
- * @param locationFrom
|
|
|
- * @param locationTo
|
|
|
- * @param createUser
|
|
|
- * @param theWeighing
|
|
|
- * @param agvCallItemDTOList
|
|
|
- * @return
|
|
|
- */
|
|
|
- public AjaxResult productsDownLineInvLSN(String locationFrom, String locationTo, String createUser
|
|
|
- , Boolean theWeighing
|
|
|
- , List<AgvCallItemDTO> agvCallItemDTOList) {
|
|
|
- AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
|
- agvCallDTO.setLocationFrom(locationFrom);
|
|
|
- agvCallDTO.setLocationTo(locationTo);
|
|
|
- agvCallDTO.setCreateUser(createUser);
|
|
|
- agvCallDTO.setTheWeighing(theWeighing);
|
|
|
- agvCallDTO.setAgvCallItemDTOList(agvCallItemDTOList);
|
|
|
- createWmsDoc(createUser, agvCallItemDTOList);
|
|
|
- return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.NINE.getValue(), agvCallDTO);
|
|
|
- }
|
|
|
|
|
|
public void createWmsDoc(String createUser
|
|
|
, List<AgvCallItemDTO> agvCallItemDTOList){
|
|
@@ -344,8 +306,65 @@ public class AgvCallProxyService {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+
|
|
|
/**
|
|
|
- * 成品下线(氯化镍)->裹膜
|
|
|
+ *获取目标库位
|
|
|
+ * @param theWrapped 是否裹膜
|
|
|
+ * @param theWeighing 是否复称
|
|
|
+ * @param taskType 任务类型 0-硫酸镍 1-氯化镍
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public String queryBaslocationTo(Boolean theWrapped,Boolean theWeighing,List<BaseLocationInfo> blfList
|
|
|
+ ,Integer taskType){
|
|
|
+
|
|
|
+ if(theWrapped) {
|
|
|
+
|
|
|
+ if (blfList.size() > 0) {
|
|
|
+ return taskType == 0 ? "8,9,10" : "11";
|
|
|
+ } else {
|
|
|
+ return "17";
|
|
|
+ }
|
|
|
+ }else{
|
|
|
+
|
|
|
+ return taskType == 0 ? "8,9,10" : "11";
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取NDC任务类型
|
|
|
+ * @param theWrapped 是否裹膜
|
|
|
+ * @param theWeighing 是否复称
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public String queryTaskType(Boolean theWrapped,Boolean theWeighing,List<BaseLocationInfo> blfList){
|
|
|
+
|
|
|
+ if(theWrapped && theWeighing){
|
|
|
+
|
|
|
+ if(blfList.size() > 0){
|
|
|
+ return "0003";
|
|
|
+ }else{
|
|
|
+ return "0000";
|
|
|
+ }
|
|
|
+ }else if(theWrapped && !theWeighing){
|
|
|
+
|
|
|
+ if(blfList.size() > 0){
|
|
|
+ return "0002";
|
|
|
+ }else{
|
|
|
+ return "0000";
|
|
|
+ }
|
|
|
+ }else if(!theWrapped && theWeighing){
|
|
|
+
|
|
|
+ return "0001";
|
|
|
+ }else{
|
|
|
+
|
|
|
+ return "0000";
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 成品下线(硫酸镍)->裹膜|成品暂存区
|
|
|
*
|
|
|
* @param locationFrom
|
|
|
* @param locationTo
|
|
@@ -354,7 +373,40 @@ public class AgvCallProxyService {
|
|
|
* @param agvCallItemDTOList
|
|
|
* @return
|
|
|
*/
|
|
|
- public AjaxResult productsDownLineLHN(String locationFrom, String locationTo, String createUser
|
|
|
+ public AjaxResult productsDownLineLSN(String locationFrom, String locationTo, String createUser,
|
|
|
+ Boolean theWrapped, Boolean theWeighing, List<AgvCallItemDTO> agvCallItemDTOList) {
|
|
|
+
|
|
|
+ //根据裹膜库位的状态判断目标点
|
|
|
+ List<BaseLocationInfo> bliList = baseLocationInfoService.selectEmptyLocationByZoneId("15");
|
|
|
+ //获取目标库区
|
|
|
+ String zoneList = queryBaslocationTo(theWrapped,theWeighing,bliList,0);
|
|
|
+
|
|
|
+ AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
|
+ agvCallDTO.setLocationFrom(locationFrom);
|
|
|
+ agvCallDTO.setLocationTo(zoneList);
|
|
|
+ agvCallDTO.setCreateUser(createUser);
|
|
|
+ agvCallDTO.setTheWeighing(theWeighing);
|
|
|
+ agvCallDTO.setExt3(queryTaskType(theWrapped,theWeighing,bliList));
|
|
|
+ agvCallDTO.setAgvCallItemDTOList(agvCallItemDTOList);
|
|
|
+ // 增加硫酸镍标识
|
|
|
+ for (AgvCallItemDTO agvCallItemDTO : agvCallItemDTOList) {
|
|
|
+ agvCallItemDTO.getLotattDTO().setLotatt18("Y"); //是否硫酸镍,Y代表否
|
|
|
+ }
|
|
|
+ createWmsDoc(createUser, agvCallItemDTOList);
|
|
|
+ return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.EIGHT.getValue(), agvCallDTO);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 成品下线(硫酸镍)->仓储区
|
|
|
+ *
|
|
|
+ * @param locationFrom
|
|
|
+ * @param locationTo
|
|
|
+ * @param createUser
|
|
|
+ * @param theWeighing
|
|
|
+ * @param agvCallItemDTOList
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public AjaxResult productsDownLineInvLSN(String locationFrom, String locationTo, String createUser
|
|
|
, Boolean theWeighing
|
|
|
, List<AgvCallItemDTO> agvCallItemDTOList) {
|
|
|
AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
@@ -363,12 +415,43 @@ public class AgvCallProxyService {
|
|
|
agvCallDTO.setCreateUser(createUser);
|
|
|
agvCallDTO.setTheWeighing(theWeighing);
|
|
|
agvCallDTO.setAgvCallItemDTOList(agvCallItemDTOList);
|
|
|
+ createWmsDoc(createUser, agvCallItemDTOList);
|
|
|
+ return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.NINE.getValue(), agvCallDTO);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 成品下线(氯化镍)->裹膜
|
|
|
+ *
|
|
|
+ * @param locationFrom
|
|
|
+ * @param locationTo
|
|
|
+ * @param createUser
|
|
|
+ * @param theWeighing
|
|
|
+ * @param agvCallItemDTOList
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public AjaxResult productsDownLineLHN(String locationFrom, String locationTo, String createUser
|
|
|
+ , Boolean theWrapped, Boolean theWeighing
|
|
|
+ , List<AgvCallItemDTO> agvCallItemDTOList) {
|
|
|
+
|
|
|
+ //根据裹膜库位的状态判断目标点
|
|
|
+ List<BaseLocationInfo> bliList = baseLocationInfoService.selectEmptyLocationByZoneId("15");
|
|
|
+ //获取目标库区
|
|
|
+ String zoneList = queryBaslocationTo(theWrapped,theWeighing,bliList,1);
|
|
|
+
|
|
|
+ AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
|
+ agvCallDTO.setLocationFrom(locationFrom);
|
|
|
+ agvCallDTO.setLocationTo(zoneList);
|
|
|
+ agvCallDTO.setCreateUser(createUser);
|
|
|
+ agvCallDTO.setTheWeighing(theWeighing);
|
|
|
+ agvCallDTO.setExt3(queryTaskType(theWrapped,theWeighing,bliList));
|
|
|
+ agvCallDTO.setAgvCallItemDTOList(agvCallItemDTOList);
|
|
|
// 增加氯化镍标识
|
|
|
for (AgvCallItemDTO agvCallItemDTO : agvCallItemDTOList) {
|
|
|
agvCallItemDTO.getLotattDTO().setLotatt18("N"); //是否硫酸镍,N代表否
|
|
|
}
|
|
|
createWmsDoc(createUser, agvCallItemDTOList);
|
|
|
- return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.ELEVEN.getValue(), agvCallDTO);
|
|
|
+
|
|
|
+ return iBusinessService.agvCall( Constant.FLOW_CONFIG_ID.TWELVE.getValue(), agvCallDTO);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -441,15 +524,18 @@ public class AgvCallProxyService {
|
|
|
/**
|
|
|
* 成品中转(硫酸镍|氯化镍)->裹膜
|
|
|
*
|
|
|
- * @param locationFrom
|
|
|
- * @param locationTo
|
|
|
* @param createUser
|
|
|
* @return
|
|
|
*/
|
|
|
- public AjaxResult productsDownLineToCache(String locationFrom, String locationTo, String createUser) {
|
|
|
+ public AjaxResult productsDownLineToCache(Boolean theWrapped, Boolean theWeighing,String createUser) {
|
|
|
+
|
|
|
+ //根据裹膜库位的状态判断目标点
|
|
|
+ List<BaseLocationInfo> bliList = baseLocationInfoService.selectEmptyLocationByZoneId("15");
|
|
|
+ if(theWrapped && bliList.size() < 1) return AjaxResult.error("裹膜库位被占用,无法下发任务,请确认库位状态!");
|
|
|
+
|
|
|
AgvCallDTO agvCallDTO = new AgvCallDTO();
|
|
|
- agvCallDTO.setLocationFrom(locationFrom);
|
|
|
- agvCallDTO.setLocationTo(locationTo);
|
|
|
+ agvCallDTO.setTheWeighing(true);
|
|
|
+ agvCallDTO.setExt3(queryTaskType(theWrapped,theWeighing,bliList));
|
|
|
agvCallDTO.setCreateUser(createUser);
|
|
|
return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.SIXTEEN.getValue(), agvCallDTO);
|
|
|
}
|
|
@@ -496,5 +582,44 @@ public class AgvCallProxyService {
|
|
|
return iBusinessService.agvCall(Constant.FLOW_CONFIG_ID.FIFTEEN.getValue(), agvCallDTO);
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * 车辆信息
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public AjaxResult getCarInfo(){
|
|
|
+
|
|
|
+ List<CarInfo> carInfoList = carInfoMapper.queryCarInfos();
|
|
|
+ return AjaxResult.success(carInfoList);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 指定车辆下发充电任务
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public AjaxResult addChargingTask(CarInfo carInfo){
|
|
|
+ log.info("-----------指定车辆下发充电任务:" + carInfo.getCarNo());
|
|
|
+
|
|
|
+ WcsTask wcsTask = new WcsTask();
|
|
|
+ wcsTask.setTaskNo(System.currentTimeMillis() + "");
|
|
|
+ wcsTask.setBusinessType(Constant.TASK_BUSINESS_TYPE.TASK_POWER.getValue());
|
|
|
+ wcsTask.setShopId("1");
|
|
|
+ wcsTask.setLocationFrom("998");
|
|
|
+ wcsTask.setLocationTo("997");
|
|
|
+ wcsTask.setDeviceName(carInfo.getCarNo());
|
|
|
+ wcsTask.setState(9L);
|
|
|
+ wcsTask.setPriority(1L);
|
|
|
+ wcsTask.setTaskType("POWER");
|
|
|
+ wcsTask.setAgvNo(carInfo.getCarNo());//车号
|
|
|
+ wcsTask.setRemark("充电任务");
|
|
|
+ wcsTask.setCreateDate(new Date());
|
|
|
+ wcsTask.setCreateUser("TS");
|
|
|
+
|
|
|
+ int result = wcsTaskMapper.insertWcsTask(wcsTask);
|
|
|
+ if (result > 0) {
|
|
|
+ return AjaxResult.success("任务生成成功");
|
|
|
+ } else {
|
|
|
+ return AjaxResult.success("任务生成失败");
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
|