From 87422530bec9baf531d2e0715b9c786a4d35667f Mon Sep 17 00:00:00 2001
From: Rodney Chen <rodney.chen@hotmail.com>
Date: 星期四, 02 一月 2025 15:59:44 +0800
Subject: [PATCH] Add new properties and classes for process and code handling

---
 Tiger.Business.MES/WorkAction/InputQty.cs |   42 ++++++++++++++++++++++++++++++++++++------
 1 files changed, 36 insertions(+), 6 deletions(-)

diff --git a/Tiger.Business.MES/WorkAction/InputQty.cs b/Tiger.Business.MES/WorkAction/InputQty.cs
index 4c5ab1d..c860232 100644
--- a/Tiger.Business.MES/WorkAction/InputQty.cs
+++ b/Tiger.Business.MES/WorkAction/InputQty.cs
@@ -69,11 +69,25 @@
 
             action.LocaleMsg = GetBeginMsg();
 
-            //濡傛灉杩斿洖鎴愬姛鍒欒涓哄綋鍓嶈涓哄彲浠ュ紑濮嬫墽琛岋紝鍚﹀垯杩斿洖澶辫触
-            CurStep.Message = Biz.L("璇疯緭鍏ユ暟閲�");
-            CurStep.Status = StepStatus.Normal;
-            action.IsSuccessed = true;
-            action.Data.ShortMsg = new("璇疯緭鍏ユ暟閲�", ShortMessage.Types.Success);
+            //濡傛灉鏄寘瑁呮潯鐮佸垯涓嶅厑璁镐慨鏀规暟閲�
+            if (MainDB.Queryable<MES_WIP_PKG>().Any(q => q.PARENT_SN == CurPosition.CurSN && q.AUTH_ORG == CurPosition.WorkBatch.WO.AUTH_ORG))
+            {
+                CurStep.Message = Biz.L("鍖呰鏉$爜涓嶅厑璁镐慨鏀规暟閲�");
+                CurStep.Status = StepStatus.Error;
+                action.IsSuccessed = false;
+                action.Data.ShortMsg = new("鍖呰鏉$爜涓嶅厑璁镐慨鏀规暟閲�", ShortMessage.Types.Error);
+                //action.LocaleMsg = new($"鍖呰鏉$爜[{0}]涓嶅厑璁镐慨鏀规暟閲忥紝璇烽噸鏂版壂鎻忔纭殑鏉$爜");
+                action.LocaleMsg = new("MES.WorkAction.InputQty.NotAllowPackage", CurPosition.CurSN);
+                CurPosition.ResetNode();
+            }
+            else
+            {
+                //濡傛灉杩斿洖鎴愬姛鍒欒涓哄綋鍓嶈涓哄彲浠ュ紑濮嬫墽琛岋紝鍚﹀垯杩斿洖澶辫触
+                CurStep.Message = Biz.L("璇疯緭鍏ユ暟閲�");
+                CurStep.Status = StepStatus.Normal;
+                action.IsSuccessed = true;
+                action.Data.ShortMsg = new("璇疯緭鍏ユ暟閲�", ShortMessage.Types.Success);
+            }
             return action;
         }
 
@@ -114,7 +128,8 @@
                                                                                            .Where(q => !CurPosition.CurWipSNs.Any(sn => sn.ID == q.WIP_ID)).DistinctBy(q => q.WIP_ID).Sum(q => q.QTY);
                     var batchInput = CurPosition.WorkBatch.WoSNs.Where(q => q.BATCH_NO == CurPosition.WorkBatch.Batch.BATCH_NO && BIZ_MES_WO_SN.STATUSs.NotInput.GetValue() < q.STATUS && q.STATUS <= BIZ_MES_WO_SN.STATUSs.Finished.GetValue())
                                                                                                .Where(q => !CurPosition.CurWipSNs.Any(sn => sn.ID == q.WIP_ID)).DistinctBy(q => q.WIP_ID).Sum(q => q.QTY);
-                    
+
+      
                     //宸ュ崟鎵规鎶曞叆鏁伴噺鍑忓幓鎶ュ簾鏁伴噺濡傛灉澶т簬绛変簬璁″垝鏁伴噺锛屽垯涓嶅厑璁哥敓浜�
                     if ((NewBatchInputQty = batchInput + newInput) > CurPosition.WorkBatch.Batch.PLAN_QTY)
                     {
@@ -174,6 +189,15 @@
             var wipVars = new List<MES_WIP_ACT_VAR>();
             foreach (var wipSn in CurPosition.CurWipSNs)
             {
+                wipSn.QTY = NewQty;
+                foreach (var item in CurPosition.CurWipSNHiss.Where(q => q.WIP_ID == wipSn.ID))
+                {
+                    item.QTY = NewQty;
+                }
+                foreach (var item in CurPosition.WorkBatch.WoSNs.Where(q => q.WIP_ID == wipSn.ID))
+                {
+                    item.QTY = NewQty;
+                }
                 var wipAct = new MES_WIP_ACT()
                 {
                     AUTH_ORG = CurPosition.WorkBatch.WO.AUTH_ORG,
@@ -250,6 +274,7 @@
                         VAR_NAME = item.VAR_NAME,
                         VAR_CONTROL = item.VAR_CONTROL,
                         VALUE_TYPE = item.VALUE_TYPE,
+                        PROCESS_VAR = item.PROCESS_VAR,
                         INPUT_VALUE = CurStep.ActionDic.GetOrDefault(item.VAR_CODE),
                         TRACE_INFO = CurStep.ActionDic.ToJson(),
                     };
@@ -278,6 +303,11 @@
                     .SetColumns(q => q.QTY == NewQty)
                     .Where(q => q.WORK_ORDER == wo && q.NODE_ID == nodeID && _wipIDs.Contains(q.WIP_ID))
                     .ExecuteCommand();
+                //鐢熶骇鍖呰璁板綍
+                db.Updateable<MES_WIP_PKG>(CurPosition.UserCode)
+                    .SetColumns(q => q.QTY == NewQty)
+                    .Where(q => q.WORK_ORDER == wo && _wipIDs.Contains(q.ID))
+                    .ExecuteCommand();
                 //宸ュ崟琛�
                 db.Updateable<BIZ_MES_WO>(CurPosition.UserCode)
                     .SetColumns(q => q.INPUT_QTY == NewWoInputQty)

--
Gitblit v1.9.3