From 515978fab272cec55342103182af68c1dcddbfea Mon Sep 17 00:00:00 2001
From: chengsc <Demo@DESKTOP-CPA90BF>
Date: 星期三, 13 十一月 2024 11:38:47 +0800
Subject: [PATCH] 修改问题

---
 Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs | 1323 +++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 860 insertions(+), 463 deletions(-)

diff --git a/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs b/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
index 2e0ef38..1ffa2f4 100644
--- a/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
+++ b/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
@@ -41,7 +41,7 @@
         /// </summary>
         /// <param name="model"></param>
         /// <returns></returns>
-        public bool ErpAddExportNotice(SoInfo model)
+        public void HttpAddExportNotice(SoInfo model)
         {
             try
             {
@@ -49,11 +49,11 @@
                 {
                     throw new Exception("鍗曟嵁绫诲瀷涓嶅彲涓虹┖!");
                 }
-                if (string.IsNullOrEmpty(model.Customer))
-                {
-                    throw new Exception("瀹㈡埛涓嶅彲涓虹┖!");
-                }
-                if (string.IsNullOrEmpty(model.OrderCode))
+                //if (string.IsNullOrEmpty(model.Customer))
+                //{
+                //    throw new Exception("瀹㈡埛涓嶅彲涓虹┖!");
+                //}
+                if (string.IsNullOrEmpty(model.OrderNo))
                 {
                     throw new Exception("绯荤粺鍗曞彿涓嶅彲涓虹┖!");
                 }
@@ -68,10 +68,10 @@
 
                 //瀹㈡埛淇℃伅
                 var customer = Db.Queryable<SysCustomer>().First(m => m.IsDel == "0" && m.CustomerNo == model.Customer);
-                if (customer == null)
-                {
-                    throw new Exception("瀹㈡埛涓嶅彲涓虹┖!");
-                }
+                //if (customer == null)
+                //{
+                //    throw new Exception("瀹㈡埛涓嶅彲涓虹┖!");
+                //}
                 var logistics = Db.Queryable<SysLogisticsInfo>().First(m => m.IsDel == "0" && m.CarrierName == model.LogisticsNo);
                 int? logisticsId = null;
                 if (logistics != null)
@@ -108,48 +108,120 @@
                         }
                         //搴撳瓨
                         List<DataStock> stocks;
+
+                        decimal q1 = 0;
+                        Dictionary<int, decimal> dic = new Dictionary<int, decimal>();
+
                         if (!string.IsNullOrWhiteSpace(d.LotNo))
                         {
                             stocks = stockList.Where(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo).ToList();
+                            if (stocks.Count < 1)
+                            {
+                                throw new Exception($"鎬诲簱瀛樹腑鏈煡璇㈠埌鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}");
+                            }
+                            //鍒ゆ柇鏁伴噺
+                            var qty = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
+                            if (d.Qty > qty)
+                            {
+                                throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                            }
+                            if (qty > d.Qty - q1)
+                            {
+                                dic.Add(stocks.First().Id, d.Qty - q1);
+
+                                q1 += d.Qty - q1;
+                            }
+                            else
+                            {
+                                q1 += qty;
+                                dic.Add(stocks.First().Id, qty);
+                            }
+
                         }
                         else
                         {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
-                        }
-                        if (stocks.Count < 1)
-                        {
-                            throw new Exception($"鎬诲簱瀛樹腑鏈煡璇㈠埌鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}");
+                            stocks = stockList.Where(m => m.SkuNo == d.SkuNo && !string.IsNullOrWhiteSpace(m.LotNo)).OrderBy(s => s.LotNo).ToList();
+
+                            foreach (var demo in stocks)
+                            {
+                                if (q1 >= d.Qty)
+                                {
+                                    continue;
+                                }
+                                var q2 = demo.Qty - demo.LockQty - demo.FrozenQty;
+
+                                if (q2 >= d.Qty - q1)
+                                {
+                                    dic.Add(demo.Id, d.Qty - q1);
+
+                                    q1 += d.Qty - q1;
+                                }
+                                else
+                                {
+                                    q1 += q2;
+                                    dic.Add(demo.Id, q2);
+                                }
+
+                            }
+                            if (d.Qty > q1)
+                            {
+                                stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
+                                if (stocks.Count == 0)
+                                {
+                                    throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}搴撳瓨鏁伴噺涓嶈冻");
+                                }
+                                var q2 = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
+                                if (q2 >= d.Qty - q1)
+                                {
+                                    dic.Add(stocks.First().Id, d.Qty - q1);
+
+                                    q1 += d.Qty - q1;
+                                }
+                                else
+                                {
+                                    q1 += q2;
+                                    dic.Add(stocks.First().Id, q2);
+                                }
+                            }
+                            if (d.Qty > q1)
+                            {
+                                throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo} 搴撳瓨鏁伴噺涓嶈冻");
+                            }
                         }
 
-                        var item = new BllExportNoticeDetail()
+                        foreach (var s in dic)
                         {
-                            SONo = billNo,
-                            SkuNo = sku.SkuNo,
-                            SkuName = sku.SkuName,
-                            Standard = sku.Standard,
-                            LotNo = d.LotNo,
-                            LotText = "",
-                            Qty = d.Qty,
-                            AllotQty = 0,
-                            FactQty = 0,
-                            CompleteQty = 0,
-                            PackagNo = sku.PackagNo,
-                            Price = sku.Price,
-                            Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * d.Qty,
-                            IsBale = "",
-                            IsBelt = "",
-                            SupplierLot = stocks.First().SupplierLot,
-                            IsWave = "0",
-                            WaveNo = "",
-                            IsIssueLotNo = string.IsNullOrWhiteSpace(d.LotNo)? "0":"1",
+                            var st = stockList.First(a => a.Id == s.Key);
+                            var item = new BllExportNoticeDetail()
+                            {
+                                SONo = billNo,
+                                SkuNo = sku.SkuNo,
+                                SkuName = sku.SkuName,
+                                Standard = sku.Standard,
+                                LotNo = st.LotNo,
+                                LotText = st.LotText,
+                                Qty = s.Value,
+                                AllotQty = 0,
+                                FactQty = 0,
+                                CompleteQty = 0,
+                                PackagNo = sku.PackagNo,
+                                Price = sku.Price,
+                                Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * d.Qty,
+                                IsBale = "",
+                                IsBelt = "",
+                                SupplierLot = stocks.First().SupplierLot,
+                                IsWave = "0",
+                                WaveNo = "",
+                                IsIssueLotNo = string.IsNullOrWhiteSpace(d.LotNo) ? "0" : "1",
 
-                            CreateUser = 0,
-                        };
-                        list.Add(item);
-                        stocks.First().LockQty += d.Qty;//閿佸畾鏁伴噺
+                                CreateUser = 0,
+                            };
+                            list.Add(item);
 
-                        var i = Db.Updateable(stocks.First()).UpdateColumns(it => new { it.LockQty })
-                            .ExecuteCommand();
+                            st.LockQty += s.Value;//閿佸畾鏁伴噺
+                            var i = Db.Updateable(st).UpdateColumns(it => new { it.LockQty })
+                                .ExecuteCommand();
+                        }
 
                     }
                     var notice = new BllExportNotice()
@@ -157,9 +229,9 @@
                         SONo = billNo,
                         Type = model.SoType,
                         Status = "0",
-                        Origin = "WMS",
-                        CustomerNo = model.Customer,
-                        CustomerName = customer.CustomerName,
+                        Origin = model.Origin,
+                        //CustomerNo = model.Customer,
+                        //CustomerName = customer.CustomerName,
                         LogisticsId = logisticsId,
                         IsWave = "0",
                         WaveNo = "",
@@ -173,12 +245,10 @@
 
                     if (n <= 0 || m <= 0)
                     {
-                        Db.RollbackTran();
-                        return false;
+                        throw new Exception("鍏ュ簱鍗曟垨鏄庣粏娣诲姞淇濆瓨澶辫触");
                     }
                     Db.CommitTran();
-                    return true;
-
+                    
                 }
                 catch (Exception ex)
                 {
@@ -190,16 +260,27 @@
             }
             catch (Exception ex)
             {
-                Db.RollbackTran();
                 throw new Exception(ex.Message);
             }
         }
 
         //鍥炰紶鍑哄簱鍗�
