本文整理汇总了C#中Samba.Domain.Models.Tickets.Ticket.MergeOrdersAndUpdateOrderNumbers方法的典型用法代码示例。如果您正苦于以下问题:C# Ticket.MergeOrdersAndUpdateOrderNumbers方法的具体用法?C# Ticket.MergeOrdersAndUpdateOrderNumbers怎么用?C# Ticket.MergeOrdersAndUpdateOrderNumbers使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Samba.Domain.Models.Tickets.Ticket
的用法示例。
在下文中一共展示了Ticket.MergeOrdersAndUpdateOrderNumbers方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CloseTicket
public TicketCommitResult CloseTicket(Ticket ticket)
{
var result = _ticketDao.CheckConcurrency(ticket);
Debug.Assert(ticket != null);
var changed = !string.IsNullOrEmpty(result.ErrorMessage);
var canSumbitTicket = !changed && ticket.CanSubmit;
if (canSumbitTicket)
{
RecalculateTicket(ticket);
//ticket.Close();
_applicationState.NotifyEvent(RuleEventNames.BeforeTicketClosing, new { Ticket = ticket, TicketId = ticket.Id, ticket.RemainingAmount, ticket.TotalAmount });
if (ticket.Orders.Count > 0)
{
var ticketType = _cacheService.GetTicketTypeById(ticket.TicketTypeId);
if (ticket.Orders.FirstOrDefault(x => !x.Locked) != null)
{
var number = _settingService.GetNextNumber(ticketType.OrderNumerator.Id);
ticket.MergeOrdersAndUpdateOrderNumbers(number);
}
if (ticket.Id == 0)
{
UpdateTicketNumber(ticket, ticketType.TicketNumerator);
_ticketDao.Save(ticket);
}
Debug.Assert(!string.IsNullOrEmpty(ticket.TicketNumber));
Debug.Assert(ticket.Id > 0);
_applicationState.NotifyEvent(RuleEventNames.TicketClosing, new { Ticket = ticket, TicketId = ticket.Id, ticket.RemainingAmount, ticket.TotalAmount });
ticket.LockTicket();
}
ticket.RemoveZeroAmountAccountTransactions();
if (ticket.Id > 0)// eğer adisyonda satır yoksa ID burada 0 olmalı.
_ticketDao.Save(ticket);
Debug.Assert(ticket.Orders.Count(x => x.OrderNumber == 0) == 0);
}
if (ticket.Id > 0)
{
foreach (var ticketEntity in ticket.TicketEntities)
{
var entityType = _cacheService.GetEntityTypeById(ticketEntity.EntityTypeId);
_applicationState.NotifyEvent(RuleEventNames.EntityUpdated, new
{
EntityTypeId = ticketEntity.EntityTypeId,
EntityId = ticketEntity.EntityId,
EntityTypeName = entityType.Name,
OpenTicketCount = _ticketServiceBase.GetOpenTicketIds(ticketEntity.EntityId).Count()
});
}
}
result.TicketId = ticket.Id;
return result;
}