From 6c3738d337fe68c2008b38ad58861aa4b48d5530 Mon Sep 17 00:00:00 2001
From: DESKTOP-9BNTV8O <DESKTOP-9BNTV8O@163.com>
Date: 星期五, 13 十二月 2024 14:46:40 +0800
Subject: [PATCH] 修改问题

---
 Wms/WMS.BLL/BllTransServer/RcsServer.cs |  275 +++++++++++++++++++++++++++++-------------------------
 1 files changed, 146 insertions(+), 129 deletions(-)

diff --git a/Wms/WMS.BLL/BllTransServer/RcsServer.cs b/Wms/WMS.BLL/BllTransServer/RcsServer.cs
index 2570700..1576fe2 100644
--- a/Wms/WMS.BLL/BllTransServer/RcsServer.cs
+++ b/Wms/WMS.BLL/BllTransServer/RcsServer.cs
@@ -28,16 +28,16 @@
         /// <param name="warehouseno">搴撳尯</param>
         /// <param name="type">鍙枡绫诲瀷</param>
         /// <returns></returns>
-        public void GetPalletNo(Pallnetmsg pallnetmsg,string url)
+        public void GetPalletNo(Pallnetmsg model,string url,out string taskNo)
         {
             DataStockDetail pallet = new DataStockDetail();
             try
             {
-                if (string.IsNullOrEmpty(pallnetmsg.Location))
+                if (string.IsNullOrEmpty(model.Location))
                 {
-                    throw new Exception("璁惧浣嶇疆涓嶅彲涓虹┖");
+                    throw new Exception("璁惧鎵�鍦ㄤ綅缃笉鍙负绌�");
                 }
-                var locatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == pallnetmsg.Location);
+                var locatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == model.Location);
                 if (locatInfo == null)
                 {
                     throw new Exception("璁惧鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
@@ -46,7 +46,7 @@
                 var urlMes = "";//鍥炰紶MES鐨勬帴鍙e湴鍧�
                 var noticeno = "0";//鍑哄叆搴撳崟鎹槑缁咺D
                 var sql = "select PalletNo,LocatNo from DataStockDetail where Status = '0'";
-                switch (pallnetmsg.Type)
+                switch (model.Type)
                 {
                     case "0"://鍙噣妗�
                         sql += $"and WareHouseNo = '{house}' and (AreaNo like '%01' or AreaNo like '%11' or AreaNo like '%21' or AreaNo like '%31') and PalletStatus = '0' order by CreateTime desc";
@@ -59,21 +59,12 @@
                         break;
                     case "1"://鍙枡妗讹紙娣锋枡锛�
                         //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(pallnetmsg.LotNo))
+                        if (string.IsNullOrWhiteSpace(model.LotNo))
                         {
                             throw new Exception("鎵规鍙蜂负绌猴紒");
                         }
-                        /*BllArrivalNoticeDetail ArriveMes = new BllArrivalNoticeDetail();
-                        //鍒ゆ柇璇ユ壒娆℃槸鍚︽湁瀵瑰簲鍏ュ簱鍗�
-                        sql = $"select * from BllArrivalNoticeDetail where LotNo =  '{pallnetmsg.LotNo}' order by CreateTime desc";
-                        ArriveMes = Db.Ado.SqlQuery<BllArrivalNoticeDetail>(sql).FirstOrDefault();
-                        if (ArriveMes == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗�");
-                        }
-                        noticeno = ArriveMes.Id.ToString();*/
                         //鏌ユ壘搴撳瓨涓槸鍚︽湁鍙敤鐨勬鎵规鐨勬贩鏂欐《
-                        sql= $@"select PalletNo,LocatNo from DataStockDetail where LotNo = '{pallnetmsg.LotNo}'and  (AreaNo like '%02' or AreaNo like '%12' or AreaNo like '%22' or AreaNo like '%32')
+                        sql= $@"select PalletNo,LocatNo from DataStockDetail where LotNo = '{model.LotNo}'and  (AreaNo like '%02' or AreaNo like '%12' or AreaNo like '%22' or AreaNo like '%32')
                                    and WareHouseNo = '{house}' and status = '0' and PalletStatus = '1' order by CompleteTime desc";
                         pallet = Db.Ado.SqlQuery<DataStockDetail>(sql).FirstOrDefault();
                         if (pallet == null)
@@ -85,12 +76,12 @@
                     case "2"://鍙枡妗讹紙涓嬫枡锛�
                         BllExportNoticeDetail bllSo = new BllExportNoticeDetail();
                         //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(pallnetmsg.LotNo))
+                        if (string.IsNullOrWhiteSpace(model.LotNo))
                         {
                             throw new Exception("鎵规鍙蜂负绌猴紒");
                         }
                         //鏌ユ壘鏄惁鏈夋鎵规鍑哄簱鍗�
-                        sql = $"select * from BllExportNoticeDetail where LotNo =  '{pallnetmsg.LotNo}' order by CreateTime desc";
+                        sql = $"select * from BllExportNoticeDetail where LotNo =  '{model.LotNo}' order by CreateTime desc";
                         bllSo = Db.Ado.SqlQuery<BllExportNoticeDetail>(sql).FirstOrDefault();
                         if (bllSo == null)
                         {
@@ -98,7 +89,7 @@
                         }
                         noticeno = bllSo.Id.ToString();
                         //鏌ユ壘搴撳瓨涓槸鍚︽湁姝ゆ壒娆$殑鍚堟牸涓嬫枡妗�
-                        sql = $@"select PalletNo,LocatNo from DataStockDetail where LotNo = '{pallnetmsg.LotNo}'and (AreaNo like '%03' or AreaNo like '%13' or AreaNo like '%23' or AreaNo like '%33')
+                        sql = $@"select PalletNo,LocatNo from DataStockDetail where LotNo = '{model.LotNo}'and (AreaNo like '%03' or AreaNo like '%13' or AreaNo like '%23' or AreaNo like '%33')
                                     and WareHouseNo = '{house}' and status = '0' and PalletStatus = '2' and InspectStatus = '1' order by CompleteTime desc";
                         pallet = Db.Ado.SqlQuery<DataStockDetail>(sql).FirstOrDefault();
                         if (pallet == null)
@@ -135,9 +126,9 @@
                             //    var task2 = new TaskDetial
                             //    {
                             //        Startport = item.LocatNo,
-                            //        Endport = pallnetmsg.Location,
+                            //        Endport = model.Location,
                             //        Pallno = item.PalletNo,
-                            //        Type = pallnetmsg.Type,
+                            //        Type = model.Type,
                             //        Crtype = "1",
                             //        Noticedetailno = int.Parse(noticeno),
                             //    };
@@ -154,13 +145,13 @@
                             var task2 = new TaskDetial
                             {
                                 Startport = item.LocatNo,
-                                Endport = pallnetmsg.Location,
+                                Endport = model.Location,
                                 Pallno = item.PalletNo,
-                                Type = pallnetmsg.Type,
+                                Type = model.Type,
                                 Crtype = "1",
                                 Noticedetailno = int.Parse(noticeno),
                             };
-                            CreateLotTask(task2, url);
+                            CreateLotTask(task2, url, out taskNo);
                             return;
                         }
                         break;
@@ -171,20 +162,20 @@
                 var task = new TaskDetial
                 {
                     Startport = pallet.LocatNo,//璧峰浣嶇疆
-                    Endport = pallnetmsg.Location,//鐩爣浣嶇疆
+                    Endport = model.Location,//鐩爣浣嶇疆
                     Pallno = pallet.PalletNo,//妗跺彿
-                    Type = pallnetmsg.Type,//妗剁被鍨�
+                    Type = model.Type,//妗剁被鍨�
                     Crtype = "1",
                     Noticedetailno = int.Parse(noticeno),
-                    LotNo = pallnetmsg.LotNo,
+                    LotNo = model.LotNo,
                 };
-                CreateLotTask(task, url);
+                CreateLotTask(task, url, out taskNo);
                 return;
             }
             catch (Exception ex)
             {
                 Db.Ado.RollbackTran();
-                throw ex;
+                throw new Exception(ex.Message);
             }
         }
 
