本文整理汇总了C#中Samba.Domain.Models.Tickets.Ticket.GetPlainSum方法的典型用法代码示例。如果您正苦于以下问题:C# Ticket.GetPlainSum方法的具体用法?C# Ticket.GetPlainSum怎么用?C# Ticket.GetPlainSum使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Samba.Domain.Models.Tickets.Ticket
的用法示例。
在下文中一共展示了Ticket.GetPlainSum方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CalculateOrderTotal
public static decimal CalculateOrderTotal(Ticket ticket, Order order)
{
var discount = ticket.GetPreTaxServicesTotal();
if (discount != 0)
{
var tsum = ticket.GetPlainSum();
var rate = tsum > 0 ? (discount * 100) / tsum : 100;
var tiTotal = order.GetTotal();
var itemDiscount = (tiTotal * rate) / 100;
return tiTotal + itemDiscount;
}
return order.GetTotal();
}
示例2: GroupLinesByValue
private IEnumerable<Order> GroupLinesByValue(Ticket ticket, Func<MenuItem, string> selector, string defaultValue, bool calcDiscounts = false)
{
var discounts = calcDiscounts ? ticket.GetPreTaxServicesTotal() : 0;
var di = discounts > 0 ? discounts / ticket.GetPlainSum() : 0;
var cache = new Dictionary<string, decimal>();
foreach (var order in ticket.Orders.OrderBy(x => x.Id).ToList())
{
var item = order;
var value = _cacheService.GetMenuItemData(item.MenuItemId, selector);
if (string.IsNullOrEmpty(value)) value = defaultValue;
if (!cache.ContainsKey(value))
cache.Add(value, 0);
var total = (item.GetTotal());
cache[value] += Decimal.Round(total - (total * di), 2);
}
return cache.Select(x => new Order
{
MenuItemName = x.Key,
Price = x.Value,
Quantity = 1,
PortionCount = 1
});
}
示例3: ReplaceDocumentVars
private static string ReplaceDocumentVars(string document, Ticket ticket, int orderNo, string userName)
{
string result = document;
if (string.IsNullOrEmpty(document)) return "";
result = FormatData(result, TagNames.TicketDate, () => ticket.Date.ToShortDateString());
result = FormatData(result, TagNames.TicketTime, () => ticket.Date.ToShortTimeString());
result = FormatData(result, TagNames.Date, () => DateTime.Now.ToShortDateString());
result = FormatData(result, TagNames.Time, () => DateTime.Now.ToShortTimeString());
result = FormatData(result, TagNames.TicketId, () => ticket.Id.ToString());
result = FormatData(result, TagNames.TicketNo, () => ticket.TicketNumber);
result = FormatData(result, TagNames.OrderNo, orderNo.ToString);
result = FormatData(result, TagNames.TicketTag, ticket.GetTagData);
result = FormatDataIf(true, result, TagNames.Department, () => GetDepartmentName(ticket.DepartmentId));
const string ticketTagPattern = TagNames.TicketTag2 + "[^}]+}";
while (Regex.IsMatch(result, ticketTagPattern))
{
var value = Regex.Match(result, ticketTagPattern).Groups[0].Value;
var tags = "";
try
{
var tag = value.Trim('{', '}').Split(':')[1];
tags = tag.Split(',').Aggregate(tags, (current, t) => current +
(!string.IsNullOrEmpty(ticket.GetTagValue(t.Trim()))
? (t + ": " + ticket.GetTagValue(t.Trim()) + "\r")
: ""));
result = FormatData(result.Trim('\r'), value, () => tags);
}
catch (Exception)
{
result = FormatData(result, value, () => "");
}
}
const string ticketTag2Pattern = TagNames.TicketTag3 + "[^}]+}";
while (Regex.IsMatch(result, ticketTag2Pattern))
{
var value = Regex.Match(result, ticketTag2Pattern).Groups[0].Value;
var tag = value.Trim('{', '}').Split(':')[1];
var tagValue = ticket.GetTagValue(tag);
try
{
result = FormatData(result, value, () => tagValue);
}
catch (Exception)
{
result = FormatData(result, value, () => "");
}
}
var title = userName;
result = FormatData(result, TagNames.LocationUser, () => title);
result = FormatData(result, TagNames.UserName, () => userName);
result = FormatData(result, TagNames.Note, () => ticket.Note);
result = FormatData(result, TagNames.AccName, () => ticket.AccountName);
if (ticket.AccountId > 0 && (result.Contains(TagNames.AccAddress) || result.Contains(TagNames.AccPhone)))
{
var account = Dao.SingleWithCache<Resource>(x => x.Id == ticket.AccountId);
result = FormatData(result, TagNames.AccPhone, () => account.SearchString);
}
result = RemoveTag(result, TagNames.AccAddress);
result = RemoveTag(result, TagNames.AccPhone);
var payment = ticket.GetPaymentAmount();
var remaining = ticket.GetRemainingAmount();
var plainTotal = ticket.GetPlainSum();
var preTaxServices = ticket.GetPreTaxServicesTotal();
var taxAmount = ticket.CalculateTax(plainTotal, preTaxServices); //GetTaxTotal(ticket.Orders, plainTotal, ticket.GetDiscountTotal());
var servicesTotal = ticket.GetPostTaxServicesTotal();
//ticket.CalculateTax(plainTotal, preTaxServices);
result = FormatDataIf(taxAmount > 0 || preTaxServices > 0 || servicesTotal > 0, result, TagNames.PlainTotal, () => plainTotal.ToString("#,#0.00"));
result = FormatDataIf(preTaxServices > 0, result, TagNames.DiscountTotal, () => preTaxServices.ToString("#,#0.00"));
result = FormatDataIf(taxAmount > 0, result, TagNames.TaxTotal, () => taxAmount.ToString("#,#0.00"));
result = FormatDataIf(taxAmount > 0, result, TagNames.TaxDetails, () => GetTaxDetails(ticket.Orders, plainTotal, preTaxServices));
result = FormatDataIf(servicesTotal > 0, result, TagNames.CalculationDetails, () => GetServiceDetails(ticket));
result = FormatDataIf(payment > 0, result, TagNames.IfPaid,
() => string.Format(Resources.RemainingAmountIfPaidValue_f, payment.ToString("#,#0.00"), remaining.ToString("#,#0.00")));
result = FormatDataIf(preTaxServices > 0, result, TagNames.IfDiscount,
() => string.Format(Resources.DiscountTotalAndTicketTotalValue_f, (plainTotal).ToString("#,#0.00"), preTaxServices.ToString("#,#0.00")));
result = FormatDataIf(preTaxServices < 0, result, TagNames.IfFlatten, () => string.Format(Resources.IfNegativeDiscountValue_f, preTaxServices.ToString("#,#0.00")));
result = FormatData(result, TagNames.TicketTotal, () => ticket.GetSum().ToString("#,#0.00"));
result = FormatData(result, TagNames.PaymentTotal, () => ticket.GetPaymentAmount().ToString("#,#0.00"));
result = FormatData(result, TagNames.Balance, () => ticket.GetRemainingAmount().ToString("#,#0.00"));
result = FormatData(result, TagNames.TotalText, () => HumanFriendlyInteger.CurrencyToWritten(ticket.GetSum()));
result = FormatData(result, TagNames.Totaltext, () => HumanFriendlyInteger.CurrencyToWritten(ticket.GetSum(), true));
result = _settingReplacer.ReplaceSettingValue("{SETTING:([^}]+)}", result);
//.........这里部分代码省略.........
示例4: GroupLinesByValue
private static IEnumerable<TicketItem> GroupLinesByValue(Ticket ticket, Func<MenuItem, object> selector, string defaultValue, bool calcDiscounts = false)
{
var discounts = calcDiscounts ? ticket.GetDiscountAndRoundingTotal() : 0;
var di = discounts > 0 ? discounts / ticket.GetPlainSum() : 0;
var cache = new Dictionary<string, decimal>();
foreach (var ticketItem in ticket.TicketItems.OrderBy(x => x.Id).ToList())
{
var item = ticketItem;
var value = selector(AppServices.DataAccessService.GetMenuItem(item.MenuItemId)).ToString();
if (string.IsNullOrEmpty(value)) value = defaultValue;
if (!cache.ContainsKey(value))
cache.Add(value, 0);
var total = (item.GetTotal());
cache[value] += Decimal.Round(total - (total * di), 2);
}
return cache.Select(x => new TicketItem
{
MenuItemName = x.Key,
Price = x.Value,
Quantity = 1,
PortionCount = 1,
CurrencyCode = LocalSettings.CurrencySymbol
});
}
示例5: ReplaceDocumentVars
private static string ReplaceDocumentVars(string document, Ticket ticket, int orderNo, int userNo, int departmentNo)
{
string result = document;
if (string.IsNullOrEmpty(document)) return "";
result = FormatData(result, Resources.TF_TicketDate, () => ticket.Date.ToShortDateString());
result = FormatData(result, Resources.TF_TicketTime, () => ticket.Date.ToShortTimeString());
result = FormatData(result, Resources.TF_DayDate, () => DateTime.Now.ToShortDateString());
result = FormatData(result, Resources.TF_DayTime, () => DateTime.Now.ToShortTimeString());
result = FormatData(result, Resources.TF_UniqueTicketId, () => ticket.Id.ToString());
result = FormatData(result, Resources.TF_TicketNumber, () => ticket.TicketNumber);
result = FormatData(result, Resources.TF_LineOrderNumber, orderNo.ToString);
result = FormatData(result, Resources.TF_TicketTag, ticket.GetTagData);
result = FormatDataIf(true, result, "{DEPARTMENT}", () => GetDepartmentName(departmentNo));
var ticketTagPattern = Resources.TF_OptionalTicketTag + "[^}]+}";
while (Regex.IsMatch(result, ticketTagPattern))
{
var value = Regex.Match(result, ticketTagPattern).Groups[0].Value;
var tags = "";
try
{
var tag = value.Trim('{', '}').Split(':')[1];
tags = tag.Split(',').Aggregate(tags, (current, t) => current +
(!string.IsNullOrEmpty(ticket.GetTagValue(t.Trim()))
? (t + ": " + ticket.GetTagValue(t.Trim()) + "\r")
: ""));
result = FormatData(result.Trim('\r'), value, () => tags);
}
catch (Exception)
{
result = FormatData(result, value, () => "");
}
}
const string ticketTag2Pattern = "{TICKETTAG:[^}]+}";
while (Regex.IsMatch(result, ticketTag2Pattern))
{
var value = Regex.Match(result, ticketTag2Pattern).Groups[0].Value;
var tag = value.Trim('{', '}').Split(':')[1];
var tagValue = ticket.GetTagValue(tag);
try
{
result = FormatData(result, value, () => tagValue);
}
catch (Exception)
{
result = FormatData(result, value, () => "");
}
}
var userName = AppServices.MainDataContext.GetUserName(userNo);
var title = ticket.LocationName;
if (string.IsNullOrEmpty(ticket.LocationName))
title = userName;
result = FormatData(result, Resources.TF_TableOrUserName, () => title);
result = FormatData(result, Resources.TF_UserName, () => userName);
result = FormatData(result, Resources.TF_TableName, () => ticket.LocationName);
result = FormatData(result, Resources.TF_TicketNote, () => ticket.Note ?? "");
result = FormatData(result, Resources.TF_AccountName, () => ticket.CustomerName);
result = FormatData(result, "{ACC GROUPCODE}", () => ticket.CustomerGroupCode);
if (ticket.CustomerId > 0 && (result.Contains(Resources.TF_AccountAddress) || result.Contains(Resources.TF_AccountPhone) || result.Contains("{ACC NOTE}")))
{
var customer = Dao.SingleWithCache<Customer>(x => x.Id == ticket.CustomerId);
result = FormatData(result, Resources.TF_AccountAddress, () => customer.Address);
result = FormatData(result, Resources.TF_AccountPhone, () => customer.PhoneNumber);
result = FormatData(result, "{ACC NOTE}", () => customer.Note);
}
if (ticket.CustomerId > 0 && result.Contains("{ACC BALANCE}"))
{
var accBalance = CashService.GetAccountBalance(ticket.CustomerId);
result = FormatDataIf(accBalance != 0, result, "{ACC BALANCE}", () => accBalance.ToString("#,#0.00"));
}
result = RemoveTag(result, Resources.TF_AccountAddress);
result = RemoveTag(result, Resources.TF_AccountPhone);
var payment = ticket.GetPaymentAmount();
var remaining = ticket.GetRemainingAmount();
var discount = ticket.GetDiscountAndRoundingTotal();
var plainTotal = ticket.GetPlainSum();
var giftAmount = ticket.GetTotalGiftAmount();
var vatAmount = GetTaxTotal(ticket.TicketItems, plainTotal, ticket.GetDiscountTotal());
var taxServicesTotal = ticket.GetTaxServicesTotal();
var ticketPaymentAmount = ticket.GetPaymentAmount();
result = FormatDataIf(vatAmount > 0 || discount > 0 || taxServicesTotal > 0, result, "{PLAIN TOTAL}", () => plainTotal.ToString("#,#0.00"));
result = FormatDataIf(discount > 0, result, "{DISCOUNT TOTAL}", () => discount.ToString("#,#0.00"));
result = FormatDataIf(vatAmount > 0, result, "{TAX TOTAL}", () => vatAmount.ToString("#,#0.00"));
result = FormatDataIf(taxServicesTotal > 0, result, "{SERVICE TOTAL}", () => taxServicesTotal.ToString("#,#0.00"));
result = FormatDataIf(vatAmount > 0, result, "{TAX DETAILS}", () => GetTaxDetails(ticket.TicketItems, plainTotal, discount));
result = FormatDataIf(taxServicesTotal > 0, result, "{SERVICE DETAILS}", () => GetServiceDetails(ticket));
result = FormatDataIf(payment > 0, result, Resources.TF_RemainingAmountIfPaid,
//.........这里部分代码省略.........