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; }
public ResultModel Complete(UserModel user, int sIId) { ResultModel result = new ResultModel(); try { DAL.SIDAL sIDAL = new SIDAL(); NFMT.Operate.DAL.InvoiceDAL invoiceDAL = new Operate.DAL.InvoiceDAL(); DAL.SIDetailDAL detailDAL = new SIDetailDAL(); using (System.Transactions.TransactionScope scope = new TransactionScope(TransactionScopeOption.Required)) { //获取财务票 result = sIDAL.Get(user, sIId); if (result.ResultStatus != 0) return result; NFMT.Invoice.Model.SI sI = result.ReturnValue as NFMT.Invoice.Model.SI; if (sI == null || sI.SIId <= 0) { result.ResultStatus = -1; result.Message = "发票验证失败"; return result; } //获取发票 result = invoiceDAL.Get(user, sI.InvoiceId); if (result.ResultStatus != 0) return result; NFMT.Operate.Model.Invoice invoice = result.ReturnValue as NFMT.Operate.Model.Invoice; if (invoice == null || invoice.InvoiceId <= 0) { result.ResultStatus = -1; result.Message = "发票获取失败"; return result; } //发票完成 result = invoiceDAL.Complete(user, invoice); if (result.ResultStatus != 0) return result; //获取明细 result = detailDAL.Load(user, sI.SIId); if (result.ResultStatus != 0) return result; List<Model.SIDetail> details = result.ReturnValue as List<Model.SIDetail>; if (details == null) { result.ResultStatus = -1; result.Message = "发票明细获取失败"; return result; } foreach (Model.SIDetail detail in details) { result = detailDAL.Complete(user, detail); if (result.ResultStatus != 0) return result; } scope.Complete(); } } catch (Exception ex) { result.ResultStatus = -1; result.Message = ex.Message; } return result; }
public ResultModel Create(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 = 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; } invoice.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; } invoice.OutCorpName = corp.CorpName; result = invoiceDAL.Insert(user, invoice); if (result.ResultStatus != 0) return result; int invoiceId = (int)result.ReturnValue; si.InvoiceId = invoiceId; result = sIDAL.Insert(user, si); if (result.ResultStatus != 0) return result; int sIId = (int)result.ReturnValue; foreach (Model.SIDetail detail in siDetails) { detail.SIId = sIId; result = sIDetailDAL.Insert(user, detail); if (result.ResultStatus != 0) return result; } invoice.InvoiceId = invoiceId; if (result.ResultStatus == 0) result.ReturnValue = invoice; scope.Complete(); } } catch (Exception e) { result.ResultStatus = -1; result.Message = e.Message; } return result; }