@@ -232,7 +223,8 @@
                         Crtype = "2",
                         Noticedetailno = 0,
                     };
-                    CreateLotTask(ztask,url);
+                    string taskNo = "";
+                    CreateLotTask(ztask, url, out taskNo);
 
                     statrtLocat.Status = "3";//鍑哄簱涓�
                     //淇敼璧峰鍌ㄤ綅鐘舵��
@@ -276,7 +268,8 @@
                     Noticedetailno = 0,
                     LotNo = "",
                 };
-                CreateLotTask(task,url);
+                string taskNo = "";
+                CreateLotTask(task,url, out taskNo);
             }
             catch (Exception ex)
             {
@@ -289,96 +282,91 @@
         /// </summary>
         /// <param name="PalletNo"></param>
         /// <returns></returns>
-        public void ApplyLocatNo(Pallnetmsg pallnetmsg,string url)
+        public void ApplyLocatNo(Pallnetmsg model,string url, out string taskNo)
         {
             var sql = $"select LocatNo from SysStorageLocat where status = '0'";
             var sql2 = "";
-            var house = "W01";//鈥︹�﹀彨妗朵綅缃紝鍚庣画鏍规嵁浣嶇疆鍏宠仈鎴栧畾涔夛紝鏉ュ垽鏂彨妗朵綅缃墍灞炶溅闂�
+            var houseNo = "";//鐢宠鍌ㄤ綅璁惧鎵�鍦ㄨ溅闂寸紪鍙�
             var noticeno = "0";//鍑哄叆搴撳崟鎹槑缁咺D
-            SysStorageLocat loction = new SysStorageLocat();
-            BllArrivalNoticeDetail ArriveMes = new BllArrivalNoticeDetail();
+            SysStorageLocat loction = new SysStorageLocat();//鐩爣鍌ㄤ綅淇℃伅
+            BllArrivalNoticeDetail noticeDetail = new BllArrivalNoticeDetail();//鍏ュ簱鍗曟槑缁�
             try
             {
-                //鍖哄煙淇℃伅
-                var areaInfo = Db.Queryable<SysStorageArea>().First(w => w.IsDel == "0" && w.DeviceCode == pallnetmsg.Location);
-                house = areaInfo.WareHouseNo;//鎵�灞炰粨搴�
-                switch (pallnetmsg.Type)
+                //璁惧鎵�鍦ㄥ偍浣嶄俊鎭�
+                var deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == model.LotNo);
+                if (deviceLocatInfo == null)
                 {
-                    case "0"://鍑�妗剁敵璇峰偍浣�
-                        sql += $"and (AreaNo like '%01' or AreaNo like '%11' or AreaNo like '%21' or AreaNo like '%31') and WareHouseNo = '{house}'";
+                    throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
+                }
+                houseNo = deviceLocatInfo.WareHouseNo;//璁惧鎵�灞炶溅闂�
+                switch (model.Type)
+                {
+                    case "3"://娓呮礂璁惧鐢宠鍌ㄤ綅锛堝噣妗剁敵璇峰偍浣嶏級
+                        sql += $" and (AreaNo like '%01' or AreaNo like '%11' or AreaNo like '%21' or AreaNo like '%31') and WareHouseNo = '{houseNo}'";
                         loction = Db.Ado.SqlQuery<SysStorageLocat>(sql).OrderByDescending(a => a.CreateTime).FirstOrDefault();
                         if (loction == null)
                         {
-                            throw new Exception("搴撳唴鏆傛棤绌轰綑鍑�妗跺偍浣�");
+                            throw new Exception("璇ヨ溅闂村噣妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
                         }
                         break;
-                    case "1"://娣锋枡妗剁敵璇峰偍浣�
+                    case "0"://鎺ユ枡璁惧鐢宠鍌ㄤ綅锛堥娣锋枡妗剁敵璇峰偍浣嶏級
                         //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(pallnetmsg.LotNo))
+                        if (string.IsNullOrWhiteSpace(model.LotNo))
+                        {
+                            throw new Exception("鎵规鍙蜂负绌猴紒");
+                        }
+                        sql += $" and (AreaNo like '%02' or AreaNo like '%12' or AreaNo like '%22' or AreaNo like '%32') and WareHouseNo = '{houseNo}'";
+                        loction = Db.Ado.SqlQuery<SysStorageLocat>(sql).OrderByDescending(a => a.CreateTime).FirstOrDefault();
+                        if (loction == null)
+                        {
+                            throw new Exception("璇ヨ溅闂撮娣峰尯鏆傛棤绌轰綑鍌ㄤ綅");
+                        }
+                        break;
+                    case "1"://娣锋枡璁惧鐢宠鍌ㄤ綅锛堝崐鎴愬搧妗剁敵璇峰偍浣嶏級
+                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
+                        if (string.IsNullOrWhiteSpace(model.LotNo))
                         {
                             throw new Exception("鎵规鍙蜂负绌猴紒");
                         }
                         //鏍¢獙姝ゆ壒娆℃槸鍚︽湁鍏ュ簱鍗�
-                        /*sql2 = $"select * from BllArrivalNoticeDetail where LotNo =  '{pallnetmsg.LotNo}' order by CreateTime desc";
-                        ArriveMes = Db.Ado.SqlQuery<BllArrivalNoticeDetail>(sql).FirstOrDefault();
-                        if (ArriveMes == null)
+                        sql2 = $"select * from BllArrivalNoticeDetail where LotNo =  '{model.LotNo}' order by CreateTime desc";
+                        noticeDetail = Db.Ado.SqlQuery<BllArrivalNoticeDetail>(sql2).FirstOrDefault();
+                        if (noticeDetail == null)
                         {
                             throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗�");
                         }
-                        noticeno = ArriveMes.Id.ToString();*/
-                        sql += $"and (AreaNo like '%02' or AreaNo like '%12' or AreaNo like '%22' or AreaNo like '%32') and WareHouseNo = '{house}'";
+                        noticeno = noticeDetail.Id.ToString();
+                        sql += $" and (AreaNo like '%03' or AreaNo like '%13' or AreaNo like '%23' or AreaNo like '%33') and WareHouseNo = '{houseNo}'";
                         loction = Db.Ado.SqlQuery<SysStorageLocat>(sql).OrderByDescending(a => a.CreateTime).FirstOrDefault();
                         if (loction == null)
                         {
-                            throw new Exception("搴撳唴鏆傛棤绌轰綑娣锋枡妗跺偍浣�");
+                            throw new Exception("璇ヨ溅闂村崐鎴愬搧鍖烘殏鏃犵┖浣欏偍浣�");
                         }
                         break;
-                    case "2"://鍗婃垚鍝佹《鐢宠鍌ㄤ綅
-                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(pallnetmsg.LotNo))
-                        {
-                            throw new Exception("鎵规鍙蜂负绌猴紒");
-                        }
-                        //鏍¢獙姝ゆ壒娆℃槸鍚︽湁鍏ュ簱鍗�
-                        sql2 = $"select * from BllArrivalNoticeDetail where LotNo =  '{pallnetmsg.LotNo}' order by CreateTime desc";
-                        ArriveMes = Db.Ado.SqlQuery<BllArrivalNoticeDetail>(sql2).FirstOrDefault();
-                        if (ArriveMes == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗�");
-                        }
-                        noticeno = ArriveMes.Id.ToString();
-                        sql += $"and (AreaNo like '%03' or AreaNo like '%13' or AreaNo like '%23' or AreaNo like '%33') and WareHouseNo = '{house}'";
+                    case "2"://涓嬫枡璁惧鐢宠鍌ㄤ綅锛堣剰妗剁敵璇峰偍浣嶏級
+                        sql += $" and (AreaNo like '%04' or AreaNo like '%14' or AreaNo like '%24' or AreaNo like '%34') and WareHouseNo = '{houseNo}'";
                         loction = Db.Ado.SqlQuery<SysStorageLocat>(sql).OrderByDescending(a => a.CreateTime).FirstOrDefault();
                         if (loction == null)
                         {
-                            throw new Exception("搴撳唴鏆傛棤绌轰綑鍗婃垚鍝佹《鍌ㄤ綅");
-                        }
-                        break;
-                    case "3"://鑴忔《鐢宠鍌ㄤ綅
-                        sql += $"and (AreaNo like '%04' or AreaNo like '%14' or AreaNo like '%24' or AreaNo like '%34') and WareHouseNo = '{house}'";
-                        loction = Db.Ado.SqlQuery<SysStorageLocat>(sql).OrderByDescending(a => a.CreateTime).FirstOrDefault();
-                        if (loction == null)
-                        {
-                            throw new Exception("搴撳唴鏆傛棤绌轰綑鑴忔《鍌ㄤ綅");
+                            throw new Exception("璇ヨ溅闂磋剰妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
                         }
                         break;
                 }
                 var task = new TaskDetial
                 {
-                    Startport = pallnetmsg.Location,
+                    Startport = model.Location,
                     Endport = loction.LocatNo,
-                    Pallno = pallnetmsg.PalletNo,
-                    Type = pallnetmsg.Type,
-                    Crtype = "0",
+                    Pallno = model.PalletNo,
+                    Type = model.Type,
+                    Crtype = "0",//鍏ュ簱
                     Noticedetailno = int.Parse(noticeno),
-                    LotNo = pallnetmsg.LotNo,
+                    LotNo = model.LotNo,
                 };
-                CreateLotTask(task,url);
+                CreateLotTask(task, url, out taskNo);
             }
-            catch (Exception)
+            catch (Exception ex)
             {
-
-                throw;
+                throw new Exception(ex.Message);
             }
         }
 
@@ -387,53 +375,78 @@
         /// </summary>
         /// <param name="req"></param>
         /// <returns></returns>
-        public void CreateLotTask(TaskDetial taskDetial,string url)
+        public void CreateLotTask(TaskDetial taskDetial,string url,out string taskNo)
         {
             try
             {
+                var stockDetail = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == taskDetial.Pallno);//妗跺簱瀛樻槑缁�
+                if (stockDetail == null)
+                {
+                    throw new Exception($"璇ユ《鏈湪搴撳瓨涓紝妗跺彿锛歿taskDetial.Pallno}");
+                }
                 //寮�鍚簨鍔�
                 Db.BeginTran();
-                var na = "";
+                var typeDesc = "";
                 switch (taskDetial.Crtype)
                 {
                     case "0":
-                        na = "鍏ュ簱";
+                        typeDesc = "鍏ュ簱";
                         break;
                     case "1":
-                        na = "鍑哄簱";
+                        typeDesc = "鍑哄簱";
                         break;
                     case "2":
-                        na = "绉诲簱";
+                        typeDesc = "绉诲簱";
                         break;
                 }
-                var bz = "";
+                var msg = "";
                 switch (taskDetial.Type)
                 {
                     case "0":
-                        bz = "鍑�妗�"+na+"浠诲姟";
+                        msg = "鍑�妗�"+ typeDesc + "浠诲姟";
                         break;
                     case "1":
-                        bz = "棰勬贩鏂欐《" + na + "浠诲姟";
+                        msg = "棰勬贩鏂欐《" + typeDesc + "浠诲姟";
                         break;
                     case "2":
-                        bz = "鍗婃垚鍝佹枡妗�" + na + "浠诲姟";
+                        msg = "鍗婃垚鍝佹枡妗�" + typeDesc + "浠诲姟";
                         break;
                     case "3":
-                        bz = "鑴忔《" + na + "浠诲姟";
+                        msg = "鑴忔《" + typeDesc + "浠诲姟";
                         break;
                 }
+                #region 鍌ㄤ綅淇℃伅
+                //璧峰鍌ㄤ綅鍦板潃淇℃伅
+                var startLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel=="0" && w.LocatNo == taskDetial.Startport);
+                if (startLoction == null)
+                {
+                    throw new Exception($"璧峰鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦紝妗跺彿锛歿taskDetial.Startport}");
+                }
+                //鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                var endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == taskDetial.Endport);
+                if (endLoction == null)
+                {
+                    throw new Exception($"鐩爣鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦紝妗跺彿锛歿taskDetial.Endport}");
+                }
+                #endregion
                 var sql = "";
                 var sql2 = "";
                 var ordertype = "3";
                 //娑夊強鍑哄叆搴撳崟鎹殑鐘舵�佷俊鎭敼鍙�
-                if (taskDetial.Type == "2" && taskDetial.Crtype =="1")//鍗婃垚鍝佸嚭搴�
+                if (taskDetial.Type == "2" && taskDetial.Crtype == "1")//鍗婃垚鍝佸嚭搴�
                 {
                     ordertype = "1";
                     sql = $"UPDATE BllExportNotice SET Status ='1' " +
                         $"where SoNO = (select SoNO from BllExportNoticeDetail where id = {taskDetial.Noticedetailno})";
                     Db.Ado.ExecuteCommand(sql);
                 }
-                else if(taskDetial.Type =="2" && taskDetial.Crtype == "0")//鍗婃垚鍝佸叆搴�
+                else if (taskDetial.Type == "0" && taskDetial.Crtype == "0")//鎺ユ枡璁惧鐢宠鍌ㄤ綅锛堟贩鏂欐《鐢宠鍌ㄤ綅锛�
+                {
+                    stockDetail.LotNo = taskDetial.LotNo;//鎵规鍙�
+                    //鏇存柊妗跺簱瀛樻槑缁嗘壒娆″彿
+                    Db.Updateable(stockDetail).ExecuteCommand();
+                }   
+                else if (taskDetial.Type == "1" && taskDetial.Crtype == "0")//娣锋枡璁惧鐢宠鍌ㄤ綅锛堝崐鎴愬搧妗剁敵璇峰偍浣嶏級
                 {
                     ordertype = "0";
                     var ArrivalMsg = Db.Queryable<BllArrivalNoticeDetail>().First(it => it.Id == taskDetial.Noticedetailno);
@@ -444,13 +457,7 @@
                     sql2 = $"UPDATE DataStockDetail SET SkuNo = '{ArrivalMsg.SkuNo}',SkuName = '{ArrivalMsg.SkuName}' " +
                         $"where PalletNo = '{taskDetial.Pallno}'and LotNo = '{taskDetial.LotNo}'";
                     Db.Ado.ExecuteCommand(sql2);
-                }
-                else if (taskDetial.Type == "1" && taskDetial.Crtype == "0")//棰勬贩妗跺叆搴�
-                {
-                    //棰勬贩妗跺叆搴撴椂娣诲姞鍒板簱瀛樹腑姝ゆ墭鐩樼殑鎵规淇℃伅
-                    sql2 = $"UPDATE DataStockDetail SET LotNo =  '{taskDetial.LotNo}' where PalletNo = '{taskDetial.Pallno}'";
-                    Db.Ado.ExecuteCommand(sql2);
-                }
+                }               
                 
                 //鍒ゆ柇浠诲姟鏄惁涓烘柊浠诲姟
                 if (string.IsNullOrWhiteSpace(taskDetial.Taskno))
