| | |
| | | using NPOI.XSSF.UserModel; |
| | | using RYB_PTL_API; |
| | | using SqlSugar; |
| | | using System.Collections.Generic; |
| | | using System.Diagnostics; |
| | | using System.Diagnostics.CodeAnalysis; |
| | | using System.DirectoryServices.Protocols; |
| | | using System.Linq; |
| | |
| | | |
| | | public List<int> TaskRelocationTypes => typeof(TaskTypeEnum).GetEnumIndexList().Where(x => x >= 900 && x < 1000).ToList(); |
| | | |
| | | public TaskService(ITaskRepository BaseDal, IMapper mapper, ICacheService cacheService, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IStationMangerRepository stationMangerRepository, IRouterRepository routerRepository, IApiInfoRepository apiInfoRepository,ILocationInfoRepository locationInfoRepository,IUnitOfWorkManage unitOfWorkManage, ILocationInfoService locationInfoService,ILocationStatusChangeRecordService locationStatusChangeRecordService,IErrorInfoRepository errorInfoRepository) : base(BaseDal) |
| | | public TaskService(ITaskRepository BaseDal, IMapper mapper, ICacheService cacheService, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IStationMangerRepository stationMangerRepository, IRouterRepository routerRepository, IApiInfoRepository apiInfoRepository, ILocationInfoRepository locationInfoRepository, IUnitOfWorkManage unitOfWorkManage, ILocationInfoService locationInfoService, ILocationStatusChangeRecordService locationStatusChangeRecordService, IErrorInfoRepository errorInfoRepository) : base(BaseDal) |
| | | { |
| | | _mapper = mapper; |
| | | _cacheService = cacheService; |
| | |
| | | _locationInfoRepository = locationInfoRepository; |
| | | _unitOfWorkManage = unitOfWorkManage; |
| | | _locationInfoService = locationInfoService; |
| | | _locationStatusChangeRecordService=locationStatusChangeRecordService; |
| | | _locationStatusChangeRecordService = locationStatusChangeRecordService; |
| | | _errorInfoRepository = errorInfoRepository; |
| | | } |
| | | static object lock_taskReceive = new object(); |
| | |
| | | { |
| | | lock (lock_taskReceive) |
| | | { |
| | | WriteLog.Write_Log("å
¥åºä»»å¡ä¸å", "WMSå
¥åºä»»å¡æ¥æ¶åæ°", "æ¥æ¶åæ°", $"åæ°ï¼{taskDTO.ToJson()}"); |
| | | List<Dt_Task> tasks = new List<Dt_Task>(); |
| | | List<Dt_Task> taskOlds = BaseDal.QueryData(x=> taskDTO.Tasks.Select(x => x.TaskDescribe.ContainerCode).Contains(x.PalletCode)); |
| | | List<Dt_LocationInfo> locationInfos = _locationInfoRepository.GetCanOut(taskDTO.Tasks.Select(x=>x.TaskDescribe.ContainerCode).ToList()); |
| | | List<Dt_Task> taskOlds = BaseDal.QueryData(x => taskDTO.Tasks.Select(x => x.TaskDescribe.ContainerCode).Contains(x.PalletCode)); |
| | | List<Dt_LocationInfo> locationInfos = _locationInfoRepository.GetCanOut(taskDTO.Tasks.Select(x => x.TaskDescribe.ContainerCode).ToList()); |
| | | List<Dt_StationManger> stationMangers = _stationMangerRepository.QueryData(); |
| | | ////ä¸åä»»å¡ç» |
| | | //string taskGroup= taskDTO.TaskGroupCode.IsNullOrEmpty() ? Guid.NewGuid().ToString().Replace("-","") : taskDTO.TaskGroupCode; |
| | | foreach (var item in taskDTO.Tasks.OrderBy(x=>x.TaskDescribe.ToStationCode)) |
| | | foreach (var item in taskDTO.Tasks.OrderBy(x => x.TaskDescribe.ToStationCode)) |
| | | { |
| | | if (item.TaskDescribe.ToStationCode.IsNullOrEmpty()) throw new Exception($"ä»»å¡{item.TaskCode}åºåºç®æ æä½å°ä¸è½ä¸ºç©º"); |
| | | //è·åæä½å° |
| | | Dt_StationManger? stationManger = stationMangers.FirstOrDefault(x => x.PickStationCode == item.TaskDescribe.ToStationCode); |
| | | if (stationManger == null) throw new Exception($"ä»»å¡{item.TaskCode}åºåºç®æ æä½å°{item.TaskDescribe.ToStationCode}ä¸åå¨"); |
| | | Dt_Task? taskOld = taskOlds.FirstOrDefault(x=>x.PalletCode==item.TaskDescribe.ContainerCode); |
| | | Dt_Task? taskOld = taskOlds.FirstOrDefault(x => x.PalletCode == item.TaskDescribe.ContainerCode); |
| | | if (taskOld != null) |
| | | { |
| | | errorMsg += $"æç®±{taskOld.PalletCode}" + (taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() ? "å
¥åºä»»å¡å·²åå¨;" : "åºåºä»»å¡å·²åå¨;"); |
| | |
| | | errorMsg += $"æç®±{item.TaskDescribe.ContainerCode}ä¸åå¨;"; |
| | | content.FailData.Add(new BinCodeObj() { Bincode = item.TaskDescribe.ContainerCode }); |
| | | continue; |
| | | }; |
| | | } |
| | | Dt_LocationInfo? noOutLocation = locationInfos.FirstOrDefault(x => (x.LocationStatus != LocationStatusEnum.InStock.ObjToInt() || x.EnableStatus != EnableStatusEnum.Normal.ObjToInt()) && x.PalletCode == item.TaskDescribe.ContainerCode); |
| | | if (noOutLocation != null) |
| | | { |
| | |
| | | |
| | | locationInfos.ForEach(x => |
| | | { |
| | | x.LocationStatus=LocationStatusEnum.Lock.ObjToInt(); |
| | | x.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); |
| | | }); |
| | | //æ·»å 任塿´æ°è´§ä½æ°æ® |
| | | _unitOfWorkManage.BeginTran(); |
| | |
| | | _locationInfoRepository.UpdateData(locationInfos); |
| | | _unitOfWorkManage.CommitTran(); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(tasks.Select(x => x.TaskNum).ToList(), "æ¥æ¶WMSä»»å¡"); |
| | | if (tasks.Count>0) |
| | | if (tasks.Count > 0) |
| | | { |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfos, LocationStatusEnum.InStock, LocationStatusEnum.Lock, LocationChangeType.OutboundAssignLocation, tasks); |
| | | } |
| | | content.OK(errorMsg.IsNullOrEmpty()? "æå": errorMsg); |
| | | content.OK(errorMsg.IsNullOrEmpty() ? "æå" : errorMsg); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// 容å¨å
¥åºåå»ºä»»å¡ |
| | | /// </summary> |
| | |
| | | Dt_LocationInfo? locationInfo = locationInfos.FirstOrDefault(x => x.PalletCode == containerFlowDTO.ContainerCode); |
| | | if (locationInfo != null) throw new Exception($"åºä½æç®±å·{containerFlowDTO.ContainerCode}å·²åå¨"); |
| | | Dt_Task taskOld = BaseDal.QueryFirst(x => x.PalletCode == containerFlowDTO.ContainerCode); |
| | | if (taskOld !=null && taskOld.PalletCode == containerFlowDTO.ContainerCode && taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() && taskOld.TaskState == TaskStatusEnum.CL_Executing.ObjToInt() && taskOld.DeviceCode == deviceCode) |
| | | if (taskOld != null && taskOld.PalletCode == containerFlowDTO.ContainerCode && taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() && taskOld.TaskState == TaskStatusEnum.CL_Executing.ObjToInt() && taskOld.DeviceCode == deviceCode) |
| | | { |
| | | Thread.Sleep(500); |
| | | return content.OK(); |
| | | } |
| | | if (taskOld != null && taskOld.PalletCode == containerFlowDTO.ContainerCode && taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() && taskOld.TaskState == TaskStatusEnum.CL_Executing.ObjToInt() && taskOld.DeviceCode != deviceCode) |
| | |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(new List<int>() { taskOld.TaskNum }, $"{oldSlotCode}æ¢è³{containerFlowDTO.SlotCode}å
¥åº"); |
| | | return content.OK(); |
| | | } |
| | | else if(taskOld != null) |
| | | else if (taskOld != null) |
| | | { |
| | | throw new Exception($"æç®±å·{containerFlowDTO.ContainerCode}" + (taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() ? "å
¥åºAGVæ§è¡ä¸": "åºåºAGVæ§è¡ä¸")); |
| | | throw new Exception($"æç®±å·{containerFlowDTO.ContainerCode}" + (taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() ? "å
¥åºAGVæ§è¡ä¸" : "åºåºAGVæ§è¡ä¸")); |
| | | } |
| | | Dt_LocationInfo? noInLocation = locationInfos.FirstOrDefault(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()); |
| | | if (noInLocation == null) throw new Exception($"å¯ç¨è´§ä½ä¸è¶³!"); |
| | |
| | | task.Roadway = noInLocation.RoadwayNo; |
| | | task.DeviceCode = stationManger.StationDeviceCode; |
| | | task.TaskState = TaskStatusEnum.CL_Executing.ObjToInt(); |
| | | |
| | | |
| | | //æ·»å ä»»å¡ |
| | | BaseDal.AddData(task); |
| | | int taskId = BaseDal.AddData(task); |
| | | if (type > 0) |
| | | { |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(new List<int>() { task.TaskNum }, "æå¨æé®å
¥åº"); |
| | |
| | | { |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(new List<int>() { task.TaskNum }, "å建å
¥åºä»»å¡"); |
| | | } |
| | | WriteLog.Write_Log("å
¥åºä»»å¡ä¸å", "容å¨å
¥åºä»»å¡æ·»å ä»»å¡", "æ·»å ä»»å¡", $"ä»»å¡ï¼{task.ToJson()}"); |
| | | content.OK("æå"); |
| | | } |
| | | catch (Exception ex) |
| | |
| | | /// ç³è¯·å
¥åº |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public WebResponseContent RequestInTask(string stationCode,string barCode) |
| | | public WebResponseContent RequestInTask(string stationCode, string barCode) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | lock (lock_requestInTask) |
| | | { |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.PalletCode == barCode && x.TaskType==TaskTypeEnum.Inbound.ObjToInt() && x.NextAddress == stationCode && x.TaskState == TaskStatusEnum.CL_Executing.ObjToInt()); |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.PalletCode == barCode && x.TaskType == TaskTypeEnum.Inbound.ObjToInt() && x.NextAddress == stationCode && x.TaskState == TaskStatusEnum.CL_Executing.ObjToInt()); |
| | | if (task == null) throw new Exception($"{barCode}æç®±æªæ¾å°ä»»å¡!"); |
| | | Dt_LocationInfo? locationInfo = _locationInfoService.AssignLocation(); |
| | | if (locationInfo == null) throw new Exception($"å¯ç¨è´§ä½ä¸è¶³!"); |
| | |
| | | _unitOfWorkManage.CommitTran(); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(new List<int>() { task.TaskNum }, $"åé
è´§ä½{locationInfo.LocationCode}"); |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Free, LocationStatusEnum.Lock, LocationChangeType.InboundAssignLocation, task.TaskNum); |
| | | WriteLog.Write_Log("å
¥åºä»»å¡ä¸å", "ç³è¯·å
¥åºæ¥å£", "æ´æ°ä»»å¡", $"ä»»å¡ï¼{task.ToJson()}"); |
| | | content.OK("æå"); |
| | | } |
| | | } |
| | |
| | | BaseDal.UpdateData(task); |
| | | |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task, task.ExceptionMessage); |
| | | |
| | | WriteLog.Write_Log("æ´æ°ä»»å¡å¼å¸¸ä¿¡æ¯", "æ´æ°ä»»å¡æ¥å£", "æ´æ°ä»»å¡", $"ä»»å¡ï¼{task.ToJson()}"); |
| | | content = WebResponseContent.Instance.OK(); |
| | | } |
| | | catch (Exception ex) |
| | |
| | | return content; |
| | | } |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ¥åWMSæå¨å®æä»»å¡ |
| | | /// </summary> |
| | |
| | | { |
| | | try |
| | | { |
| | | WriteLog.Write_Log("æ¥åWMSæå¨å®æä»»å¡", "æ¥åWMSæå¨å®æä»»å¡æ¥å£", "ä»»å¡å·", $"ä»»å¡å·ï¼{taskNum}"); |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task != null) |
| | | { |
| | |
| | | /// <returns></returns> |
| | | public WebResponseContent AgvTaskFlow(string code) |
| | | { |
| | | WebResponseContent content=new WebResponseContent(); |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | WriteLog.Write_Log("AGV任塿¾è¡", "AGV任塿¾è¡æ¥å£", "æç®±å·", $"æç®±ï¼{code}"); |
| | | string? url = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.AgvTaskFlow.ToString())?.ApiAddress; |
| | | if (string.IsNullOrEmpty(url)) throw new Exception($"{code},æªæ¾å°AGV任塿¾è¡æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | AgvTaskFlowDTO agvTaskFlowDTO = new AgvTaskFlowDTO() |
| | |
| | | }; |
| | | string request = JsonConvert.SerializeObject(agvTaskFlowDTO, settings); |
| | | string response = HttpHelper.Post(url, request); |
| | | WriteLog.Write_Log("AGV任塿¾è¡æ¥å£è¯·æ±AGV", "AGV任塿¾è¡æ¥å£", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | AgvResponseContent agvResponse = JsonConvert.DeserializeObject<AgvResponseContent>(response) ?? throw new Exception($"{code},æªæ¥æ¶å°AGV任塿¾è¡è¿åå¼"); |
| | | if (!agvResponse.Success) throw new Exception($"æç®±{code},AGV任塿¾è¡é误,ä¿¡æ¯:{agvResponse.Message}"); |
| | | content.OK(); |
| | |
| | | /// WMSæç®±å°è¾¾æ£éä½ä¸æ¥ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public WebResponseContent WMSPickUp(string stationCode,string pickCode) |
| | | public WebResponseContent WMSPickUp(string stationCode, string pickCode) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | WriteLog.Write_Log("WMSæç®±å°è¾¾æ£éä½ä¸æ¥", "WMSæç®±å°è¾¾æ£éä½ä¸æ¥ææ¥å£", "ä¿¡æ¯", $"æ£éä½ï¼{stationCode}ï¼æç®±ï¼{pickCode}"); |
| | | string? url = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMSPickArrivedUp.ToString())?.ApiAddress; |
| | | if (string.IsNullOrEmpty(url)) throw new Exception($"æªæ¾å°WMSæç®±å°è¾¾æ£éä½ä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | ContainerArriveDTO containerArriveDTO = new ContainerArriveDTO() |
| | |
| | | }; |
| | | string request = JsonConvert.SerializeObject(containerArriveDTO, settings); |
| | | string response = HttpHelper.Post(url, request); |
| | | WriteLog.Write_Log("䏿¥WMSæç®±å°è¾¾", "䏿¥WMSæç®±å°è¾¾", "ä¿¡æ¯", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | WMSResponseContent wMSResponse = JsonConvert.DeserializeObject<WMSResponseContent>(response) ?? throw new Exception($"{pickCode},æªæ¥æ¶å°WMSæç®±å°è¾¾æ£éä½ä¸æ¥è¿åå¼"); |
| | | if (wMSResponse.Code != "0") throw new Exception($"æç®±{pickCode}WMSæç®±å°è¾¾æ£éä½ä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"); |
| | | content.OK(); |
| | |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | WriteLog.Write_Log("ä»»å¡å®æ", "ä»»å¡å®ææ¥å£", "ä»»å¡å·", $"ä»»å¡ï¼{taskNum}"); |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)//åºåºä»»å¡å®æé»è¾ |
| | | { |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x=>x.PalletCode==task.PalletCode); |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.PalletCode == task.PalletCode); |
| | | if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | { |
| | | return content.Error($"{locationInfo.LocationCode}è´§ä½ç¶æä¸æ£ç¡®"); |
| | |
| | | CompleteType = 1 |
| | | }; |
| | | string request = JsonConvert.SerializeObject(containerInFinishDTO, settings); |
| | | |
| | | |
| | | _unitOfWorkManage.BeginTran(); |
| | | _locationInfoRepository.UpdateData(locationInfo); |
| | | BaseDal.DeleteAndMoveIntoHty(task, App.User?.UserId == 0 ? OperateTypeEnum.èªå¨å®æ : OperateTypeEnum.äººå·¥å®æ); |
| | |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Lock, LocationStatusEnum.Free, LocationChangeType.OutboundCompleted, task.TaskNum); |
| | | //è°ç¨æ¥å£ |
| | | string response = HttpHelper.Post(url, request); |
| | | WriteLog.Write_Log("WMSåºåºä»»å¡å®æåä¼ ", "ä»»å¡å®ææ¥å£", "ä»»å¡ä¿¡æ¯", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | WMSResponseContent wMSResponse = JsonConvert.DeserializeObject<WMSResponseContent>(response) ?? throw new Exception($"{taskNum},æªæ¥æ¶å°WMSåºåºä¸æ¥è¿åå¼"); |
| | | if (wMSResponse.Code != "0") content.Message=$"åºåºä»»å¡{task.TaskNum}WMSåºåºä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"; |
| | | if (wMSResponse.Code != "0") content.Message = $"åºåºä»»å¡{task.TaskNum}WMSåºåºä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"; |
| | | } |
| | | else if(task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup)//å
¥åºä»»å¡å®æé»è¾ |
| | | else if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup)//å
¥åºä»»å¡å®æé»è¾ |
| | | { |
| | | string? url = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMSInOutBoundBack.ToString())?.ApiAddress; |
| | | if (string.IsNullOrEmpty(url)) |
| | |
| | | CompleteType = 2 |
| | | }; |
| | | string request = JsonConvert.SerializeObject(containerInFinishDTO, settings); |
| | | |
| | | |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | { |
| | |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Lock, LocationStatusEnum.InStock, LocationChangeType.InboundCompleted, task.TaskNum); |
| | | //è°ç¨æ¥å£ |
| | | string response = HttpHelper.Post(url, request); |
| | | WriteLog.Write_Log("WMSå
¥åºä»»å¡å®æåä¼ ", "ä»»å¡å®ææ¥å£", "ä»»å¡ä¿¡æ¯", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | WMSResponseContent wMSResponse = JsonConvert.DeserializeObject<WMSResponseContent>(response) ?? throw new Exception($"{taskNum},æªæ¥æ¶å°WMSå
¥åºä¸æ¥è¿åå¼"); |
| | | if (wMSResponse.Code != "0") content.Message = $"å
¥åºä»»å¡{task.TaskNum}WMSå
¥åºä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"; |
| | | } |
| | |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | content.Error(ex.Message); |
| | | } |
| | | return content; |
| | | } |
| | | /// <summary> |
| | | /// 人工æå¨åæ¶æå®ä»»å¡ |
| | | /// </summary> |
| | | /// <param name="taskNum">ä»»å¡ç¼å·</param> |
| | | /// <returns>æä½ç»æ</returns> |
| | | public WebResponseContent ManualTaskCancellation(int taskNum) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | WriteLog.Write_Log("ä»»å¡åæ¶æ¥æ¶", "人工æå¨åæ¶æå®ä»»å¡", "ä»»å¡å·", $"ä»»å¡ï¼{taskNum}"); |
| | | // 1. è·åä»»å¡ä¿¡æ¯ |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task == null) return content.Error($"ä»»å¡{taskNum}ä¸åå¨"); |
| | | |
| | | TaskTypeGroup group = task.TaskType.GetTaskTypeGroup(); |
| | | if (group == TaskTypeGroup.InboundGroup)// å
¥åºä»»å¡åæ¶ |
| | | { |
| | | // è·åç®æ è´§ä½ |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | if (locationInfo == null) return content.Error($"ç®æ è´§ä½{task.TargetAddress}ä¸åå¨"); |
| | | // éªè¯è´§ä½ç¶æ |
| | | if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | return content.Error($"{task.TargetAddress}è´§ä½ç¶æå¼å¸¸ï¼æ æ³åæ¶"); |
| | | |
| | | // æ¢å¤è´§ä½ç¶æ |
| | | locationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt(); // æ¢å¤ä¸ºç©ºé²ç¶æ |
| | | locationInfo.PalletCode = ""; // æ¸
空æçå· |
| | | // æ´æ°æ°æ®åº |
| | | _unitOfWorkManage.BeginTran(); |
| | | _locationInfoRepository.UpdateData(locationInfo); |
| | | BaseDal.DeleteAndMoveIntoHty(task, OperateTypeEnum.人工å é¤); |
| | | _unitOfWorkManage.CommitTran(); |
| | | // è®°å½ç¶æåæ´ |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord( |
| | | locationInfo, |
| | | LocationStatusEnum.Lock, |
| | | LocationStatusEnum.Free, |
| | | LocationChangeType.InboundCancelled, |
| | | task.TaskNum |
| | | ); |
| | | content.OK("ä»»å¡åæ¶æå"); |
| | | } |
| | | else |
| | | { |
| | | content.Error("åªè½å
¥åºä»»å¡åæ¶ï¼"); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | content.Error($"åæ¶å¤±è´¥: {ex.Message}"); |
| | | // è®°å½è¯¦ç»é误 |
| | | _taskExecuteDetailService.AddTaskExecuteDetail( |
| | | new Dt_Task { TaskNum = taskNum }, |
| | | $"ä»»å¡åæ¶å¼å¸¸: {ex.Message}" |
| | | ); |
| | | } |
| | | return content; |
| | | } |
| | | /// <summary> |
| | | /// ä»»å¡åæ¶ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public WebResponseContent TaskCancelCompleted(int taskNum) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | WriteLog.Write_Log("ä»»å¡åæ¶æ¥æ¶", "ä»»å¡åæ¶æ¥å£", "ä»»å¡å·", $"ä»»å¡ï¼{taskNum}"); |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)//åºåºä»»å¡å®æé»è¾ |
| | | { |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.PalletCode == task.PalletCode); |
| | | if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | { |
| | | return content.Error($"{locationInfo.LocationCode}è´§ä½ç¶æä¸æ£ç¡®"); |
| | | } |
| | | task.TaskState = TaskStatusEnum.Cancel.ObjToInt(); |
| | | locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); |
| | | _unitOfWorkManage.BeginTran(); |
| | | _locationInfoRepository.UpdateData(locationInfo); |
| | | BaseDal.DeleteAndMoveIntoHty(task, App.User?.UserId == 0 ? OperateTypeEnum.èªå¨å®æ : OperateTypeEnum.äººå·¥å®æ); |
| | | _unitOfWorkManage.CommitTran(); |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Lock, LocationStatusEnum.InStock, LocationChangeType.InboundCompleted, task.TaskNum); |
| | | content.OK(); |
| | | } |
| | | else |
| | | { |
| | | content.Error($"æªæ¾å°åºåºä»»å¡{taskNum}"); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content.Error(ex.Message); |
| | | } |
| | | return content; |
| | | } |
| | | /// <summary> |
| | | /// ä»»å¡åæ¶ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public WebResponseContent TaskCancel(List<TaskCancel> taskCancels) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | // åæ°éªè¯ |
| | | if (taskCancels == null || taskCancels.Count == 0) |
| | | { |
| | | return content.Error("ä¼ å
¥åæ°ä¸è½ä¸ºç©º"); |
| | | } |
| | | |
| | | WriteLog.Write_Log("ä»»å¡åæ¶æ¥æ¶", "ä»»å¡åæ¶æ¥å£", "ä»»å¡åæ¶", $"ä»»å¡ï¼{taskCancels.ToJson()}"); |
| | | |
| | | // è·åææåºåºä»»å¡ï¼åªæ¥è¯¢ä¸æ¬¡ï¼ |
| | | List<Dt_Task> outTasks = BaseDal.QueryData(x => |
| | | x.TaskType == TaskTypeEnum.Outbound.ObjToInt()); |
| | | |
| | | if (outTasks.Count == 0) |
| | | { |
| | | return content.Error("æªæ¾å°å¯¹åºçä»»å¡"); |
| | | } |
| | | |
| | | // æGroupIdåç»å¤ç |
| | | var tasksByGroup = outTasks.GroupBy(x => x.GroupId) |
| | | .Where(g => !string.IsNullOrEmpty(g.Key)) |
| | | .ToDictionary(g => g.Key, g => g.ToList()); |
| | | |
| | | List<Dt_Task> cancelTasks = new List<Dt_Task>(); |
| | | List<Dt_Task> cancelTasksCompleted = new List<Dt_Task>(); |
| | | // æ¶éææéè¦æ£æ¥çä»»å¡ç» |
| | | var groupsToCheck = new List<List<Dt_Task>>(); |
| | | |
| | | foreach (var taskCancel in taskCancels) |
| | | { |
| | | // æ¾å°è¯¥ä»»å¡æå¨çç» |
| | | var group = tasksByGroup.Values.FirstOrDefault(g => |
| | | g.Any(t => t.PalletCode == taskCancel.ContainerCode)); |
| | | |
| | | if (group != null && !groupsToCheck.Contains(group)) |
| | | { |
| | | groupsToCheck.Add(group); |
| | | } |
| | | } |
| | | // éªè¯ä»»å¡ç¶æ |
| | | foreach (var group in groupsToCheck) |
| | | { |
| | | var firstTask = group.FirstOrDefault(); |
| | | if (firstTask == null) continue; |
| | | |
| | | // æ£æ¥ç»å
ææä»»å¡ç¶æ |
| | | foreach (var task in group) |
| | | { |
| | | if (task.TaskState == TaskStatusEnum.AGV_TakeFinish.ObjToInt()) |
| | | { |
| | | task.IsCancel = 1; |
| | | cancelTasks.Add(task); |
| | | } |
| | | else if (task.TaskState == TaskStatusEnum.AGV_Executing.ObjToInt()) |
| | | { |
| | | cancelTasksCompleted.Add(task); |
| | | } |
| | | else |
| | | { |
| | | return content.Error($"ä»»å¡åæ¶å¤±è´¥{task.PalletCode}ä»»å¡ç¶æä¸å¯åæ¶ï¼"); |
| | | } |
| | | } |
| | | } |
| | | //WriteLog.Write_Log("ä»»å¡åæ¶æ¥æ¶", "ä»»å¡åæ¶æ¥å£", "ä»»å¡åæ¶", $"ä»»å¡ï¼{taskCancels.ToJson()}"); |
| | | //if (taskCancels==null || taskCancels.Count<=0) |
| | | //{ |
| | | // return content.Error("ä¼ å
¥ä¸è½ä¸ºç©º"); |
| | | //} |
| | | ////è·åæææç®± |
| | | //List<Dt_Task> outTasks = BaseDal.QueryData(x=>x.TaskType==TaskTypeEnum.Outbound.ObjToInt()); |
| | | //List<Dt_Task> cancelTasks = new List<Dt_Task>(); |
| | | //List<Dt_Task> cancelTasksCompleted = new List<Dt_Task>(); |
| | | //HashSet<string> processedGroups = new HashSet<string>(); |
| | | ////夿æ¯å¦æä»»å¡åå¨ |
| | | //foreach (var item in taskCancels) |
| | | //{ |
| | | // Dt_Task? taskExist = outTasks.FirstOrDefault(x=>x.PalletCode == item.ContainerCode); |
| | | // if (taskExist==null) |
| | | // { |
| | | // content.Message += $"{item.ContainerCode}ä»»å¡ä¸åå¨"; |
| | | // WriteLog.Write_Log("ä»»å¡åæ¶æ¥æ¶", "ä»»å¡åæ¶æ¥å£", "ä»»å¡ä¸åå¨", $"ä»»å¡ï¼{item.ContainerCode}"); |
| | | // continue; |
| | | // } |
| | | // if (string.IsNullOrEmpty(taskExist.GroupId)) |
| | | // { |
| | | // continue; |
| | | // } |
| | | // processedGroups.Add(taskExist.GroupId); |
| | | // //if (taskExist.TaskState == TaskStatusEnum.AGV_TakeFinish.ObjToInt()) |
| | | // //{ |
| | | // // taskExist.IsCancel = 1; |
| | | // // cancelTasks.Add(taskExist); |
| | | // //} |
| | | // //else if(taskExist.TaskState == TaskStatusEnum.AGV_Executing.ObjToInt()) |
| | | // //{ |
| | | // // cancelTasksCompleted.Add(taskExist); |
| | | // //} |
| | | // //else |
| | | // //{ |
| | | // // return content.Error($"ä»»å¡åæ¶å¤±è´¥{item.TaskCode}ä»»å¡ç¶æä¸å¯åæ¶ï¼"); |
| | | // //} |
| | | //} |
| | | //// åæ¶æ´ä¸ªç» |
| | | //foreach(var processed in processedGroups) |
| | | //{ |
| | | // List<Dt_Task> groupTask = BaseDal.QueryData(x => x.TaskType == TaskTypeEnum.Outbound.ObjToInt() && x.GroupId == processed); |
| | | // foreach (var group in groupTask) |
| | | // { |
| | | // if (group.TaskState == TaskStatusEnum.AGV_TakeFinish.ObjToInt()) |
| | | // { |
| | | // group.IsCancel = 1; |
| | | // cancelTasks.Add(group); |
| | | // } |
| | | // else if (group.TaskState == TaskStatusEnum.AGV_Executing.ObjToInt()) |
| | | // { |
| | | // cancelTasksCompleted.Add(group); |
| | | // } |
| | | // else |
| | | // { |
| | | // return content.Error($"ä»»å¡åæ¶å¤±è´¥{group.PalletCode}ä»»å¡ç¶æä¸å¯åæ¶ï¼"); |
| | | // } |
| | | // } |
| | | //} |
| | | |
| | | _unitOfWorkManage.BeginTran(); |
| | | BaseDal.UpdateData(cancelTasks); |
| | | foreach (var item in cancelTasksCompleted) |
| | | { |
| | | WebResponseContent responseContent = TaskCancelCompleted(item.TaskNum); |
| | | if (!responseContent.Status) |
| | | { |
| | | throw new Exception(responseContent.Message); |
| | | } |
| | | } |
| | | _unitOfWorkManage.CommitTran(); |
| | | cancelTasks.AddRange(cancelTasksCompleted); |
| | | foreach (var item in cancelTasks) |
| | | { |
| | | AgvTaskCancelDTO agvTaskCancel = new AgvTaskCancelDTO() |
| | | { |
| | | RequestId = DateTime.Now.ToString("yyMMddHHmmssfff"), |
| | | MissionCode = item.GroupId, |
| | | ContainerCode = item.PalletCode, |
| | | Position = "", |
| | | CancelMode = "CTU_REDIRECT_START", |
| | | Reason = "" |
| | | }; |
| | | AgvCancelTask(agvTaskCancel); |
| | | } |
| | | content.OK(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content.Error(ex.Message); |
| | | } |
| | | return content; |
| | |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | public WebResponseContent WmsRecovery() |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | // å é¤ç¬¬ä¸ä¸ªå¼å¸¸ |
| | | // æå建æ¶é´ååºè·åç¬¬ä¸æ¡è®°å½ |
| | | var orderBy = new Dictionary<string, OrderByType> |
| | | { |
| | | { "CreateDate", OrderByType.Asc } |
| | | }; |
| | | Dt_ErrorInfo errorInfo = _errorInfoRepository.QueryFirst(x => true, orderBy); |
| | | if (errorInfo == null) |
| | | { |
| | | return content.Error("å½å没æå¼å¸¸ä»»å¡"); |
| | | } |
| | | // è·å第ä¸ä¸ªå¼å¸¸ï¼æå建æ¶é´æåºï¼ |
| | | _unitOfWorkManage.BeginTran(); |
| | | _errorInfoRepository.DeleteData(errorInfo); |
| | | _unitOfWorkManage.CommitTran(); |
| | | // 䏿¥æ¢å¤ |
| | | string? apiErrorBack = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMSErrorBack.ToString())?.ApiAddress; |
| | | if (string.IsNullOrEmpty(apiErrorBack)) throw new Exception($"æªæ¾å°WMSæ
é䏿¥,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | TaskError taskError = new TaskError() |
| | | { |
| | | MsgID = errorInfo.Id, |
| | | StationCode = errorInfo.StationCode, |
| | | MsgCode = 0, |
| | | Msg = "æ¢å¤" |
| | | }; |
| | | string reqErrorBack = JsonConvert.SerializeObject(taskError, settings); |
| | | HttpHelper.Post(apiErrorBack, reqErrorBack); |
| | | return content.OK(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | return content.Error(ex.Message); |
| | | throw new Exception(ex.Message); |
| | | } |
| | | } |
| | | } |
| | | } |