-        public bool FinishSo(int id, string url, int userId)
+        public bool FinishSo(int id, string url, string userNo, string pwd, int userId)
         {
             try
             {
+                var loginPwd = Md5Tools.CalcMd5(pwd);
+                var date = Db.Queryable<SysUserInfor>().First(m => m.IsDel == "0" && m.UserName == userNo && m.PassWord == loginPwd);
+
+                if (date == null) //璐﹀彿瀵嗙爜鏄惁姝g‘
+                {
+                    throw new Exception("璐﹀彿瀵嗙爜涓嶆纭垨娌℃湁姝よ处鍙�");
+                }
+                if (date.Status != "0") //褰撳墠璐﹀彿鏄惁姝e父鍚敤
+                {
+                    throw new Exception("褰撳墠璐﹀彿闈炲惎鐢ㄧ姸鎬�");
+                }
+
                 var notice = Db.Queryable<BllExportNotice>().First(m => m.Id == id && m.IsDel == "0");
                 if (notice == null)
                 {
@@ -214,7 +295,7 @@
                 {
                     throw new Exception("鏈煡璇㈠埌鍗曟嵁鏄庣粏淇℃伅");
                 }
-                if (userId == notice.UpdateUser)
+                if (date.Id == notice.UpdateUser)
                 {
                     throw new Exception("澶嶆牳澶辫触锛屽鏍镐汉鍛樺拰鍏抽棴璁㈠崟浜哄憳涓嶈兘鐩稿悓锛�");
                 }
@@ -231,7 +312,7 @@
                 }
                 var soInfo = new SoInfo()
                 {
-                    OrderCode = notice.OrderCode,
+                    OrderNo = notice.OrderCode,
                     SoDetails = list
                 };
                 #region 閫氳繃鎺ュ彛鍙戦�佽嚦erp
@@ -249,10 +330,10 @@
 
                 notice.Status = "6";
                 notice.CheckTime = DateTime.Now;
-                notice.CheckUser = userId;
+                notice.CheckUser = date.Id;
                 Db.Updateable(notice).ExecuteCommand();
 
-                new OperationSOServer().AddLogOperationSo("鍑哄簱浣滀笟", "鍑哄簱鍗曟嵁", notice.SONo, "澶嶆牳", $"澶嶆牳浜嗗崟鎹彿涓簕notice.SONo}鐨勫崟鎹俊鎭�", userId);
+                new OperationSOServer().AddLogOperationSo("鍑哄簱浣滀笟", "鍑哄簱鍗曟嵁", notice.SONo, "澶嶆牳", $"{date.RealName}澶嶆牳浜嗗崟鎹彿涓簕notice.SONo}鐨勫崟鎹俊鎭�", userId);
                 return true;
             }
             catch (Exception e)
@@ -294,31 +375,31 @@
                     .LeftJoin<SysUserInfor>((a, b, c, d, e) => a.CheckUser == e.Id)
                     .Select((a, b, c, d, e) => new ExportNoticeDto()
                     {
-                        Id = a.Id,
-                        SONo = a.SONo,
-                        Type = a.Type,
-                        Status = a.Status,
-                        Origin = a.Origin,
-                        CustomerNo = a.CustomerNo,
-                        CustomerName = a.CustomerName,
-                        LotNo = a.LotNo,
-                        LotText = a.LotText,
-                        SupplierLot = a.SupplierLot,
-                        LogisticsId = a.LogisticsId,
+                        //Id = a.Id,
+                        //SONo = a.SONo,
+                        //Type = a.Type,
+                        //Status = a.Status,
+                        //Origin = a.Origin,
+                        //CustomerNo = a.CustomerNo,
+                        //CustomerName = a.CustomerName,
+                        //LotNo = a.LotNo,
+                        //LotText = a.LotText,
+                        //SupplierLot = a.SupplierLot,
+                        //LogisticsId = a.LogisticsId,
                         LogisticsName = b.CarrierName,
-                        IsWave = a.IsWave,
-                        WaveNo = a.WaveNo,
-                        IsDespatch = a.IsDespatch,
-                        Demo = a.Demo,
+                        //IsWave = a.IsWave,
+                        //WaveNo = a.WaveNo,
+                        //IsDespatch = a.IsDespatch,
+                        //Demo = a.Demo,
 
                         CreateUserName = c.RealName,
                         UpdateUserName = c.RealName,
-                        CreateTime = a.CreateTime,
-                        UpdateTime = a.UpdateTime,
+                        //CreateTime = a.CreateTime,
+                        //UpdateTime = a.UpdateTime,
 
                         CheckUserName = e.RealName,
-                        CheckTime = a.CheckTime
-                    })
+                        //CheckTime = a.CheckTime
+                    },true)
                     .OrderByDescending(a => a.CreateTime)
                     .ToOffsetPage(page, limit, ref total);
                 count = total;
@@ -331,42 +412,60 @@
             }
         }
 
-        public List<ExStockInfoDto> GetStockGroupList(string type, string msg)
+        public List<ExStockInfoDto> GetStockGroupList(string type, string ownerNo, string msg)
         {
             try
             {
+                if (string.IsNullOrEmpty(type))
+                {
+                    throw new Exception("璇烽�夋嫨鍑哄簱鍗曠被鍨�");
+                }
+                if (type == "6" && string.IsNullOrEmpty(ownerNo))
+                {
+                    throw new Exception("浠e偍鍗曟嵁璇烽�夋嫨璐т富");
+                }
                 var plnList = new List<string>() { "100099" };
                 var skuList = new List<string>();
                 var sku = Db.Queryable<SysMaterials>().Where(m => m.IsDel == "0" && !plnList.Contains(m.SkuNo)); //鎺掗櫎绌烘墭鐩樼殑鐗╂枡闆嗗悎
                 string skuType = string.Empty;
+                string inspectStatus = string.Empty;
                 switch (type)//0锛氬師鏂� 1锛氬寘鏉� 2锛氭垚鍝� 3锛氳�楁潗 4锛氬崐鎴愬搧
                 {
-                    case "0"://鎴愬搧鍏ュ簱
+                    case "0"://鎴愬搧鍑哄簱
                         skuType = "(2)";
+                        inspectStatus = "1";
                         break;
                     case "1"://棰嗘枡鍑哄簱
                         skuType = "(0,1,3)";
+                        inspectStatus = "1";
                         break;
                     case "2"://鎶芥鍑哄簱
-                        skuType = "(2)";
+                        skuType = "(0,1,2,3)";
+                        inspectStatus = "0,1,2";
                         break;
                     case "3"://鐗╂枡鍙栨牱鍑哄簱
-                        skuType = "(0)";
+                        skuType = "(0,1,2,3)";
+                        inspectStatus = "0";
                         break;
                     case "4"://涓嶅悎鏍煎搧鍑哄簱
-                        skuType = "(2)";
+                        skuType = "(0,1,2,3,4)";
+                        inspectStatus = "2";
                         break;
                     case "5"://涓棿鍝佸嚭搴�
                         skuType = "(4)";
+                        inspectStatus = "0,1";
                         break;
                     case "6"://浠e偍鍑哄簱
-                        skuType = "(2)";
+                        skuType = "(0,1,2,3,4)";
+                        inspectStatus = "0,1,2";
                         break;
                     case "8"://瀵勫瓨鍑哄簱
-                        skuType = "(3)";
+                        skuType = "(0,1,2,3)";
+                        inspectStatus = "0,1";
                         break;
                     default: //鍏跺畠鍑哄簱
                         skuType = "(0,1,2,3,4)";
+                        inspectStatus = "0,1";
                         break;
                 }
                 skuList = sku.Where(m => skuType.Contains(m.Type)).Select(m => m.SkuNo).ToList();
@@ -374,13 +473,24 @@
                 {
                     throw new Exception("鏈煡鍒板搴斿嚭搴撶被鍨嬬殑鐗╂枡");
                 }
+
+                if (type != "8")
+                {
+                    skuList = skuList.Where(m => m != "100088").ToList();
+                }
+                else
+                {
+                    skuList = skuList.Where(m => m == "100088").ToList();
+                }
                 //skuList = sku.Select(m => m.SkuNo).ToList();
                 var stockRst = new StockServer();
                 var stockDetailRst = new StockDetailServer();
                 Expression<Func<DataStockDetail, bool>> item = Expressionable.Create<DataStockDetail>()
                     //.And(it => it.WareHouseNo == wareHouseNo)
-                    .And(it => it.InspectStatus == "1")
+                    .AndIF(!string.IsNullOrWhiteSpace(inspectStatus), it => inspectStatus.Contains(it.InspectStatus))
                     .And(m => skuList.Contains(m.SkuNo))
+                    .AndIF(type == "6", m => m.OwnerNo == ownerNo)//浠e偍鍑哄簱闇�瑕佸叧鑱旇揣涓�
+                    .AndIF(type != "6", m=> string.IsNullOrWhiteSpace(m.OwnerNo))
                     .AndIF(!string.IsNullOrWhiteSpace(msg), it => (it.SkuNo.Contains(msg) || it.SkuName.Contains(msg) || it.LotNo.Contains(msg)))
                     .And(it => (it.Qty - it.LockQty - it.FrozenQty) > 0)
                     .And(it => (it.Status == "0" || it.Status == "1"))
@@ -409,7 +519,8 @@
                     SkuName = it.SkuName,
                     LotNo = it.LotNo,
                     Standard = it.Standard,
-                    Qty = type == "4" ? it.Qty : it.Qty - it.LockQty - it.FrozenQty
+                    //Qty = type == "4" ? it.Qty : it.Qty - it.LockQty - it.FrozenQty,
+                    Qty = it.Qty - it.LockQty - it.FrozenQty,
 
                 }).ToList();
 
@@ -494,27 +605,80 @@
                         }
                         //搴撳瓨
                         List<DataStock> stocks;
-                        //List<DataStockDetail> pallets;
+
+                        decimal q1 = 0;
+                        Dictionary<int, decimal> dic = new Dictionary<int, decimal>();
                         if (!string.IsNullOrWhiteSpace(d.LotNo))
                         {
                             stocks = stockList.Where(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo).ToList();
-                            //pallets = palletList.Where(p => p.SkuNo == d.SkuNo && p.LotNo == d.LotNo).ToList();
+                            //if (stocks.Count < 1)
+                            //{
+                            //    throw new Exception($"鎬诲簱瀛樹腑鏈煡璇㈠埌鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}");
+                            //}
+                            ////鍒ゆ柇鏁伴噺
+                            //var qty = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
+                            //if (d.Qty > qty)
+                            //{
+                            //    throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                            //}
+                            //if (qty > d.Qty - q1)
+                            //{
+                            //    q1 += d.Qty - q1;
+                            //    dic.Add(stocks.First().Id, d.Qty - q1);
+                            //}
+                            //else
+                            //{
+                            //    q1 += qty;
+                            //    dic.Add(stocks.First().Id, qty);
+                            //}
                         }
                         else
                         {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
-                            //pallets = palletList.Where(p => p.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(p.LotNo)).ToList();
-                        }
-                        if (stocks.Count < 1)
-                        {
-                            throw new Exception($"鎬诲簱瀛樹腑鏈煡璇㈠埌鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}");
-                        }
+                            //stocks = stockList.Where(m => m.SkuNo == d.SkuNo && !string.IsNullOrWhiteSpace(m.LotNo)).OrderBy(s => s.LotNo).ToList();
 
