Esempio n. 1
0
        public ResultModel Update(UserModel user, NFMT.Operate.Model.Invoice invoice, Model.SI si, List<Model.SIDetail> siDetails)
        {
            ResultModel result = new ResultModel();
            NFMT.Operate.DAL.InvoiceDAL invoiceDAL = new Operate.DAL.InvoiceDAL();
            DAL.SIDAL sIDAL = new SIDAL();
            DAL.SIDetailDAL sIDetailDAL = new SIDetailDAL();
            NFMT.User.DAL.CorporationDAL corporationDAL = new User.DAL.CorporationDAL();

            try
            {
                using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
                {
                    //获取发票信息
                    result = invoiceDAL.Get(user, invoice.InvoiceId);
                    if (result.ResultStatus != 0)
                        return result;
                    NFMT.Operate.Model.Invoice resultObj = result.ReturnValue as NFMT.Operate.Model.Invoice;
                    if (resultObj == null || resultObj.InvoiceId <= 0)
                    {
                        result.Message = "获取发票信息失败";
                        result.ResultStatus = -1;
                        return result;
                    }

                    //获取公司信息
                    result = corporationDAL.Get(user, invoice.InCorpId);
                    if (result.ResultStatus != 0)
                        return result;

                    NFMT.User.Model.Corporation corp = result.ReturnValue as NFMT.User.Model.Corporation;
                    if (corp == null)
                    {
                        result.ResultStatus = -1;
                        result.Message = "公司信息不存在";
                        return result;
                    }
                    resultObj.InCorpName = corp.CorpName;

                    result = corporationDAL.Get(user, invoice.OutCorpId);
                    if (result.ResultStatus != 0)
                        return result;

                    corp = result.ReturnValue as NFMT.User.Model.Corporation;
                    if (corp == null)
                    {
                        result.ResultStatus = -1;
                        result.Message = "公司信息不存在";
                        return result;
                    }
                    resultObj.OutCorpName = corp.CorpName;

                    resultObj.InvoiceDate = invoice.InvoiceDate;
                    resultObj.InvoiceName = invoice.InvoiceName;
                    resultObj.InvoiceType = invoice.InvoiceType;
                    resultObj.InvoiceBala = invoice.InvoiceBala;
                    resultObj.CurrencyId = invoice.CurrencyId;
                    resultObj.InvoiceDirection = invoice.InvoiceDirection;
                    resultObj.OutCorpId = invoice.OutCorpId;
                    resultObj.InCorpId = invoice.InCorpId;
                    resultObj.Memo = invoice.Memo;

                    //更新发票信息
                    result = invoiceDAL.Update(user, resultObj);
                    if (result.ResultStatus != 0)
                        return result;

                    //更新价外票信息
                    result = sIDAL.Update(user, si);
                    if (result.ResultStatus != 0)
                        return result;

                    //作废价外票
                    result = sIDetailDAL.InvalidAll(user, si.SIId);
                    if (result.ResultStatus != 0)
                        return result;

                    foreach (Model.SIDetail detail in siDetails)
                    {
                        detail.SIId = si.SIId;
                        result = sIDetailDAL.Insert(user, detail);
                        if (result.ResultStatus != 0)
                            return result;
                    }
                    scope.Complete();
                }
            }
            catch (Exception e)
            {
                result.ResultStatus = -1;
                result.Message = e.Message;
            }

            return result;
        }