From ac0d220e150a8103b586a81340faf39ddb5e08fe Mon Sep 17 00:00:00 2001
From: Ben Lin <maobin001@msn.com>
Date: 星期五, 20 九月 2024 10:12:49 +0800
Subject: [PATCH] 一些已知更改

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

diff --git a/Tiger.Business.MES/Transaction/Position.cs b/Tiger.Business.MES/Transaction/Position.cs
index fae36cc..700e73a 100644
--- a/Tiger.Business.MES/Transaction/Position.cs
+++ b/Tiger.Business.MES/Transaction/Position.cs
@@ -73,8 +73,8 @@
         public bool NeedTemporaryStoreDBCommitAction { get; set; } = false;
         protected Dictionary<string, List<Action>> DBCommitList { get; set; } = new();
         protected List<Position> NodeCommitList { get; set; } = new();
-        protected Dictionary<string, OperInfo> OperInfoDic { get; set; } = new();
-        //protected OperInfo CurOperInfo { get; set; }
+        private Dictionary<string, OperInfo> OperInfoDic = new();
+
         #endregion Propertys & Variables
 
         #region Functions
@@ -120,6 +120,13 @@
                         action.IsSuccessed = false;
                         //action.LocaleMsg = new($"宸ュ崟[{input.OrderNo}]娌℃湁涓嬪彂鍒颁骇绾跨姸鎬乕{CurLine.LINE_CODE}]");
                         action.LocaleMsg = new("MES.Transaction.Position.SelectOrder.LineException", input.OrderNo, CurLine.LINE_CODE);
+                        return action;
+                    }
+                    if (batch.STATUS != BIZ_MES_WO_BATCH.STATUSs.Release.GetValue() && batch.STATUS != BIZ_MES_WO_BATCH.STATUSs.Working.GetValue())
+                    {
+                        action.IsSuccessed = false;
+                        //action.LocaleMsg = new($"宸ュ崟[{input.OrderNo}]鐘舵�乕{wo.STATUS.GetEnum<BIZ_MES_WO_BATCH.STATUSs>().GetName()}]涓嶈兘鐢熶骇");
+                        action.LocaleMsg = new("MES.Transaction.Position.SelectOrder.StatusException", input.OrderNo, batch.STATUS.GetEnum<BIZ_MES_WO_BATCH.STATUSs>().GetName());
                         return action;
                     }
                     var wb = new WorkBatch(input.OrderNo).Init(CurLine.LINE_CODE);
@@ -189,22 +196,32 @@
             CurDefects.Clear();
         }
 
+        //鑾峰彇褰撳墠鐨勫伐搴忎俊鎭�
+        protected OperInfo CurOperInfo(string locale)
+        {
+            OperInfo info = new();
+            if (CurBatch?.Batch?.BATCH_NO != null)
+            {
+                info = OperInfoDic[CurBatch.Batch.BATCH_NO ];
+                info.StepsInfo = Steps.Select(q => q.GetInfo(locale)).ToList();
+            }
+            return info;
+        }
+
         /// <summary>
         /// 璁剧疆褰撳墠鏉$爜鐨勫伐搴忎俊鎭�
         /// </summary>
-        public OperInfo SetOperNodeInfo(OperInfo info, string locale)
+        public OperInfo SetOperNodeInfo(OperInfo info)
         {
             if (CurWipSNs.Any())
             {
                 info.CurNode = CurWipSNs.First().NODE_NAME;
                 info.NextNode = string.Join(",", CurBatch.GetNextNodes(CurWipSNs.First()).Select(q => q.NODE_NAME));
-                info.StepsInfo = Steps.Select(q => q.GetInfo(locale)).ToList();
             }
             else
             {
                 info.CurNode = "   鈥�   ";
                 info.NextNode = "   鈥�   ";
-                info.StepsInfo = new();
             }
             return info;
         }
@@ -417,13 +434,14 @@
             }
         }
 
+        #region 鎵撳嵃涓撶敤鏂规硶
         /// <summary>
         /// 鑾峰彇鎵撳嵃鏍囩妯℃澘杩囩▼鍙橀噺鍊�
         /// </summary>
         /// <param name="labelPVs">杩囩▼鍙橀噺鍒楄〃</param>
         /// <param name="label">鏍囩妯℃澘</param>
         /// <returns></returns>
-        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_TEMP label)
+        public BAS_LABEL_TEMP SetLabelVariables(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_TEMP label, IWorkAction action)
         {
             foreach (var item in label.Variables)
             {
@@ -433,7 +451,7 @@
                         item.Value = item.VAR_VALUE;
                         break;
                     case BAS_LABEL_VAR.VAR_TYPEs.ProcessVariable:
-                        item.Value = GetPrintProcessValue(labelPVs, item);
+                        item.Value = GetPrintProcessValue(labelPVs, item, action);
                         break;
                     case BAS_LABEL_VAR.VAR_TYPEs.DateVariable:
                         item.Value = DateTime.Now.ToString(item.VAR_VALUE);
@@ -456,7 +474,7 @@
         /// <param name="labelPVs">杩囩▼鍙橀噺鍒楄〃</param>
         /// <param name="lv">鏍囩妯℃澘鍙橀噺</param>
         /// <returns></returns>
-        public string GetPrintProcessValue(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_VAR lv)
+        public string GetPrintProcessValue(List<BAS_LABEL_PV> labelPVs, BAS_LABEL_VAR lv, IWorkAction action)
         {
             var pv = labelPVs.FirstOrDefault(q => q.VAR_CODE == lv.VAR_VALUE);
             if (!pv.IsNullOrEmpty())
@@ -542,6 +560,7 @@
             return result;
         }
 
+        #endregion
         #endregion Functions
 
         public override bool Close(bool needSaveHistoryLog = false)

--
Gitblit v1.9.3