From f978872b6de4e7e20d992a2ee7cda902c11347b9 Mon Sep 17 00:00:00 2001
From: kazelee <1847801760@qq.com>
Date: 星期一, 30 六月 2025 15:31:56 +0800
Subject: [PATCH] 优化配置文件读取逻辑,将ERP反馈接口写入配置文件中配置

---
 wms/LocationHelper.cs |  120 ++++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 88 insertions(+), 32 deletions(-)

diff --git a/wms/LocationHelper.cs b/wms/LocationHelper.cs
index ef584a3..67fcff2 100644
--- a/wms/LocationHelper.cs
+++ b/wms/LocationHelper.cs
@@ -127,21 +127,25 @@
         }
 
         /// <summary>
-        /// 鍏ュ簱閿佸畾缁堢偣锛屽嚭搴撻攣瀹氳捣鐐�-        /// 浣犲垱寤轰换鍔¢攣瀹氳揣浣嶇殑鏃跺�锛屾妸閿佺殑鏉ユ簮灏辨槸浠诲姟鍙蜂篃鍐欎笂鍘伙紙鍔犻攣鐨勬柟娉曞姞涓弬鏁帮紝鍙┖鐨勫弬鏁帮級锛岃В閿佺殑鏃跺�鎶婃潵婧愮疆绌恒�
+        /// 璧风偣鍑哄簱閿侊紙鍙兘瀵规棤閿佽揣浣嶄笂閿侊級
         /// </summary>
         /// <param name="loc"></param>
-        /// <param name="lockState">1:鍏ュ簱閿併�2:鍑哄簱閿併�2:鍏跺畠閿�/param>
-        /// <param name="lockSource">閿佺殑鏉ユ簮=浠诲姟鍙�/param>
+        /// <param name="lockSource"></param>
         /// <returns></returns>