@@ -475,8 +482,9 @@
                     OrderType = ordertype,//鍗曟嵁绫诲瀷 0 鍏ュ簱 1 鍑哄簱 3鍏朵粬
                     Status = "0",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
                     NoticeDetailNo = int.Parse(taskDetial.Noticedetailno.ToString()),
-                    Msg = bz, //鍏抽敭淇℃伅
+                    Msg = msg, //鍏抽敭淇℃伅
                 };
+                taskNo = logTaskEntry.TaskNo;
 
                 #region 鍛煎彨灏忚溅浠g爜
                 List<AgvSchedulingTask> agvTaskList = new List<AgvSchedulingTask>();
@@ -485,27 +493,46 @@
                 //璧峰浣嶇疆
                 PositionCodePath path1 = new PositionCodePath();
                 path1.positionCode = taskDetial.Startport;
-                path1.type = "05";
-
+                if (taskDetial.Crtype == "1")//鍙《锛堟《鍑哄簱锛�
+                {
+                    path1.type = "05";
+                }
+                else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+                {
+                    path1.type = "05";
+                }
                 pahtList.Add(path1);
 
                 //鐩爣浣嶇疆
                 PositionCodePath path2 = new PositionCodePath();
                 path2.positionCode = taskDetial.Endport;
-                path2.type = "00";
-
+                if (taskDetial.Crtype == "1")//鍙《锛堟《鍑哄簱锛�
+                {
+                    path2.type = "05";
+                }
+                else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+                {
+                    path2.type = "05";
+                }
                 pahtList.Add(path2);
