From 257e141d4b8e7f29c5324f9d733ef3df31843c6a Mon Sep 17 00:00:00 2001
From: bklLiudl <673013083@qq.com>
Date: 星期五, 15 三月 2024 11:23:32 +0800
Subject: [PATCH] 入库问题修改

---
 Wms/WMS.BLL/BllAsnServer/PalletBindServer.cs |  109 ++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 69 insertions(+), 40 deletions(-)

diff --git a/Wms/WMS.BLL/BllAsnServer/PalletBindServer.cs b/Wms/WMS.BLL/BllAsnServer/PalletBindServer.cs
index 271b584..e226b67 100644
--- a/Wms/WMS.BLL/BllAsnServer/PalletBindServer.cs
+++ b/Wms/WMS.BLL/BllAsnServer/PalletBindServer.cs
@@ -563,18 +563,23 @@
 
         #region 鎸囧畾鍌ㄤ綅
         //鎸囧畾鍌ㄤ綅鏁版嵁婧愶紙姝e父鐨勭┖鍌ㄤ綅锛�
-        public List<LocatDto> GetLocateList(string houseNo, string roadwayNo, string row, string column, string layer, string locateNo, string BindId, int page, int limit, out int count)
+        public List<LocatDto> GetLocateList(string houseNo, string roadwayNo, string row, string column, string layer, 
+            string locateNo, string BindId, int page, int limit, out int count)
         {
             try
             {
                 //鑾峰彇鎵樼洏缁戝畾
-                var bindASNDetailNo = Db.Queryable<BllPalletBind>().Where(a => a.IsDel == "0" && a.Status == "0" && a.Id == int.Parse(BindId)).Select(a => a.ASNDetailNo).First();
+                var bindASNDetailNo = Db.Queryable<BllPalletBind>().Where(a => a.IsDel == "0" && a.Status == "0" 
+                && a.Id == int.Parse(BindId)).Select(a => a.ASNDetailNo).First();
                 //鑾峰彇鍗曟嵁鏄庣粏
-                var noticeDetailSkuNo = Db.Queryable<BllArrivalNoticeDetail>().Where(a => a.Id == bindASNDetailNo && a.IsDel == "0").Select(a => a.SkuNo).First();
+                var noticeDetailSkuNo = Db.Queryable<BllArrivalNoticeDetail>().Where(a => a.Id == bindASNDetailNo 
+                && a.IsDel == "0").Select(a => a.SkuNo).First();
                 //鑾峰彇鐗╂枡
-                var skuCategoryNo = Db.Queryable<SysMaterials>().Where(a => a.IsDel == "0" && a.SkuNo == noticeDetailSkuNo).Select(a => a.CategoryNo).First();
+                var skuCategoryNo = Db.Queryable<SysMaterials>().Where(a => a.IsDel == "0" && a.SkuNo == noticeDetailSkuNo)
+                    .Select(a => a.CategoryNo).First();
                 //鑾峰彇鐗╂枡瀵瑰簲鍖哄煙
-                var categoryAreaNo = Db.Queryable<SysMaterialCategory>().Where(a => a.IsDel == "0" && a.CategoryNo == skuCategoryNo).Select(a => a.AreaNo).First();
+                var categoryAreaNo = Db.Queryable<SysMaterialCategory>().Where(a => a.IsDel == "0" && a.CategoryNo == skuCategoryNo)
+                    .Select(a => a.AreaNo).First();
 
                 Expression<Func<SysStorageLocat, bool>> item = Expressionable.Create<SysStorageLocat>()
                    .AndIF(!string.IsNullOrWhiteSpace(roadwayNo), m => m.RoadwayNo == roadwayNo)
@@ -595,6 +600,7 @@
                         Row = a.Row,
                         Column = a.Column,
                         Layer = a.Layer,
+                        Depth = a.Depth,
                         Status = a.Status
                     }).ToOffsetPage(page, limit, ref total);
                 count = total;
