From 9556c5fc2168b71e5aba4bd5353fcd70e681ee46 Mon Sep 17 00:00:00 2001
From: Ben Lin <maobin001@msn.com>
Date: 星期一, 09 十二月 2024 01:54:25 +0800
Subject: [PATCH] 调用U9C接口生成入库单更新

---
 Tiger.Business.MES/iERP/MES_U9C.cs |  136 ++++++++++++++++++++-------------------------
 1 files changed, 61 insertions(+), 75 deletions(-)

diff --git a/Tiger.Business.MES/iERP/MES_U9C.cs b/Tiger.Business.MES/iERP/MES_U9C.cs
index 15eac1f..5770308 100644
--- a/Tiger.Business.MES/iERP/MES_U9C.cs
+++ b/Tiger.Business.MES/iERP/MES_U9C.cs
@@ -45,30 +45,25 @@
             var action = new ApiAction<RcvRptDocCreateInput>();
             try
             {
-                //鍏堜繚瀛樻暟鎹�
-                bool IsSuccessed = true;
-
                 //淇濆瓨鎴愬姛锛岃皟鐢║9C鎺ュ彛-娴嬭瘯鐢�
                 //int i = 1;
-                //List<BIZ_ERP_PROD_IN_BTH> ErpProdInBths = new List<BIZ_ERP_PROD_IN_BTH>();
                 //foreach (var item in input.RcvRptDocBases.Where(q => q.Status != "Y"))
                 //{
-                //    var ErpProdInBth = Biz.Db.Queryable<BIZ_ERP_PROD_IN_BTH>().Where(q => q.WORK_ORDER == item.WorkOrder).First();
+                //    var ErpProdInBth = input.ErpProdInBths.Where(q => q.WORK_ORDER == item.WorkOrder).FirstOrDefault();
                 //    item.Status = "Y";
                 //    if (!ErpProdInBth.IsNullOrEmpty())
                 //    {
-                //        ErpProdInBth.ORDER_NO = $"YDRKD241200006";
+                //        ErpProdInBth.ORDER_NO = $"YDRKD24120000{5+i}";
                 //        ErpProdInBth.IS_HANDLED = "Y";
                 //        ErpProdInBth.HANDLED_DATE = DateTime.Now;
-                //        ErpProdInBths.Add(ErpProdInBth);
                 //    }
                 //    foreach (var p in input.PrintJsons)
                 //    {
                 //        var d = p.Items.Where(q => q.WORK_ORDER == item.WorkOrder).FirstOrDefault();
                 //        if (!d.IsNullOrEmpty())
                 //        {
-                //            d.ORDER_NO = $"YDRKD241200006";
-                //            d.STATUS = "Y";
+                //            d.ORDER_NO = $"YDRKD24120000{5 + i}";
+                //            d.IS_HANDLED = "Y";
                 //        }
                 //    }
                 //    i++;
@@ -76,7 +71,7 @@
                 //var _db = Biz.Db;
                 //var _dbTran = _db.UseTran(() =>
                 //{
-                //    _db.Updateable(ErpProdInBths, "U9C_RcvRptDocCreate").UpdateColumns(x => new { x.ORDER_NO, x.REMARK, x.IS_HANDLED, x.HANDLED_DATE }).ExecuteCommand();
+                //    _db.Updateable(input.ErpProdInBths, "U9C_RcvRptDocCreate").UpdateColumns(x => new { x.ORDER_NO, x.REMARK, x.IS_HANDLED, x.HANDLED_DATE, x.UPDATE_USER, x.UPDATE_TIME }).ExecuteCommand();
                 //});
                 //if (!_dbTran.IsSuccess)
                 //{
@@ -84,20 +79,16 @@
                 //    Logger.Interface.Error(action.Message);
                 //    IsSuccessed = false;
                 //}
-                //input.ErpProdInBths = ErpProdInBths;
 
                 //淇濆瓨鎴愬姛锛岃皟鐢║9C鎺ュ彛
-                if (IsSuccessed)
+                var u9CLoginResult = await HttpHelper.GetAsync<U9CLoginResult>($"{U9CAuthLoginUrl}userCode={input.userId}{secret}");
+                if (u9CLoginResult.Success)
                 {
-                    var u9CLoginResult = await HttpHelper.GetAsync<U9CLoginResult>($"{U9CAuthLoginUrl}userCode={input.userId}{secret}");
-                    if (u9CLoginResult.Success)
+                    var token = u9CLoginResult.Data;
+                    Logger.Interface.Info($"U9C鐧诲綍token: {token}");
+                    foreach (var item in input.RcvRptDocBases.Where(q => q.Status != "Y"))
                     {
-                        var token = u9CLoginResult.Data;
-                        Logger.Interface.Info($"U9C鐧诲綍token: {token}");
-                        List<BIZ_ERP_PROD_IN_BTH> ErpProdInBths = new List<BIZ_ERP_PROD_IN_BTH>();
-                        foreach (var item in input.RcvRptDocBases.Where(q => q.Status != "Y"))
-                        {
-                            List<RcvRptDocCreateParam> param = new() {
+                        List<RcvRptDocCreateParam> param = new() {
                                 new() {
                                     CompleteList = new(){
                                        new CompleteList
@@ -116,70 +107,65 @@
                                     BusinessDate = DateTime.Now,
                                 }
                             };
-                            var response = await HttpHelper.PostAsync(RcvRptDocCreateUrl, JsonConvert.SerializeObject(param), new Dictionary<string, string>() { { "token", token } });
-                            var result = JsonConvert.DeserializeObject<U9CResult>(response.Message);
-                            var ErpProdInBth = Biz.Db.Queryable<BIZ_ERP_PROD_IN_BTH>().Where(q => q.WORK_ORDER == item.WorkOrder).First();
-                            if (result != null)
+                        var response = await HttpHelper.PostAsync(RcvRptDocCreateUrl, JsonConvert.SerializeObject(param), new Dictionary<string, string>() { { "token", token } });
+                        var result = JsonConvert.DeserializeObject<U9CResult>(response.Message);
+                        var ErpProdInBth = input.ErpProdInBths.Where(q => q.WORK_ORDER == item.WorkOrder).FirstOrDefault();.Where(q => q.WORK_ORDER == item.WorkOrder).FirstOrDefault();
+                        if (result != null)
+                        {
+                            if (result.Success && result.Data[0].m_isSucess)
                             {
-                                if (result.Success && result.Data[0].m_isSucess)
+                                Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曟帴鍙f彁浜son: {JsonConvert.SerializeObject(param)}锛岃繑鍥濲son: {response.Message}");
+                                item.Status = "Y";
+                                if (!ErpProdInBth.IsNullOrEmpty())
                                 {
-                                    Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曟帴鍙f彁浜son: {JsonConvert.SerializeObject(param)}锛岃繑鍥濲son: {response.Message}");
-                                    item.Status = "Y";
-                                    if (!ErpProdInBth.IsNullOrEmpty())
-                                    {
-                                        ErpProdInBth.ORDER_NO = result.Data[0].m_code;
-                                        ErpProdInBth.IS_HANDLED = "Y";
-                                        ErpProdInBth.HANDLED_DATE = DateTime.Now;
-                                        ErpProdInBths.Add(ErpProdInBth);
-                                    }
-                                    foreach (var p in input.PrintJsons)
-                                    {
-                                        var d = p.Items.Where(q => q.WORK_ORDER == item.WorkOrder && q.IS_HANDLED != "P").FirstOrDefault();
-                                        if (!d.IsNullOrEmpty())
-                                        {
-                                            d.ORDER_NO = result.Data[0].m_code;
-                                            d.IS_HANDLED = "Y";
-                                        }
-                                    }
-                                    Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曟垚鍔�");
+                                    ErpProdInBth.ORDER_NO = result.Data[0].m_code;
+                                    ErpProdInBth.IS_HANDLED = "Y";
+                                    ErpProdInBth.HANDLED_DATE = DateTime.Now;
                                 }
-                                else
+                                foreach (var p in input.PrintJsons)
                                 {
-                                    action.IsSuccessed = false;
-                                    action.LocaleMsg = new($"{action.Message}; {result.Data[0].m_errorMsg}");
-                                    item.Status = "F";
-                                    if (!ErpProdInBth.IsNullOrEmpty())
+                                    var d = p.Items.Where(q => q.WORK_ORDER == item.WorkOrder && q.IS_HANDLED != "P").FirstOrDefault();
+                                    if (!d.IsNullOrEmpty())
                                     {
-                                        ErpProdInBth.REMARK = result.Data[0].m_errorMsg;
-                                        ErpProdInBth.IS_HANDLED = "F";
-                                        ErpProdInBth.HANDLED_DATE = DateTime.Now;
-                                        ErpProdInBths.Add(ErpProdInBth);
+                                        d.ORDER_NO = result.Data[0].m_code;
+                                        d.IS_HANDLED = "Y";
                                     }
-                                    foreach (var p in input.PrintJsons)
-                                    {
-                                        var d = p.Items.Where(q => q.WORK_ORDER == item.WorkOrder && q.IS_HANDLED != "P").FirstOrDefault();
-                                        if (!d.IsNullOrEmpty())
-                                        {
-                                            d.ORDER_NO = result.Data[0].m_code;
-                                            d.IS_HANDLED = "F";
-                                        }
-                                    }
-                                    Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曞け璐�:{result.Data[0].m_errorMsg}");
                                 }
+                                Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曟垚鍔�");
+                            }
+                            else
+                            {
+                                action.IsSuccessed = false;
+                                action.LocaleMsg = new($"{action.Message}; {result.Data[0].m_errorMsg}");
+                                item.Status = "F";
+                                if (!ErpProdInBth.IsNullOrEmpty())
+                                {
+                                    ErpProdInBth.REMARK = result.Data[0].m_errorMsg;
+                                    ErpProdInBth.IS_HANDLED = "F";
+                                    ErpProdInBth.HANDLED_DATE = DateTime.Now;
+                                }
+                                foreach (var p in input.PrintJsons)
+                                {
+                                    var d = p.Items.Where(q => q.WORK_ORDER == item.WorkOrder && q.IS_HANDLED != "P").FirstOrDefault();
+                                    if (!d.IsNullOrEmpty())
+                                    {
+                                        d.ORDER_NO = result.Data[0].m_code;
+                                        d.IS_HANDLED = "F";
+                                    }
+                                }
+                                Logger.Interface.Info($"鐢熸垚鍏ュ簱鍗曞け璐�:{result.Data[0].m_errorMsg}");
                             }
                         }
-                        var _db = Biz.Db;
-                        var _dbTran = _db.UseTran(() =>
-                        {
-                            _db.Updateable(ErpProdInBths, "U9C_RcvRptDocCreate").UpdateColumns(x => new { x.ORDER_NO, x.REMARK, x.IS_HANDLED, x.HANDLED_DATE, x.UPDATE_USER, x.UPDATE_TIME }).ExecuteCommand();
-                        });
-                        if (!_dbTran.IsSuccess)
-                        {
-                            action.CatchExceptionWithLog(_dbTran.ErrorException, $"鏁版嵁澶勭悊澶辫触");
-                            Logger.Interface.Error(action.Message);
-                            IsSuccessed = false;
-                        }
-                        input.ErpProdInBths = ErpProdInBths;
+                    }
+                    var _db = Biz.Db;
+                    var _dbTran = _db.UseTran(() =>
+                    {
+                        _db.Updateable(input.ErpProdInBths, "U9C_RcvRptDocCreate").UpdateColumns(x => new { x.ORDER_NO, x.REMARK, x.IS_HANDLED, x.HANDLED_DATE, x.UPDATE_USER, x.UPDATE_TIME }).ExecuteCommand();
+                    });
+                    if (!_dbTran.IsSuccess)
+                    {
+                        action.CatchExceptionWithLog(_dbTran.ErrorException, $"鏁版嵁澶勭悊澶辫触");
+                        Logger.Interface.Error(action.Message);
                     }
                 }
                 input.labels = GetLabels(input.PrintJsons);

--
Gitblit v1.9.3