コード例 #1
0
ファイル: SIBLL.cs プロジェクト: weiliji/NFMT
        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;
        }
コード例 #2
0
ファイル: SIBLL.cs プロジェクト: weiliji/NFMT
        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;
        }
コード例 #3
0
ファイル: SIBLL.cs プロジェクト: weiliji/NFMT
        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;
        }