-                        //鍒ゆ柇鏁伴噺
-                        var qty = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
-                        if (d.Qty > qty)
-                        {
-                            throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                            //foreach (var demo in stocks)
+                            //{
+                            //    if (q1 >= d.Qty)
+                            //    {
+                            //        continue;
+                            //    }
+                            //    var q2 = demo.Qty - demo.LockQty - demo.FrozenQty;
+
+                            //    if (q2 > d.Qty - q1)
+                            //    {
+                            //        q1 += d.Qty - q1;
+                            //        dic.Add(demo.Id, d.Qty - q1);
+                            //    }
+                            //    else
+                            //    {
+                            //        q1 += q2;
+                            //        dic.Add(demo.Id, q2);
+                            //    }
+
+                            //}
+                            //if (d.Qty >= q1)
+                            //{
+                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
+                            //    if (stocks.Count == 0)
+                            //    {
+                            //        throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}搴撳瓨鏁伴噺涓嶈冻");
+                            //    }
+                            //    var q2 = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
+                            //    if (q2 > d.Qty - q1)
+                            //    {
+                            //        q1 += d.Qty - q1;
+                            //        dic.Add(stocks.First().Id, d.Qty - q1);
+                            //    }
+                            //    else
+                            //    {
+                            //        q1 += q2;
+                            //        dic.Add(stocks.First().Id, q2);
+                            //    }
+                            //}
+                            //if (d.Qty > q1)
+                            //{
+                            //    throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo} 搴撳瓨鏁伴噺涓嶈冻");
+                            //}
                         }
 
                         var item = new BllExportNoticeDetail()
@@ -542,10 +706,19 @@
                             CreateUser = userId,
                         };
                         list.Add(item);
-                        stocks.First().LockQty += d.Qty;//閿佸畾鏁伴噺
 
+
+                        stocks.First().LockQty += d.Qty;//閿佸畾鏁伴噺
                         var i = Db.Updateable(stocks.First()).UpdateColumns(it => new { it.LockQty })
                             .ExecuteCommand();
+
+                        //foreach (var s in dic)
+                        //{
+                        //    var st = stockList.First(m => m.Id == s.Key);
+                        //    st.LockQty += s.Value;//閿佸畾鏁伴噺
+                        //    var i = Db.Updateable(st).UpdateColumns(it => new { it.LockQty })
+                        //        .ExecuteCommand();
+                        //}
 
                     }
                     var notice = new BllExportNotice()
@@ -688,161 +861,285 @@
 
                 try
                 {
-                    //鍒犻櫎鏃�
-                    foreach (var d in noticeDetail)
+                    if (notice.Origin == "WMS")
                     {
-                        var mq = model.Detail.Where(o => o.SkuNo == d.SkuNo).ToList();
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
+                        //鍒犻櫎鏃�
+                        foreach (var d in noticeDetail)
                         {
-                            mq = mq.Where(o => o.LotNo == d.LotNo).ToList();
-                        }
-                        if (mq.Any()) //濡傛灉鏈夎繖涓墿鏂欏強鎵规鍒欒烦杩�
-                        {
-                            continue;
-                        }
-                        //
-                        var fl = stockList.Where(s => s.SkuNo == d.SkuNo).ToList();
-                        DataStock fls;
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            fls = fl.FirstOrDefault(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo);
-                        }
-                        else
-                        {
-                            fls = fl.FirstOrDefault(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo));
-                        }
-                        if (fls == null)
-                        {
-                            throw new Exception($"鏈壘鍒扮墿鏂檣d.SkuNo}銆佹壒娆d.LotNo} 鐨勫簱瀛樹俊鎭�");
-                        }
-                        fls.LockQty -= d.Qty;
-                        d.IsDel = "1";
-                        d.UpdateUser = userId;
-                        d.UpdateTime = DateTime.Now;
-                        Db.Updateable(d).ExecuteCommand();
-                        Db.Updateable(fls).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
-                    }
-
-                    //鏇存柊鍑哄簱鍗�
-                    foreach (var d in model.Detail)
-                    {
-                        if (d.Qty < 1)
-                        {
-                            throw new Exception("鍑哄簱鏁版嵁蹇呴』澶т簬0");
-                        }
-                        var sku = skuList.FirstOrDefault(a => a.SkuNo == d.SkuNo);
-                        if (sku == null)
-                        {
-                            throw new Exception("鍑哄簱鐗╁搧涓虹┖");
-                        }
-                        //搴撳瓨
-                        List<DataStock> stocks;
-                        List<DataStockDetail> pallet;
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo).ToList();
-                            pallet = palletList.Where(p => p.SkuNo == d.SkuNo && p.LotNo == d.LotNo).ToList();
-                        }
-                        else
-                        {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
-                            pallet = palletList.Where(p => p.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(p.LotNo)).ToList();
-                        }
-
-                        if (stocks.Count < 1)
-                        {
-                            throw new Exception("鍑哄簱鐗╁搧搴撳瓨涓嶈冻");
-                        }
-                        var stock = stocks.First();//鎬诲簱瀛�
-                        //
-                        BllExportNoticeDetail old;
-                        if (string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(o.LotNo));
-                        }
-                        else
-                        {
-                            old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && o.LotNo == d.LotNo);
-                        }
-
-                        //鏂板姞椤�
-                        if (old == null)
-                        {
-                            //鍒ゆ柇鏁伴噺
-                            var qty = stock.Qty - stock.LockQty - stock.FrozenQty;
-                            if (d.Qty > qty)
+                            var mq = model.Detail.Where(o => o.SkuNo == d.SkuNo).ToList();
+                            if (!string.IsNullOrWhiteSpace(d.LotNo))
                             {
-                                throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                                mq = mq.Where(o => o.LotNo == d.LotNo).ToList();
                             }
-
-                            var item = new BllExportNoticeDetail()
+                            if (mq.Any()) //濡傛灉鏈夎繖涓墿鏂欏強鎵规鍒欒烦杩�
                             {
-                                SONo = notice.SONo,
-                                SkuNo = sku.SkuNo,
-                                SkuName = sku.SkuName,
-                                Standard = sku.Standard,
-                                LotNo = d.LotNo,
-                                LotText = "",
-                                Status = "0",
-                                Qty = d.Qty,
-                                AllotQty = 0,
-                                FactQty = 0,
-                                CompleteQty = 0,
-                                PackagNo = sku.PackagNo,
-                                Price = sku.Price,
-                                Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * qty,
-                                IsBale = d.IsBale,
-                                IsBelt = d.IsBelt,
-                                SupplierLot = stocks.First().SupplierLot,
-                                IsWave = "0",
-                                WaveNo = "",
-
-                                CreateUser = userId,
-                            };
-
-                            stock.LockQty += d.Qty;//閿佸畾鏁伴噺
-                            var m = Db.Insertable<BllExportNoticeDetail>(item).ExecuteCommand();
-                            var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
-                        }
-                        else if (old.Qty != d.Qty || old.IsBale != d.IsBale || old.IsBelt != d.IsBelt)
-                        {
-                            if (d.Qty > (stock.Qty - stock.FrozenQty - stock.LockQty) + old.Qty)
-                            {
-                                throw new Exception("鐗╁搧搴撳瓨鏁伴噺涓嶈冻");
+                                continue;
                             }
-                            //澧炲姞
-                            if (d.Qty > old.Qty)
+                            //
+                            var fl = stockList.Where(s => s.SkuNo == d.SkuNo).ToList();
+                            DataStock fls;
+                            if (!string.IsNullOrWhiteSpace(d.LotNo))
                             {
-                                stock.LockQty += d.Qty - old.Qty;
+                                fls = fl.FirstOrDefault(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo);
                             }
                             else
                             {
-                                stock.LockQty -= old.Qty - d.Qty;
+                                fls = fl.FirstOrDefault(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo));
                             }
