From 5695f1eb41693f799de0c76efd22909df34ff6d0 Mon Sep 17 00:00:00 2001
From: Rodney Chen <rodney.chen@hotmail.com>
Date: 星期五, 27 十二月 2024 21:27:30 +0800
Subject: [PATCH] 优化标准上下架逻辑

---
 Tiger.Business.MES/Transaction/Position.cs |   45 +++++++++++++++++++++++++++------------------
 1 files changed, 27 insertions(+), 18 deletions(-)

diff --git a/Tiger.Business.MES/Transaction/Position.cs b/Tiger.Business.MES/Transaction/Position.cs
index d7fc0b3..f4cf4b5 100644
--- a/Tiger.Business.MES/Transaction/Position.cs
+++ b/Tiger.Business.MES/Transaction/Position.cs
@@ -144,8 +144,7 @@
                         action.LocaleMsg = new("MES.Transaction.Position.SelectOrder.BatchStatusException", input.OrderNo, batch.BATCH_NO, batch.STATUS.GetEnumDesc<BIZ_MES_WO_BATCH.STATUSs>());
                         return action;
                     }
-                    var wb = new WorkBatch(input.OrderNo).Init(CurLine.LINE_CODE);
-                    WoContext.WoBatchDic.Add(wb.Batch.BATCH_NO, wb);
+                    var wb = WoContext.Add(input.OrderNo, CurLine.LINE_CODE);
                     batchNo = wb.Batch.BATCH_NO;
                 }
                 CurBatch = WoContext.GetBatch(input.OrderNo, CurLine.LINE_CODE, batchNo);
@@ -651,6 +650,10 @@
                                         {
                                             minPkgList = GetMinPkgList(_pkaction);
                                         }
+                                        if (curAction is PrintInStoreLabel)
+                                        {
+                                            minPkgList = (curAction as PrintInStoreLabel).CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
+                                        }
                                     }
                                     return string.Join("\r\n", minPkgList);
                                 case "GetDescription":
@@ -673,6 +676,10 @@
                                         if (_action != null)
                                         {
                                             list = _action.CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
+                                        }
+                                        if (curAction is PrintInStoreLabel)
+                                        {
+                                            list = (curAction as PrintInStoreLabel).CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
                                         }
                                     }
                                     return GetHuaWeiWeek(WorkBatch.Batch.ORDER_NO, list);
@@ -707,28 +714,30 @@
                                 case "GetVarByWo":
                                     return GetLabelVarWo(lv, "");
                                 case "GetLOTNO":
+                                    List<string> snList = new List<string>();
                                     string _lotnos = "";
                                     var _orderAction = curAction is PackingAction ? curAction as PackingAction : null;
                                     if (!CurPkg.IsNullOrEmpty())
                                     {
-                                        qtylist = CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
+                                        snList = CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
                                     }
                                     else
                                     {
                                         if (_orderAction != null)
                                         {
-                                            var snList = _orderAction.CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
-                                            //if (!snList.Any())
-                                            {
-                                                snList.Add(_orderAction.CurPkg.CustSN?.FLOW_SN);
-                                            }
-                                            _lotnos = string.Join(",", MainDB.Queryable<MES_CUST_SN>()
-                                                .Where((q) => snList.Contains(q.FLOW_SN))
-                                                .Select((q) => q.WORK_ORDER).Distinct().ToList());
-                                            return _lotnos;
+                                            snList = _orderAction.CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
+                                            snList.Add(_orderAction.CurPkg.CustSN?.FLOW_SN);
+                                        }
+                                        if (curAction is PrintInStoreLabel)
+                                        {
+                                            snList = (curAction as PrintInStoreLabel).CurPkg.Item.GetWipSnList().Select(q => q.Value).ToList();
+                                            snList.Add((curAction as PrintInStoreLabel).CurPkg.CustSN?.FLOW_SN);
                                         }
                                     }
-                                    return "";
+                                    _lotnos = string.Join(",", MainDB.Queryable<MES_CUST_SN>()
+                                        .Where((q) => snList.Contains(q.FLOW_SN))
+                                        .Select((q) => q.WORK_ORDER).Distinct().ToList());
+                                    return _lotnos;
                                 case "GetNOTES":
                                     return GetLabelVarWo(lv, WorkBatch.Product.ExtInfo?.Remark);
                                 case "GetXH":
@@ -779,9 +788,9 @@
                             switch (pv.VAR_METHOD)
                             {
                                 case "GetCartonGenerate":
-                                    return Biz.CodeRule[lv.BARCODE_RULE ?? ""]?.Generate("B", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
+                                    return Cache.CodeRule[lv.BARCODE_RULE ?? ""]?.Generate("B", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
                                 case "GetHW21SNGenerate":
-                                    return Biz.CodeRule[lv.BARCODE_RULE ?? ""]?.Generate("SN:", "05").Data.ToString() ?? "";
+                                    return Cache.CodeRule[lv.BARCODE_RULE ?? ""]?.Generate("SN:", "05").Data.ToString() ?? "";
                                 default:
                                     return "";
                             }
@@ -838,7 +847,7 @@
         /// <returns></returns>
         private string GetBoxCode()
         {
-            return Biz.CodeRule["WhiteBoxNo"]?.Generate("W", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
+            return Cache.CodeRule["WhiteBoxNo"]?.Generate("W", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
         }
 
         /// <summary>
@@ -847,7 +856,7 @@
         /// <returns></returns>
         private string GetCardCode()
         {
-            return Biz.CodeRule["CartonNo"]?.Generate("B", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
+            return Cache.CodeRule["CartonNo"]?.Generate("B", $"{WorkBatch.Batch.BATCH_NO}-{WorkBatch.Batch.PLAN_QTY}-").Data.ToString() ?? "";
         }
 
         /// <summary>
@@ -957,7 +966,7 @@
         /// <returns></returns>
         public string GenerateSN(string ruleCode, IWorkAction curAction)
         {
-            var rule = Biz.CodeRule[ruleCode ?? ""];
+            var rule = Cache.CodeRule[ruleCode ?? ""];
             if (!rule.IsNullOrEmpty())
             {
                 switch (rule.RULE_CODE)

--
Gitblit v1.9.3