+
                 //涓嬭溅浠诲姟鍗�
                 AgvSchedulingTask agvTask = new AgvSchedulingTask();
                 agvTask.reqCode = logTaskEntry.TaskNo;//浠诲姟鍙�
-                agvTask.ctnrTyp = "3";
-                agvTask.reqTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//璇锋眰鏃堕棿
-                agvTask.taskTyp = "Z2";//浠诲姟绫诲瀷 绾胯竟鍒版墭鐩樻敹闆嗗櫒 Z1锛� 鎵樼洏鍨涚敵璇峰叆搴� Z2
+                agvTask.ctnrTyp = "1";
+                agvTask.reqTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//璇锋眰鏃堕棿                
                 agvTask.wbCode = "";
                 agvTask.positionCodePath = pahtList;//灏忚溅璺緞
                 agvTask.podCode = "";
-                agvTask.userCallCode = taskDetial.Endport;//鐩爣浣嶇疆
-
+                agvTask.userCallCode = "";//taskDetial.Endport;//鐩爣浣嶇疆
+                if (taskDetial.Crtype == "1")//鍙《锛堟《鍑哄簱锛�
+                {
+                    agvTask.taskTyp = "Z3";//浠诲姟绫诲瀷 绾胯竟鍒版墭鐩樻敹闆嗗櫒 Z1锛� 鎵樼洏鍨涚敵璇峰叆搴� Z2
+                }
+                else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+                {
+                    agvTask.taskTyp = "Z4";//浠诲姟绫诲瀷 绾胯竟鍒版墭鐩樻敹闆嗗櫒 Z1锛� 鎵樼洏鍨涚敵璇峰叆搴� Z2
+                }
                 agvTaskList.Add(agvTask);
 
                 // 姝e紡杩愯绋嬪簭鏀惧紑