-                            old.IsBale = d.IsBale;
-                            old.IsBelt = d.IsBelt;
-                            old.Qty = d.Qty;
-                            old.UpdateUser = userId;
-                            old.UpdateTime = DateTime.Now;
-                            var m = Db.Updateable(old).UpdateColumns(it => new { it.IsBale, it.IsBelt, it.Qty, it.UpdateUser, it.UpdateTime }).ExecuteCommand();
-                            var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            if (fls == null)
+                            {
+                                throw new Exception($"鏈壘鍒扮墿鏂檣d.SkuNo}銆佹壒娆d.LotNo} 鐨勫簱瀛樹俊鎭�");
+                            }
+                            fls.LockQty -= d.Qty;
+                            d.IsDel = "1";
+                            d.UpdateUser = userId;
+                            d.UpdateTime = DateTime.Now;
+                            Db.Updateable(d).ExecuteCommand();
+                            Db.Updateable(fls).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                        }
+
+                        //鏇存柊鍑哄簱鍗�
+                        foreach (var d in model.Detail)
+                        {
+                            if (d.Qty < 1)
+                            {
+                                throw new Exception("鍑哄簱鏁版嵁蹇呴』澶т簬0");
+                            }
+                            var sku = skuList.FirstOrDefault(a => a.SkuNo == d.SkuNo);
+                            if (sku == null)
+                            {
+                                throw new Exception("鍑哄簱鐗╁搧涓虹┖");
+                            }
+                            //搴撳瓨
+                            List<DataStock> stocks;
+                            List<DataStockDetail> pallet;
+                            if (!string.IsNullOrWhiteSpace(d.LotNo))
+                            {
+                                stocks = stockList.Where(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo).ToList();
+                                pallet = palletList.Where(p => p.SkuNo == d.SkuNo && p.LotNo == d.LotNo).ToList();
+                            }
+                            else
+                            {
+                                stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
+                                pallet = palletList.Where(p => p.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(p.LotNo)).ToList();
+                            }
+
+                            if (stocks.Count < 1)
+                            {
+                                throw new Exception("鍑哄簱鐗╁搧搴撳瓨涓嶈冻");
+                            }
+                            var stock = stocks.First();//鎬诲簱瀛�
+                            //
+                            BllExportNoticeDetail old;
+                            if (string.IsNullOrWhiteSpace(d.LotNo))
+                            {
+                                old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(o.LotNo));
+                            }
+                            else
+                            {
+                                old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && o.LotNo == d.LotNo);
+                            }
+
+                            //鏂板姞椤�
+                            if (old == null)
+                            {
+                                //鍒ゆ柇鏁伴噺
+                                var qty = stock.Qty - stock.LockQty - stock.FrozenQty;
+                                if (d.Qty > qty)
+                                {
+                                    throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                                }
+
+                                var item = new BllExportNoticeDetail()
+                                {
+                                    SONo = notice.SONo,
+                                    SkuNo = sku.SkuNo,
+                                    SkuName = sku.SkuName,
+                                    Standard = sku.Standard,
+                                    LotNo = d.LotNo,
+                                    LotText = "",
+                                    Status = "0",
+                                    Qty = d.Qty,
+                                    AllotQty = 0,
+                                    FactQty = 0,
+                                    CompleteQty = 0,
+                                    PackagNo = sku.PackagNo,
+                                    Price = sku.Price,
+                                    Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * qty,
+                                    IsBale = d.IsBale,
+                                    IsBelt = d.IsBelt,
+                                    SupplierLot = stocks.First().SupplierLot,
+                                    IsWave = "0",
+                                    WaveNo = "",
+
+                                    CreateUser = userId,
+                                };
+
+                                stock.LockQty += d.Qty;//閿佸畾鏁伴噺
+                                var m = Db.Insertable<BllExportNoticeDetail>(item).ExecuteCommand();
+                                var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            }
+                            else if (old.Qty != d.Qty || old.IsBale != d.IsBale || old.IsBelt != d.IsBelt)
+                            {
+                                if (d.Qty > (stock.Qty - stock.FrozenQty - stock.LockQty) + old.Qty)
+                                {
+                                    throw new Exception("鐗╁搧搴撳瓨鏁伴噺涓嶈冻");
+                                }
+                                //澧炲姞
+                                if (d.Qty > old.Qty)
+                                {
+                                    stock.LockQty += d.Qty - old.Qty;
+                                }
+                                else
+                                {
+                                    stock.LockQty -= old.Qty - d.Qty;
+                                }
+                                old.IsBale = d.IsBale;
+                                old.IsBelt = d.IsBelt;
+                                old.Qty = d.Qty;
+                                old.UpdateUser = userId;
+                                old.UpdateTime = DateTime.Now;
+                                var m = Db.Updateable(old).UpdateColumns(it => new { it.IsBale, it.IsBelt, it.Qty, it.UpdateUser, it.UpdateTime }).ExecuteCommand();
+                                var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            }
+                        }
+
+                        //瀹㈡埛淇℃伅
+                        var customer = Db.Queryable<SysCustomer>().Where(m => m.IsDel == "0" && m.CustomerNo == model.CustomerNo).ToList().FirstOrDefault();
+                        notice.Type = model.Type;
+                        notice.CustomerNo = model.CustomerNo;
+                        notice.CustomerName = customer == null ? "" : customer.CustomerName;
+                        notice.LogisticsId = model.LogisticsId;
+                        notice.UpdateUser = userId;
+                        notice.UpdateTime = DateTime.Now;
+
+                        var n = Db.Updateable(notice).ExecuteCommand();
+                        if (n <= 0)
+                        {
+                            Db.RollbackTran();
+                            return false;
                         }
                     }
-
-                    //瀹㈡埛淇℃伅
-                    var customer = Db.Queryable<SysCustomer>().Where(m => m.IsDel == "0" && m.CustomerNo == model.CustomerNo).ToList().FirstOrDefault();
-                    notice.Type = model.Type;
-                    notice.CustomerNo = model.CustomerNo;
-                    notice.CustomerName = customer == null ? "" : customer.CustomerName;
-                    notice.LogisticsId = model.LogisticsId;
-                    notice.UpdateUser = userId;
-                    notice.UpdateTime = DateTime.Now;
-
-                    var n = Db.Updateable(notice).ExecuteCommand();
-                    if (n <= 0)
+                    else  //erp/mes
                     {
-                        Db.RollbackTran();
-                        return false;
+                        //鏇存柊鍑哄簱鍗�
+                        foreach (var d in model.Detail)
+                        {
+                            if (d.Qty < 1)
+                            {
+                                throw new Exception("鍑哄簱鏁版嵁蹇呴』澶т簬0");
+                            }
+                            var sku = skuList.FirstOrDefault(a => a.SkuNo == d.SkuNo);
+                            if (sku == null)
+                            {
+                                throw new Exception("鍑哄簱鐗╁搧涓虹┖");
+                            }
+                            //搴撳瓨
+                            List<DataStock> stocks;
+                            if (!string.IsNullOrWhiteSpace(d.LotNo))
+                            {
+                                stocks = stockList.Where(s => s.SkuNo == d.SkuNo && d.LotNo.Contains(s.LotNo)).ToList();
+                            }
+                            else
+                            {
+                                stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
+                            }
+
+                            if (stocks.Count < 1)
+                            {
+                                throw new Exception("鍑哄簱鐗╁搧搴撳瓨涓嶈冻");
+                            }
+                            var stock = stocks.First();//鎬诲簱瀛�
+                            //
+                            BllExportNoticeDetail old;
+                            if (string.IsNullOrWhiteSpace(d.LotNo))
+                            {
+                                old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(o.LotNo));
+                            }
+                            else
+                            {
+                                old = noticeDetail.FirstOrDefault(o => o.SkuNo == d.SkuNo && o.LotNo == d.LotNo);
+                            }
+
+                            //鏂板姞椤�
+                            if (old == null)
+                            {
+                                //鍒ゆ柇鏁伴噺
+                                var qty = stock.Qty - stock.LockQty - stock.FrozenQty;
+                                if (d.Qty > qty)
+                                {
+                                    throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
+                                }
+
+                                var item = new BllExportNoticeDetail()
+                                {
+                                    SONo = notice.SONo,
+                                    SkuNo = sku.SkuNo,
+                                    SkuName = sku.SkuName,
+                                    Standard = sku.Standard,
+                                    LotNo = d.LotNo,
+                                    LotText = "",
+                                    Status = "0",
+                                    Qty = d.Qty,
+                                    AllotQty = 0,
+                                    FactQty = 0,
+                                    CompleteQty = 0,
+                                    PackagNo = sku.PackagNo,
+                                    Price = sku.Price,
+                                    Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * qty,
+                                    IsBale = d.IsBale,
+                                    IsBelt = d.IsBelt,
+                                    SupplierLot = stocks.First().SupplierLot,
+                                    IsWave = "0",
+                                    WaveNo = "",
+
+                                    CreateUser = userId,
+                                };
+
+                                stock.LockQty += d.Qty;//閿佸畾鏁伴噺
+                                var m = Db.Insertable<BllExportNoticeDetail>(item).ExecuteCommand();
+                                var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            }
+                            else if (old.Qty != d.Qty || old.IsBale != d.IsBale || old.IsBelt != d.IsBelt)
+                            {
+                                if (d.Qty > (stock.Qty - stock.FrozenQty - stock.LockQty) + old.Qty)
+                                {
+                                    throw new Exception("鐗╁搧搴撳瓨鏁伴噺涓嶈冻");
+                                }
+                                //澧炲姞
+                                if (d.Qty > old.Qty)
+                                {
+                                    stock.LockQty += d.Qty - old.Qty;
+                                }
+                                else
+                                {
+                                    stock.LockQty -= old.Qty - d.Qty;
+                                }
+                                old.IsBale = d.IsBale;
+                                old.IsBelt = d.IsBelt;
+                                old.Qty = d.Qty;
+                                old.UpdateUser = userId;
+                                old.UpdateTime = DateTime.Now;
+                                var m = Db.Updateable(old).UpdateColumns(it => new { it.IsBale, it.IsBelt, it.Qty, it.UpdateUser, it.UpdateTime }).ExecuteCommand();
+                                var i = Db.Updateable(stock).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            }
+                        }
+
+                        //瀹㈡埛淇℃伅
+                        var customer = Db.Queryable<SysCustomer>().Where(m => m.IsDel == "0" && m.CustomerNo == model.CustomerNo).ToList().FirstOrDefault();
+                        notice.Type = model.Type;
+                        notice.CustomerNo = model.CustomerNo;
+                        notice.CustomerName = customer == null ? "" : customer.CustomerName;
+                        notice.LogisticsId = model.LogisticsId;
+                        notice.UpdateUser = userId;
+                        notice.UpdateTime = DateTime.Now;
+
+                        var n = Db.Updateable(notice).ExecuteCommand();
+                        if (n <= 0)
+                        {
+                            Db.RollbackTran();
+                            return false;
+                        }
                     }
                     //娣诲姞鎿嶄綔鏃ュ織璁板綍
                     var k = new OperationSOServer().AddLogOperationSo("鍑哄簱浣滀笟", "鍑哄簱鍗曟嵁", notice.SONo, "缂栬緫", $"缂栬緫浜嗗崟鎹彿涓簕notice.SONo}鐨勫崟鎹俊鎭�", userId);
@@ -949,9 +1246,9 @@
                 {
                     throw new Exception("鏈煡璇㈠埌鍑哄簱鍗曟嵁淇℃伅");
                 }
-                if (notice.Status != "4")
+                if (notice.Status != "4" && notice.Status != "3")
                 {
-                    throw new Exception("鍙傛暟寮傚父,璇锋鏌ョ姸鎬佹槸鍚︿负鎵ц瀹屾垚鎴栬鍗曞叧闂�");
+                    throw new Exception("鍙傛暟寮傚父,璇锋鏌ョ姸鎬佹槸鍚︿负姝e湪鎵ц鎴栨墽琛屽畬鎴�");
                 }
                 //鎬诲簱瀛樹俊鎭�
                 var stockList = Db.Queryable<DataStock>().ToList();
