From 35b1af99c388b5f03b8bf8de53852e5b5e9e60c4 Mon Sep 17 00:00:00 2001
From: liulijun <liulijun@hnkhzn.com>
Date: 星期二, 31 三月 2026 14:08:21 +0800
Subject: [PATCH] 调整了货位详细信息悬浮窗的显示位置

---
 项目代码/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs |   35 +++++++++++++++++++++++++++++------
 1 files changed, 29 insertions(+), 6 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
index 45e4270..8a17d2e 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
@@ -59,13 +59,16 @@
                 // 鑾峰彇鎵�鏈夎鍗旾D
                 var orderIds = pageData.Rows.Select(o => o.Id).ToList();
                 
-                // 鎵归噺鏌ヨ鎵�鏈夊叧鑱旂殑鏄庣粏锛岃繃婊ゆ帀鐗╂枡缂栧彿涓虹┖鐨勬暟鎹�
+                // 鎵归噺鏌ヨ鎵�鏈夊叧鑱旂殑鏄庣粏锛屾寜OutSGOrderId鍗囧簭銆両d闄嶅簭鎺掑簭锛屼笌璁㈠崟鏄庣粏椤甸潰淇濇寔涓�鑷�
                 var allDetails = BaseDal.Db.Queryable<Dt_OutSGOrderDetail>()
-                    .Where(d => orderIds.Contains(d.OutSGOrderId) && !string.IsNullOrEmpty(d.MaterialNo))
+                    .Where(d => orderIds.Contains(d.OutSGOrderId))
+                    .OrderBy(d => d.OutSGOrderId)
+                    .OrderByDescending(d => d.Id)
                     .ToList();
                 
-                // 鎸夎鍗旾D鍒嗙粍
-                var detailsByOrderId = allDetails.GroupBy(d => d.OutSGOrderId).ToDictionary(g => g.Key, g => g.ToList());
+                // 鎸夎鍗旾D鍒嗙粍锛屾瘡缁勬槑缁嗘寜Id闄嶅簭鎺掑簭锛屼笌璁㈠崟鏄庣粏椤甸潰淇濇寔涓�鑷�
+                var detailsByOrderId = allDetails.GroupBy(d => d.OutSGOrderId)
+                    .ToDictionary(g => g.Key, g => g.OrderByDescending(d => d.Id).ToList());
                 
                 // 澶勭悊姣忎釜璁㈠崟
                 foreach (var order in pageData.Rows)
@@ -90,11 +93,29 @@
                         order.MaterialWides = uniqueWidths.Count == 1 
                             ? uniqueWidths[0] 
                             : string.Join("/", uniqueWidths);
+                        
+                        // 璁剧疆妤炲埆锛屽彧鏄剧ず涓�涓紙鍥犱负鎵�鏈夋鍒浉鍚岋級
+                        order.BoardFluteNos = details.FirstOrDefault()?.BoardFluteNo ?? "";
+                        
+                        // 璁剧疆鏄惁缂烘枡锛氬鏋滄湁浠讳綍涓�涓槑缁嗘槸缂烘枡鐘舵�侊紝灏辫缃负true
+                        // 寮曠敤WIDESEA_Common.OrderEnum鍛藉悕绌洪棿鏉ヤ娇鐢∣utOrderStatusEnum鏋氫妇
+                        order.IsLackMaterial = details.Any(d => d.OutSGOrderDetailStatus == 3); // 3鏄己鏂欑姸鎬佺殑鏋氫妇鍊�
+                        
+                        // 鐢熸垚鐗╂枡缂烘枡鐘舵�佸瓧绗︿覆锛氱墿鏂欑紪鍙�:鐘舵��,鐗╂枡缂栧彿:鐘舵��
+                        var materialLackStatus = new List<string>();
+                        foreach (var detail in details)
+                        {
+                            var isLack = detail.OutSGOrderDetailStatus == 3;
+                            materialLackStatus.Add($"{detail.MaterialNo}:{isLack.ToString().ToLower()}");
+                        }
+                        order.MaterialLackStatus = string.Join(",", materialLackStatus);
                     }
                     else
                     {
                         order.MaterialNos = "";
                         order.MaterialWides = "";
+                        order.IsLackMaterial = false;
+                        order.MaterialLackStatus = "";
                     }
                 }
             }
@@ -108,8 +129,8 @@
             try
             {
                 //鑾峰彇鎵�鏈夋帓绋嬪崟
-                List<Dt_OutSGOrder> outSGOrders = BaseDal.Db.Queryable<Dt_OutSGOrder>().Includes(x => x.Details).ToList();
-                List<Dt_OutSGOrderDetail> outSGOrderDetails= outSGOrders.SelectMany(x=>x.Details).ToList();
+                //List<Dt_OutSGOrder> outSGOrders = BaseDal.Db.Queryable<Dt_OutSGOrder>().Includes(x => x.Details).ToList();
+                //List<Dt_OutSGOrderDetail> outSGOrderDetails= outSGOrders.SelectMany(x=>x.Details).ToList();
                 ////鍒ゆ柇鍗曟嵁
                 //Dt_OutSGOrderDetail? ExistAddOutOrderDetail = outSGOrderDetails.FirstOrDefault(x => outOrderDTOs.Select(t => t.BoardMpsDetailId).Distinct().Contains(x.BoardMpsDetailId));
                 //if (ExistAddOutOrderDetail != null)
@@ -150,11 +171,13 @@
                     //鍒ゆ柇宸ュ崟鏄惁宸茬粡瀛樺湪
                     if (ExistOutSGOrder != null)
                     {
+                        outSGOrderDetail.Number = ExistOutSGOrder.Number;
                         ExistOutSGOrder.Details.Add(outSGOrderDetail);
                     }
                     else
                     {
                         Dt_OutSGOrder outSGOrder = _mapper.Map<Dt_OutSGOrder>(item);
+                        outSGOrderDetail.Number = outSGOrder.Number;
                         outSGOrder.Details = new List<Dt_OutSGOrderDetail>() { outSGOrderDetail };
                         AddOutSGOrders.Add(outSGOrder);
                     }

--
Gitblit v1.9.3