BusinessUtil.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. using MySystem.Models.Main;
  2. using Library;
  3. using MySystem.Service.Main;
  4. using System.Collections.Generic;
  5. using System;
  6. using System.Linq;
  7. namespace MySystem
  8. {
  9. /// <summary>
  10. /// 经营数据工具类
  11. /// </summary>
  12. public class BusinessUtil
  13. {
  14. #region 经营数据记录(月)
  15. /// <summary>
  16. /// 经营数据记录(月)
  17. /// </summary>
  18. /// <param name="MerchantId">商户Id</param>
  19. /// <param name="TradeMonth">月份</param>
  20. /// <param name="pageSize">条数</param>
  21. /// <param name="pageNum">页数</param>
  22. /// <returns></returns>
  23. public static List<Dictionary<string, object>> BussinessRecordForMonth(int MerchantId, string TradeMonth, int pageSize, int pageNum)
  24. {
  25. List<RelationData> relationData = new List<RelationData>();
  26. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  27. if (!new MerchantTradeSummaryService().CheckTableExist(TradeMonth))
  28. {
  29. return dataList;
  30. }
  31. List<Dictionary<string, object>> source = MerchantTradeSummaryService.List2(relationData, " and MerchantId=" + MerchantId, TradeMonth, pageNum, pageSize,"TradeDate desc");
  32. foreach (Dictionary<string, object> subdata in source)
  33. {
  34. Dictionary<string, object> curData = new Dictionary<string, object>();
  35. curData.Add("TradeDate", subdata["TradeDate"].ToString()); //日期
  36. curData.Add("TotalAmount", decimal.Parse(subdata["TradeAmount"].ToString()).ToString("f2")); //营业总金额
  37. curData.Add("InFactAmount", decimal.Parse(subdata["InFactAmount"].ToString()).ToString("f2")); //实收总金额
  38. curData.Add("ActAmount", decimal.Parse(subdata["ActAmount"].ToString()).ToString("f2")); //活动总金额
  39. curData.Add("NonActAmount", decimal.Parse(subdata["NonActAmount"].ToString()).ToString("f2")); //非活动总金额
  40. curData.Add("WeChatInFactAmount", decimal.Parse(subdata["WeChatInfactAmount"].ToString()).ToString("f2")); //微信实收
  41. curData.Add("AliPayInFactAmount", decimal.Parse(subdata["AliPayInFactAmount"].ToString()).ToString("f2")); //支付宝实收
  42. curData.Add("OrderCount", subdata["OderCount"].ToString()); //订单数
  43. curData.Add("Kind", 2); //通道(1 直连 2 银联)
  44. dataList.Add(curData);
  45. }
  46. return dataList;
  47. }
  48. #endregion
  49. #region 经营数据记录(半年)
  50. /// <summary>
  51. /// 经营数据记录(半年)
  52. /// </summary>
  53. /// <param name="MerchantId">商户Id</param>
  54. /// <param name="pageSize">条数</param>
  55. /// <param name="pageNum">页数</param>
  56. /// <returns></returns>
  57. public static List<Dictionary<string, object>> BussinessRecordForHalfYear(int MerchantId, int pageSize, int pageNum)
  58. {
  59. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  60. List<Dictionary<string, object>> source = UserTradeDbconn.Instance.GetMonthTradeList(MerchantId, "TradeAmount,InFactAmount,ActAmount,NonActAmount,WeChatInfactAmount,AliPayInFactAmount,OderCount");
  61. foreach (Dictionary<string, object> subdata in source)
  62. {
  63. Dictionary<string, object> curData = new Dictionary<string, object>();
  64. curData.Add("TradeDate", subdata["TradeDate"].ToString()); //日期
  65. curData.Add("TotalAmount", decimal.Parse(subdata["TradeAmount"].ToString()).ToString("f2")); //营业总金额
  66. curData.Add("InFactAmount", decimal.Parse(subdata["InFactAmount"].ToString()).ToString("f2")); //实收总金额
  67. curData.Add("ActAmount", decimal.Parse(subdata["ActAmount"].ToString()).ToString("f2")); //活动总金额
  68. curData.Add("NonActAmount", decimal.Parse(subdata["NonActAmount"].ToString()).ToString("f2")); //非活动总金额
  69. curData.Add("WeChatInFactAmount", decimal.Parse(subdata["WeChatInfactAmount"].ToString()).ToString("f2")); //微信实收
  70. curData.Add("AliPayInFactAmount", decimal.Parse(subdata["AliPayInFactAmount"].ToString()).ToString("f2")); //支付宝实收
  71. curData.Add("OrderCount", subdata["OderCount"].ToString()); //订单数
  72. dataList.Add(curData);
  73. }
  74. return dataList;
  75. }
  76. #endregion
  77. #region 经营详情列表
  78. /// <summary>
  79. /// 经营详情列表
  80. /// </summary>
  81. /// <param name="condition">查询条件</param>
  82. /// <param name="pageSize">条数</param>
  83. /// <param name="pageNum">页数</param>
  84. /// <returns></returns>
  85. public static List<Dictionary<string, object>> DayDetailList(string condition, int pageSize, int pageNum)
  86. {
  87. List<RelationData> relationData = new List<RelationData>();
  88. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  89. List<Dictionary<string, object>> source = ConsumerOrdersService.List(relationData, condition, pageNum, pageSize);
  90. foreach (Dictionary<string, object> subdata in source)
  91. {
  92. Dictionary<string, object> curData = new Dictionary<string, object>();
  93. curData.Add("Id", subdata["Id"].ToString()); //订单Id
  94. curData.Add("TradeDate", DateTime.Parse(subdata["CreateDate"].ToString()).ToString("HH:mm:ss")); //日期
  95. curData.Add("PayMode", subdata["PayMode"].ToString()); //支付方式(1 支付宝 2 微信)
  96. curData.Add("IsAct", subdata["IsAct"].ToString()); //是否活动(1 是 0 否)
  97. curData.Add("PayMoney", decimal.Parse(subdata["PayMoney"].ToString()).ToString("f2")); //订单金额
  98. curData.Add("Kind", 2); //通道(1 直连 2 银联)
  99. dataList.Add(curData);
  100. }
  101. return dataList;
  102. }
  103. #endregion
  104. #region 交易详情
  105. /// <summary>
  106. /// 交易详情
  107. /// </summary>
  108. /// <param name="condition">查询条件</param>
  109. /// <returns></returns>
  110. public static Dictionary<string, object> OrderDetail(string condition)
  111. {
  112. List<RelationData> relationData = new List<RelationData>();
  113. Dictionary<string, object> obj = new Dictionary<string, object>();
  114. List<Dictionary<string, object>> source = ConsumerOrdersService.List(relationData, condition, 1, 999);
  115. foreach (Dictionary<string, object> subdata in source)
  116. {
  117. var leaveAmount = decimal.Parse(subdata["MaxDivi"].ToString()) - decimal.Parse(subdata["CurDivi"].ToString());
  118. obj.Add("TradeDate", DateTime.Parse(subdata["CreateDate"].ToString()).ToString("yyyy-MM-dd HH:mm:ss")); //日期
  119. obj.Add("PayMode", subdata["PayMode"].ToString()); //支付方式(1 微信 2 支付宝)
  120. obj.Add("PayMoney", decimal.Parse(subdata["PayMoney"].ToString()).ToString("f2")); //支付金额
  121. obj.Add("IsAct", subdata["IsAct"].ToString()); //是否活动(1 是 0 否)
  122. obj.Add("OrderNo", subdata["OrderNo"].ToString()); //订单号
  123. obj.Add("ReturnFlag", int.Parse(subdata["ReturnFlag"].ToString())); //返现标记(0 否 1 是)
  124. obj.Add("Kind", 2); //通道(1 直连 2 银联)
  125. obj.Add("LeaveAmount", leaveAmount); //剩余返现金额
  126. obj.Add("MerchantName", MerchantInfoService.Query(int.Parse(subdata["MerchantId"].ToString())).Name); //交易门店
  127. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  128. List<Dictionary<string, object>> dics = ConsumerProfitService.List(relationData, " and OrderId=" + int.Parse(subdata["Id"].ToString()) + "", 1, 999);
  129. foreach (Dictionary<string, object> dic in dics)
  130. {
  131. Dictionary<string, object> cdata = new Dictionary<string, object>();
  132. var CreateDate = DateTime.Parse(dic["CreateDate"].ToString());
  133. var TradeDate = CreateDate.Month + "月" + CreateDate.Day + "日" + " " + CreateDate.ToString("HH:mm");
  134. cdata.Add("ProfitDate", TradeDate); //分红时间
  135. cdata.Add("ProfitAmount", decimal.Parse(dic["GetMoney"].ToString()).ToString("f2")); //分红金额
  136. dataList.Add(cdata);
  137. }
  138. obj.Add("ProfitTotalAmount", ConsumerProfitService.Sum(" OrderId=" + int.Parse(subdata["Id"].ToString()) + "", "GetMoney").ToString("f2")); //分红总金额
  139. obj.Add("ProfitList", dataList); //订单分红记录列表
  140. }
  141. return obj;
  142. }
  143. #endregion
  144. }
  145. }