@@ -972,64 +1269,67 @@
 
                     foreach (var d in noticeDetail)
                     {
-                        //鏇存敼搴撳瓨鏄庣粏閿佸畾鏁伴噺
-                        //var orders = dataContext.WmsExportOrder.Where(o => o.ExportDetailId == d.Id
-                        //                && o.ExportExecuteFlag != "4" && o.ExportExecuteFlag == "3" && o.pickingType == 0).ToList();
-                        //foreach (var o in orders)
-                        //{
-                        //    if (o.ExportQuantity > o.PickedNum) //鍒ゆ柇鎷h揣鏄惁宸叉嫞瀹�
-                        //    {
-                        //        var pq = dataContext.WmsStockTray.Where(t => t.StockGoodId == o.ExportGoodsCode && t.StockStockCode == o.ExportStockCode);
-
-                        //        if (string.IsNullOrWhiteSpace(o.ExportLotNo))
-                        //        {
-                        //            pq = pq.Where(t => t.StockLotNo == null || t.StockLotNo == "");
-                        //        }
-                        //        else
-                        //        {
-                        //            pq = pq.Where(t => t.StockLotNo == o.ExportLotNo);
-                        //        }
-                        //        var pallet = pq.FirstOrDefault();
-                        //        //搴撳瓨鎵樼洏淇℃伅閿佸畾鏁伴噺杩樺師涓烘湭閿佸畾
-                        //        if (pq != null)
-                        //        {
-                        //            pallet.LockQuantity -= o.ExportQuantity.Value - o.PickedNum;
-                        //            pallet.StockQuantity += o.ExportQuantity.Value - o.PickedNum;
-                        //        }
-                        //    }
-                        //}
-
-                        if (d.Qty != d.CompleteQty)
+                        if (notice.Type == "0")//鎴愬搧鍑哄簱
                         {
-                            throw new Exception("褰撳墠鍗曟嵁鏄庣粏涓鍒掓暟閲忎笌鎷h揣鏁伴噺涓嶇锛岃鏍稿疄");
-                        }
-                        #region 搴撳瓨琛ㄥ噺鍘婚攣瀹氭暟閲忎笌鎬绘暟閲�(PDA鎷h揣鐨勬椂鍊欏凡缁忓噺鍘绘暟閲忎簡)
-                        /*var sq = stocks.Where(s => s.SkuNo == d.SkuNo);
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            sq = sq.Where(s => s.LotNo == d.LotNo);
-                        }
-                        else
-                        {
-                            sq = sq.Where(s => string.IsNullOrWhiteSpace(s.LotNo));
-                        }
-                        var st = sq.FirstOrDefault();
-                        if (st != null)
-                        {
-                            if (d.CompleteQty <= d.Qty)
+                            if (d.Qty != d.CompleteQty)
                             {
-                                st.Qty += d.Qty - d.CompleteQty.Value;
+                                throw new Exception("褰撳墠鍗曟嵁鏄庣粏涓鍒掓暟閲忎笌鎷h揣鏁伴噺涓嶇锛岃鏍稿疄");
+                            }
+                        }
+                        if (d.Qty < d.CompleteQty)
+                        {
+                            //鏇存敼搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                            var allotList = Db.Queryable<BllExportAllot>().Where(o => o.SODetailNo == d.Id && o.Status == "3" && o.IsDel == "0").ToList();
+                            foreach (var o in allotList)
+                            {
+                                if (o.Qty > o.CompleteQty) //鍒ゆ柇鎷h揣鏄惁宸叉嫞瀹�
+                                {
+                                    var pq = Db.Queryable<DataStockDetail>().Where(t => t.IsDel == "0" && t.Id == o.StockId && t.SkuNo == o.SkuNo);
+
+                                    if (string.IsNullOrWhiteSpace(o.LotNo))
+                                    {
+                                        pq = pq.Where(t => string.IsNullOrWhiteSpace(t.LotNo));
+                                    }
+                                    else
+                                    {
+                                        pq = pq.Where(t => t.LotNo == o.LotNo);
+                                    }
+                                    var pallet = pq.First();
+                                    //搴撳瓨鎵樼洏淇℃伅閿佸畾鏁伴噺杩樺師涓烘湭閿佸畾
+                                    if (pq != null)
+                                    {
+                                        //pallet.Qty -= o.CompleteQty.Value - o.Qty;
+                                        pallet.LockQty -= o.Qty - o.CompleteQty.Value;
+                                        Db.Updateable(pallet).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                                    }
+                                }
+                            }
+
+
+                            #region 搴撳瓨琛ㄥ噺鍘婚攣瀹氭暟閲忎笌鎬绘暟閲�(PDA鎷h揣鐨勬椂鍊欏凡缁忓噺鍘绘暟閲忎簡)
+                            var sq = stocks.Where(s => s.SkuNo == d.SkuNo);
+                            if (!string.IsNullOrWhiteSpace(d.LotNo))
+                            {
+                                sq = sq.Where(s => s.LotNo == d.LotNo);
                             }
                             else
                             {
-                                st.Qty -= d.CompleteQty.Value - d.Qty;
+                                sq = sq.Where(s => string.IsNullOrWhiteSpace(s.LotNo));
                             }
-                            st.LockQty -= d.Qty;
-                            st.Qty -= d.Qty;
-                            //淇敼鎬诲簱瀛樿〃
-                            Db.Updateable(st).UpdateColumns(it => new { it.Qty, it.LockQty }).ExecuteCommand();
-                        }*/
-                        #endregion
+                            if (notice.Type == "6")//浠e偍
+                            {
+                                sq = sq.Where(s => s.OwnerNo == notice.CustomerNo);
+                            }
+                            var st = sq.FirstOrDefault();
+                            if (st != null)
+                            {
+                                st.LockQty -= d.Qty - d.CompleteQty.Value;
+                                //淇敼鎬诲簱瀛樿〃
+                                Db.Updateable(st).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                            }
+                            #endregion
+                        }
+
                     }
                     //娣诲姞鎿嶄綔鏃ュ織璁板綍
                     var k = new OperationSOServer().AddLogOperationSo("鍑哄簱浣滀笟", "鍑哄簱鍗曟嵁", notice.SONo, "鍏冲崟", $"鍏抽棴浜嗗崟鎹彿涓簕notice.SONo}鐨勫崟鎹俊鎭�", userId);
@@ -1598,6 +1898,7 @@
                                     OutMode = "",  //鐩爣鍦板潃
                                     Order = 1
                                 });
+                                taskNoStr = exTask.TaskNo;
                             }
                             else if (locate.Depth == "02") //娣卞害涓�2
                             {
@@ -1686,7 +1987,7 @@
                                                     IsSuccess = 0, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
 
                                                     StartLocat = stockNew.LocatNo,//璧峰浣嶇疆
-                                                    EndLocat = "",//鐩爣浣嶇疆
+                                                    EndLocat = toLocation,//鐩爣浣嶇疆
                                                     PalletNo = stockNew.PalletNo,//鎵樼洏鐮�
                                                     IsSend = 1,//鏄惁鍙啀娆′笅鍙�
                                                     IsCancel = 1,//鏄惁鍙彇娑�
@@ -1703,7 +2004,7 @@
                                                     StartRoadway = slotBefore.RoadwayNo, //璧峰宸烽亾
                                                     PalletNo = stockNew.PalletNo,//鎵樼洏鍙�
                                                     StartLocate = stockNew.LocatNo, // 璧峰浣嶇疆
-                                                    EndLocate = "", // 鐩爣浣嶇疆 
+                                                    EndLocate = toLocation, // 鐩爣浣嶇疆 
                                                     EndRoadway = "", // 鐩爣宸烽亾 
                                                     TaskNo = exYkTask1.TaskNo, // 浠诲姟鍙�
                                                     TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
@@ -1740,7 +2041,7 @@
                                     IsSuccess = 0, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
 
                                     StartLocat = locate.LocatNo,//璧峰浣嶇疆
-                                    EndLocat = "",//鐩爣浣嶇疆
+                                    EndLocat = toLocation,//鐩爣浣嶇疆
                                     PalletNo = item.PalletNo,//鎵樼洏鐮�
                                     IsSend = 1,//鏄惁鍙啀娆′笅鍙�
                                     IsCancel = 1,//鏄惁鍙彇娑�
@@ -1751,13 +2052,13 @@
                                     Msg = locate.LocatNo + "鐨勫嚭搴撲换鍔�"
                                 };
                                 Db.Insertable(exTask1).ExecuteCommand();
