| | |
| | | inspectStatus = "0"; |
| | | break; |
| | | case "4"://不合格品出库 |
| | | skuType = "(0,1,2,3)"; |
| | | skuType = "(0,1,2,3,4)"; |
| | | inspectStatus = "2"; |
| | | break; |
| | | case "5"://中间品出库 |
| | | skuType = "(4)"; |
| | | inspectStatus = "0,1"; |
| | | inspectStatus = "1"; |
| | | break; |
| | | case "6"://代储出库 |
| | | skuType = "(0,1,2,3,4)"; |
| | |
| | | { |
| | | 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("获取失败,出库单状态不允许!"); |
| | | } |
| | | } |
| | | |
| | | #endregion |
| | | |
| | | Expression<Func<DataStockDetail, bool>> item = Expressionable.Create<DataStockDetail>() |
| | |
| | | { |
| | | 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>(); |
| | | decimal outQtys = 0; |
| | |
| | | IsBelt = stock.IsBelt, |
| | | Qty = st.Qty, |
| | | CompleteQty = 0, |
| | | Status = "0", |
| | | Status = notice.Status == "4"? "2":"0", |
| | | LogisticsId = notice.LogisticsId, |
| | | IsAdvance = "0", |
| | | OutMode = "",//出库口 |
| | |
| | | //库存明细 |
| | | 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; |