|
|
@ -55,6 +55,8 @@ namespace BBWY.Server.Business |
|
|
|
|
|
|
|
public XingXinagSearchResponse XingXiangStatistics(XingXiangSearchOrderRequest xingXiangSearchOrderRequest) |
|
|
|
{ |
|
|
|
var mdsShop = freeSqlMultiDBManager.MDSfsql.Select<Shops>().Where(s => s.ShopId == xingXiangSearchOrderRequest.ShopId.ToString()).ToOne(); |
|
|
|
var platformCommissionRatio = mdsShop.PlatformCommissionRatio ?? 0.05M; |
|
|
|
var beginTime = xingXiangSearchOrderRequest.SearchDate.Date; |
|
|
|
var endTime = xingXiangSearchOrderRequest.SearchDate.Date.AddDays(1).AddSeconds(-1); |
|
|
|
IList<XingXiangItemResponse> detailList = null; |
|
|
@ -66,6 +68,7 @@ namespace BBWY.Server.Business |
|
|
|
.Where((o, oc) => !invalidOrderStateList.Contains(o.OrderState.Value)) |
|
|
|
.WhereIf(xingXiangSearchOrderRequest.SpuList != null && xingXiangSearchOrderRequest.SpuList.Count() > 0, |
|
|
|
(o, oc) => fsql.Select<OrderSku>().As("osku").Where(osku => xingXiangSearchOrderRequest.SpuList.Contains(osku.ProductId) && osku.OrderId == o.Id).Any()) |
|
|
|
.OrderByDescending((o, oc) => o.StartTime) |
|
|
|
.ToList((o, oc) => new Order() |
|
|
|
{ |
|
|
|
Id = o.Id, |
|
|
@ -78,7 +81,8 @@ namespace BBWY.Server.Business |
|
|
|
SDCommissionAmount = oc.SDCommissionAmount, |
|
|
|
DeliveryExpressFreight = oc.DeliveryExpressFreight, |
|
|
|
PreferentialAmount = oc.PreferentialAmount, |
|
|
|
OrderSellerPrice = o.OrderSellerPrice |
|
|
|
OrderSellerPrice = o.OrderSellerPrice, |
|
|
|
SellerPreferentialAmount = o.SellerPreferentialAmount |
|
|
|
}); |
|
|
|
|
|
|
|
if (orderList.Count() == 0) |
|
|
@ -106,9 +110,9 @@ namespace BBWY.Server.Business |
|
|
|
var profit = 0M; |
|
|
|
var sdCost = 0M; |
|
|
|
var prodcutAmount = group.Sum(osku => osku.Price * osku.ItemTotal) ?? 0; //货款
|
|
|
|
var preferentialAmount = order.PreferentialAmount / skuCount * group.Count(); //该SPU分摊的商家优惠金额
|
|
|
|
prodcutAmount -= preferentialAmount; |
|
|
|
var commissionAmount = prodcutAmount * 0.05M; //该SPU的平台扣点金额
|
|
|
|
var skuSellerPreferentialAmount = order.SellerPreferentialAmount / skuCount * group.Count(); //该SPU分摊的商家优惠金额
|
|
|
|
prodcutAmount -= skuSellerPreferentialAmount; |
|
|
|
var commissionAmount = prodcutAmount * platformCommissionRatio; //该SPU的平台扣点金额
|
|
|
|
var freightPriceByUser = order.FreightPrice == 0 ? 0 : order.FreightPrice / skuCount * group.Count(); //该SPU分摊的用户承担运费
|
|
|
|
var currentOrderCostDetailList = orderCostDetailList.Where(ocd => ocd.OrderId == order.Id && ocd.ProductId == spuId).ToList(); |
|
|
|
var purchaseAmount = currentOrderCostDetailList.Count() > 0 ? currentOrderCostDetailList.Sum(ocd => ocd.TotalCost) : 0; |
|
|
|