-
+                                logTaskList.Add(exTask1);
                                 outDto2.Add(new OutCommandDto()
                                 {
                                     StartRoadway = locate.RoadwayNo, //璧峰宸烽亾
                                     PalletNo = item.PalletNo,//鎵樼洏鍙�
                                     StartLocate = locate.LocatNo, // 璧峰浣嶇疆
-                                    EndLocate = "", // 鐩爣浣嶇疆 
+                                    EndLocate = toLocation, // 鐩爣浣嶇疆 
                                     EndRoadway = locate.RoadwayNo, //鐩爣宸烽亾
                                     TaskNo = exTask1.TaskNo, // 浠诲姟鍙�
                                     TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
@@ -1832,7 +2133,7 @@
                             var taskNo = Db.Queryable<LogTask>().First(m => m.OrderType == "1" && m.TaskNo != item.TaskNo && m.Status == "1" && m.PalletNo == item.PalletNo);
                             if (taskNo == null)
                             {
-                                taskNo = logTaskList.First(m => m.PalletNo == item.PalletNo);//褰撳墠鏈夊悓鎵樼洏涓嶅悓鐗╂枡鍑哄簱
+                                taskNo = logTaskList.FirstOrDefault(m => m.PalletNo == item.PalletNo);//褰撳墠鏈夊悓鎵樼洏涓嶅悓鐗╂枡鍑哄簱
                             }
                             if (taskNo == null)
                             {
@@ -1851,7 +2152,8 @@
                             flagList.Add(1);
                         }
                     }
-
+                    outDto1.AddRange(moveDto);
+                    outDto1.AddRange(outDto2);
                     //娣诲姞鎿嶄綔鏃ュ織璁板綍
                     var k = new OperationSOServer().AddLogOperationSo("鍑哄簱浣滀笟", "鍑哄簱鍗曟嵁", soNo, "鍑哄簱", $"鐐瑰嚮鍑哄簱鎸夐挳鍑哄簱鍗曞彿涓猴細{soNo}鐨勫嚭搴撳崟", userId);
                     Db.CommitTran();
@@ -1877,6 +2179,10 @@
                     {
                         str += "3.瑕佸嚭搴撶殑鎵樼洏姝e湪鍏ュ簱銆�";
                     }
+                    if (string.IsNullOrWhiteSpace(str))
+                    {
+                        str += "鎵樼洏鍙墽琛岋紝鏃犻渶涓嬪彂鍑哄簱浠诲姟";
+                    }
                     if (outDto1.Count > 0)
                     {
                         // 姝e紡杩愯绋嬪簭鏀惧紑
@@ -1886,23 +2192,23 @@
 
                         try
                         {
-                            //var time1 = DateTime.Now;//鍙戦�佹椂闂� .ToString("yyyy-MM-dd HH:mm:ss")
-                            //response = HttpHelper.DoPost(url, jsonData, "涓嬪彂缁橶CS鍑哄簱鍛戒护", "WCS");
-                            //var time2 = DateTime.Now;//杩斿洖鏃堕棿 .ToString("yyyy-MM-dd HH:mm:ss")
+                            var time1 = DateTime.Now;//鍙戦�佹椂闂� .ToString("yyyy-MM-dd HH:mm:ss")
+                            response = HttpHelper.DoPost(url, jsonData, "涓嬪彂缁橶CS鍑哄簱鍛戒护", "WCS");
+                            var time2 = DateTime.Now;//杩斿洖鏃堕棿 .ToString("yyyy-MM-dd HH:mm:ss")
 
                             //////瑙f瀽杩斿洖鏁版嵁 
-                            //var wcsModel = JsonConvert.DeserializeObject<WcsModel>(response);
-                            //if (wcsModel.StatusCode == 0)
-                            //{
-                            //    //鏇存敼浠诲姟鐨勫彂閫佽繑鍥炴椂闂�//
-                            //    new TaskServer().EditTaskIssueOk(list2, time1, time2);
-                            //    str += "涓嬪彂鎴愬姛";
-                            //}
-                            //if (wcsModel.StatusCode == -1)
-                            //{
-                            //    new TaskServer().EditTaskIssueNo(list2, time1, time2, wcsModel.Msg);
-                            //    throw new Exception(wcsModel.Msg);
-                            //}
+                            var wcsModel = JsonConvert.DeserializeObject<WcsModel>(response);
+                            if (wcsModel.StatusCode == 0)
+                            {
+                                //鏇存敼浠诲姟鐨勫彂閫佽繑鍥炴椂闂�//
+                                new TaskServer().EditTaskIssueOk(list2, time1, time2);
+                                str += "涓嬪彂鎴愬姛";
+                            }
+                            if (wcsModel.StatusCode == -1)
+                            {
+                                new TaskServer().EditTaskIssueNo(list2, time1, time2, wcsModel.Msg);
+                                throw new Exception(wcsModel.Msg);
+                            }
                         }
                         catch (Exception ex)
                         {
@@ -2169,7 +2475,7 @@
 
 
         //閲嶆柊涓嬪彂鍑哄簱浠诲姟
-        public OutCommandDto AgainSendSoTask(string taskNo, int userId, string url)
+        public OutCommandDto AgainSendSoTask(string taskNo, string Receiver, int userId, string url)
         {
             try
             {
@@ -2220,22 +2526,42 @@
                 {
                     //绋嬪簭姝e紡鍙戝竷鍚庢斁寮�
                     var time1 = DateTime.Now;//鍙戦�佹椂闂� .ToString("yyyy-MM-dd HH:mm:ss")
-                    var response = HttpHelper.DoPost(url, jsonData, "涓嬪彂缁橶CS鍑哄簱鍛戒护", "WCS");
+                    var response = HttpHelper.DoPost(url, jsonData, Receiver == "WCS" ? "涓嬪彂缁橶CS鍑哄簱鍛戒护" : "涓嬪彂缁橝GV鍑哄簱鍛戒护", "WCS");
                     var time2 = DateTime.Now;//杩斿洖鏃堕棿 .ToString("yyyy-MM-dd HH:mm:ss")
 
-                    ////瑙f瀽杩斿洖鏁版嵁 
-                    var wcsModel = JsonConvert.DeserializeObject<WcsModel>(response);
-                    if (wcsModel.StatusCode == 0)
+                    if (Receiver == "WCS")
                     {
-                        //鏇存敼浠诲姟鐨勫彂閫佽繑鍥炴椂闂�//
-                        new TaskServer().EditTaskIssueOk(list, time1, time2);
+                        ////瑙f瀽杩斿洖鏁版嵁 
+                        var wcsModel = JsonConvert.DeserializeObject<WcsModel>(response);
+                        if (wcsModel.StatusCode == 0)
+                        {
+                            //鏇存敼浠诲姟鐨勫彂閫佽繑鍥炴椂闂�//
+                            new TaskServer().EditTaskIssueOk(list, time1, time2);
 
+                        }
+                        if (wcsModel.StatusCode == -1)
+                        {
+                            new TaskServer().EditTaskIssueNo(list, time1, time2, wcsModel.Msg);
+                            throw new Exception($"wcs杩斿洖鐘舵�佸紓甯革細{wcsModel.Msg}");
+                        }
                     }
-                    if (wcsModel.StatusCode == -1)
+                    else if (Receiver == "AGV")
                     {
-                        new TaskServer().EditTaskIssueNo(list, time1, time2, wcsModel.Msg);
-                        throw new Exception($"wcs杩斿洖鐘舵�佸紓甯革細{wcsModel.Msg}");
+                        ////瑙f瀽杩斿洖鏁版嵁 
+                        var agvModel = JsonConvert.DeserializeObject<OutCommanAgvDto>(response);
+                        if (agvModel.Code == "0")
+                        {
+                            //鏇存敼浠诲姟鐨勫彂閫佽繑鍥炴椂闂�//
+                            new TaskServer().EditTaskIssueOk(list, time1, time2);
+
+                        }
+                        if (agvModel.Code == "1")
+                        {
+                            new TaskServer().EditTaskIssueNo(list, time1, time2, agvModel.Message);
+                            throw new Exception($"agv杩斿洖鐘舵�佸紓甯革細{agvModel.Message}");
+                        }
                     }
+                    
                 }
                 catch (Exception ex)
                 {
@@ -2263,6 +2589,38 @@
                     {
                         throw new Exception("鏈煡璇㈠埌浠诲姟淇℃伅");
                     }
+                    //鑾峰彇瀵瑰簲搴撲綅淇℃伅
+                    var startlocat = Db.Queryable<SysStorageLocat>().First(a => a.IsDel == "0" && a.WareHouseNo == "W01" && a.LocatNo == task.StartLocat);
+                    if (startlocat == null)
+                    {
+                        throw new Exception("鏈煡璇㈠埌鍌ㄤ綅淇℃伅");
+                    }
+                    startlocat.Status = "0";//淇敼鍒嗛厤淇℃伅鐘舵��
+                    //鑾峰彇鍌ㄤ綅淇℃伅
+                    var locat = Db.Queryable<SysStorageLocat>().First(a => a.IsDel == "0" && a.WareHouseNo == "W01" && a.LocatNo == task.StartLocat);
+                    //鑾峰彇绉诲簱浠籨鍔″搴旂洰鏍囧偍浣嶄俊鎭�
+                    SysStorageLocat endlocat = new SysStorageLocat();
+                    if (task.Type == "2")
+                    {
+                        endlocat = Db.Queryable<SysStorageLocat>().First(a => a.IsDel == "0" && a.WareHouseNo == "W01" && a.LocatNo == task.EndLocat);
+                        if (endlocat == null)
+                        {
+                            throw new Exception("鏈煡璇㈠埌鐩爣鍌ㄤ綅淇℃伅");
+                        }
+                    }
+                    if (locat == null)
+                    {
+                        Db.RollbackTran();
+                        throw new Exception("鏈煡璇㈠埌鍌ㄤ綅淇℃伅锛岃鏍稿疄锛�");
+                    }
+                    locat.Status = "1"; //鏈夌墿鍝�
+                    Db.Updateable(locat).ExecuteCommand();
+                    if (endlocat != null)
+                    {
+                        endlocat.Status = "0"; //绌哄偍浣� 0
+                        Db.Updateable(endlocat).ExecuteCommand();
+                    }
+
                     //淇敼浠诲姟 
                     task.IsSuccess = 1;
                     task.IsSend = 0;
@@ -2286,31 +2644,6 @@
 
                         noticeDetail.FactQty -= item.Qty; //淇敼鍑哄簱鍗曟槑缁嗙殑涓嬫灦鏁伴噺
                         Db.Updateable(noticeDetail).ExecuteCommand();
-
-                        //鑾峰彇鍌ㄤ綅淇℃伅
-                        var locat = Db.Queryable<SysStorageLocat>().First(a => a.IsDel == "0" && a.WareHouseNo == "W01" && a.LocatNo == task.StartLocat);
-                        //鑾峰彇绉诲簱浠诲姟瀵瑰簲鐩爣鍌ㄤ綅淇℃伅
-                        SysStorageLocat endlocat = new SysStorageLocat();
-                        if (task.Type == "2")
-                        {
-                            endlocat = Db.Queryable<SysStorageLocat>().First(a => a.IsDel == "0" && a.WareHouseNo == "W03" && a.LocatNo == task.EndLocat);
-                            if (endlocat == null)
-                            {
-                                throw new Exception("鏈煡璇㈠埌鐩爣鍌ㄤ綅淇℃伅");
-                            }
-                        }
-                        if (locat == null)
-                        {
-                            Db.RollbackTran();
-                            throw new Exception("鏈煡璇㈠埌鍌ㄤ綅淇℃伅锛岃鏍稿疄锛�");
-                        }
-                        locat.Status = "1"; //鏈夌墿鍝�
-                        Db.Updateable(locat).ExecuteCommand();
-                        if (endlocat != null)
-                        {
-                            endlocat.Status = "0"; //绌哄偍浣� 0
-                            Db.Updateable(endlocat).ExecuteCommand();
-                        }
 
                         if (noticeDetail.FactQty == 0)
                         {
@@ -2553,7 +2886,7 @@
                         }
                         else
                         {
-                            stockDetail = stockDetail.Where(m => m.SkuNo == detail.SkuNo && m.IsDel == "0").ToList(); //&& string.IsNullOrWhiteSpace(m.LotNo)
+                            stockDetail = stockDetail.Where(m => m.SkuNo == detail.SkuNo && m.IsDel == "0" && string.IsNullOrWhiteSpace(m.LotNo)).ToList(); //
                         }
 
                         if (stockDetail.Count < 1)
@@ -2561,13 +2894,17 @@
                             throw new Exception("搴撳瓨涓嶈冻,鏃犲彲鍑哄簱搴撳瓨");
                         }
                         //0:鎴愬搧鍑哄簱銆�1:棰嗘枡鍑哄簱銆�2:鎶芥鍑哄簱銆�3锛氱墿鏂欏彇鏍峰嚭搴撱��4:涓嶅悎鏍煎搧鍑哄簱銆�5:涓棿鍝佸嚭搴撱��6:浠e偍鍑哄簱銆�7:鍏朵粬鍑哄簱銆�8:瀵勫瓨鍑哄簱
-                        if (notice.Type == "0" || notice.Type == "1" || notice.Type == "2" || notice.Type == "5")//鎴愬搧銆佸師杈呮枡鍑哄簱
+                        if (notice.Type == "0" || notice.Type == "1")//鎴愬搧銆佸師杈呮枡鍑哄簱
                         {
                             stockDetail = stockDetail.Where(m => m.InspectStatus == "1").ToList();
                         }
-                        else if (notice.Type == "3" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")//鍙栨牱鍑哄簱
+                        else if (notice.Type == "3")//鍙栨牱鍑哄簱
                         {
                             stockDetail = stockDetail.Where(m => m.InspectStatus == "0").ToList();
+                        }
+                        else if (notice.Type == "5" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")
+                        {
+                            stockDetail = stockDetail.Where(m => m.InspectStatus == "0" || m.InspectStatus == "1").ToList();
                         }
                         else if (notice.Type == "4")//涓嶅悎鏍煎嚭搴�
                         {
@@ -2577,41 +2914,43 @@
                         #region 鍖呰淇℃伅
 
                         var pack = packList.FirstOrDefault(p => p.PackagNo == detail.PackagNo);
-                        if (pack == null)
-                        {
-                            throw new Exception("鏈煡璇㈠埌鐗╂枡鍖呰");
-                        }
                         var pNum = 0;//鎵樼洏鐗╁搧鏁伴噺
                         var bNum = 0;//绠辩墿鍝佹暟閲�
-                        if (pack.L5Num.HasValue)
+                        if (pack != null)
                         {
-                            pNum = Convert.ToInt32(pack.L5Num);
-                            bNum = Convert.ToInt32(pack.L4Num);
+                            //throw new Exception("鏈煡璇㈠埌鐗╂枡鍖呰");
+                            if (pack.L5Num.HasValue)
+                            {
+                                pNum = Convert.ToInt32(pack.L5Num);
+                                bNum = Convert.ToInt32(pack.L4Num);
+                            }
+                            else if (pack.L4Num.HasValue)
+                            {
+                                pNum = Convert.ToInt32(pack.L4Num);
+                                bNum = Convert.ToInt32(pack.L3Num);
+                            }
+                            else if (pack.L3Num.HasValue)
+                            {
+                                pNum = Convert.ToInt32(pack.L3Num);
+                                bNum = Convert.ToInt32(pack.L2Num);
+                            }
+                            else if (pack.L2Num.HasValue)
+                            {
+                                pNum = Convert.ToInt32(pack.L2Num);
+                                bNum = Convert.ToInt32(pack.L1Num);
+                            }
+                            else if (pack.L1Num.HasValue)
+                            {
+                                pNum = Convert.ToInt32(pack.L1Num);
+                                bNum = Convert.ToInt32(pack.L1Num);
+                            }
                         }
-                        else if (pack.L4Num.HasValue)
-                        {
-                            pNum = Convert.ToInt32(pack.L4Num);
-                            bNum = Convert.ToInt32(pack.L3Num);
-                        }
-                        else if (pack.L3Num.HasValue)
-                        {
-                            pNum = Convert.ToInt32(pack.L3Num);
-                            bNum = Convert.ToInt32(pack.L2Num);
-                        }
-                        else if (pack.L2Num.HasValue)
-                        {
-                            pNum = Convert.ToInt32(pack.L2Num);
-                            bNum = Convert.ToInt32(pack.L1Num);
-                        }
-                        else if (pack.L1Num.HasValue)
-                        {
-                            pNum = Convert.ToInt32(pack.L1Num);
-                            bNum = Convert.ToInt32(pack.L1Num);
-                        }
-                        if (pNum == 0)
-                        {
-                            throw new Exception("鏈煡璇㈠埌鐗╂枡鍖呰鎵樼鍏崇郴淇℃伅");
-                        }
+
+
+                        //if (pNum == 0)
+                        //{
+                        //    throw new Exception("鏈煡璇㈠埌鐗╂枡鍖呰鎵樼鍏崇郴淇℃伅");
+                        //}
                         #endregion
                         //鍙栧悎閫傚簱瀛樺晢鍝�
                         Dictionary<int, decimal> stockQtyDic = new Dictionary<int, decimal>();//鎵樺嚭搴撶墿鍝佹暟
@@ -2665,21 +3004,21 @@
                             }
 
                             var sd = Db.Updateable(s).UpdateColumns(it => new { it.LockQty, it.Status }).ExecuteCommand();
-                            if (notice.Type == "1" || notice.Type == "5" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")//1锛氶鏂欏嚭搴撱��
-                            {
-                                if (string.IsNullOrWhiteSpace(detail.LotNo))
-                                {
-                                    detail.LotNo = s.LotNo;
+                            //if (notice.Type == "1" || notice.Type == "5" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")//1锛氶鏂欏嚭搴撱��
+                            //{
+                            //    if (string.IsNullOrWhiteSpace(detail.LotNo))
+                            //    {
+                            //        detail.LotNo = s.LotNo;
 
-                                }
-                                else
-                                {
-                                    if (!detail.LotNo.Contains(s.LotNo))
-                                    {
-                                        detail.LotNo += ";" + s.LotNo;
-                                    }
-                                }
-                            }
+                            //    }
+                            //    else
+                            //    {
+                            //        if (!detail.LotNo.Contains(s.LotNo))
+                            //        {
+                            //            detail.LotNo += ";" + s.LotNo;
+                            //        }
+                            //    }
+                            //}
 
                         }
                         detail.AllotQty += qty;
@@ -2820,14 +3159,14 @@
                         d.UpdateUser = userId;
                         d.UpdateTime = DateTime.Now;
 
-                        if (notice.Type == "1" || notice.Type == "5" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")//1锛氶鏂欏嚭搴撱��
-                        {
-                            if (d.IsIssueLotNo != "1")
-                            {
-                                d.LotNo = "";
-                            }
-                            
-                        }
+                        //if (notice.Type == "1" || notice.Type == "5" || notice.Type == "6" || notice.Type == "7" || notice.Type == "8")//1锛氶鏂欏嚭搴撱��
+                        //{
+                        //    if (d.IsIssueLotNo != "1")
+                        //    {
+                        //        d.LotNo = "";
+                        //    }
+
+                        //}
                     }
                     notice.Status = "0";
                     notice.UpdateUser = userId;
@@ -2896,26 +3235,63 @@
                 {
                     throw new Exception("鑾峰彇澶辫触锛屾湭鎵惧埌鎸囧畾鍑哄簱鍗曪紒");
                 }
-                if (detail.Status != "0" && detail.Status != "1" && detail.AllotQty >= detail.Qty)
-                {
-                    throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟鐘舵�佷笉鏄瓑寰呮墽琛屾垨鍒嗛厤涓紒");
-                }
-                if (detail.AllotQty >= detail.Qty)
-                {
-                    throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴�!");
-                }
+
                 var notice = Db.Queryable<BllExportNotice>().First(a => a.SONo == detail.SONo);
                 if (notice == null)
                 {
                     throw new Exception("鑾峰彇澶辫触锛屾湭鎵惧埌鎸囧畾鍑哄簱鍗�!");
                 }
-                if (notice.Status == "3" && detail.AllotQty >= detail.Qty || notice.Status == "4" || notice.Status == "5")
+                if (notice.Type != "1" && notice.Type != "2" && notice.Type != "3")
                 {
-                    throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟鐘舵�佷笉鍏佽!");
+                    if (detail.Status != "0" && detail.Status != "1" && detail.AllotQty >= detail.Qty)
+                    {
+                        throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟鐘舵�佷笉鏄瓑寰呮墽琛屾垨鍒嗛厤涓紒");
+                    }
+                    if (detail.AllotQty >= detail.Qty)
+                    {
+                        throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴�!");
+                    }
+
+                    if (notice.Status == "3" && detail.AllotQty >= detail.Qty || notice.Status == "4" || notice.Status == "5")
+                    {
+                        throw new Exception("鑾峰彇澶辫触锛屽嚭搴撳崟鐘舵�佷笉鍏佽!");
+                    }
+                }
+                string inspectStatus = string.Empty;
+                switch (notice.Type)//0锛氬師鏂� 1锛氬寘鏉� 2锛氭垚鍝� 3锛氳�楁潗 4锛氬崐鎴愬搧
+                {
+                    case "0"://鎴愬搧鍑哄簱
+                        inspectStatus = "1";
+                        break;
+                    case "1"://棰嗘枡鍑哄簱
+                        inspectStatus = "1";
+                        break;
+                    case "2"://鎶芥鍑哄簱
+                        inspectStatus = "0,1,2";
+                        break;
+                    case "3"://鐗╂枡鍙栨牱鍑哄簱
+                        inspectStatus = "0";
+                        break;
+                    case "4"://涓嶅悎鏍煎搧鍑哄簱
+                        inspectStatus = "2";
+                        break;
+                    case "5"://涓棿鍝佸嚭搴�
+                        inspectStatus = "1";
+                        break;
+                    case "6"://浠e偍鍑哄簱
+                        inspectStatus = "0,1,2";
+                        break;
+                    case "8"://瀵勫瓨鍑哄簱
+                        inspectStatus = "0,1";
+                        break;
+                    default: //鍏跺畠鍑哄簱
+                        inspectStatus = "0,1";
+                        break;
                 }
                 #endregion
 
                 Expression<Func<DataStockDetail, bool>> item = Expressionable.Create<DataStockDetail>()
+                    .AndIF(!string.IsNullOrWhiteSpace(inspectStatus), m => inspectStatus.Contains(m.InspectStatus))
                     .AndIF(!string.IsNullOrWhiteSpace(houseNo), m => m.WareHouseNo == houseNo)
                     .AndIF(!string.IsNullOrWhiteSpace(roadwayNo), m => m.RoadwayNo == roadwayNo)
                     .AndIF(!string.IsNullOrWhiteSpace(locateNo), m => m.LocatNo == locateNo)
@@ -2963,39 +3339,48 @@
                 {
                     throw new Exception("鎿嶄綔澶辫触锛屾湭鎵惧埌鎸囧畾鍑哄簱鍗曡鎯咃紒");
                 }
-                if (detail.AllotQty >= detail.Qty || (detail.Status != "0" && detail.Status != "1"))
-                {
-                    throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴愶紒");
-                }
                 var notice = Db.Queryable<BllExportNotice>().First(a => a.IsDel == "0" && a.SONo == detail.SONo);
                 if (notice == null)
                 {
                     throw new Exception("鎿嶄綔澶辫触锛屾湭鎵惧埌鎸囧畾鍑哄簱鍗曪紒");
                 }
-                if (notice.Status == "3" && detail.AllotQty >= detail.Qty || notice.Status == "4" || notice.Status == "5")
+                if (notice.Type != "1" && notice.Type != "2" && notice.Type !="3")
                 {
-                    throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴愶紒");
+                    if (detail.AllotQty >= detail.Qty || (detail.Status != "0" && detail.Status != "1"))
+                    {
+                        throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴愶紒");
+                    }
+
+                    if (notice.Status == "3" && detail.AllotQty >= detail.Qty || notice.Status == "4" || notice.Status == "5")
+                    {
+                        throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撳崟宸插垎閰嶅畬鎴愶紒");
+                    }
+
+                    //鍗曟嵁鏄庣粏闇�瑕佺殑鍑哄簱鏁伴噺
+                    var needQty = detail.Qty - detail.AllotQty;
+                    //鍒嗛厤鐨勫嚭搴撴暟閲�
+                    var outQty = model.StockList.Select(s => s.Qty).ToList().Sum();
+                    if (outQty < needQty)
+                    {
+                        throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撴暟閲忎笉鑳藉ぇ浜庤鍒掓暟閲忥紒");
+                    }
                 }
+                
                 #endregion
 
-                //鍗曟嵁鏄庣粏闇�瑕佺殑鍑哄簱鏁伴噺
-                var needQty = detail.Qty - detail.AllotQty;
-                //鍒嗛厤鐨勫嚭搴撴暟閲�
-                var outQty = model.StockList.Select(s => s.Qty).ToList().Sum();
-                if (outQty != needQty)
-                {
-                    throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撴暟閲忎笌璁″垝鏁伴噺涓嶄竴鑷达紒");
-                }
+                
                 var stockIds = model.StockList.Select(a => a.StockId).ToList();
                 //搴撳瓨鏄庣粏
                 var stockList = Db.Queryable<DataStockDetail>().Where(a => stockIds.Contains(a.Id)).ToList();
 
+                //鍒嗛厤淇℃伅
+                var allots = Db.Queryable<BllExportAllot>().Where(m => m.IsDel == "0" && m.SODetailNo == detail.Id && m.Status == "0").ToList();
 
                 //搴撳瓨鎬昏〃
-                //var stockz = Db.Queryable<DataStock>().First(d => d.IsDel == "0" && d.SkuNo == detail.SkuNo && d.LotNo == detail.LotNo);
+                var stockz = Db.Queryable<DataStock>().First(d => d.IsDel == "0" && d.SkuNo == detail.SkuNo && d.LotNo == detail.LotNo);
 
                 var allotList = new List<BllExportAllot>();
-                var outQtys = 0;
+                decimal outQtys = 0;
                 foreach (var st in model.StockList)
                 {
                     var stock = stockList.First(a => a.Id == st.StockId);
@@ -3003,45 +3388,57 @@
                     {
                         throw new Exception("鎿嶄綔澶辫触锛岄儴鍒嗗偍浣嶅簱瀛樺紓甯革紒");
                     }
-                    if (st.Qty > (stock.Qty - stock.LockQty - stock.FrozenQty - stock.InspectQty))
+                    if (st.Qty > (stock.Qty - stock.LockQty - stock.FrozenQty))     // 杈撳叆鐨勬暟閲� -  鎵樼洏涓婂彲鐢ㄧ殑鏁伴噺锛堟墭鐩樹笂鏁伴噺-閿佸畾鐨勬暟閲�-鍐荤粨鐨勬暟閲忥級
                     {
                         throw new Exception("鎿嶄綔澶辫触锛屽嚭搴撴暟閲忚秴鍑哄簱瀛樻暟閲忥紒");
                     }
-                    //娣诲姞鍒嗛厤琛ㄤ俊鎭�
-                    var allot = new BllExportAllot
-                    {
-                        SONo = notice.SONo,
-                        WaveNo = "",
-                        SODetailNo = detail.Id,
-                        StockId = st.StockId,
-                        LotNo = stock.LotNo,
-                        LotText = stock.LotText,
-                        SupplierLot = stock.SupplierLot,
-                        SkuNo = stock.SkuNo,
-                        SkuName = stock.SkuName,
-                        Standard = stock.Standard,
-                        PalletNo = stock.PalletNo,
-                        IsBale = stock.IsBale,
-                        IsBelt = stock.IsBelt,
-                        Qty = st.Qty,
-                        CompleteQty = 0,
-                        Status = "0",
-                        LogisticsId = notice.LogisticsId,
-                        IsAdvance = "0",
-                        OutMode = "",//鍑哄簱鍙�
 
-                        CreateUser = userId,
-                        CreateTime = DateTime.Now
-                    };
-                    allotList.Add(allot);
+                    var bl = allots.FirstOrDefault(m => m.StockId == st.StockId);
+                    if (bl == null)
+                    {
+                        //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                        var allot = new BllExportAllot
+                        {
+                            SONo = notice.SONo,
+                            WaveNo = "",
+                            SODetailNo = detail.Id,
+                            StockId = st.StockId,
+                            LotNo = stock.LotNo,
+                            LotText = stock.LotText,
+                            SupplierLot = stock.SupplierLot,
+                            SkuNo = stock.SkuNo,
+                            SkuName = stock.SkuName,
+                            Standard = stock.Standard,
+                            PalletNo = stock.PalletNo,
+                            IsBale = stock.IsBale,
+                            IsBelt = stock.IsBelt,
+                            Qty = st.Qty,
+                            CompleteQty = 0,
+                            Status = notice.Status == "4"? "2":"0",
+                            LogisticsId = notice.LogisticsId,
+                            IsAdvance = "0",
+                            OutMode = "",//鍑哄簱鍙�
+
+                            CreateUser = userId,
+                            CreateTime = DateTime.Now
+                        };
+                        allotList.Add(allot);
+                    }
+                    else
+                    {
+                        bl.Qty += st.Qty;
+                        Db.Updateable(bl).ExecuteCommand();
+                    }
+
                     //搴撳瓨鏄庣粏
                     stock.LockQty += st.Qty;
                     stock.Status = stock.LockQty == stock.Qty ? "2" : "1";
-
-                    //搴撳瓨鎬昏〃
-                    //stockz.LockQty += st.Qty;
-                    //Db.Updateable(stockz).ExecuteCommand();
-
+                    if (detail.AllotQty+ st.Qty > detail.Qty)
+                    {
+                        //搴撳瓨鎬昏〃
+                        stockz.LockQty += (decimal)detail.AllotQty + st.Qty - detail.Qty;
+                        Db.Updateable(stockz).ExecuteCommand();
+                    }
 
                     Db.Updateable(stock).UpdateColumns(it => new { it.LockQty, it.Status }).ExecuteCommand();
                     outQtys += st.Qty;

--
Gitblit v1.8.0