From 1f9a89458a66c12c1f7dfbceb2588ada8fbf16f4 Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期四, 13 十一月 2025 17:35:36 +0800
Subject: [PATCH] 新增移库页面与WebSocket支持,优化任务逻辑新增移库页面支持移库任务输入与提交。新增 WebSocket 支持(`websocket.js`、`WebSocketSetup.cs`),实现实时通信功能。 在任务状态枚举中新增 AGV 移库任务状`TaskStatusEnum.cs`)- 重构库存数据展示页面(`Home.vue`),新增数据总览与图表展示功能。 - 新增库存数据接口(`StockInfoService.cs`、`StockInfoController.cs`),支持库存统计与展示。 - 优化任务状态管理逻辑,支持 AGV 移库任务(`Dt_TaskService.cs`)。

---
 项目代码/WMS/WIDESEA_WMSServer/WIDESEA_OrderServices/Dt_ProductionOutboundOrderService.cs |   55 ++++++++++---------------------------------------------
 1 files changed, 10 insertions(+), 45 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_OrderServices/Dt_ProductionOutboundOrderService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_OrderServices/Dt_ProductionOutboundOrderService.cs"
index b727a2b..dbd4d68 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_OrderServices/Dt_ProductionOutboundOrderService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_OrderServices/Dt_ProductionOutboundOrderService.cs"
@@ -172,7 +172,7 @@
                                 MaterielCode = outboundOrderdetail.MaterielCode,
                                 Position = item.LocationCode,
                                 PalletCode = item.PalletCode,
-                                AreaId = Convert.ToInt32(requestOut.AreaId),
+                                AreaId = Convert.ToInt32(2),
                             };
                             taskDtos.Add(task);
                             item.StockInfoDetails.Where(x => x.MaterielCode == outboundOrderdetail.MaterielCode).FirstOrDefault().Status = (int)StockStateEmun.鍑哄簱閿佸畾;
@@ -193,45 +193,6 @@
                                     OutboundQuantity = x.OutboundQuantity,
                                 });
                             });
-
-                            item.StockInfoDetails.Where(x => x.OutboundQuantity == 0 || (x.Quantity - x.OutboundQuantity) > 0).ForEach(x =>
-                            {
-                                if(x.MaterielCode == outboundOrderdetail.MaterielCode)
-                                {
-                                    outDetails.Add(new Dt_OrderOutDetails()
-                                    {
-                                        OrderNo = "",
-                                        PalletCode = item.PalletCode,
-                                        OrderType = (int)OrderTypeEmun.璋冩嫧鍑哄簱鍗�,
-                                        ERPOrderId = "",
-                                        MaterielCode = x.MaterielCode,
-                                        MaterielName = x.MaterielName,
-                                        AllocateWarehouse = "WMS鍑哄簱缂撳瓨鍖�",
-                                        Warehouse = "鏅鸿兘绔嬪簱",
-                                        WareHouseId = "107",
-                                        AllocateWarehouseId = "205",
-                                        OutboundQuantity = x.Quantity - x.OutboundQuantity,
-                                    });
-                                }
-                                else
-                                {
-                                    outDetails.Add(new Dt_OrderOutDetails()
-                                    {
-                                        OrderNo = "",
-                                        PalletCode = item.PalletCode,
-                                        OrderType = (int)OrderTypeEmun.璋冩嫧鍑哄簱鍗�,
-                                        ERPOrderId = "",
-                                        MaterielCode = x.MaterielCode,
-                                        MaterielName = x.MaterielName,
-                                        AllocateWarehouse = "WMS鍑哄簱缂撳瓨鍖�",
-                                        Warehouse = "鏅鸿兘绔嬪簱",
-                                        WareHouseId = "107",
-                                        AllocateWarehouseId = "205",
-                                        OutboundQuantity = x.Quantity,
-                                    });
-                                }
-                                
-                            });
                         });
                         List<Dt_Task> taskNews = new List<Dt_Task>();
                         List<WMSTaskDTO> taskDTOs = new List<WMSTaskDTO>();
@@ -249,19 +210,17 @@
                         {
                             taskDTOs.Add(CreateTaskDTO(item));
                             var result1 = _taskService.UpdateLocationStatus(item.SourceAddress, LocationEnum.InStockDisable, item.TaskNum.Value, (int)StatusChangeTypeEnum.AutomaticOutbound);
-                            var result2 = _taskService.UpdateLocationStatus(item.TargetAddress, LocationEnum.Lock, item.TaskNum.Value, (int)StatusChangeTypeEnum.AutomaticOutbound);
                             locationStatusChangeRecords.AddRange(result1.Item1);
-                            locationStatusChangeRecords.AddRange(result2.Item1);
                             locations.AddRange(result1.Item2);
-                            locations.AddRange(result2.Item2);
                         }
-
+                        outboundOrder.OrderStatus = (int)OrderStateEmun.寮�濮�;
                         await _unitOfWorkManage.UseTranAsync(async () =>
                         {
                             _taskRepository.AddData(taskNews);
                             _stockInfoRepository.UpdateDataNav(result.Item1);
                             await _locationStatusChangeRecordRepository.AddDataAsync(locationStatusChangeRecords);
                             await _locationRepository.UpdateDataAsync(locations);
+                            BaseDal.UpdateData(outboundOrder);
                             _productionoutboundOrderDetailRepository.UpdateData(result.Item2);
                             _outDetailsRepository.AddData(outDetails);
                         });
@@ -290,7 +249,8 @@
                 Id = 0,
                 TaskType = task.TaskType,
                 AGVTaskNum = task.AGVTaskNum,
-                Remark = task.Remark
+                Remark = task.Remark,
+                Floor =task.Floor,
             };
         }
         public (List<DtStockInfo>, Dt_ProductionOutboundOrderDetail) AssignStockOutbound(Dt_ProductionOutboundOrderDetail outboundOrderdetail, List<StockSelectViewDTO> stockSelectViews)
@@ -346,11 +306,16 @@
 
             }
             outboundOrderdetail.OverOutQuantity = outboundOrderdetail.OrderQuantity - needQuantity;
+            outboundOrderdetail.NotOutQuantity = outboundOrderdetail.OrderQuantity - outboundOrderdetail.OverOutQuantity;
 
             if (outboundOrderdetail.OverOutQuantity != 0)
             {
                 outboundOrderdetail.OrderDetailStatus = (int)OrderStateEmun.寮�濮�;
             }
+            if (outboundOrderdetail.OverOutQuantity == outboundOrderdetail.OrderQuantity)
+            {
+                outboundOrderdetail.OrderDetailStatus = (int)OrderStateEmun.宸插畬鎴�;
+            }
             return (outStockNews, outboundOrderdetail);
         }
 

--
Gitblit v1.9.3