MerchantRebateDetailController.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. /*
  2. * 商户返利明细
  3. */
  4. using System;
  5. using System.Web;
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.Linq;
  9. using System.Data;
  10. using System.Threading.Tasks;
  11. using Microsoft.AspNetCore.Mvc;
  12. using Microsoft.AspNetCore.Http;
  13. using Microsoft.Extensions.Logging;
  14. using Microsoft.Extensions.Options;
  15. using MySystem.Models;
  16. using Library;
  17. using LitJson;
  18. using MySystemLib;
  19. namespace MySystem.Areas.Admin.Controllers
  20. {
  21. [Area("Admin")]
  22. [Route("Admin/[controller]/[action]")]
  23. public class MerchantRebateDetailController : BaseController
  24. {
  25. public MerchantRebateDetailController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  26. {
  27. OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  28. }
  29. #region 商户返利明细列表
  30. /// <summary>
  31. /// 根据条件查询商户返利明细列表
  32. /// </summary>
  33. /// <returns></returns>
  34. public IActionResult Index(MerchantRebateDetail data, string right)
  35. {
  36. ViewBag.RightInfo = RightInfo;
  37. ViewBag.right = right;
  38. return View();
  39. }
  40. #endregion
  41. #region 根据条件查询商户返利明细列表
  42. /// <summary>
  43. /// 商户返利明细列表
  44. /// </summary>
  45. /// <returns></returns>
  46. public JsonResult IndexData(MerchantRebateDetail data, string MerchantNo, string MerchantName, string TradeMonthSelect, string SyncStatusSelect, int page = 1, int limit = 30)
  47. {
  48. Dictionary<string, string> Fields = new Dictionary<string, string>();
  49. Fields.Add("BrandId", "1"); //品牌
  50. Fields.Add("CreateDate", "3"); //时间
  51. Fields.Add("SnNo", "2"); //渠道SN号
  52. string condition = " and Status>-1";
  53. //商户编号
  54. if (!string.IsNullOrEmpty(MerchantNo))
  55. {
  56. condition += " and MerchantId in (select MerchantId from MerchantForCode where Code='" + MerchantNo + "')";
  57. }
  58. //商户名称
  59. if (!string.IsNullOrEmpty(MerchantName))
  60. {
  61. condition += " and MerchantId in (select MerchantId from MerchantForName where Name='" + MerchantName + "')";
  62. }
  63. //交易月份
  64. if(!string.IsNullOrEmpty(TradeMonthSelect))
  65. {
  66. condition += " and TradeMonth=" + TradeMonthSelect.Replace("-", "");
  67. }
  68. //同步状态
  69. if (!string.IsNullOrEmpty(SyncStatusSelect))
  70. {
  71. condition += " and SyncStatus=" + SyncStatusSelect;
  72. }
  73. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("MerchantRebateDetail", Fields, "Id desc", "0", page, limit, condition);
  74. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  75. foreach (Dictionary<string, object> dic in diclist)
  76. {
  77. dic["BrandId"] = RelationClass.GetKqProductBrandInfo(int.Parse(dic["BrandId"].ToString()));
  78. int MerchantId = int.Parse(dic["MerchantId"].ToString());
  79. MerchantInfo merchant = db.MerchantInfo.FirstOrDefault(m => m.Id == MerchantId) ?? new MerchantInfo();
  80. dic["MerchantNo"] = "";
  81. dic["MerchantName"] = merchant.Name;
  82. dic["MerchantRealName"] = "";
  83. // int SyncStatus = int.Parse(dic["SyncStatus"].ToString());
  84. // if (SyncStatus == 0) dic["SyncStatus"] = "初始";
  85. // if (SyncStatus == 1) dic["SyncStatus"] = "已验证和同步";
  86. }
  87. Dictionary<string, object> other = new Dictionary<string, object>();
  88. string CreditTradeAmt = "0.00", DebitTradeAmt = "0.00", CreditPrizeAmt = "0.00", DebitPrizeAmt = "0.00";
  89. DataTable dt = OtherMySqlConn.dtable("select sum(CreditTradeAmt),sum(DebitTradeAmt),sum(CreditPrizeAmt),sum(DebitPrizeAmt) from MerchantRebateDetail where 1=1" + condition);
  90. if(dt.Rows.Count > 0)
  91. {
  92. CreditTradeAmt = dt.Rows[0][0].ToString();
  93. DebitTradeAmt = dt.Rows[0][1].ToString();
  94. CreditPrizeAmt = dt.Rows[0][2].ToString();
  95. DebitPrizeAmt = dt.Rows[0][3].ToString();
  96. }
  97. other.Add("CreditTradeAmt", CreditTradeAmt);
  98. other.Add("DebitTradeAmt", DebitTradeAmt);
  99. other.Add("CreditPrizeAmt", CreditPrizeAmt);
  100. other.Add("DebitPrizeAmt", DebitPrizeAmt);
  101. obj.Add("other", other);
  102. return Json(obj);
  103. }
  104. #endregion
  105. #region 增加商户返利明细
  106. /// <summary>
  107. /// 增加或修改商户返利明细信息
  108. /// </summary>
  109. /// <returns></returns>
  110. public IActionResult Add(string right)
  111. {
  112. ViewBag.RightInfo = RightInfo;
  113. ViewBag.right = right;
  114. return View();
  115. }
  116. #endregion
  117. #region 增加商户返利明细
  118. /// <summary>
  119. /// 增加或修改商户返利明细信息
  120. /// </summary>
  121. /// <returns></returns>
  122. [HttpPost]
  123. public string Add(MerchantRebateDetail data)
  124. {
  125. Dictionary<string, object> Fields = new Dictionary<string, object>();
  126. Fields.Add("SeoTitle", data.SeoTitle);
  127. Fields.Add("SeoKeyword", data.SeoKeyword);
  128. Fields.Add("SeoDescription", data.SeoDescription);
  129. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("MerchantRebateDetail", Fields, 0);
  130. AddSysLog(data.Id.ToString(), "MerchantRebateDetail", "add");
  131. db.SaveChanges();
  132. return "success";
  133. }
  134. #endregion
  135. #region 修改商户返利明细
  136. /// <summary>
  137. /// 增加或修改商户返利明细信息
  138. /// </summary>
  139. /// <returns></returns>
  140. public IActionResult Edit(string right, int Id = 0)
  141. {
  142. ViewBag.RightInfo = RightInfo;
  143. ViewBag.right = right;
  144. MerchantRebateDetail editData = db.MerchantRebateDetail.FirstOrDefault(m => m.Id == Id) ?? new MerchantRebateDetail();
  145. ViewBag.data = editData;
  146. return View();
  147. }
  148. #endregion
  149. #region 修改商户返利明细
  150. /// <summary>
  151. /// 增加或修改商户返利明细信息
  152. /// </summary>
  153. /// <returns></returns>
  154. [HttpPost]
  155. public string Edit(MerchantRebateDetail data)
  156. {
  157. Dictionary<string, object> Fields = new Dictionary<string, object>();
  158. Fields.Add("SeoTitle", data.SeoTitle);
  159. Fields.Add("SeoKeyword", data.SeoKeyword);
  160. Fields.Add("SeoDescription", data.SeoDescription);
  161. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MerchantRebateDetail", Fields, data.Id);
  162. AddSysLog(data.Id.ToString(), "MerchantRebateDetail", "update");
  163. db.SaveChanges();
  164. return "success";
  165. }
  166. #endregion
  167. #region 删除商户返利明细信息
  168. /// <summary>
  169. /// 删除商户返利明细信息
  170. /// </summary>
  171. /// <returns></returns>
  172. public string Delete(string Id)
  173. {
  174. string[] idlist = Id.Split(new char[] { ',' });
  175. AddSysLog(Id, "MerchantRebateDetail", "del");
  176. foreach (string subid in idlist)
  177. {
  178. int id = int.Parse(subid);
  179. Dictionary<string, object> Fields = new Dictionary<string, object>();
  180. Fields.Add("Status", -1);
  181. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MerchantRebateDetail", Fields, id);
  182. }
  183. db.SaveChanges();
  184. return "success";
  185. }
  186. #endregion
  187. #region 开启
  188. /// <summary>
  189. /// 开启
  190. /// </summary>
  191. /// <returns></returns>
  192. public string Open(string Id)
  193. {
  194. string[] idlist = Id.Split(new char[] { ',' });
  195. AddSysLog(Id, "MerchantRebateDetail", "open");
  196. foreach (string subid in idlist)
  197. {
  198. int id = int.Parse(subid);
  199. Dictionary<string, object> Fields = new Dictionary<string, object>();
  200. Fields.Add("Status", 1);
  201. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MerchantRebateDetail", Fields, id);
  202. }
  203. db.SaveChanges();
  204. return "success";
  205. }
  206. #endregion
  207. #region 关闭
  208. /// <summary>
  209. /// 关闭
  210. /// </summary>
  211. /// <returns></returns>
  212. public string Close(string Id)
  213. {
  214. string[] idlist = Id.Split(new char[] { ',' });
  215. AddSysLog(Id, "MerchantRebateDetail", "close");
  216. foreach (string subid in idlist)
  217. {
  218. int id = int.Parse(subid);
  219. Dictionary<string, object> Fields = new Dictionary<string, object>();
  220. Fields.Add("Status", 0);
  221. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MerchantRebateDetail", Fields, id);
  222. }
  223. db.SaveChanges();
  224. return "success";
  225. }
  226. #endregion
  227. #region 排序
  228. /// <summary>
  229. /// 排序
  230. /// </summary>
  231. /// <param name="Id"></param>
  232. public string Sort(int Id, int Sort)
  233. {
  234. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("MerchantRebateDetail", Sort, Id);
  235. AddSysLog(Id.ToString(), "MerchantRebateDetail", "sort");
  236. return "success";
  237. }
  238. #endregion
  239. #region 导入数据
  240. /// <summary>
  241. /// 导入数据
  242. /// </summary>
  243. /// <param name="ExcelData"></param>
  244. public string Import(string ExcelData)
  245. {
  246. ExcelData = HttpUtility.UrlDecode(ExcelData);
  247. JsonData list = JsonMapper.ToObject(ExcelData);
  248. for (int i = 1; i < list.Count; i++)
  249. {
  250. JsonData dr = list[i];
  251. db.MerchantRebateDetail.Add(new MerchantRebateDetail()
  252. {
  253. CreateDate = DateTime.Now,
  254. UpdateDate = DateTime.Now,
  255. });
  256. db.SaveChanges();
  257. }
  258. AddSysLog("0", "MerchantRebateDetail", "Import");
  259. return "success";
  260. }
  261. #endregion
  262. #region 导出Excel
  263. /// <summary>
  264. /// 导出Excel
  265. /// </summary>
  266. /// <returns></returns>
  267. public JsonResult ExportExcel(MerchantRebateDetail data, string MerchantNo, string MerchantName, string TradeMonthSelect, string SyncStatusSelect)
  268. {
  269. Dictionary<string, string> Fields = new Dictionary<string, string>();
  270. Fields.Add("BrandId", "1"); //品牌
  271. Fields.Add("CreateDate", "3"); //时间
  272. Fields.Add("SnNo", "2"); //渠道SN号
  273. string condition = " and Status>-1";
  274. //商户编号
  275. if (!string.IsNullOrEmpty(MerchantNo))
  276. {
  277. condition += " and MerchantId in (select MerchantId from MerchantForCode where Code='" + MerchantNo + "')";
  278. }
  279. //商户名称
  280. if (!string.IsNullOrEmpty(MerchantName))
  281. {
  282. condition += " and MerchantId in (select MerchantId from MerchantForName where Name='" + MerchantName + "')";
  283. }
  284. //交易月份
  285. if(!string.IsNullOrEmpty(TradeMonthSelect))
  286. {
  287. condition += " and TradeMonth=" + TradeMonthSelect.Replace("-", "");
  288. }
  289. //同步状态
  290. if (!string.IsNullOrEmpty(SyncStatusSelect))
  291. {
  292. condition += " and SyncStatus=" + SyncStatusSelect;
  293. }
  294. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("MerchantRebateDetail", Fields, "Id desc", "0", 1, 20000, condition, "BrandId,TradeMonth,TradeDate,MerNo,SnNo,MerRegTime,MerStandardDate,MerchantId,MmpUserNo,MmpUserName,CreditTradeAmt,DebitTradeAmt,CreditRewardAmount,DebitRewardAmount,SyncStatus,RewardDesc", false);
  295. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  296. foreach (Dictionary<string, object> dic in diclist)
  297. {
  298. dic["BrandId"] = RelationClass.GetKqProductBrandInfo(int.Parse(dic["BrandId"].ToString()));
  299. int MerchantId = int.Parse(dic["MerchantId"].ToString());
  300. MerchantInfo merchant = db.MerchantInfo.FirstOrDefault(m => m.Id == MerchantId) ?? new MerchantInfo();
  301. dic["MerchantNo"] = "";
  302. dic["MerchantName"] = merchant.Name;
  303. dic["MerchantRealName"] = "";
  304. int SyncStatus = int.Parse(dic["SyncStatus"].ToString());
  305. if (SyncStatus == 0) dic["SyncStatus"] = "初始";
  306. if (SyncStatus == 1) dic["SyncStatus"] = "已验证和同步";
  307. dic.Remove("MerchantId");
  308. }
  309. Dictionary<string, object> result = new Dictionary<string, object>();
  310. result.Add("Status", "1");
  311. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  312. result.Add("Obj", diclist);
  313. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  314. ReturnFields.Add("BrandId", "产品类型");
  315. ReturnFields.Add("TradeDate", "达标日期");
  316. ReturnFields.Add("MerNo", "快钱商户编号");
  317. ReturnFields.Add("SnNo", "快钱SN号");
  318. ReturnFields.Add("TradeMonth", "交易月");
  319. ReturnFields.Add("MerRegTime", "快钱注册时间");
  320. ReturnFields.Add("MerStandardDate", "商户激活时间");
  321. ReturnFields.Add("MerchantName", "商户名称");
  322. ReturnFields.Add("MerchantMobile", "商户手机号");
  323. ReturnFields.Add("MerchantRealName", "商户真实姓名");
  324. ReturnFields.Add("MmpUserNo", "KYS刷APP用户编号");
  325. ReturnFields.Add("MmpUserName", "KYS商户真实姓名");
  326. ReturnFields.Add("CreditTradeAmt", "贷记卡交易总金额(元)");
  327. ReturnFields.Add("DebitTradeAmt", "借记卡交易总金额(元)");
  328. ReturnFields.Add("CreditRewardAmount", "贷记卡交易奖励金额(元)");
  329. ReturnFields.Add("DebitRewardAmount", "借记卡交易奖励金额(元)");
  330. ReturnFields.Add("SyncStatus", "同步MMP");
  331. ReturnFields.Add("RewardDesc", "奖励描述");
  332. ReturnFields.Add("CreateDate", "创建时间");
  333. result.Add("Fields", ReturnFields);
  334. AddSysLog("0", "MerchantRebateDetail", "ExportExcel");
  335. return Json(result);
  336. }
  337. #endregion
  338. }
  339. }