Example #1
0
        public ResultModel Complete(UserModel user, int receiptId)
        {
            ResultModel result = new ResultModel();

            try
            {
                DAL.StockDAL stockDAL = new StockDAL();
                DAL.StockLogDAL stockLogDAL = new StockLogDAL();

                using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
                {
                    result = this.stockreceiptDAL.Get(user, receiptId);
                    if (result.ResultStatus != 0)
                        return result;

                    StockReceipt stockReceipt = result.ReturnValue as StockReceipt;

                    if (stockReceipt == null || stockReceipt.ReceiptId <= 0)
                    {
                        result.ResultStatus = -1;
                        result.Message = "该数据不存在,不能作废";
                        return result;
                    }

                    result = this.stockreceiptDAL.Complete(user, stockReceipt);
                    if (result.ResultStatus != 0)
                        return result;

                    StockReceiptDetailDAL detailDAL = new StockReceiptDetailDAL();
                    result = detailDAL.Load(user, stockReceipt.ReceiptId);
                    if (result.ResultStatus != 0)
                        return result;

                    List<Model.StockReceiptDetail> details = result.ReturnValue as List<Model.StockReceiptDetail>;
                    if (details == null)
                    {
                        result.ResultStatus = -1;
                        result.Message = "获取回执明细失败";
                        return result;
                    }
                    foreach (Model.StockReceiptDetail detail in details)
                    {
                        result = detailDAL.Complete(user, detail);
                        if (result.ResultStatus != 0)
                            return result;

                        ////获取库存
                        //result = stockDAL.Get(user, detail.StockId);
                        //if (result.ResultStatus != 0)
                        //    return result;

                        //Model.Stock stock = result.ReturnValue as Model.Stock;
                        //if (stock == null || stock.StockId <= 0)
                        //{
                        //    result.ResultStatus = -1;
                        //    result.Message = "库存不存在";
                        //    return result;
                        //}

                        ////更新库存净重
                        //if (stockReceipt.ReceiptType == (int)ReceiptTypeEnum.入库回执)
                        //{
                        //    stock.ReceiptInGap += detail.QtyMiss;
                        //    //stock.NetAmount += detail.QtyMiss;
                        //}
                        //else
                        //    stock.ReceiptOutGap += detail.QtyMiss;
                        //stock.CurNetAmount += detail.QtyMiss;

                        //result = stockDAL.Update(user, stock);
                        //if (result.ResultStatus != 0)
                        //    return result;
                    }

                    scope.Complete();
                }
            }
            catch (Exception ex)
            {
                result.ResultStatus = -1;
                result.Message = ex.Message;
            }
            finally
            {
                if (result.ResultStatus != 0)
                    log.ErrorFormat("{0} {1},序号:{2}", user.EmpName, result.Message, result.ReturnValue);
                else if (log.IsInfoEnabled)
                    log.InfoFormat("{0} {1},序号:{2}", user.EmpName, result.Message, result.ReturnValue);
            }

            return result;
        }