@@ -755,6 +761,7 @@
         {
             try
             {
+                #region 楠岃瘉鎵樼洏鍚堟硶鎬�
                 //楠岃瘉鎵樼洏鏉$爜鏄惁涓虹┖
                 if (string.IsNullOrEmpty(palletNo))
                 {
@@ -771,17 +778,17 @@
                     throw new Exception("骞冲簱璇蜂娇鐢≒DA鎵嬫寔杩涜骞冲簱鍏ュ簱");
                 }
 
-                OutCommandDto comDto;//杩斿洖wcs鐨勫叆搴撳懡浠�
-                var isHaveLocateNo = false; //鎵樼洏缁戝畾淇℃伅涓槸鍚﹀凡鏈夋寚瀹氬偍浣�
-
                 var stock = Db.Queryable<SysPallets>().First(a => a.PalletNo == palletNo);//鎵樼洏淇℃伅
-
                 //鍒ゆ柇鎵樼洏鏉$爜鏄惁鏈夋晥
                 if (stock == null)
                 {
                     throw new Exception("鎵樼洏鏉$爜涓嶅彈WMS绠$悊锛屼笉鍙叆搴擄紒");
                 }
+                #endregion
 
+
+                OutCommandDto comDto;//杩斿洖wcs鐨勫叆搴撳懡浠�
+                var isHaveLocateNo = false; //  鏄惁宸叉湁鎸囧畾鍌ㄤ綅
                 #region 
 
                 //鏌ヨ鎵樼洏缁戝畾淇℃伅(鐘舵�佷负绛夊緟鍏ュ簱鐨�)
@@ -823,6 +830,8 @@
                         isHaveLocateNo = true; //宸叉湁鎸囧畾鍌ㄤ綅
                     }
 
+
+                    //  楠岃瘉鏄惁鍏宠仈鍗曟嵁锛岃幏鍙栨墭鐩樹笂瀛樻斁鐨勭墿鏂�
                     if (palletBindList.First().Type == "0") //鐗╂枡鎵樺叆搴�
                     {
                         //鍒ゆ柇鏄惁缁戝畾鍗曟嵁鍙婂崟鎹姸鎬佹槸鍚︽甯�
@@ -833,7 +842,7 @@
                             {
                                 throw new Exception("鎵樼洏瀛樺湪鐗╂枡鏈粦瀹氬叆搴撳崟锛屼笉鍙叆搴擄紒");
                             }
-                            if (notice.Status == "3")
+                            if (notice.Status == "3" || notice.Status == "4")
                             {
                                 throw new Exception($"鍏ュ簱鍗晎item.ASNNo}宸插叧闂紝涓嶅彲鍏ュ簱锛�");
                             }
@@ -865,29 +874,23 @@
                     skuNo = stockDetail.First().SkuNo;
 
                     //鑾峰彇瀵瑰簲鍥炲簱瑙勫垯
-                    var function = Db.Queryable<SysFunSetting>().First(a => a.IsDel == "0" && a.FunSetName == "鎵樼洏鍥炲簱楠岃瘉" && a.IsEnable == "NO");
+                    var function = Db.Queryable<SysFunSetting>().First(a => a.IsDel == "0" && a.FunSetNo == "Fun041" && a.IsEnable == "NO");
                     #region 鎵樼洏鍥炲簱瑙勫垯
-
                     if (function != null)
                     {
                         //鎷h揣瀹屾垚鍚庡厑璁告墭鐩樺洖搴�
-                        if (function.SetValue == "CompletePick")
-                        {
-                            var allot = Db.Queryable<BllExportAllot>().First(a => a.IsDel == "0" && a.LotNo == stockDetail[0].LotNo && a.PalletNo == palletNo && a.SkuNo == stockDetail[0].SkuNo);
+                        var allot = Db.Queryable<BllExportAllot>().First(a => a.IsDel == "0" && a.LotNo == stockDetail[0].LotNo && a.PalletNo == palletNo && a.SkuNo == stockDetail[0].SkuNo);
 
-                            //楠岃瘉鎷h揣鏄庣粏鏄惁瀛樺湪
-                            if (allot != null)
+                        //楠岃瘉鎷h揣鏄庣粏鏄惁瀛樺湪
+                        if (allot != null)
+                        {
+                            //楠岃瘉褰撳墠鎵樼洏鎷h揣淇℃伅鏄惁宸插畬鎴�
+                            if (allot.Status != "5")
                             {
-                                //楠岃瘉褰撳墠鎵樼洏鎷h揣淇℃伅鏄惁宸插畬鎴�
-                                if (allot.Status != "5")
-                                {
-                                    throw new Exception("褰撳墠鎵樼洏鎷h揣淇℃伅鏈畬鎴愶紝璇峰畬鎴愬悗鍥炲簱锛�");
-                                }
+                                throw new Exception("褰撳墠鎵樼洏鎷h揣淇℃伅鏈畬鎴愶紝璇峰畬鎴愬悗鍥炲簱锛�");
                             }
                         }
                     }
-
-
                     #endregion
                 }
 
@@ -895,6 +898,7 @@
 
                 SysStorageLocat locate;
 
+                #region 鏍规嵁sku纭鍖哄煙鍒掑垎
                 var sku = skuList.FirstOrDefault(m => m.SkuNo == skuNo);
                 if (sku == null)
                 {
@@ -940,9 +944,10 @@
                     .GroupBy(m => m.RoadwayNo).OrderBy(m => m.RoadwayNo).Select(m => m.RoadwayNo).ToList();
 
                 SysRoadwayUseLog useLog = Db.Queryable<SysRoadwayUseLog>().Where(m => m.IsDel == "0" && roadList.Contains(m.RoadwayNo)).OrderByDescending(l => l.Id).First(); //宸烽亾鏈�鍚庝竴娆′娇鐢ㄨ褰�
+                #endregion
+
 
                 #region 纭畾宸烽亾鎺掑簭
-
                 List<string> roadList2 = new List<string>();
                 List<string> roadSmall = new List<string>();
                 List<string> roadLarge = new List<string>();
@@ -1054,19 +1059,43 @@
                 Db.BeginTran();
                 try
                 {
-                    if (roadNo != null)
+                    //娣诲姞宸烽亾浣跨敤璁板綍
+                    var log = new SysRoadwayUseLog
                     {
-                        //娣诲姞宸烽亾浣跨敤璁板綍
-                        var log = new SysRoadwayUseLog
-                        {
-                            RoadwayNo = roadNo,
-                            WareHouseNo = houseNo,
-                            Row = 0,
-                            Column = 0,
-                            Layer = 0,
-                        };
-                        Db.Insertable(log).ExecuteCommand();
-                    }
+                        RoadwayNo = roadNo,
+                        WareHouseNo = houseNo,
+                        Row = 0,
+                        Column = 0,
+                        Layer = 0,
+                    };
+                    Db.Insertable(log).ExecuteCommand();
+
+                    // 娣诲姞鍏ュ簱鏃ュ織璁板綍
+                    var taskNo = new Common().GetMaxNo("TK");
+                    var exTask = new LogTask    //鍏ュ簱浠诲姟
+                    {
+                        TaskNo = taskNo,
+                        Sender = "WMS",
+                        Receiver = "WCS",
+                        IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+                        SendDate = DateTime.Now,  //鍙戦�佹椂闂�
+                        BackDate = DateTime.Now,  //杩斿洖鏃堕棿
+                        StartRoadway = "",            // 璧峰宸烽亾
+                        StartLocat = "",//璧峰浣嶇疆
+                        EndLocat = "",//鐩爣浣嶇疆
+                        EndRoadway = roadNo,  // 鐩爣宸烽亾
+                        PalletNo = palletNo,//鎵樼洏鐮�
+                        IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                        IsCancel = 1,//鏄惁鍙彇娑�
+                        IsFinish = 1,//鏄惁鍙畬鎴�
+                        Type = "0",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                        Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                        OrderType = "0",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                        Msg = "鍏ュ簱鍙e埌=>>" + roadNo + "宸烽亾鐨勫叆搴撲换鍔�", //鍏抽敭淇℃伅
+
+                    };
+                    Db.Insertable(exTask).ExecuteCommand();
+
 
                     if (palletBindList.Count >= 1)
                     {
@@ -1079,6 +1108,7 @@
                         Db.Updateable(palletBindList).ExecuteCommand();
                     }
                     Db.CommitTran();
+
                     comDto = new OutCommandDto()
                     {
                         PalletNo = palletNo,//鎵樼洏鍙�
@@ -1086,12 +1116,11 @@
                         StartLocate = "", // 璧峰浣嶇疆
                         EndLocate = "", // 鐩爣浣嶇疆 
                         EndRoadway = roadNo,   // 鐩爣宸烽亾
-                        TaskNo = "", // 浠诲姟鍙�
-                        TaskType = "0",// 浠诲姟绫诲瀷 (鍑哄簱)
+                        TaskNo = taskNo, // 浠诲姟鍙�
+                        TaskType = "0",// 浠诲姟绫诲瀷:鍏ュ簱浠诲姟
                         OutMode = "",  //鐩爣鍦板潃
                         Order = 1
                     };
-
                 }
                 catch (Exception ex)
                 {

--
Gitblit v1.8.0