-        public static bool LockLoc(ref TN_Location loc, int lockState, string lockSource = "") {
-            if (loc == null || loc.N_LOCK_STATE != 0) {
+        public static bool LockStartLoc(ref TN_Location loc, string lockSource = "") {
+            if (loc == null) {
+                LogHelper.Info($"璧风偣鍑哄簱閿侊細浼犲叆鐨勮揣浣嶅弬鏁颁负null");
+                return false;
+            }
+
+            if (loc.N_LOCK_STATE != 0 || loc.S_LOCK_STATE != "鏃�) {
+                LogHelper.Info($"璧风偣鍑哄簱閿侊細璐т綅褰撳墠宸叉湁閿�{loc.N_LOCK_STATE},{loc.S_LOCK_STATE})");
                 return false;
             }
 
             if (loc != null && loc.N_LOCK_STATE == 0) {
-                loc.N_LOCK_STATE = lockState;
-                loc.S_LOCK_STATE = TN_Location.GetLockStateStr(lockState);
+                loc.N_LOCK_STATE = 2; // 璧风偣鍑哄簱閿�+                loc.S_LOCK_STATE = TN_Location.GetLockStateStr(2); // 璧风偣鍑哄簱閿�                 loc.S_LOCK_OP = lockSource;
                 loc.T_MODIFY = System.DateTime.Now;
             }
@@ -150,32 +154,53 @@
         }
 
         /// <summary>
-        /// 鍏ュ簱閿佸畾缁堢偣锛屽嚭搴撻攣瀹氳捣鐐�+        /// 缁堢偣鍏ュ簱閿侊紙鍙兘瀵规棤閿佽揣浣嶄笂閿侊級
         /// </summary>
-        /// <remarks>
-        /// 鍒涘缓浠诲姟閿佸畾璐т綅鐨勬椂鍊欙紝鎶婇攣鐨勬潵婧愬氨鏄换鍔″彿涔熷啓涓婂幓锛堝姞閿佺殑鏂规硶鍔犱釜鍙傛暟锛屽彲绌虹殑鍙傛暟锛夛紝瑙i攣鐨勬椂鍊欐妸鏉ユ簮缃┖
-        /// </remarks>
         /// <param name="loc"></param>
-        /// <param name="lockState">1:鍏ュ簱閿併�2:鍑哄簱閿併�3:鍏跺畠閿�/param>
-        /// <param name="lockSource">閿佺殑鏉ユ簮=浠诲姟鍙�/param>
+        /// <param name="lockSource"></param>
         /// <returns></returns>
-        public static bool LockLoc(string loc, int lockState, string lockSource = "")
-        {
-            var res = false;
-            var db = new SqlHelper<object>().GetInstance();
-            var model = db.Queryable<TN_Location>().Where(a => a.S_CODE == loc).First();
-            LogHelper.Info($"閿佽揣浣峽loc},鐘舵�{lockState},淇℃伅" + JsonConvert.SerializeObject(model));
-            if (model != null && model.N_LOCK_STATE == 0)
-            {
-                model.N_LOCK_STATE = lockState;
-                model.S_LOCK_STATE = TN_Location.GetLockStateStr(lockState);
-                model.S_LOCK_OP = lockSource;
-                model.T_MODIFY = System.DateTime.Now;
-                res = db.Updateable<TN_Location>(model).UpdateColumns(it => new { it.N_LOCK_STATE, it.S_LOCK_STATE, it.S_LOCK_OP, it.T_MODIFY }).ExecuteCommand() > 0;
+        public static bool LockEndLoc(ref TN_Location loc, string lockSource = "") {
+            if (loc == null) {
+                LogHelper.Info($"缁堢偣鍏ュ簱閿侊細浼犲叆鐨勮揣浣嶅弬鏁颁负null");
+                return false;
             }
-            LogHelper.Info($"閿佽揣浣峽loc}杩斿洖{res}");
 
-            return res;
+            if (loc.N_LOCK_STATE != 0 || loc.S_LOCK_STATE != "鏃�) {
+                LogHelper.Info($"缁堢偣鍏ュ簱閿侊細璐т綅褰撳墠宸叉湁閿�{loc.N_LOCK_STATE},{loc.S_LOCK_STATE})");
+                return false;
+            }
+
+            if (loc != null && loc.N_LOCK_STATE == 0) {
+                loc.N_LOCK_STATE = 1; // 缁堢偣鍑哄簱閿�+                loc.S_LOCK_STATE = TN_Location.GetLockStateStr(1); // 缁堢偣鍑哄簱閿�+                loc.S_LOCK_OP = lockSource;
+                loc.T_MODIFY = System.DateTime.Now;
+            }
+
+            return true;
+        }
+
+        /// <summary>
+        /// 鏋勫缓璐т綅鏌ヨ琛ㄨ揪寮忥細褰撳墠鏁伴噺銆佽揣鍖恒�鍚嶇О
+        /// </summary>
+        /// <param name="db"></param>
+        /// <param name="nCurrentNum"></param>
+        /// <param name="areas"></param>
+        /// <param name="name"></param>
+        /// <returns></returns>
+        public static ISugarQueryable<TN_Location> GetLocQuery(SqlSugarClient db, int nCurrentNum = 0, List<string> areas = null, string name = null) {
+            var query = db.Queryable<TN_Location>()
+                .Where(l => l.N_LOCK_STATE == 0 && l.S_LOCK_STATE == "鏃� && l.C_ENABLE == "Y" && l.N_CURRENT_NUM == nCurrentNum);
+
+            if (areas != null && !areas.Any()) {
+                query = query.Where(l => areas.Contains(l.S_AREA_CODE));
+            }
+
+            if (!string.IsNullOrEmpty(name)) {
+                query = query.Where(l => l.S_CODE == name);
+            }
+
+            return query;
         }
 
         /// <summary>
@@ -224,7 +249,6 @@
                 }
                 cntrs = lcrList.Select(a => a.S_CNTR_CODE).ToList();
 
-
                 var log = JsonConvert.SerializeObject(cntrs);
                 var location = db.Queryable<TN_Location>().First(a => a.S_CODE == loc);
                 if (location != null)
@@ -233,8 +257,30 @@
                     location.S_LOCK_STATE = "鏃�;
                     location.N_LOCK_STATE = 0;
 
+                    //var containerList = new List<TN_Container>();
+                    //foreach (var item in lcrList) {
+                    //    // 閽堝瀹瑰櫒绫诲瀷娣诲姞鐨勬柊閫昏緫
+                    //    var cntr = db.Queryable<TN_Container>()
+                    //        .Where(c => c.S_CODE == item.S_CNTR_CODE).First();
+                    //    if (cntr == null) {
+                    //        LogHelper.Info($"璐т綅瑙g粦鏃讹紝瀹瑰櫒{item.S_CNTR_CODE}娌℃湁鍦ㄥ鍣ㄤ俊鎭〃涓煡鍒帮紝杩欓噷鏍规嵁璐т綅瀹瑰櫒鍏崇郴娣诲姞");
+                    //        containerList.Add(new TN_Container {
+                    //            S_CODE = item.S_CNTR_CODE,
+                    //            S_TYPE = item.S_CNTR_TYPE,
+                    //        });
+                    //    }
+                    //}
+
                     using (var tran = db.Ado.UseTran())
                     {
+                        //if (containerList.Count > 0) {
+                        //    if (db.Insertable<TN_Container>(containerList).ExecuteCommand() <= 0) {
+                        //        LogHelper.Info($"鎻掑叆瀹瑰櫒淇℃伅琛ㄥけ璐� + JsonConvert.SerializeObject(containerList));
+                        //        tran.RollbackTran();
+                        //        return "璐т綅瑙g粦瀹瑰櫒澶辫触锛� + logs;
+                        //    }
+                        //}
+
                         if (db.Deleteable<TN_Loc_Container>().Where(it => cntrs.Contains(it.S_CNTR_CODE) && it.S_LOC_CODE == loc).ExecuteCommand() > 0)
                         {
                             LogHelper.Info($"鍒犻櫎璐т綅瀹瑰櫒鍏崇郴琛ㄦ垚鍔燂紝{log}");
@@ -300,9 +346,19 @@
                 var bindLocCntList = new List<TN_Loc_Container>();
                 foreach (var item in cntrs)
                 {
-                    bindLocCntList.Add(new TN_Loc_Container() { S_LOC_CODE = loc, S_CNTR_CODE = item });
-                }
+                    // 閽堝瀹瑰櫒绫诲瀷娣诲姞鐨勬柊閫昏緫
+                    var cntr = db.Queryable<TN_Container>()
+                        .Where(c => c.S_CODE == item)
+                        .First();
 
+                    if (cntr == null) {
+                        LogHelper.Info($"璐т綅瑙g粦鏃讹紝瀹瑰櫒{item}娌℃湁鍦ㄥ鍣ㄤ俊鎭〃涓煡鍒帮紝涓嶈褰曞鍣ㄧ被鍨�);
+                        bindLocCntList.Add(new TN_Loc_Container() { S_LOC_CODE = loc, S_CNTR_CODE = item });
+                    }
+                    else {
+                        bindLocCntList.Add(new TN_Loc_Container() { S_LOC_CODE = loc, S_CNTR_CODE = item, S_CNTR_TYPE = cntr.S_TYPE });
+                    }
+                }
 
                 var log = JsonConvert.SerializeObject(bindLocCntList);
 

--
Gitblit v1.9.1