| | |
| | | #endregion << ç æ¬ 注 é >> |
| | | |
| | | using AutoMapper; |
| | | using Newtonsoft.Json; |
| | | using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; |
| | | using SqlSugar; |
| | | using SqlSugar.Extensions; |
| | | using System; |
| | | using System.Collections.Generic; |
| | | using System.ComponentModel; |
| | |
| | | using System.Reflection; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | using WIDESEAWCS_Common.LocationEnum; |
| | | using WIDESEAWCS_Common.ServiceLog; |
| | | using WIDESEAWCS_Common.TaskEnum; |
| | | using WIDESEAWCS_Core; |
| | | using WIDESEAWCS_Core.BaseRepository; |
| | | using WIDESEAWCS_Core.BaseServices; |
| | | using WIDESEAWCS_Core.Enums; |
| | | using WIDESEAWCS_Core.Helper; |
| | | using WIDESEAWCS_DTO.TaskInfo; |
| | | using WIDESEAWCS_IBasicRepository; |
| | | using WIDESEAWCS_ITaskInfoRepository; |
| | | using WIDESEAWCS_ITaskInfoService; |
| | | using WIDESEAWCS_Model.Models; |
| | |
| | | private readonly IRouterService _routerService; |
| | | private readonly ITaskExecuteDetailService _taskExecuteDetailService; |
| | | private readonly ITaskExecuteDetailRepository _taskExecuteDetailRepository; |
| | | private readonly ILocationInfoRepository _locationInfoRepository; |
| | | private readonly IMapper _mapper; |
| | | private readonly IUnitOfWorkManage _unitOfWorkManage; |
| | | |
| | | private Dictionary<string, OrderByType> _taskOrderBy = new() |
| | | { |
| | |
| | | |
| | | public List<int> TaskOutboundTypes => typeof(TaskOutboundTypeEnum).GetEnumIndexList(); |
| | | |
| | | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper) : base(BaseDal) |
| | | public List<int> TaskRelocationboundTypes => typeof(TaskRelocationTypeEnum).GetEnumIndexList(); |
| | | |
| | | public List<int> TaskOtherboundTypes => typeof(TaskOtherTypeEnum).GetEnumIndexList(); |
| | | |
| | | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ILocationInfoRepository locationInfoRepository, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) |
| | | { |
| | | _routerService = routerService; |
| | | _taskExecuteDetailService = taskExecuteDetailService; |
| | | _taskExecuteDetailRepository = taskExecuteDetailRepository; |
| | | _mapper = mapper; |
| | | _locationInfoRepository = locationInfoRepository; |
| | | _unitOfWorkManage = unitOfWorkManage; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | return content; |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ¥æ¶MESä»»å¡ä¿¡æ¯ |
| | | /// </summary> |
| | | /// <param name="taskDTO">MESä»»å¡å¯¹è±¡</param> |
| | | /// <returns>è¿åå¤çç»æ</returns> |
| | | public WebResponseContent ReceiveMESTask([NotNull] MESTaskDTO taskDTO) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | string inparam = JsonConvert.SerializeObject(taskDTO); |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ReceiveMESTaskæ¹æ³å
¥å{inparam}"); |
| | | Dt_Task task = new Dt_Task(); |
| | | Dt_Task taskinfo = BaseDal.QueryFirst(x => x.TaskNum == taskDTO.task_id); |
| | | if(taskDTO.cmd==101)//妿æ¯101ææ§çä»»å¡å·å»æ¥ |
| | | { |
| | | taskinfo = BaseDal.QueryFirst(x => x.TaskNum == taskDTO.weight); |
| | | } |
| | | |
| | | if (taskDTO.cmd!=3001&& taskDTO.cmd != 101 && taskinfo != null) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ä»»å¡å·éå¤ï¼ä»»å¡å·ï¼{taskDTO.task_id}"); |
| | | return content = WebResponseContent.Instance.Error($"ä»»å¡å·éå¤ï¼ä»»å¡å·ï¼{taskDTO.task_id}"); |
| | | } |
| | | Dt_LocationInfo locationsrc = _locationInfoRepository.QueryFirst(x => x.Remark == taskDTO.src_station.ToString()); |
| | | Dt_LocationInfo locationdsc = _locationInfoRepository.QueryFirst(x => x.Remark == taskDTO.dest_station.ToString()); |
| | | switch (taskDTO.cmd) |
| | | { |
| | | case 1001://AGV请æ±å
¥åº |
| | | task.TaskType = (int)TaskInboundTypeEnum.Inbound; |
| | | task.TaskState = (int)TaskInStatusEnum.InNew; |
| | | task.Roadway = "SC01"; |
| | | task.Grade = 2; |
| | | task.WMSId = 0;//表示èªå¨å
¥åº |
| | | if (locationsrc != null) |
| | | { |
| | | task.SourceAddress = locationsrc.LocationCode; |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | break; |
| | | case 3001://AGVæ¾è´§å®æ WMSå3001çåæ¶ä¼åæåä¿¡å· |
| | | if (BaseDal.QueryFirst(x => x.TaskNum == taskDTO.task_id) == null)//æå¨å
¥åºç´æ¥å3001ï¼éè¦çæä»»å¡ï¼å 为没æ1001ç¯è |
| | | { |
| | | |
| | | task.TaskType = (int)TaskInboundTypeEnum.Inbound; |
| | | task.TaskState = (int)TaskInStatusEnum.AGV_InExecuting; |
| | | task.Roadway = "SC01"; |
| | | task.WMSId = 1;//表示æå¨å
¥åº |
| | | task.Grade = 2; |
| | | if (locationsrc != null) |
| | | { |
| | | task.SourceAddress = locationsrc.LocationCode; |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | if (taskinfo != null) |
| | | { |
| | | UpdateTaskStatus(taskinfo.TaskId, (int)TaskInStatusEnum.AGV_InExecuting); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"AGVå
¥åºæ§è¡ä¸"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVå
¥åºæ§è¡ä¸ï¼èªå¨3001ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | return content = WebResponseContent.Instance.OK($"AGVå
¥åºæ§è¡ä¸ï¼èªå¨3001ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error($"AGVå
¥åºæ§è¡ä¸ï¼èªå¨3001ï¼æ´æ°ç¶ææ¶ï¼æ¥è¯¢ä¸å°ä»»å¡å·"); |
| | | |
| | | } |
| | | } |
| | | break; |
| | | case 101://æåæºæå宿 |
| | | if (taskinfo != null) |
| | | { |
| | | //æ´æ°ä»»å¡è¡¨ä¸NextAddressåæ®µä¸ºæ°çä»»å¡å· taskDTO.weight-æ§çä»»å¡å· taskDTO.task_id-æ°çä»»å¡å· |
| | | UpdateTaskStatus(taskinfo.TaskId, taskDTO.task_id, (int)TaskInStatusEnum.AGV_InFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"AGVæ¬è¿å®æ"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | return content = WebResponseContent.Instance.OK($"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææ¶ï¼æ¥è¯¢ä¸å°ä»»å¡å·"); |
| | | return content = WebResponseContent.Instance.Error($"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææ¶ï¼æ¥è¯¢ä¸å°ä»»å¡å·"); |
| | | } |
| | | break; |
| | | |
| | | case 103://产åç§»åºï¼ç§»åºï¼åºåºï¼ |
| | | task.TaskType= (int)TaskRelocationTypeEnum.Relocation; |
| | | task.TaskState = (int)TaskOutStatusEnum.OutNew; |
| | | task.Roadway = "SC01"; |
| | | task.Grade = 1; |
| | | break; |
| | | case 102: |
| | | if(taskDTO.dest_station ==1003)//空车åºåº æåä½-->è¾é线 |
| | | { |
| | | task.TaskType = (int)TaskOutboundTypeEnum.OutPick; |
| | | task.TaskState = (int)TaskOutStatusEnum.OutNew; |
| | | task.Roadway = "SC01"; |
| | | task.Grade = 1; |
| | | } |
| | | else if(taskDTO.dest_station ==1001|| taskDTO.dest_station == 1002)//å¼å¸¸åºåº |
| | | { |
| | | task.TaskType = (int)TaskOutboundTypeEnum.OutInventory; |
| | | task.TaskState = (int)TaskOutStatusEnum.OutNew; |
| | | task.Roadway = "SC01"; |
| | | task.Grade = 1; |
| | | } |
| | | if (locationdsc != null) |
| | | { |
| | | task.TargetAddress = locationdsc.LocationCode; |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | break; |
| | | case 104://ç»ç«æºä¸æ æåä½-->ç»ç«æº |
| | | { |
| | | task.TaskType = (int)TaskOtherTypeEnum.Feed; |
| | | task.TaskState = (int)TaskOutStatusEnum.OutNew; |
| | | task.Grade = 1; |
| | | task.Remark = taskDTO.total.ToString()+"-"+taskDTO.startIndex.ToString();//忻屿°åå½å屿° |
| | | //ä¸ä¼ä¼ ç»ç«æºä¸æç«ç¹ï¼åªä¼ä¼ æååºä½ï¼éæ ¹æ®æååºä½å»æ¥è´§ä½è¡¨ä¸çç»ç«æºç«ç¹åºä½å· |
| | | |
| | | Dt_LocationInfo locationtemp = _locationInfoRepository.QueryFirst(x => x.Row==taskDTO.src_rack&&x.Column==taskDTO.src_col&&x.Layer==taskDTO.src_row); |
| | | if (locationtemp != null) |
| | | { |
| | | task.TargetAddress = locationtemp.Remark; |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{task.TargetAddress.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{task.TargetAddress.ToString()}"); |
| | | } |
| | | //æ ¹æ®ç®æ å°åï¼ç»ç«æºï¼æ¥è¯¢é»è®¤çæ§è¡ä»»å¡çå°å åæºç¼å· |
| | | Dt_LocationInfo locationtemp2 = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress.ToString()); |
| | | if (locationtemp2 != null) |
| | | { |
| | | task.Roadway = locationtemp2.Remark.Trim();//ç¡®å®é»è®¤æ§è¡ä»»å¡çå°å åæºç¼å· |
| | | } |
| | | else |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç»ç«æºå¯¹åºçé»è®¤å°å åæºé
ç½®"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç»ç«æºå¯¹åºçé»è®¤å°å åæºé
ç½®"); |
| | | } |
| | | |
| | | } |
| | | |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | |
| | | task.TaskNum = taskDTO.task_id; |
| | | task.PalletCode = taskDTO.CarId; |
| | | |
| | | if (string.IsNullOrEmpty(task.SourceAddress))//妿䏿¯ç«ç¹ï¼ç´æ¥åè¡åå± |
| | | { |
| | | task.SourceAddress = $"SC01-{taskDTO.src_rack.ToString().PadLeft(3, '0')}-{taskDTO.src_col.ToString().PadLeft(3, '0')}-{taskDTO.src_row.ToString().PadLeft(3, '0')}"; |
| | | } |
| | | if(string.IsNullOrEmpty(task.TargetAddress))//妿䏿¯ç«ç¹ï¼ç´æ¥åè¡åå± |
| | | { |
| | | task.TargetAddress = $"SC01-{taskDTO.dest_rack.ToString().PadLeft(3, '0')}-{taskDTO.dest_col.ToString().PadLeft(3, '0')}-{taskDTO.dest_row.ToString().PadLeft(3, '0')}"; |
| | | } |
| | | task.Creater = "MES"; |
| | | |
| | | //å¤æè´§ä½ç¶æ |
| | | Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | Dt_LocationInfo tarLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | if (srcLocation != null && tarLocation != null) |
| | | { |
| | | if (srcLocation.EnableStatus == (int)EnableStatusEnum.Disable) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æºå°åå·²ç¦ç¨ï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"æºå°åå·²ç¦ç¨ï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if (tarLocation.EnableStatus == (int)EnableStatusEnum.Disable) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç®æ å°åå·²ç¦ç¨ï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç®æ å°åå·²ç¦ç¨ï¼{tarLocation.LocationCode}"); |
| | | } |
| | | if (taskDTO.cmd != 101)//å
¥åºæ¶ä¸éè¦å¤ææ¯å¦éå®ï¼éå®ç¶ææ¯å¨çæä»»å¡æ¶éå® |
| | | { |
| | | |
| | | if (taskinfo != null && taskDTO.cmd==3001&&taskinfo.WMSId==1)//å¦ææ¯æå¨å
¥åºï¼å3001ï¼ä¼çæä»»å¡ï¼éè¦å¤æåºä½æ¯å¦éå®;èªå¨æ¨¡å¼å1001çæ¶åå°±çæäºä»»å¡ï¼åå3001å°±ä¸éè¦å¤ææ¯å¦éå®äº |
| | | { |
| | | if (srcLocation.LocationStatus == (int)LocationStatusEnum.Lock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æºå°åå·²éå®ï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"æºå°åå·²éå®ï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if (tarLocation.LocationStatus == (int)LocationStatusEnum.Lock) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç®æ å°åå·²éå®ï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç®æ å°åå·²éå®ï¼{tarLocation.LocationCode}"); |
| | | } |
| | | } |
| | | } |
| | | if (task.TaskType == (int)TaskInboundTypeEnum.Inbound)//å
¥åº è·¯å¾ï¼æåæºåºä½-->åºä½ |
| | | { |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâ空é²â并䏿ªç¦ç¨ï¼éå®åºä½ä¿®æ¹åºä½ç¶æä¸ºâéå®âï¼çæWCS产åå
¥åºä»»å¡ï¼å å
¥WCSä»»å¡éåä¸ã |
| | | if (tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"å
¥åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"å
¥åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{tarLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | tarLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | |
| | | //if (srcLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | //{ |
| | | // return content = WebResponseContent.Instance.Error($"å
¥åº-æºå°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | //} |
| | | |
| | | |
| | | |
| | | } |
| | | else if (task.TaskType == (int)TaskRelocationTypeEnum.Relocation) //产åç§»åºï¼ç§»åºï¼åºåºå
±ç¨ï¼ è·¯å¾ï¼åºä½-->åºä½/æååºä½ |
| | | { |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâæè´§âï¼åºä½/æååºä½æ¯å¦â空é²â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç§»åº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç§»åº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if(tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç§»åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç§»åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | tarLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | |
| | | } |
| | | else if (task.TaskType == (int)TaskOutboundTypeEnum.OutInventory) //å¼å¸¸åºåºï¼éåºï¼ è·¯å¾ï¼åºä½-->æåæºåºä½ |
| | | { |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"å¼å¸¸åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"å¼å¸¸åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | //tarLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | //if (tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | //{ |
| | | // return content = WebResponseContent.Instance.Error($"å¼å¸¸åºåº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | //} |
| | | |
| | | } |
| | | else if (task.TaskType == (int)TaskOutboundTypeEnum.OutPick) //空车åºåº è·¯å¾ï¼æååºä½-->è¾é线 |
| | | { |
| | | //WCSæ¥è¯¢æååºä½æ¯å¦âæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"空车åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"空车åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | //tarLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | //if (tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | //{ |
| | | // return content = WebResponseContent.Instance.Error($"空车åºåº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | //} |
| | | } |
| | | else if (task.TaskType == (int)TaskOtherTypeEnum.Feed) //䏿 è·¯å¾ï¼æåä½-->ç»ç«æº |
| | | { |
| | | //WCSæ¥è¯¢æååºä½æ¯å¦âæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"䏿任å¡-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"䏿任å¡-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | //tarLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | | |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"åºä½å°åä¸åå¨ï¼ä»»å¡å·:{task.TaskNum}"); |
| | | return content = WebResponseContent.Instance.Error($"åºä½å°åä¸åå¨ï¼ä»»å¡å·:{task.TaskNum}"); |
| | | } |
| | | |
| | | |
| | | |
| | | try |
| | | { |
| | | //å¼å¯äºç© |
| | | _unitOfWorkManage.BeginTran(); |
| | | _locationInfoRepository.UpdateData(tarLocation); |
| | | _locationInfoRepository.UpdateData(srcLocation); |
| | | BaseDal.AddData(task); |
| | | Dt_Task tasktemp= BaseDal.QueryFirst(x => x.TaskNum ==task.TaskNum); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(tasktemp.TaskId, "æ¥æ¶MESä»»å¡"); |
| | | //æäº¤äºå¡ |
| | | _unitOfWorkManage.CommitTran(); |
| | | |
| | | } |
| | | catch (Exception) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | throw; |
| | | } |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æ¥æ¶ä»»å¡æåï¼ä»»å¡å·:{task.TaskNum}"); |
| | | content = WebResponseContent.Instance.OK($"æ¥æ¶ä»»å¡æåï¼ä»»å¡å·:{task.TaskNum}", task); |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"任塿¥æ¶é误,é误信æ¯:{ex.Message}"); |
| | | content = WebResponseContent.Instance.Error($"任塿¥æ¶é误,é误信æ¯:{ex.Message}"); |
| | | } |
| | | return content; |
| | | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ ¹æ®æçå·ãèµ·å§å°ååWMS请æ±ä»»å¡ |
| | | /// </summary> |
| | |
| | | return content; |
| | | } |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ ¹æ®è®¾å¤ç¼å·ãå½åå°åæ¥è¯¢è¾éçº¿æªæ§è¡çä»»å¡ |
| | | /// </summary> |
| | |
| | | /// <returns></returns> |
| | | public Dt_Task QueryExecutingConveyorLineTask(int taskNum, string nextAddress) |
| | | { |
| | | return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.NextAddress == nextAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); |
| | | //return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.NextAddress == nextAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); |
| | | return null; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | /// <returns></returns> |
| | | public Dt_Task QueryCompletedConveyorLineTask(int taskNum, string currentAddress) |
| | | { |
| | | return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InFinish || x.TaskState == (int)TaskOutStatusEnum.Line_OutFinish), TaskOrderBy); |
| | | //return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InFinish || x.TaskState == (int)TaskOutStatusEnum.Line_OutFinish), TaskOrderBy); |
| | | return null; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | /// <returns></returns> |
| | | public Dt_Task? QuertStackerCraneTask(string deviceNo, TaskTypeGroup? taskTypeGroup = null) |
| | | { |
| | | if(taskTypeGroup == null) |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); |
| | | if(taskTypeGroup.Value == TaskTypeGroup.InboundGroup) |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish, TaskOrderBy); |
| | | if(taskTypeGroup.Value == TaskTypeGroup.OutbondGroup) |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy); |
| | | //if(taskTypeGroup == null) |
| | | // return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); |
| | | //if(taskTypeGroup.Value == TaskTypeGroup.InboundGroup) |
| | | // return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish, TaskOrderBy); |
| | | //if(taskTypeGroup.Value == TaskTypeGroup.OutbondGroup) |
| | | // return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy); |
| | | return null; |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ ¹æ®è®¾å¤ç¼å·ãå½åå°åæç
§ä¼å
级以åå建æ¶é´æåºæ¥è¯¢ä»»å¡æ± æ°å¢çä»»å¡ |
| | | /// æ ¹æ®è®¾å¤ç¼å· æç
§ä¼å
级以åå建æ¶é´æåºæ¥è¯¢ä»»å¡æ± æ°å¢çä»»å¡ |
| | | /// </summary> |
| | | /// <param name="deviceNo">设å¤ç¼å·</param> |
| | | /// <param name="currentAddress">å½åå°å</param> |
| | | /// <returns>è¿åä»»å¡å®ä½å¯¹è±¡ï¼å¯è½ä¸ºnull</returns> |
| | | public Dt_Task QueryStackerCraneTask(string deviceNo, string currentAddress = "") |
| | | public Dt_Task QueryStackerCraneTask(string deviceNo) |
| | | { |
| | | if (string.IsNullOrEmpty(currentAddress)) |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); |
| | | else |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.CurrentAddress == currentAddress && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.AGV_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew || TaskRelocationboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew || TaskOtherboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ¥è¯¢å°å åæºä»»å¡ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public Dt_Task QueryStackerCraneTask() |
| | | { |
| | | return BaseDal.QueryFirst(x => (x.Roadway =="SC02"|| x.Roadway == "SC03")&& x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ¥è¯¢å°å åæºåºåºå®æä»»å¡ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public Dt_Task QueryStackerCraneFinishTask() |
| | | { |
| | | return BaseDal.QueryFirst(x => (x.Roadway == "SC02" || x.Roadway == "SC03") && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish, TaskOrderBy); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ¥è¯¢å
¥åºä»»å¡ 对åºWMSè¯·æ± 1001-AGVè¯·æ±æ¯å¦å
计è¿å
¥ |
| | | /// </summary> |
| | | /// <param name="deviceNo"></param> |
| | | /// <returns></returns> |
| | | public Dt_Task QueryStackerCraneTaskByAGVRequest(string deviceNo) |
| | | { |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew), TaskOrderBy); |
| | | } |
| | | /// <summary> |
| | | /// 对åºWMSè¯·æ± 3001-AGVæ¾è´§å®æ |
| | | /// </summary> |
| | | /// <param name="deviceNo"></param> |
| | | /// <returns></returns> |
| | | public Dt_Task QueryStackerCraneTaskByAGVPutFinish(string deviceNo) |
| | | { |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.AGV_InExecuting), TaskOrderBy); |
| | | } |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ ¹æ®è®¾å¤ç¼å·ãå½åå°åæç
§ä¼å
级以åå建æ¶é´æåºæ¥è¯¢ä»»å¡æ± å
¥åºç±»åçæ°å¢çä»»å¡ |
| | |
| | | /// <returns>è¿åä»»å¡å®ä½å¯¹è±¡ï¼å¯è½ä¸ºnull</returns> |
| | | public Dt_Task QueryStackerCraneInTask(string deviceNo, string currentAddress = "") |
| | | { |
| | | if (string.IsNullOrEmpty(currentAddress)) |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish, TaskOrderBy); |
| | | else |
| | | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish && x.CurrentAddress == currentAddress, TaskOrderBy); |
| | | //if (string.IsNullOrEmpty(currentAddress)) |
| | | // return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish, TaskOrderBy); |
| | | //else |
| | | // return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish && x.CurrentAddress == currentAddress, TaskOrderBy); |
| | | return null; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | /// <summary> |
| | | /// æ´æ°ä»»å¡ç¶æä¿¡æ¯ï¼å¹¶åæ¥è³WMS |
| | | /// </summary> |
| | | /// <param name="taskNum">ä»»å¡å·</param> |
| | | /// <param name="taskId">ä»»å¡ID</param> |
| | | /// <param name="status">ä»»å¡ç¶æ</param> |
| | | public void UpdateTaskStatus(int taskNum, int status) |
| | | public void UpdateTaskStatus(int taskId, int status) |
| | | { |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskId == taskId); |
| | | if (task == null) return; |
| | | task.TaskState = status; |
| | | task.Modifier = "System"; |
| | | task.ModifyDate = DateTime.Now; |
| | | BaseDal.UpdateData(task); |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ´æ°ä»»å¡ç¶æä¿¡æ¯åæ°çä»»å¡å·ï¼1001ï¼3001æ¶ä¸æ ·ä»»å¡å·ï¼ |
| | | /// </summary> |
| | | /// <param name="taskId">ä»»å¡ID</param> |
| | | /// <param name="newtaskId">WMSæ°(101)çä»»å¡å·</param> |
| | | /// <param name="status">ä»»å¡ç¶æ</param> |
| | | public void UpdateTaskStatus(int taskId,int newtaskId, int status) |
| | | { |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskId == taskId); |
| | | if (task == null) return; |
| | | task.TaskState = status; |
| | | task.Modifier = "System"; |
| | | task.NextAddress = newtaskId.ToString(); |
| | | task.ModifyDate = DateTime.Now; |
| | | BaseDal.UpdateData(task); |
| | | } |
| | |
| | | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>(); |
| | | task.TaskState = nextStatus; |
| | | |
| | | if (task.TaskState == (int)TaskInStatusEnum.Line_InFinish) |
| | | //if (task.TaskState == (int)TaskInStatusEnum.Line_InFinish) |
| | | { |
| | | Random random = new Random(); |
| | | task.CurrentAddress = task.NextAddress; |
| | |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task == null) return WebResponseContent.Instance.Error($"æªæ¾å°è¯¥ä»»å¡ä¿¡æ¯,ä»»å¡å·:ã{taskNum}ã"); |
| | | |
| | | //å¼å¸¸åºåºã空车åºåº ç»ç¹ä¸ä¸æ · 1,å¼å¸¸åºåºï¼éåºï¼ è·¯å¾ï¼åºä½-->æåæºåºä½ 2,空车åºåº è·¯å¾ï¼æååºä½-->è¾é线 |
| | | if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup && task.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting) |
| | | { |
| | | List<Dt_Router> routers = _routerService.QueryNextRoutes(task.NextAddress, task.TargetAddress); |
| | | if (!routers.Any()) return WebResponseContent.Instance.Error($"æªæ¾å°è®¾å¤è·¯ç±ä¿¡æ¯"); |
| | | { |
| | | try |
| | | { |
| | | Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.SC_OutFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | |
| | | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskOutStatusEnum>(); |
| | | task.TaskState = nextStatus; |
| | | task.CurrentAddress = task.NextAddress; |
| | | task.NextAddress = routers.FirstOrDefault().ChildPosi; |
| | | task.ModifyDate = DateTime.Now; |
| | | task.Modifier = "System"; |
| | | BaseDal.UpdateData(task); |
| | | //å¼å¯äºç© |
| | | _unitOfWorkManage.BeginTran(); |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.OutFinish); |
| | | _locationInfoRepository.UpdateData(srcLocation); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡å®æ"); |
| | | //æäº¤äºå¡ |
| | | _unitOfWorkManage.CommitTran(); |
| | | //åºåºå®æï¼åä¼ WMS |
| | | //åä¼ å°WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | //todo 忥å°WMS |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | |
| | | //æä¸èèå¤ä¸ªåºåºå£ |
| | | |
| | | |
| | | } |
| | | //å
¥åº è·¯å¾ï¼æåæºåºä½-->åºä½ |
| | | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup && task.TaskState == (int)TaskInStatusEnum.SC_InExecuting) |
| | | { |
| | | //todo |
| | | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>(); |
| | | task.TaskState = nextStatus; |
| | | task.ModifyDate = DateTime.Now; |
| | | task.Modifier = "System"; |
| | | BaseDal.UpdateData(task); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºå
¥åºå®æ"); |
| | | |
| | | WMSTaskDTO taskDTO = new WMSTaskDTO() |
| | | try |
| | | { |
| | | TaskNum = Convert.ToInt32(DateTime.Now.ToString("HHmmss")), |
| | | Grade = 1, |
| | | PalletCode = task.PalletCode + "S", |
| | | RoadWay = "SC01", |
| | | SourceAddress = task.TargetAddress, |
| | | TargetAddress = "CLOutAreaA", |
| | | TaskState = (int)TaskOutStatusEnum.OutNew, |
| | | Id = 0, |
| | | TaskType = (int)TaskOutboundTypeEnum.Outbound |
| | | }; |
| | | Dt_LocationInfo tarLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | tarLocation.LocationStatus = (int)LocationStatusEnum.InStock;//åºä½ç¶ææ´æ°ä¸ºæè´§ |
| | | |
| | | content = ReceiveWMSTask(new List<WMSTaskDTO> { taskDTO }); |
| | | UpdateTaskStatus(task.TaskId, (int)TaskInStatusEnum.SC_InFinish); |
| | | |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºå
¥åºå®æ"); |
| | | //å¼å¯äºç© |
| | | _unitOfWorkManage.BeginTran(); |
| | | |
| | | UpdateTaskStatus(task.TaskId, (int)TaskInStatusEnum.InFinish); |
| | | |
| | | _locationInfoRepository.UpdateData(tarLocation); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å
¥åºä»»å¡å®æ"); |
| | | //æäº¤äºå¡ |
| | | _unitOfWorkManage.CommitTran(); |
| | | |
| | | //å
¥åºå®æï¼åä¼ MES å
¥åºå®æåä¼ task.NextAddress ä¹å101è¯·æ±æ¶åçæ°ä»»å¡å· |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = int.Parse(task.NextAddress), status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MESå
¥å:{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æå
¥åºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡å
¥åºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡å
¥åºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | } |
| | | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.RelocationGroup) |
| | | //ç§»åºä»»å¡ï¼ç§»åºï¼åºåºå
±ç¨ï¼ è·¯å¾ï¼åºä½-->åºä½/æååºä½ |
| | | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.RelocationGroup && task.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting) |
| | | { |
| | | //todo è°ç¨WMSç§»åºå®æ |
| | | try |
| | | { |
| | | Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | |
| | | Dt_LocationInfo tarLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | tarLocation.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.SC_OutFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | |
| | | //å¼å¯äºç© |
| | | _unitOfWorkManage.BeginTran(); |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.OutFinish); |
| | | _locationInfoRepository.UpdateData(srcLocation); |
| | | _locationInfoRepository.UpdateData(tarLocation); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡å®æ"); |
| | | //æäº¤äºå¡ |
| | | _unitOfWorkManage.CommitTran(); |
| | | //ç§»åºå®æï¼åä¼ MES |
| | | //åä¼ å°WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æåºåºä»»å¡ååä¼ MESå
¥å:{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | } |
| | | //䏿 |
| | | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OtherGroup) |
| | | { |
| | | try |
| | | { |
| | | Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | |
| | | |
| | | //å¼å¯äºç© |
| | | _unitOfWorkManage.BeginTran(); |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.SC_OutFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | //UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.OutFinish); |
| | | //_locationInfoRepository.UpdateData(srcLocation); |
| | | //_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡å®æ"); |
| | | //æäº¤äºå¡ |
| | | _unitOfWorkManage.CommitTran(); |
| | | //䏿宿ï¼åä¼ WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡åä¼ MESå
¥å{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | content = WebResponseContent.Instance.Error($"å°å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | //夿æ¯å¦å®æçæåä¸å±ï¼èªå¨çæç©ºè½¦åºåºä»»å¡ |
| | | string[] Levels = task.Remark.Split("-"); |
| | | if (Levels.Length == 2) |
| | | { |
| | | if (!string.IsNullOrEmpty(Levels[0])&& !string.IsNullOrEmpty(Levels[1])) |
| | | { |
| | | //妿å½åæå屿°çäºæ»å±æï¼å表示æè½¦ææç屿°åå® |
| | | if(Convert.ToInt16(Levels[0])== Convert.ToInt16(Levels[1])) |
| | | { |
| | | string[] SourceCodes = task.SourceAddress.Split("-"); |
| | | string startPlan = ""; |
| | | if (SourceCodes.Length == 4) |
| | | { |
| | | startPlan= "101"+ SourceCodes[2].Substring(1,2); |
| | | } |
| | | DeliveryPlan send = new DeliveryPlan { startPlan = startPlan, isQuit = false, CarId = task.PalletCode }; |
| | | string inparam2 = JsonConvert.SerializeObject(send); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡åä¼ MESå
¥å{inparam2}"); |
| | | ApiInvoke.DeliveryPlanCMD(send);//åè°MESæ¥å£çæç©ºè½¦åºåºä»»å¡ |
| | | //ææç屿°é½åå®ï¼éè¦ææåä½ç¶ææ¹ä¸ºç©ºé²ç¶æ |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | _locationInfoRepository.UpdateData(srcLocation); |
| | | } |
| | | |
| | | } |
| | | |
| | | } |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"å°å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡ç±»åé误,æªæ¾å°è¯¥ä»»å¡ç±»å,ä»»å¡å·:ã{taskNum}ã,ä»»å¡ç±»å:ã{task.TaskType}ã"); |
| | | throw new Exception($"ä»»å¡ç±»åé误,æªæ¾å°è¯¥ä»»å¡ç±»å,ä»»å¡å·:ã{taskNum}ã,ä»»å¡ç±»å:ã{task.TaskType}ã"); |
| | | } |
| | | content = WebResponseContent.Instance.OK(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡å®ææå,ä»»å¡å·:ã{taskNum}ã"); |
| | | content = WebResponseContent.Instance.OK($"ä»»å¡å®ææå,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã"); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã{ex.Message}"); |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã{ex.Message}"); |
| | | } |
| | | return content; |
| | | } |
| | |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | |
| | | |
| | | } |
| | | } |