From b6837f097e9cdb2645368aed4ddb03f580c331e4 Mon Sep 17 00:00:00 2001 From: z8018 <1282578289@qq.com> Date: 星期一, 05 五月 2025 17:29:07 +0800 Subject: [PATCH] 1 --- 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs | 514 +++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 394 insertions(+), 120 deletions(-) diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" index 058e2e0..f0eb3c3 100644 --- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" +++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" @@ -15,39 +15,58 @@ *----------------------------------------------------------------*/ #endregion << 鐗� 鏈� 娉� 閲� >> +using System.Text; +using System.Threading.Tasks; using AutoMapper; +using HslCommunication; using HslCommunication.WebSocket; using SqlSugar; using WIDESEAWCS_BasicInfoRepository; using WIDESEAWCS_BasicInfoService; using WIDESEAWCS_Common; using WIDESEAWCS_Core; +using WIDESEAWCS_Core.BaseRepository; using WIDESEAWCS_Core.BaseServices; +using WIDESEAWCS_Core.Enums; using WIDESEAWCS_Core.Helper; +using WIDESEAWCS_DTO.BasicInfo; +using WIDESEAWCS_DTO.PlacedBlockDTO; using WIDESEAWCS_DTO.TaskInfo; using WIDESEAWCS_IBasicInfoRepository; +using WIDESEAWCS_IBasicInfoService; using WIDESEAWCS_ITaskInfoRepository; using WIDESEAWCS_ITaskInfoService; using WIDESEAWCS_Model.Models; using WIDESEAWCS_QuartzJob.Repository; +using static Dm.net.buffer.ByteArrayBuffer; namespace WIDESEAWCS_TaskInfoService { public class TaskService : ServiceBase<Dt_Task, ITaskRepository>, ITaskService { + private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly IMapper _mapper; private readonly IContainerRepository _containerRepository; private readonly IContainerItemRepository _containerItemRepository; private readonly WebSocketServer _webSocketServer; private readonly IOrderDetailsRepository _orderDetailsRepository; + private readonly IContainerService _containerService; + private readonly IOrderDetailsService _orderDetailsService; + private readonly IOrderrowsRepository _orderrowsRepository; + private readonly IOrderContainerRepository _orderContainerRepository; - public TaskService(ITaskRepository BaseDal, IMapper mapper, IContainerRepository containerRepository, IContainerItemRepository containerItemRepository, WebSocketServer webSocketServer, IOrderDetailsRepository orderDetailsRepository) : base(BaseDal) + public TaskService(ITaskRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IMapper mapper, IContainerRepository containerRepository, IContainerItemRepository containerItemRepository, WebSocketServer webSocketServer, IOrderDetailsRepository orderDetailsRepository, IContainerService containerService, IOrderDetailsService orderDetailsService, IOrderrowsRepository orderrowsRepository, IOrderContainerRepository orderContainerRepository) : base(BaseDal) { + _unitOfWorkManage = unitOfWorkManage; _mapper = mapper; _containerRepository = containerRepository; _containerItemRepository = containerItemRepository; _webSocketServer = webSocketServer; _orderDetailsRepository = orderDetailsRepository; + _containerService = containerService; + _orderDetailsService = orderDetailsService; + _orderrowsRepository = orderrowsRepository; + _orderContainerRepository = orderContainerRepository; } public Dt_Task? QueryAGantryUnExecuteTask(string gantryDeviceNo) @@ -65,14 +84,9 @@ return WebResponseContent.Instance.Error("鏈壘鍒拌鍗曟槑缁嗕俊鎭�"); } - Dt_Container putContainer = _containerRepository.QueryFirst(x => x.ContainerType == ContainerTypeEnum.PutContainer.ObjToInt()); - if (putContainer == null) - { - return WebResponseContent.Instance.Error("鏀捐揣浣嶇疆涓嶅瓨鍦�"); - } - - ContainerSize containerSize = new ContainerSize(1500, putContainer.ContainerWidth, putContainer.ContainerHeight); List<PlacedBlock> placedBlocks = new List<PlacedBlock>(); + + string putPosition = ""; for (int i = 0; i < orderDetails.Count; i++) { @@ -84,25 +98,107 @@ int width = Convert.ToInt32(orderDetails[i].Orderdetails_width); int height = Convert.ToInt32(orderDetails[i].Orderdetails_thickness); - TaskPosition taskPosition = new TaskPosition(); - taskPosition = GetTakePutPosition(length, width, height, containerSize, placedBlocks); - - PlacedBlock placedBlock = new PlacedBlock(new Point3D(taskPosition.PositionX, taskPosition.PositionY, taskPosition.PositionZ), length, width, height); - placedBlocks.Add(placedBlock); - - object obj = new + if (length < 300 || width < 50) { - x = taskPosition.PutCenterPositionX - containerSize.Length / 2, - y = taskPosition.PutCenterPositionY - containerSize.Width / 2, - z = taskPosition.PutCenterPositionZ, - length, - width, - height, - }; + continue; + } - _webSocketServer.PublishAllClientPayload(obj.Serialize()); + OrderInfo orderInfo = _orderDetailsService.GetOrderInfoByBarcode(orderDetails[i].Orderdetails_outid); - Thread.Sleep(100); + var (flag, taskPosition, message) = _containerService.GetPosition(orderInfo.OrderHeadId, orderInfo.OrderNo, length, width, height); + if (flag && taskPosition != null) + { + if (string.IsNullOrEmpty(putPosition)) + { + putPosition = taskPosition.PutPosition; + } + + if (putPosition != taskPosition.PutPosition) + { + continue; + } + + Dt_OrderContainer orderContainer = _orderContainerRepository.QueryFirst(x => x.OrderNo == orderInfo.OrderNo && x.ContainerCode == taskPosition.PutPosition); + + Dt_Container putContainer = _containerRepository.QueryFirst(x => x.ContainerCode == taskPosition.PutPosition); + if (putContainer == null) + { + //todo + throw new Exception("鏈壘鍒版斁璐т綅缃�"); + } + + bool isAdd = false; + if (orderContainer == null) + { + orderContainer = new Dt_OrderContainer() + { + OrderId = orderInfo.OrderHeadId, + ContainerCode = putContainer.ContainerCode, + ContainerId = putContainer.Id, + OrderNo = orderInfo.OrderNo, + }; + orderContainer.MaxLength = putContainer.ContainerLength; + isAdd = true; + } + + if (taskPosition != null) + { + Dt_ContainerItem dt_ContainerItem = new Dt_ContainerItem() + { + ContainerId = putContainer.Id, + ItemCode = orderInfo.Barcode, + ItemLength = length, + ItemWidth = width, + ItemHeight = height, + ItemPositionX = taskPosition.PositionX, + ItemPositionY = taskPosition.PositionY, + ItemPositionZ = taskPosition.PositionZ, + ItemRelaPositionX = taskPosition.PutPositionX, + ItemRelaPositionY = taskPosition.PutPositionY, + ItemRelaPositionZ = taskPosition.PutPositionZ, + ItemStatus = (int)ItemStatusEnum.Assigned, + ItemName = orderInfo.Barcode + }; + + Dt_Task dt_Task = new Dt_Task() + { + PalletCode = orderInfo.Barcode, + DeviceCode = putContainer.DeviceCode, + TaskState = (int)TaskStatusEnum.Gantry_Wait, + TaskType = 0, + SourceAddress = "", + TargetAddress = $"F06", + CurrentAddress = $"F06*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}", + NextAddress = $"{putContainer.ContainerCode}*{taskPosition.PutPositionX}*{taskPosition.PutPositionY}*{taskPosition.PutPositionZ}*{taskPosition.PositionR}", + ItemInfo = $"{length}*{width}*{height}", + Grade = 0, + }; + putContainer.ContainerStatus = ContainerStatusEnum.NonEmpty.ObjToInt(); + _unitOfWorkManage.BeginTran(); + BaseDal.AddData(dt_Task); + _containerRepository.UpdateData(putContainer); + _containerItemRepository.AddData(dt_ContainerItem); + if (isAdd) + { + _orderContainerRepository.AddData(orderContainer); + } + _unitOfWorkManage.CommitTran(); + + PlacedBlock placedBlock = new PlacedBlock(new Point3D(taskPosition.PositionX, taskPosition.PositionY, taskPosition.PositionZ), length > width ? length : width, width > length ? length : width, height); + placedBlocks.Add(placedBlock); + + object obj = new + { + x = taskPosition.PutCenterPositionX - putContainer.ContainerLength / 2, + y = taskPosition.PutCenterPositionY - putContainer.ContainerWidth / 2, + z = taskPosition.PutCenterPositionZ, + length, + width, + height, + }; + _webSocketServer.PublishAllClientPayload(obj.Serialize()); + } + } } } catch (Exception ex) @@ -118,91 +214,6 @@ } } - public TaskPosition GetTakePutPosition(int length, int width, int height, ContainerSize containerSize, List<PlacedBlock> placedBlocks) - { - try - { - PlaceBlockService placeBlockService = new PlaceBlockService(containerSize, placedBlocks); - - Point3D? point3D = placeBlockService.PlaceBlock(length, width, height); - if (point3D == null) - { - throw new Exception("鏀捐揣浣嶇疆宸叉弧"); - } - - //鏀捐揣浣嶇疆鏉挎潗涓績鐐� - Point3D putCenter = new Point3D(point3D.Value.X + length / 2, point3D.Value.Y + width / 2, point3D.Value.Z + height / 2); - - //鍙栬揣浣嶇疆鏉挎潗涓績鐐� - Point3D takeCenter = new Point3D(length / 2, width / 2, height / 2); - - //鍚哥洏闀�530 闂撮殧660 鏈�澶�920 鍚哥洏瀹�130 - - int positionR = 1; - - int takePositionX = 0; - int takePositionY = 0; - int takePositionZ = 0; - int putPositionX = 0; - int putPositionY = 0; - int putPositionZ = 0; - - //1.濡傛灉闀垮害澶т簬920锛屽搴﹀ぇ浜庣瓑浜�300锛屽垯鍙互浣跨敤鍙屽惛鐩樻í鍚戝惛鍙� - if (length > 920 && width >= 300) - { - // - Point3D deviceCenter = new Point3D(530 / 2, 920 / 2, 0); - - positionR = 1; - takePositionX = takeCenter.Y - deviceCenter.X; - takePositionY = takeCenter.X - deviceCenter.Y; - takePositionZ = 10; - - putPositionX = putCenter.Y - deviceCenter.X; - putPositionY = putCenter.X - deviceCenter.Y; - putPositionZ = point3D.Value.Z; // putCenter.Z /*+ 10*/; - } - else - { - positionR = 0; - Point3D deviceCenter = new Point3D(130 / 2, 530 / 2, 0); - takePositionX = takeCenter.Y - deviceCenter.X; - takePositionY = takeCenter.X - deviceCenter.Y; - takePositionZ = 10; - - putPositionX = putCenter.Y - deviceCenter.X; - putPositionY = putCenter.X - deviceCenter.Y; - putPositionZ = point3D.Value.Z; //putCenter.Z /*+ 10*/; - } - - TaskPosition taskPosition = new TaskPosition() - { - PositionR = positionR, - TakePositionX = takePositionX, - TakePositionY = takePositionY, - TakePositionZ = takePositionZ, - PutPositionX = putPositionX, - PutPositionY = putPositionY, - PutPositionZ = putPositionZ, - TakeCenterPositionX = takeCenter.X, - TakeCenterPositionY = takeCenter.Y, - TakeCenterPositionZ = takeCenter.Z, - PutCenterPositionX = putCenter.X, - PutCenterPositionY = putCenter.Y, - PutCenterPositionZ = putCenter.Z, - PositionX = point3D.Value.X, - PositionY = point3D.Value.Y, - PositionZ = point3D.Value.Z - }; - - return taskPosition; - } - catch (Exception ex) - { - throw new Exception(ex.Message); - } - } - public WebResponseContent CreateTask(string takePosition, string putPosition, string deviceCode, int length, int width, int height) { try @@ -213,19 +224,31 @@ return WebResponseContent.Instance.Error("鍙栬揣浣嶇疆涓嶅瓨鍦�"); } + List<Dt_Container> containers = _containerRepository.QueryData(x => x.DeviceCode == deviceCode && x.ContainerType == ContainerTypeEnum.PutContainer.ObjToInt()); + Dt_Container putContainer = _containerRepository.QueryFirst(x => x.ContainerCode == putPosition && x.ContainerType == ContainerTypeEnum.PutContainer.ObjToInt()); if (putContainer == null) { return WebResponseContent.Instance.Error("鏀捐揣浣嶇疆涓嶅瓨鍦�"); } + int edge = 0; + if (putContainer.ContainerNo == containers.Min(x => x.ContainerNo)) + { + edge = 1; + } + ContainerSize containerSize = new ContainerSize(putContainer.ContainerLength, putContainer.ContainerWidth, putContainer.ContainerHeight); List<Dt_ContainerItem> containerItems = _containerItemRepository.QueryData(x => x.ContainerId == putContainer.Id); - List<PlacedBlock> placedBlocks = containerItems.Select(x => new PlacedBlock(new Point3D(x.ItemPositionX, x.ItemPositionY, x.ItemPositionZ), x.ItemLength, x.ItemWidth, x.ItemHeight)).ToList(); + List<PlacedBlock> placedBlocks = containerItems.Select(x => new PlacedBlock(new Point3D(x.ItemPositionX, x.ItemPositionY, x.ItemPositionZ), x.ItemLength > x.ItemLength ? x.ItemLength : x.ItemWidth, x.ItemLength > x.ItemLength ? x.ItemWidth : x.ItemLength, x.ItemHeight)).ToList(); - TaskPosition taskPosition = GetTakePutPosition(length, width, height, containerSize, placedBlocks); + TaskPosition? taskPosition = _containerService.GetTaskPosition(length, width, height, containerSize, placedBlocks, edge); + if (taskPosition == null) + { + return WebResponseContent.Instance.Error("鏈壘鍒板悎閫傛斁缃綅缃�"); + } object obj = new { @@ -248,24 +271,27 @@ ItemLength = length, ItemWidth = width, ItemHeight = height, - ItemPositionX = taskPosition.PutPositionX, - ItemPositionY = taskPosition.PutPositionY, - ItemPositionZ = taskPosition.PutPositionZ, + ItemPositionX = taskPosition.PositionX, + ItemPositionY = taskPosition.PositionY, + ItemPositionZ = taskPosition.PositionZ, + ItemRelaPositionX = taskPosition.PutPositionX, + ItemRelaPositionY = taskPosition.PutPositionY, + ItemRelaPositionZ = taskPosition.PutPositionZ, ItemStatus = (int)ItemStatusEnum.Assigned, ItemName = code }; Dt_Task dt_Task = new Dt_Task() { - TaskNum = 1, PalletCode = code, - DeviceCode = deviceCode, + DeviceCode = putContainer.DeviceCode, TaskState = (int)TaskStatusEnum.Gantry_New, TaskType = 0, - SourceAddress = $"{takePosition}*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}", - TargetAddress = $"{putPosition}*{taskPosition.PutPositionX}*{taskPosition.PutPositionX}*{taskPosition.PutPositionZ}*{taskPosition.PositionR}", - CurrentAddress = $"{takePosition}*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}", - NextAddress = $"{putPosition}*{taskPosition.PutPositionX}*{taskPosition.PutPositionX}*{taskPosition.PutPositionZ}*{taskPosition.PositionR}", + SourceAddress = "", + TargetAddress = $"{takeContainer.ContainerNo}", + CurrentAddress = $"{takeContainer.ContainerCode}*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}", + NextAddress = $"{putContainer.ContainerCode}*{taskPosition.PutPositionX}*{taskPosition.PutPositionY}*{taskPosition.PutPositionZ}*{taskPosition.PositionR}", + ItemInfo = $"{length}*{width}*{height}", Grade = 0, }; @@ -279,5 +305,253 @@ return WebResponseContent.Instance.Error(ex.Message); } } + + public (bool, Dt_Task?, string) GenerateTask(OrderInfo orderInfo) + { + try + { + int length = Convert.ToInt32(orderInfo.Length); + int width = Convert.ToInt32(orderInfo.Width); + int height = Convert.ToInt32(orderInfo.Thickness); + + var (flag, taskPosition, message) = _containerService.GetPosition(orderInfo.OrderHeadId, orderInfo.OrderNo, length, width, height); + if (flag && taskPosition != null) + { + Dt_Container putContainer = _containerRepository.QueryFirst(x => x.ContainerCode == taskPosition.PutPosition); + if (putContainer == null) + { + return (false, null, "鏈壘鍒版斁璐т綅缃�"); + } + + Dt_Container? takeContainer = GetTakePosition(putContainer.DeviceCode); + if (takeContainer == null) + { + return (false, null, "鏈壘鍒板彇璐т綅缃�"); + } + + Dt_OrderContainer orderContainer = _orderContainerRepository.QueryFirst(x => x.OrderNo == orderInfo.OrderNo && x.ContainerCode == putContainer.ContainerCode); + + bool isAdd = false; + bool isUpdate = false; + if (orderContainer == null) + { + orderContainer = new Dt_OrderContainer() + { + OrderId = orderInfo.OrderHeadId, + ContainerCode = putContainer.ContainerCode, + ContainerId = putContainer.Id, + OrderNo = orderInfo.OrderNo, + }; + orderContainer.MaxLength = putContainer.ContainerLength; + isAdd = true; + } + + Dt_ContainerItem dt_ContainerItem = new Dt_ContainerItem() + { + ContainerId = putContainer.Id, + ItemCode = orderInfo.Barcode, + ItemLength = length, + ItemWidth = width, + ItemHeight = height, + ItemPositionX = taskPosition.PositionX, + ItemPositionY = taskPosition.PositionY, + ItemPositionZ = taskPosition.PositionZ, + ItemRelaPositionX = taskPosition.PutPositionX, + ItemRelaPositionY = taskPosition.PutPositionY, + ItemRelaPositionZ = taskPosition.PutPositionZ, + ItemStatus = (int)ItemStatusEnum.Assigned, + ItemName = orderInfo.Barcode, + Remark = $"{takeContainer.ContainerCode}*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}" + }; + + Dt_Task dt_Task = new Dt_Task() + { + PalletCode = orderInfo.Barcode, + DeviceCode = putContainer.DeviceCode, + TaskState = (int)TaskStatusEnum.Gantry_Wait, + TaskType = 0, + SourceAddress = "", + TargetAddress = $"{takeContainer.ContainerNo}", + CurrentAddress = $"{takeContainer.ContainerCode}*{taskPosition.TakePositionX}*{taskPosition.TakePositionY}*{taskPosition.TakePositionZ}*{taskPosition.PositionR}", + NextAddress = $"{putContainer.ContainerCode}*{taskPosition.PutPositionX}*{taskPosition.PutPositionY}*{taskPosition.PutPositionZ}*{taskPosition.PositionR}", + ItemInfo = $"{length}*{width}*{height}", + Grade = 0, + }; + putContainer.ContainerStatus = ContainerStatusEnum.NonEmpty.ObjToInt(); + _unitOfWorkManage.BeginTran(); + BaseDal.AddData(dt_Task); + _containerRepository.UpdateData(putContainer); + _containerItemRepository.AddData(dt_ContainerItem); + if (isAdd) + { + _orderContainerRepository.AddData(orderContainer); + } + else if (isUpdate) + { + _orderContainerRepository.UpdateData(orderContainer); + } + _unitOfWorkManage.CommitTran(); + + return (true, dt_Task, ""); + } + else + { + return (false, null, $"鏃犲彲鏀剧疆浣嶇疆,{orderInfo.Serialize()}"); + } + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return (false, null, $"閿欒,{ex.ExceptionToString()}"); + } + } + + public Dt_Container? GetTakePosition(string deviceCode) + { + Dictionary<string, OrderByType> orderby = new Dictionary<string, OrderByType>() { { nameof(Dt_Container.ContainerSort), OrderByType.Asc } }; + List<Dt_Container> containers = _containerRepository.QueryData(x => x.ContainerType == ContainerTypeEnum.TakeContainer.ObjToInt() && x.DeviceCode == deviceCode && x.ContainerEnable, orderby); + + try + { + if (containers == null || containers.Count == 0) + { + throw new Exception($"鏈壘鍒板搴旂殑鍙栬揣浣嶇疆,璁惧缂栧彿:{deviceCode}"); + } + + Dictionary<string, OrderByType> taskOrderby = new Dictionary<string, OrderByType>() { { nameof(Dt_Task.TaskNum), OrderByType.Desc } }; + Dt_Task task = BaseDal.QueryFirst(x => x.DeviceCode == deviceCode, taskOrderby); + if (task != null) + { + string? sourceCode = task.SourceAddress.Split("*").FirstOrDefault(); + if (!string.IsNullOrEmpty(sourceCode)) + { + Dt_Container? container = containers.FirstOrDefault(x => x.ContainerCode == sourceCode); + if (container != null) + { + int index = containers.IndexOf(container); + + if (index + 1 < containers.Count) + { + return containers[index + 1]; + } + else + { + return containers.FirstOrDefault(); + } + } + } + } + } + catch (Exception ex) + { + + } + return containers.FirstOrDefault(); + } + + public WebResponseContent TaskComplete(Dt_Task task) + { + try + { + task.TaskState = TaskStatusEnum.Gantry_Completed.ObjToInt(); + _unitOfWorkManage.BeginTran(); + OrderDetails orderDetails = _orderDetailsRepository.QueryFirst(x => x.Orderdetails_outid == task.PalletCode); + if (orderDetails != null) + { + orderDetails.Orderdetails_status = PalletingStatusEnmu.PalletingSuccess.ObjToInt(); + + Orderrows orderrows = _orderrowsRepository.QueryFirst(x => x.id == orderDetails.Orderrowsid); + if (orderrows != null) + { + orderrows.Orderrows_PalletNum = orderrows.Orderrows_PalletNum ?? 0 + 1; + + Dt_Container container = _containerRepository.QueryFirst(x => task.NextAddress.Contains(x.ContainerCode)); + + _orderDetailsRepository.UpdateData(orderDetails); + _orderrowsRepository.UpdateData(orderrows); + + try + { + List<string> containerItemCodes = _containerItemRepository.QueryData(x => x.ContainerId == container.Id).Select(x => x.ItemCode).ToList(); + + List<OrderDetails> totalDetails = _orderDetailsRepository.QueryData(x => x.Orderrowsid == orderrows.id); + List<OrderDetails> details = totalDetails.Where(x => x.Orderrowsid == orderrows.id && x.Orderdetails_status == PalletingStatusEnmu.PalletingSuccess.ObjToInt() && containerItemCodes.Contains(x.Orderdetails_outid)).ToList(); + + int sortedNum = totalDetails.Where(x => x.Orderrowsid == orderrows.id && x.Orderdetails_status == PalletingStatusEnmu.PalletingSuccess.ObjToInt()).Count(); + object data = new object(); + if (totalDetails.Count <= sortedNum) + { + data = new + { + stationCode = task.NextAddress.Split("*").FirstOrDefault(), + release = 1, + data = new + { + stationCode = task.NextAddress.Split("*").FirstOrDefault(), + orderTotalNum = totalDetails.Count, + sortedNum = sortedNum, + unsortedNum = totalDetails.Count - sortedNum, + stationSortedNum = details.Count, + orderId = orderrows.id, + orderData = new + { + orderCode = orderrows.Orderrows_orderid, + cusName = orderrows.Orderrows_customer, + orderName = orderrows.Orderrows_name, + batch = orderrows.Orderrows_batchid, + productName = "", + } + } + }; + } + else + { + data = new + { + stationCode = task.NextAddress.Split("*").FirstOrDefault(), + release = 0, + data = new + { + stationCode = task.NextAddress.Split("*").FirstOrDefault(), + orderTotalNum = totalDetails.Count, + sortedNum = sortedNum, + unsortedNum = totalDetails.Count - sortedNum, + stationSortedNum = details.Count, + orderId = orderrows.id, + orderData = new + { + orderCode = orderrows.Orderrows_orderid, + cusName = orderrows.Orderrows_customer, + orderName = orderrows.Orderrows_name, + batch = orderrows.Orderrows_batchid, + productName = "", + } + } + }; + } + List<WebSocketSession> webSocketSessions2 = _webSocketServer.OnlineSessions.ToList(); + List<WebSocketSession> webSocketSessions = _webSocketServer.OnlineSessions.Where(x => x.Url.Contains(task.DeviceCode ?? "")).ToList(); + foreach (var item in webSocketSessions) + { + _webSocketServer.SendClientPayload(item, data.Serialize()); + } + } + catch (Exception ex) + { + + } + } + } + + BaseDal.DeleteAndMoveIntoHty(task, App.User?.UserId > 0 ? OperateTypeEnum.浜哄伐瀹屾垚 : OperateTypeEnum.鑷姩瀹屾垚); + _unitOfWorkManage.CommitTran(); + return WebResponseContent.Instance.OK(); + } + catch (Exception ex) + { + _unitOfWorkManage.RollbackTran(); + return WebResponseContent.Instance.Error(ex.Message); + } + } } } -- Gitblit v1.9.3