using MySystem.Models.Main;
using Library;
using MySystem.Service.Main;
using System.Collections.Generic;
using System;
using System.Linq;
namespace MySystem
{
///
/// 经营数据工具类
///
public class BusinessUtil
{
#region 经营数据记录(月)
///
/// 经营数据记录(月)
///
/// 商户Id
/// 月份
/// 条数
/// 页数
///
public static List> BussinessRecordForMonth(int MerchantId, string TradeMonth, int pageSize, int pageNum)
{
List relationData = new List();
List> dataList = new List>();
if (!new MerchantTradeSummaryService().CheckTableExist(TradeMonth))
{
return dataList;
}
List> source = MerchantTradeSummaryService.List2(relationData, " and MerchantId=" + MerchantId, TradeMonth, pageNum, pageSize,"TradeDate desc");
foreach (Dictionary subdata in source)
{
Dictionary curData = new Dictionary();
curData.Add("TradeDate", subdata["TradeDate"].ToString()); //日期
curData.Add("TotalAmount", decimal.Parse(subdata["TradeAmount"].ToString()).ToString("f2")); //营业总金额
curData.Add("InFactAmount", decimal.Parse(subdata["InFactAmount"].ToString()).ToString("f2")); //实收总金额
curData.Add("ActAmount", decimal.Parse(subdata["ActAmount"].ToString()).ToString("f2")); //活动总金额
curData.Add("NonActAmount", decimal.Parse(subdata["NonActAmount"].ToString()).ToString("f2")); //非活动总金额
curData.Add("WeChatInFactAmount", decimal.Parse(subdata["WeChatInfactAmount"].ToString()).ToString("f2")); //微信实收
curData.Add("AliPayInFactAmount", decimal.Parse(subdata["AliPayInFactAmount"].ToString()).ToString("f2")); //支付宝实收
curData.Add("OrderCount", subdata["OderCount"].ToString()); //订单数
curData.Add("Kind", 2); //通道(1 直连 2 银联)
dataList.Add(curData);
}
return dataList;
}
#endregion
#region 经营数据记录(半年)
///
/// 经营数据记录(半年)
///
/// 商户Id
/// 条数
/// 页数
///
public static List> BussinessRecordForHalfYear(int MerchantId, int pageSize, int pageNum)
{
List> dataList = new List>();
List> source = UserTradeDbconn.Instance.GetMonthTradeList(MerchantId, "TradeAmount,InFactAmount,ActAmount,NonActAmount,WeChatInfactAmount,AliPayInFactAmount,OderCount");
foreach (Dictionary subdata in source)
{
Dictionary curData = new Dictionary();
curData.Add("TradeDate", subdata["TradeDate"].ToString()); //日期
curData.Add("TotalAmount", decimal.Parse(subdata["TradeAmount"].ToString()).ToString("f2")); //营业总金额
curData.Add("InFactAmount", decimal.Parse(subdata["InFactAmount"].ToString()).ToString("f2")); //实收总金额
curData.Add("ActAmount", decimal.Parse(subdata["ActAmount"].ToString()).ToString("f2")); //活动总金额
curData.Add("NonActAmount", decimal.Parse(subdata["NonActAmount"].ToString()).ToString("f2")); //非活动总金额
curData.Add("WeChatInFactAmount", decimal.Parse(subdata["WeChatInfactAmount"].ToString()).ToString("f2")); //微信实收
curData.Add("AliPayInFactAmount", decimal.Parse(subdata["AliPayInFactAmount"].ToString()).ToString("f2")); //支付宝实收
curData.Add("OrderCount", subdata["OderCount"].ToString()); //订单数
dataList.Add(curData);
}
return dataList;
}
#endregion
#region 经营详情列表
///
/// 经营详情列表
///
/// 查询条件
/// 条数
/// 页数
///
public static List> DayDetailList(string condition, int pageSize, int pageNum)
{
List relationData = new List();
List> dataList = new List>();
List> source = ConsumerOrdersService.List(relationData, condition, pageNum, pageSize);
foreach (Dictionary subdata in source)
{
Dictionary curData = new Dictionary();
curData.Add("Id", subdata["Id"].ToString()); //订单Id
curData.Add("TradeDate", DateTime.Parse(subdata["CreateDate"].ToString()).ToString("HH:mm:ss")); //日期
curData.Add("PayMode", subdata["PayMode"].ToString()); //支付方式(1 支付宝 2 微信)
curData.Add("IsAct", subdata["IsAct"].ToString()); //是否活动(1 是 0 否)
curData.Add("PayMoney", decimal.Parse(subdata["PayMoney"].ToString()).ToString("f2")); //订单金额
curData.Add("Kind", 2); //通道(1 直连 2 银联)
dataList.Add(curData);
}
return dataList;
}
#endregion
#region 交易详情
///
/// 交易详情
///
/// 查询条件
///
public static Dictionary OrderDetail(string condition)
{
List relationData = new List();
Dictionary obj = new Dictionary();
List> source = ConsumerOrdersService.List(relationData, condition, 1, 999);
foreach (Dictionary subdata in source)
{
var leaveAmount = decimal.Parse(subdata["MaxDivi"].ToString()) - decimal.Parse(subdata["CurDivi"].ToString());
obj.Add("TradeDate", DateTime.Parse(subdata["CreateDate"].ToString()).ToString("yyyy-MM-dd HH:mm:ss")); //日期
obj.Add("PayMode", subdata["PayMode"].ToString()); //支付方式(1 微信 2 支付宝)
obj.Add("PayMoney", decimal.Parse(subdata["PayMoney"].ToString()).ToString("f2")); //支付金额
obj.Add("IsAct", subdata["IsAct"].ToString()); //是否活动(1 是 0 否)
obj.Add("OrderNo", subdata["OrderNo"].ToString()); //订单号
obj.Add("ReturnFlag", int.Parse(subdata["ReturnFlag"].ToString())); //返现标记(0 否 1 是)
obj.Add("Kind", 2); //通道(1 直连 2 银联)
obj.Add("LeaveAmount", leaveAmount); //剩余返现金额
obj.Add("MerchantName", MerchantInfoService.Query(int.Parse(subdata["MerchantId"].ToString())).Name); //交易门店
List> dataList = new List>();
List> dics = ConsumerProfitService.List(relationData, " and OrderId=" + int.Parse(subdata["Id"].ToString()) + "", 1, 999);
foreach (Dictionary dic in dics)
{
Dictionary cdata = new Dictionary();
var CreateDate = DateTime.Parse(dic["CreateDate"].ToString());
var TradeDate = CreateDate.Month + "月" + CreateDate.Day + "日" + " " + CreateDate.ToString("HH:mm");
cdata.Add("ProfitDate", TradeDate); //分红时间
cdata.Add("ProfitAmount", decimal.Parse(dic["GetMoney"].ToString()).ToString("f2")); //分红金额
dataList.Add(cdata);
}
obj.Add("ProfitTotalAmount", ConsumerProfitService.Sum(" OrderId=" + int.Parse(subdata["Id"].ToString()) + "", "GetMoney").ToString("f2")); //分红总金额
obj.Add("ProfitList", dataList); //订单分红记录列表
}
return obj;
}
#endregion
}
}