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