public ResultModel ContractOutInvalidStockOperate(UserModel user, int subId) { ResultModel result = new ResultModel(); try { NFMT.WareHouse.DAL.StockOutApplyDAL stockOutApplyDAL = new NFMT.WareHouse.DAL.StockOutApplyDAL(); NFMT.WareHouse.DAL.StockOutApplyDetailDAL stockOutApplyDetailDAL = new NFMT.WareHouse.DAL.StockOutApplyDetailDAL(); NFMT.Operate.DAL.ApplyDAL applyDAL = new NFMT.Operate.DAL.ApplyDAL(); NFMT.WareHouse.DAL.StockExclusiveDAL stockExclusiveDAL = new NFMT.WareHouse.DAL.StockExclusiveDAL(); //获取子合约出库申请 result = stockOutApplyDAL.LoadBySubId(user, subId); if (result.ResultStatus != 0) return result; List<NFMT.WareHouse.Model.StockOutApply> outApplies = result.ReturnValue as List<NFMT.WareHouse.Model.StockOutApply>; if (outApplies == null || outApplies.Count == 0) { result.ResultStatus = -1; result.Message = "获取出库申请失败"; return result; } foreach (NFMT.WareHouse.Model.StockOutApply outApply in outApplies) { result = applyDAL.Get(user, outApply.ApplyId); if (result.ResultStatus != 0) return result; NFMT.Operate.Model.Apply apply = result.ReturnValue as NFMT.Operate.Model.Apply; if (apply == null || apply.ApplyId <= 0) { result.ResultStatus = -1; result.Message = "获取主申请失败"; return result; } //申请作废 result = applyDAL.Invalid(user, apply); if (result.ResultStatus != 0) return result; //获取出库申请明细 result = stockOutApplyDetailDAL.Load(user, outApply.StockOutApplyId); if (result.ResultStatus != 0) return result; List<NFMT.WareHouse.Model.StockOutApplyDetail> details = result.ReturnValue as List<NFMT.WareHouse.Model.StockOutApplyDetail>; if (details == null) { result.ResultStatus = -1; result.Message = "获取出库申请明细失败"; return result; } foreach (NFMT.WareHouse.Model.StockOutApplyDetail detail in details) { detail.DetailStatus = StatusEnum.已录入; result = stockOutApplyDetailDAL.Invalid(user, detail); if (result.ResultStatus != 0) return result; //获取排他明细 result = stockExclusiveDAL.Get(user, apply.ApplyId, outApply.StockOutApplyId, detail.DetailId); if (result.ResultStatus != 0) return result; NFMT.WareHouse.Model.StockExclusive stockExclusive = result.ReturnValue as NFMT.WareHouse.Model.StockExclusive; if (stockExclusive == null || stockExclusive.ExclusiveId <= 0) { result.ResultStatus = -1; result.Message = "获取排他明细失败"; return result; } //作废排他明细 stockExclusive.ExclusiveStatus = StatusEnum.已录入; result = stockExclusiveDAL.Invalid(user, stockExclusive); if (result.ResultStatus != 0) return result; } } } catch (Exception ex) { result.ResultStatus = -1; result.Message = ex.Message; } return result; }
public ResultModel StockOutApplyDetailClose(UserModel user, int stockOutApplyId, List<int> detailIds, string memo) { ResultModel result = new ResultModel(); try { using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required)) { //加载对应出库申请 StockOutApplyDAL applyDAL = new StockOutApplyDAL(); result = applyDAL.Get(user, stockOutApplyId); if (result.ResultStatus != 0) return result; StockOutApply stockOutApply = result.ReturnValue as StockOutApply; if (stockOutApply == null || stockOutApply.StockOutApplyId <= 0) { result.ResultStatus = -1; result.Message = "对应出库申请加载失败"; return result; } //获取出库申请明细 DAL.StockOutApplyDetailDAL stockOutApplyDetailDAL = new StockOutApplyDetailDAL(); result = stockOutApplyDetailDAL.Load(user, stockOutApplyId); if (result.ResultStatus != 0) return result; List<Model.StockOutApplyDetail> stockOutApplyDetails = result.ReturnValue as List<Model.StockOutApplyDetail>; if (stockOutApplyDetails == null) { result.ResultStatus = -1; result.Message = "出库申请明细获取失败"; return result; } //判断detailIds 是否都在出库申请明细中 List<int> applyDetails = new List<int>(); foreach (Model.StockOutApplyDetail detail in stockOutApplyDetails) { applyDetails.Add(detail.DetailId); } foreach (int id in detailIds) { if (!applyDetails.Contains(id)) { result.ResultStatus = -1; result.Message = "出库申请不包含选中库存"; return result; } } //关闭申请明细 StockExclusiveDAL excDAL = new StockExclusiveDAL(); foreach (int id in detailIds) { Model.StockOutApplyDetail applyDetail = stockOutApplyDetails.FirstOrDefault(temp => temp.DetailId == id); if (applyDetail == null || applyDetail.DetailId <= 0) { result.ResultStatus = -1; result.Message = "出库申请不包含选中库存"; return result; } if (applyDetail.DetailStatus != StatusEnum.已生效) { result.ResultStatus = -1; result.Message = "选中库存状态不匹配,不能进行关闭"; return result; } result = stockOutApplyDetailDAL.Close(user, applyDetail); if (result.ResultStatus != 0) return result; //加载对应排他明细 result = excDAL.Get(user, stockOutApply.ApplyId, stockOutApply.StockOutApplyId, applyDetail.DetailId); if (result.ResultStatus != 0) return result; Model.StockExclusive excl = result.ReturnValue as Model.StockExclusive; if (excl == null || excl.ExclusiveId <= 0) { result.ResultStatus = -1; result.Message = "获取排他明细失败"; return result; } //关闭排他明细 result = excDAL.Close(user, excl); if (result.ResultStatus != 0) return result; } scope.Complete(); } } catch (Exception ex) { result.ResultStatus = -1; result.Message = ex.Message; } return result; }