@@ -515,7 +542,6 @@
                 jsonData = jsonData.Substring(1);
                 jsonData = jsonData.Substring(0, jsonData.Length - 1);
                 string response = "";
-
                 try
                 {
                     logTaskEntry.SendDate = DateTime.Now;//鍙戦�佹椂闂�
@@ -530,23 +556,14 @@
                         //璇锋眰鎴愬姛淇敼浠诲姟琛ㄧ浉搴斿瓧娈电姸鎬�
                         logTaskEntry.IsSuccess = 1;
                         logTaskEntry.BackDate = DateTime.Now;
-                        logTaskEntry.Status = "1";
-                        if (taskDetial.Crtype == "0" || taskDetial.Crtype == "2")
-                        {
-                            sql = $"UPDATE SysStorageLocat SET Status = '2' where LocatNo = '{taskDetial.Endport}'";
-                            if (taskDetial.Type == "2")
-                            {
-                                sql2 = $"UPDATE DataStockDetail SET PalletStatus = '{taskDetial.Type}'" +
-                                $"where PalletNo = '{taskDetial.Pallno}'";
-                                Db.Ado.ExecuteCommand(sql2);
-                            }
-                        }
-                        else
-                        {
-                            sql = $"UPDATE SysStorageLocat SET Status = '3' where LocatNo = '{taskDetial.Startport}' ";
-                        }
+                        logTaskEntry.Status = "1";                        
                         Db.Insertable(logTaskEntry).ExecuteCommand();
-                        Db.Ado.ExecuteCommand(sql);
+
+                        startLoction.Status = "3";//鍑哄簱涓�
+                        Db.Updateable(startLoction).ExecuteCommand();
+
+                        endLoction.Status = "2";//鍏ュ簱涓�
+                        Db.Updateable(endLoction).ExecuteCommand();
                     }
                     if (agvModel.Code == "1")
                     {

--
Gitblit v1.8.0