From 40df5d91f800bb8b7be2638c13b4f9292d461221 Mon Sep 17 00:00:00 2001
From: Rodney Chen <rodney.chen@hotmail.com>
Date: 星期一, 10 三月 2025 18:13:50 +0800
Subject: [PATCH] 增加送货单清点事务

---
 Tiger.Business.MES/Transaction/Position.cs |   77 ++++++++++++++++----------------------
 1 files changed, 33 insertions(+), 44 deletions(-)

diff --git a/Tiger.Business.MES/Transaction/Position.cs b/Tiger.Business.MES/Transaction/Position.cs
index 601f1a3..7ded706 100644
--- a/Tiger.Business.MES/Transaction/Position.cs
+++ b/Tiger.Business.MES/Transaction/Position.cs
@@ -500,8 +500,8 @@
                     {
                         DBCommitList.Add("AppendSaveAction", new List<Action>());
                     }
-                    var commitList = DBCommitList["AppendSaveAction"];
-                    commitList.Add(appendToSave);
+                    var appendList = DBCommitList["AppendSaveAction"];
+                    appendList.Add(appendToSave);
                 }
             }
 
@@ -570,12 +570,12 @@
         /// <param name="labelPVs">杩囩▼鍙橀噺鍒楄〃</param>
         /// <param name="label">鏍囩妯℃澘</param>
         /// <returns></returns>
-        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_TEMP label, IWorkAction action)
+        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_PROCESS_VAR> labelPVs, BAS_LABEL_TEMP label, IWorkAction action)
         {
             return SetLabelVariables(labelPVs, label, action, null);
         }
 
-        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_TEMP label, IWorkAction action, WipPkg? CurPkg)
+        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_PROCESS_VAR> labelPVs, BAS_LABEL_TEMP label, IWorkAction action, WipPkg? CurPkg)
         {
             foreach (var item in label.Variables.OrderBy(q => q.VAR_TYPE == BAS_LABEL_VAR.VAR_TYPEs.BarcodeGenerate.GetValue() ? 0 : 1))
             {
@@ -608,14 +608,14 @@
         /// <param name="labelPVs">杩囩▼鍙橀噺鍒楄〃</param>
         /// <param name="lv">鏍囩妯℃澘鍙橀噺</param>
         /// <returns></returns>
-        public string GetPrintProcessValue(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_VAR lv, List<BAS_LABEL_VAR> lvars, IWorkAction curAction, WipPkg? CurPkg)
+        public string GetPrintProcessValue(List<BAS_PROCESS_VAR> labelPVs, BAS_LABEL_VAR lv, List<BAS_LABEL_VAR> lvars, IWorkAction curAction, WipPkg? CurPkg)
         {
             var pv = labelPVs.FirstOrDefault(q => q.VAR_CODE == lv.VAR_VALUE);
             if (!pv.IsNullOrEmpty())
             {
-                switch (pv.VAR_TYPE.GetEnum<BAS_LABEL_PV.VAR_TYPEs>())
+                switch (pv.VAR_TYPE.GetEnum<BAS_PROCESS_VAR.VAR_TYPEs>())
                 {
-                    case BAS_LABEL_PV.VAR_TYPEs.ServerMethod:
+                    case BAS_PROCESS_VAR.VAR_TYPEs.ServerMethod:
                         {
                             switch (pv.VAR_METHOD)
                             {
@@ -650,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":
@@ -672,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);
@@ -706,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":
@@ -749,9 +759,9 @@
                                     return "";
                             }
                         }
-                    case BAS_LABEL_PV.VAR_TYPEs.WebApi:
+                    case BAS_PROCESS_VAR.VAR_TYPEs.WebApi:
                         break;
-                    case BAS_LABEL_PV.VAR_TYPEs.StoredProcedure:
+                    case BAS_PROCESS_VAR.VAR_TYPEs.StoredProcedure:
                         break;
                     default:
                         break;
@@ -766,14 +776,14 @@
         /// <param name="labelPVs"></param>
         /// <param name="lv"></param>
         /// <returns></returns>
-        public string GetGeneratePValue(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_VAR lv)
+        public string GetGeneratePValue(List<BAS_PROCESS_VAR> labelPVs, BAS_LABEL_VAR lv)
         {
             var pv = labelPVs.FirstOrDefault(q => q.VAR_CODE == lv.VAR_VALUE);
             if (!pv.IsNullOrEmpty())
             {
-                switch (pv.VAR_TYPE.GetEnum<BAS_LABEL_PV.VAR_TYPEs>())
+                switch (pv.VAR_TYPE.GetEnum<BAS_PROCESS_VAR.VAR_TYPEs>())
                 {
-                    case BAS_LABEL_PV.VAR_TYPEs.BarcodeGenerate:
+                    case BAS_PROCESS_VAR.VAR_TYPEs.BarcodeGenerate:
                         {
                             switch (pv.VAR_METHOD)
                             {
@@ -991,27 +1001,6 @@
                 list.AddRange(GetPackageList(item));
             }
             return list;
-        }
-        #endregion
-        #region 鎻愪氦鍓嶉�氱敤鏂规硶
-        /// <summary>
-        /// 鎻愪氦鍓嶆鏌ユ槸鍚﹀矖浣嶃�佸伐鍗曞拰涓嶈壇浠g爜
-        /// </summary>
-        /// <param name="code"></param>
-        /// <returns></returns>
-        public async Task<ApiAction<CheckCodeOutput>> CheckCode(string code) {
-            var action = new ApiAction<CheckCodeOutput>($"妫�鏌ユ潯鐮亄code}鎴愬姛", new CheckCodeOutput());
-            try
-            {
-                action.Data.Position = DbCache.Cache.Position[code];
-                action.Data.WorkOrder = await MainDB.Queryable<BIZ_MES_WO>().Where(q=>q.ORDER_NO == code).FirstAsync();
-                action.Data.Defect = DbCache.Cache.Defect[code];
-            }
-            catch (Exception ex)
-            {
-                action.CatchExceptionWithLog(ex, $"妫�鏌ユ潯鐮亄code}寮傚父");
-            }
-            return action;
         }
         #endregion
         #endregion Functions

--
Gitblit v1.9.3