本文整理汇总了C#中OpenCBS.CoreDomain.Contracts.Loans.Loan.GetCloseEvent方法的典型用法代码示例。如果您正苦于以下问题:C# Loan.GetCloseEvent方法的具体用法?C# Loan.GetCloseEvent怎么用?C# Loan.GetCloseEvent使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类OpenCBS.CoreDomain.Contracts.Loans.Loan
的用法示例。
在下文中一共展示了Loan.GetCloseEvent方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SaveInstallmentsAndRepaymentEvents
public Loan SaveInstallmentsAndRepaymentEvents(Loan loan, IList<Installment> newInstallments, EventStock eventStock)
{
var repayEvent = eventStock.GetRepaymentEvents().First(i => !i.IsFired).Copy();
var amount =
eventStock.GetRepaymentEvents()
.Where(i => !i.IsFired)
.Sum(i => i.Commissions.Value + i.Penalties.Value + i.Interests.Value + i.Principal.Value);
using (var sqlTransaction = _loanManager.GetConnection().BeginTransaction())
{
try
{
if (ApplicationSettings.GetInstance(User.CurrentUser.Md5).UseMandatorySavingAccount)
{
var saving =
(from item in loan.Project.Client.Savings where item.Product.Code == "default" select item)
.FirstOrDefault();
if (saving == null)
{
MessageBox.Show("Make sure that client has default saving account");
return loan;
}
saving = ServicesProvider.GetInstance().GetSavingServices().GetSaving(saving.Id);
var balance = saving.GetBalance(repayEvent.Date);
if (amount > balance)
{
MessageBox.Show("Balance is not enough to repay");
return loan;
}
if (amount <= 0)
return loan;
ServicesProvider.GetInstance()
.GetSavingServices()
.Withdraw(saving, repayEvent.Date, amount,
"Withdraw for loan repayment " + loan.Code, User.CurrentUser,
new Teller(),
sqlTransaction);
eventStock.GetRepaymentEvents().First(i => !i.IsFired).Comment =
saving.Events.Last().Id.ToString(CultureInfo.InvariantCulture);
}
loan.Events = eventStock;
_ePs.FireEvent(repayEvent, loan, sqlTransaction);
ArchiveInstallments(loan, repayEvent, sqlTransaction);
loan.InstallmentList = newInstallments.ToList();
foreach (var installment in newInstallments)
_instalmentManager.UpdateInstallment(installment, loan.Id, repayEvent.Id, sqlTransaction);
if (newInstallments.All(installment => installment.IsRepaid))
{
_ePs.FireEvent(loan.GetCloseEvent(TimeProvider.Now), loan, sqlTransaction);
loan.Closed = true;
loan.ContractStatus = OContractStatus.Closed;
_loanManager.UpdateLoan(loan, sqlTransaction);
}
var repaymentEvents = (from item in loan.Events.GetRepaymentEvents()
where item.ParentId == repayEvent.Id || item.Id == repayEvent.Id
select item).ToList();
var listOfRble = (from item in repaymentEvents where item.Code == "RBLE" select item).ToList();
var listOfRgle = repaymentEvents.Except(listOfRble).ToList();
if (repayEvent.Code == "RBLE")
CallInterceptor(new Dictionary<string, object>
{
{"Loan", loan},
{
"Event", new BadLoanRepaymentEvent
{
Code = "RBLE",
Principal = listOfRble.Sum(item => item.Principal.Value),
Interests = listOfRble.Sum(item => item.Interests.Value),
Commissions = listOfRble.Sum(item => item.Commissions.Value),
Penalties = listOfRble.Sum(item => item.Fees.Value),
Id = repayEvent.Id,
Date = repayEvent.Date
}
},
{"SqlTransaction", sqlTransaction}
});
CallInterceptor(new Dictionary<string, object>
{
{"Loan", loan},
{
"Event", new RepaymentEvent
{
Code = "RGLE",
Principal = listOfRgle.Sum(item => item.Principal.Value),
Interests = listOfRgle.Sum(item => item.Interests.Value),
Commissions = listOfRgle.Sum(item => item.Commissions.Value),
Penalties = listOfRgle.Sum(item => item.Fees.Value),
Id = repayEvent.Id,
Date = repayEvent.Date
}
},
{"SqlTransaction", sqlTransaction}
});
sqlTransaction.Commit();
}
catch (Exception)
{
sqlTransaction.Rollback();
throw;
}
//.........这里部分代码省略.........