ProfitRewardRecordController.cs 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759
  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 ProfitRewardRecordController : BaseController
  24. {
  25. public ProfitRewardRecordController(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(ProfitRewardRecord data, string right, string BrandId)
  35. {
  36. ViewBag.RightInfo = RightInfo;
  37. ViewBag.right = right;
  38. ViewBag.BrandId = BrandId;
  39. string Condition = "";
  40. Condition += "ProfitType:\"" + data.ProfitType + "\",";
  41. Condition += "CheckStatus:\"" + data.CheckStatus + "\",";
  42. Condition += "TradeMonth:\"" + data.TradeMonth + "\",";
  43. if (!string.IsNullOrEmpty(Condition))
  44. {
  45. Condition = Condition.TrimEnd(',');
  46. Condition = ", where: {" + Condition + "}";
  47. }
  48. ViewBag.Condition = Condition;
  49. return View();
  50. }
  51. #endregion
  52. #region 根据条件查询分润奖励记录列表
  53. /// <summary>
  54. /// 分润奖励记录列表
  55. /// </summary>
  56. /// <returns></returns>
  57. public JsonResult IndexData(ProfitRewardRecord data, string BrandId, string MakerCode, string RealName, string ProfitTypeSelect, string CheckStatusSelect, string CreateDateData, int page = 1, int limit = 30)
  58. {
  59. Dictionary<string, string> Fields = new Dictionary<string, string>();
  60. Fields.Add("BrandId", "1");
  61. Fields.Add("TopUserId", "0"); //顶级创客
  62. string condition = " and Status>-1";
  63. //创客编号
  64. if (!string.IsNullOrEmpty(MakerCode))
  65. {
  66. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  67. }
  68. //创客名称
  69. if (!string.IsNullOrEmpty(RealName))
  70. {
  71. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  72. }
  73. //创客分润类型
  74. if (!string.IsNullOrEmpty(ProfitTypeSelect))
  75. {
  76. condition += " and ProfitType=" + ProfitTypeSelect;
  77. }
  78. //验证和同步账户状态
  79. if (!string.IsNullOrEmpty(CheckStatusSelect))
  80. {
  81. condition += " and CheckStatus=" + CheckStatusSelect;
  82. }
  83. //交易时间
  84. // if(!string.IsNullOrEmpty(CreateDateData))
  85. // {
  86. // string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None);
  87. // string start = datelist[0];
  88. // string end = datelist[1];
  89. // condition += " and CreateDate>='" + start + " 00:00:00' and CreateDate<='" + end + " 23:59:59'";
  90. // }
  91. if (!string.IsNullOrEmpty(CreateDateData))
  92. {
  93. string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None);
  94. var start = Convert.ToDateTime(datelist[0]).ToString("yyyyMMdd");
  95. var end = Convert.ToDateTime(datelist[1]).ToString("yyyyMMdd");
  96. var check = db.ProfitRewardRecord.Any(m => Convert.ToInt32(m.SeoTitle) >= Convert.ToInt32(start) && m.BrandId == Convert.ToInt32(BrandId));
  97. var checks = db.ProfitRewardRecord.Any(m => Convert.ToInt32(m.SeoTitle) <= Convert.ToInt32(end) && m.BrandId == Convert.ToInt32(BrandId));
  98. if (check)
  99. {
  100. var sId = db.ProfitRewardRecord.Where(m => Convert.ToInt32(m.SeoTitle) >= Convert.ToInt32(start) && m.BrandId == Convert.ToInt32(BrandId)).Min(m => m.Id);
  101. condition += " and Id >=" + sId;
  102. }
  103. if (checks)
  104. {
  105. var eId = db.ProfitRewardRecord.Where(m => Convert.ToInt32(m.SeoTitle) <= Convert.ToInt32(end) && m.BrandId == Convert.ToInt32(BrandId)).Max(m => m.Id);
  106. condition += " and Id <=" + eId;
  107. }
  108. }
  109. else
  110. {
  111. var start = DateTime.Now.AddMonths(-1).ToString("yyyyMM") + "01";
  112. var check = db.ProfitRewardRecord.Any(m => Convert.ToInt32(m.SeoTitle) >= Convert.ToInt32(start) && m.BrandId == Convert.ToInt32(BrandId));
  113. if (check)
  114. {
  115. var minId = db.ProfitRewardRecord.Where(m => Convert.ToInt32(m.SeoTitle) >= Convert.ToInt32(start) && m.BrandId == Convert.ToInt32(BrandId)).Min(m => m.Id);
  116. var Info = function.ReadInstance("/WritePage/ProfitRewardRecord/ProfitRewardRecord" + BrandId + ".txt");
  117. if (string.IsNullOrEmpty(Info.ToString()))
  118. {
  119. function.WritePage("/WritePage/ProfitRewardRecord/", "ProfitRewardRecord" + BrandId + ".txt", minId.ToString());
  120. condition += " and Id >=" + minId;
  121. }
  122. else
  123. {
  124. condition += " and Id >=" + Convert.ToInt32(Info);
  125. }
  126. }
  127. else
  128. {
  129. condition += " and Id =0";
  130. }
  131. }
  132. // TODO: 读取太慢,要优化
  133. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProfitRewardRecord", Fields, "Id desc", "0", page, limit, condition);
  134. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  135. foreach (Dictionary<string, object> dic in diclist)
  136. {
  137. //创客
  138. int UserId = int.Parse(dic["UserId"].ToString());
  139. Users puser = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  140. dic["MakerCode"] = puser.MakerCode;
  141. dic["RealName"] = puser.RealName;
  142. //顶级创客
  143. int TopUserId = int.Parse(dic["TopUserId"].ToString());
  144. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopUserId) ?? new Users();
  145. dic["TopMakerCode"] = tuser.MakerCode;
  146. dic["TopRealName"] = tuser.RealName;
  147. //创客分润类型
  148. int ProfitType = int.Parse(dic["ProfitType"].ToString());
  149. if (ProfitType == 0) dic["ProfitType"] = "直营商户交易分润";
  150. if (ProfitType == 1) dic["ProfitType"] = "团队交易分润";
  151. if (ProfitType == 2) dic["ProfitType"] = "其他";
  152. //创客分润类型
  153. int CheckStatus = int.Parse(dic["CheckStatus"].ToString());
  154. if (CheckStatus == 0) dic["CheckStatus"] = "初始";
  155. if (CheckStatus == 1) dic["CheckStatus"] = "已验证和同步";
  156. //其他产品交易额(元)
  157. string OtherTradeAmt = "";
  158. OtherTradeAmt += "其他产品交易总金额:" + dic["OtherTradeAmt"].ToString() + "<br />";
  159. OtherTradeAmt += "其他产品贷记卡交易总金额:" + dic["OtherCreditTradeAmt"].ToString() + "<br />";
  160. OtherTradeAmt += "其他产品借记卡非封顶交易总金额:" + dic["OtherDebitNotCapTradeAmt"].ToString() + "<br />";
  161. dic["OtherTradeAmt"] = OtherTradeAmt;
  162. //贷记卡交易金额(元)
  163. string CreditTradeAmt = "";
  164. CreditTradeAmt += "贷记卡交易总金额:" + dic["CreditTradeAmt"].ToString() + "<br />";
  165. CreditTradeAmt += "(云闪付)贷记卡交易总金额:" + dic["QrCreditTradeAmt"].ToString() + "<br />";
  166. CreditTradeAmt += "(非云闪付)贷记卡交易总金额:" + dic["NonQrCreditTradeAmt"].ToString() + "<br />";
  167. CreditTradeAmt += "(非扶持期)(非云闪付)贷记卡交易总金额:" + dic["NotHelpCreditTradeAmt"].ToString() + "<br />";
  168. CreditTradeAmt += "(扶持期)(非云闪付)贷记卡交易总金额:" + dic["HelpCreditTradeAmt"].ToString() + "<br />";
  169. dic["CreditTradeAmt"] = CreditTradeAmt;
  170. //商户借记卡交易金额(元)
  171. string MerDebitTradeAmt = "";
  172. MerDebitTradeAmt += "商户非封顶借记卡交易总额:" + dic["DebitNonCapTradeAmt"].ToString() + "<br />";
  173. MerDebitTradeAmt += "(云闪付)商户非封顶借记卡交易总额:" + dic["QrDebitNotCapTradeAmt"].ToString() + "<br />";
  174. MerDebitTradeAmt += "(非云闪付)商户非封顶借记卡交易总额:" + dic["NonQrDebitNotCapTradeAmt"].ToString() + "<br />";
  175. MerDebitTradeAmt += "(非扶持期)(非云闪付)借记卡非封顶交易总金额:" + dic["NotHelpDebitNonCapTradeAmt"].ToString() + "<br />";
  176. MerDebitTradeAmt += "(扶持期)(非云闪付)借记卡非封顶交易总金额:" + dic["HelpDebitNonCapTradeAmt"].ToString() + "<br />";
  177. MerDebitTradeAmt += "商户借记卡封顶交易总额:" + dic["DebitCapTradeAmt"].ToString() + "<br />";
  178. MerDebitTradeAmt += "商户借记卡封顶交易总笔数:" + dic["DebitCapTradeNum"].ToString() + "<br />";
  179. dic["MerDebitTradeAmt"] = MerDebitTradeAmt;
  180. //贷记卡分润金额
  181. string CreditProfitAmt = "";
  182. CreditProfitAmt += "贷记卡分润总金额:" + dic["CreditTradeProfit"].ToString() + "<br />";
  183. CreditProfitAmt += "(云闪付)贷记卡交易分润:" + dic["QrCreditTradeProfit"].ToString() + "<br />";
  184. CreditProfitAmt += "(非云闪付)贷记卡交易分润:" + dic["NonQrCreditTradeProfit"].ToString() + "<br />";
  185. CreditProfitAmt += "(非扶持期)(非云闪付)贷记卡分润总金额:" + dic["NotHelpCreditTradeProfit"].ToString() + "<br />";
  186. CreditProfitAmt += "(扶持期)(非云闪付)贷记卡分润总金额:" + dic["HelpCreditTradeProfit"].ToString() + "<br />";
  187. dic["CreditProfitAmt"] = CreditProfitAmt;
  188. //借记卡交易分润金额
  189. string DebitProfitAmt = "";
  190. DebitProfitAmt += "借记卡非封顶交易分润总金额:" + dic["DebitNonTradeCapProfit"].ToString() + "<br />";
  191. DebitProfitAmt += "(云闪付)借记卡非封顶交易分润总金额:" + dic["QrDebitNonTradeCapProfit"].ToString() + "<br />";
  192. DebitProfitAmt += "(非云闪付)借记卡非封顶交易分润总金额:" + dic["NonQrDebitNonTradeCapProfit"].ToString() + "<br />";
  193. DebitProfitAmt += "(非扶持期)(非云闪付)借记卡非封顶交易分润总金额:" + dic["NotHelpDebitNonTradeCapProfit"].ToString() + "<br />";
  194. DebitProfitAmt += "(扶持期)(非云闪付)借记卡非封顶交易分润总金额:" + dic["HelpDebitNonTradeCapProfit"].ToString() + "<br />";
  195. DebitProfitAmt += "借记卡封顶交易分润总金额:" + dic["DebitTradeCapProfit"].ToString() + "<br />";
  196. dic["DebitProfitAmt"] = DebitProfitAmt;
  197. }
  198. Dictionary<string, object> other = new Dictionary<string, object>();
  199. string MerchantTradeAmount = "0.00";//商户交易总额
  200. string CreditTradeAmount = "0.00";//贷记卡交易总金额
  201. string MerchantProfitAmount = "0.00";//商户交易分润总金额
  202. string CreditProfitAmount = "0.00";//贷记卡分润总金额
  203. // TODO: 读取太慢,要优化
  204. DataTable dt = OtherMySqlConn.dtable("SELECT SUM(if(BrandId=" + BrandId + ",TradeAmt,0)),SUM(if(BrandId=" + BrandId + ",CreditTradeAmt,0)),SUM(if(BrandId=" + BrandId + ",TradeProfit,0)),SUM(if(BrandId=" + BrandId + ",CreditTradeProfit,0)) FROM ProfitRewardRecord where 1=1 " + condition);
  205. if (dt.Rows.Count > 0)
  206. {
  207. MerchantTradeAmount = decimal.Parse(function.CheckNum(dt.Rows[0][0].ToString())).ToString();
  208. CreditTradeAmount = decimal.Parse(function.CheckNum(dt.Rows[0][1].ToString())).ToString();
  209. MerchantProfitAmount = decimal.Parse(function.CheckNum(dt.Rows[0][2].ToString())).ToString();
  210. CreditProfitAmount = decimal.Parse(function.CheckNum(dt.Rows[0][3].ToString())).ToString();
  211. }
  212. other.Add("MerchantTradeAmount", MerchantTradeAmount);
  213. other.Add("CreditTradeAmount", CreditTradeAmount);
  214. other.Add("MerchantProfitAmount", MerchantProfitAmount);
  215. other.Add("CreditProfitAmount", CreditProfitAmount);
  216. obj.Add("other", other);
  217. return Json(obj);
  218. }
  219. #endregion
  220. #region 增加分润奖励记录
  221. /// <summary>
  222. /// 增加或修改分润奖励记录信息
  223. /// </summary>
  224. /// <returns></returns>
  225. public IActionResult Add(string right)
  226. {
  227. ViewBag.RightInfo = RightInfo;
  228. ViewBag.right = right;
  229. return View();
  230. }
  231. #endregion
  232. #region 增加分润奖励记录
  233. /// <summary>
  234. /// 增加或修改分润奖励记录信息
  235. /// </summary>
  236. /// <returns></returns>
  237. [HttpPost]
  238. public string Add(ProfitRewardRecord data)
  239. {
  240. Dictionary<string, object> Fields = new Dictionary<string, object>();
  241. Fields.Add("SeoTitle", data.SeoTitle);
  242. Fields.Add("SeoKeyword", data.SeoKeyword);
  243. Fields.Add("SeoDescription", data.SeoDescription);
  244. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("ProfitRewardRecord", Fields, 0);
  245. AddSysLog(data.Id.ToString(), "ProfitRewardRecord", "add");
  246. db.SaveChanges();
  247. return "success";
  248. }
  249. #endregion
  250. #region 修改分润奖励记录
  251. /// <summary>
  252. /// 增加或修改分润奖励记录信息
  253. /// </summary>
  254. /// <returns></returns>
  255. public IActionResult Edit(string right, int Id = 0)
  256. {
  257. ViewBag.RightInfo = RightInfo;
  258. ViewBag.right = right;
  259. ProfitRewardRecord editData = db.ProfitRewardRecord.FirstOrDefault(m => m.Id == Id) ?? new ProfitRewardRecord();
  260. ViewBag.data = editData;
  261. return View();
  262. }
  263. #endregion
  264. #region 修改分润奖励记录
  265. /// <summary>
  266. /// 增加或修改分润奖励记录信息
  267. /// </summary>
  268. /// <returns></returns>
  269. [HttpPost]
  270. public string Edit(ProfitRewardRecord data)
  271. {
  272. Dictionary<string, object> Fields = new Dictionary<string, object>();
  273. Fields.Add("SeoTitle", data.SeoTitle);
  274. Fields.Add("SeoKeyword", data.SeoKeyword);
  275. Fields.Add("SeoDescription", data.SeoDescription);
  276. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProfitRewardRecord", Fields, data.Id);
  277. AddSysLog(data.Id.ToString(), "ProfitRewardRecord", "update");
  278. db.SaveChanges();
  279. return "success";
  280. }
  281. #endregion
  282. #region 删除分润奖励记录信息
  283. /// <summary>
  284. /// 删除分润奖励记录信息
  285. /// </summary>
  286. /// <returns></returns>
  287. public string Delete(string Id)
  288. {
  289. string[] idlist = Id.Split(new char[] { ',' });
  290. AddSysLog(Id, "ProfitRewardRecord", "del");
  291. foreach (string subid in idlist)
  292. {
  293. int id = int.Parse(subid);
  294. Dictionary<string, object> Fields = new Dictionary<string, object>();
  295. Fields.Add("Status", -1);
  296. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProfitRewardRecord", Fields, id);
  297. }
  298. db.SaveChanges();
  299. return "success";
  300. }
  301. #endregion
  302. #region 开启
  303. /// <summary>
  304. /// 开启
  305. /// </summary>
  306. /// <returns></returns>
  307. public string Open(string Id)
  308. {
  309. string[] idlist = Id.Split(new char[] { ',' });
  310. AddSysLog(Id, "ProfitRewardRecord", "open");
  311. foreach (string subid in idlist)
  312. {
  313. int id = int.Parse(subid);
  314. Dictionary<string, object> Fields = new Dictionary<string, object>();
  315. Fields.Add("Status", 1);
  316. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProfitRewardRecord", Fields, id);
  317. }
  318. db.SaveChanges();
  319. return "success";
  320. }
  321. #endregion
  322. #region 关闭
  323. /// <summary>
  324. /// 关闭
  325. /// </summary>
  326. /// <returns></returns>
  327. public string Close(string Id)
  328. {
  329. string[] idlist = Id.Split(new char[] { ',' });
  330. AddSysLog(Id, "ProfitRewardRecord", "close");
  331. foreach (string subid in idlist)
  332. {
  333. int id = int.Parse(subid);
  334. Dictionary<string, object> Fields = new Dictionary<string, object>();
  335. Fields.Add("Status", 0);
  336. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProfitRewardRecord", Fields, id);
  337. }
  338. db.SaveChanges();
  339. return "success";
  340. }
  341. #endregion
  342. #region 排序
  343. /// <summary>
  344. /// 排序
  345. /// </summary>
  346. /// <param name="Id"></param>
  347. public string Sort(int Id, int Sort)
  348. {
  349. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("ProfitRewardRecord", Sort, Id);
  350. AddSysLog(Id.ToString(), "ProfitRewardRecord", "sort");
  351. return "success";
  352. }
  353. #endregion
  354. #region 导入数据
  355. /// <summary>
  356. /// 导入数据
  357. /// </summary>
  358. /// <param name="ExcelData"></param>
  359. public string Import(string ExcelData)
  360. {
  361. ExcelData = HttpUtility.UrlDecode(ExcelData);
  362. JsonData list = JsonMapper.ToObject(ExcelData);
  363. for (int i = 1; i < list.Count; i++)
  364. {
  365. JsonData dr = list[i];
  366. db.ProfitRewardRecord.Add(new ProfitRewardRecord()
  367. {
  368. CreateDate = DateTime.Now,
  369. UpdateDate = DateTime.Now,
  370. });
  371. db.SaveChanges();
  372. }
  373. AddSysLog("0", "ProfitRewardRecord", "Import");
  374. return "success";
  375. }
  376. #endregion
  377. #region 导出Excel
  378. /// <summary>
  379. /// 导出Excel
  380. /// </summary>
  381. /// <returns></returns>
  382. public JsonResult ExportExcel(ProfitRewardRecord data, string MakerCode, string RealName, string ProfitTypeSelect, string CheckStatusSelect)
  383. {
  384. Dictionary<string, string> Fields = new Dictionary<string, string>();
  385. Fields.Add("BrandId", "1");
  386. Fields.Add("CreateDate", "3"); //交易时间
  387. Fields.Add("TopUserId", "0"); //顶级创客
  388. string condition = " and Status>-1";
  389. //创客编号
  390. if (!string.IsNullOrEmpty(MakerCode))
  391. {
  392. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  393. }
  394. //创客名称
  395. if (!string.IsNullOrEmpty(RealName))
  396. {
  397. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  398. }
  399. //创客分润类型
  400. if (!string.IsNullOrEmpty(ProfitTypeSelect))
  401. {
  402. condition += " and ProfitType=" + ProfitTypeSelect;
  403. }
  404. //验证和同步账户状态
  405. if (!string.IsNullOrEmpty(CheckStatusSelect))
  406. {
  407. condition += " and CheckStatus=" + CheckStatusSelect;
  408. }
  409. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProfitRewardRecord", Fields, "Id desc", "0", 1, 20000, condition, "UserId,TopUserId,ProfitType,OtherTradeAmt,OtherCreditTradeAmt,OtherDebitNotCapTradeAmt,TradeAmt,CreditTradeAmt,QrCreditTradeAmt,NonQrCreditTradeAmt,DebitNonCapTradeAmt,QrDebitNotCapTradeAmt,NonQrDebitNotCapTradeAmt,DebitCapTradeAmt,DebitCapTradeNum,TradeProfit,CreditTradeProfit,QrCreditTradeProfit,NonQrCreditTradeProfit,DebitNonTradeCapProfit,QrDebitNonTradeCapProfit,NonQrDebitNonTradeCapProfit,DebitTradeCapProfit,CheckStatus,TradeMonth,RecordNo", false);
  410. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  411. foreach (Dictionary<string, object> dic in diclist)
  412. {
  413. //创客
  414. int UserId = int.Parse(dic["UserId"].ToString());
  415. Users puser = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  416. dic["MakerCode"] = puser.MakerCode;
  417. dic["RealName"] = puser.RealName;
  418. //顶级创客
  419. int TopUserId = int.Parse(dic["TopUserId"].ToString());
  420. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopUserId) ?? new Users();
  421. dic["TopMakerCode"] = tuser.MakerCode;
  422. dic["TopRealName"] = tuser.RealName;
  423. //创客分润类型
  424. int ProfitType = int.Parse(dic["ProfitType"].ToString());
  425. if (ProfitType == 0) dic["ProfitType"] = "直营商户交易分润";
  426. if (ProfitType == 1) dic["ProfitType"] = "团队交易分润";
  427. if (ProfitType == 2) dic["ProfitType"] = "其他";
  428. //创客分润类型
  429. int CheckStatus = int.Parse(dic["CheckStatus"].ToString());
  430. if (CheckStatus == 0) dic["CheckStatus"] = "初始";
  431. if (CheckStatus == 1) dic["CheckStatus"] = "已验证和同步";
  432. dic.Remove("UserId");
  433. dic.Remove("TopUserId");
  434. }
  435. Dictionary<string, object> result = new Dictionary<string, object>();
  436. result.Add("Status", "1");
  437. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  438. result.Add("Obj", diclist);
  439. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  440. ReturnFields.Add("RecordNo", "记录单号");
  441. ReturnFields.Add("MakerCode", "创客编号");
  442. ReturnFields.Add("RealName", "创客姓名");
  443. ReturnFields.Add("TopMakerCode", "顶级创客编号");
  444. ReturnFields.Add("TopRealName", "顶级创客名称");
  445. ReturnFields.Add("TradeMonth", "交易月");
  446. ReturnFields.Add("ProfitType", "创客分润类型");
  447. ReturnFields.Add("OtherTradeAmt", "其他产品交易总金额");
  448. ReturnFields.Add("OtherCreditTradeAmt", "其他产品贷记卡交易总金额");
  449. ReturnFields.Add("OtherDebitNotCapTradeAmt", "其他产品借记卡非封顶交易总金额");
  450. ReturnFields.Add("TradeAmt", "商户交易总额");
  451. ReturnFields.Add("CreditTradeAmt", "贷记卡交易总金额");
  452. ReturnFields.Add("QrCreditTradeAmt", "(云闪付)贷记卡交易总金额");
  453. ReturnFields.Add("NonQrCreditTradeAmt", "(非云闪付)贷记卡交易总金额");
  454. ReturnFields.Add("DebitNonCapTradeAmt", "商户非封顶借记卡交易总额");
  455. ReturnFields.Add("QrDebitNotCapTradeAmt", "(云闪付)商户非封顶借记卡交易总额");
  456. ReturnFields.Add("NonQrDebitNotCapTradeAmt", "(非云闪付)商户非封顶借记卡交易总额");
  457. ReturnFields.Add("DebitCapTradeAmt", "商户借记卡封顶交易总额");
  458. ReturnFields.Add("DebitCapTradeNum", "商户借记卡封顶交易总笔数");
  459. ReturnFields.Add("TradeProfit", "交易分润");
  460. ReturnFields.Add("CreditTradeProfit", "贷记卡分润总金额");
  461. ReturnFields.Add("QrCreditTradeProfit", "(云闪付)贷记卡交易分润");
  462. ReturnFields.Add("NonQrCreditTradeProfit", "(非云闪付)贷记卡交易分润");
  463. ReturnFields.Add("DebitNonTradeCapProfit", "借记卡非封顶交易分润总金额");
  464. ReturnFields.Add("QrDebitNonTradeCapProfit", "(云闪付)借记卡非封顶交易分润总金额");
  465. ReturnFields.Add("NonQrDebitNonTradeCapProfit", "(非云闪付)借记卡非封顶交易分润总金额");
  466. ReturnFields.Add("DebitTradeCapProfit", "借记卡封顶交易分润总金额");
  467. ReturnFields.Add("CheckStatus", "验证和同步账户状态");
  468. result.Add("Fields", ReturnFields);
  469. AddSysLog("0", "ProfitRewardRecord", "ExportExcel");
  470. return Json(result);
  471. }
  472. #endregion
  473. #region 同步到余额
  474. public string SycnData(int BrandId, int OpType = 0)
  475. {
  476. string date = DateTime.Now.AddMonths(-1).ToString("yyyyMM");
  477. string OpTypeString = "";
  478. if (OpType > 0)
  479. {
  480. OpTypeString += "-" + OpType;
  481. }
  482. string check = function.ReadInstance("/Balance/" + BrandId + "/" + date + OpTypeString + ".txt");
  483. if (string.IsNullOrEmpty(check))
  484. {
  485. function.WritePage("/Balance/" + BrandId + "/", date + OpTypeString + ".txt", DateTime.Now.ToString());
  486. // DoTradeProfit(BrandId, date, OpType);
  487. // DoSubsidyProfit(BrandId, date, OpType);
  488. RedisDbconn.Instance.AddList("SycnProfitQueue2", BrandId + "#cut#" + date + "#cut#" + OpType + "#cut#" + SysUserName);
  489. return "success";
  490. }
  491. return date + "分润已同步,请勿重复操作";
  492. }
  493. public string SycnDataByCondi(int BrandId, string MakerCode, int OpType = 0)
  494. {
  495. string date = DateTime.Now.AddMonths(-1).ToString("yyyyMM");
  496. string OpTypeString = "";
  497. if (OpType > 0)
  498. {
  499. OpTypeString += "-" + OpType;
  500. }
  501. string check = function.ReadInstance("/Balance/" + BrandId + "/" + MakerCode + "/" + date + OpTypeString + ".txt");
  502. if (string.IsNullOrEmpty(check))
  503. {
  504. function.WritePage("/Balance/" + BrandId + "/" + MakerCode + "/", date + OpTypeString + ".txt", DateTime.Now.ToString());
  505. UserForMakerCode forMakerCode = db.UserForMakerCode.FirstOrDefault(m => m.MakerCode == MakerCode) ?? new UserForMakerCode();
  506. DoTradeProfitByCondi(forMakerCode.UserId, BrandId, date, OpType);
  507. DoSubsidyProfitByCondi(forMakerCode.UserId, BrandId, date, OpType);
  508. return "success";
  509. }
  510. return date + "分润已同步,请勿重复操作";
  511. }
  512. //交易分润
  513. private void DoTradeProfitByCondi(int Id, int BrandId, string date, int OpType = 0)
  514. {
  515. int OpTypeDo = OpType + 1;
  516. WebCMSEntities db = new WebCMSEntities();
  517. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  518. DataTable dt = OtherMySqlConn.dtable("select UserId,ProfitType,sum(CreditTradeProfit+DebitNonTradeCapProfit+DebitTradeCapProfit+QrCreditTradeProfit) from ProfitRewardRecord where CheckStatus=" + OpType + " and BrandId=" + BrandId + " and TradeMonth='" + date + "' and UserId=" + Id + " group by UserId,ProfitType");
  519. foreach (DataRow dr in dt.Rows)
  520. {
  521. int UserId = int.Parse(dr["UserId"].ToString());
  522. ulong ProfitType = ulong.Parse(dr["ProfitType"].ToString());
  523. OtherMySqlConn.op("update ProfitRewardRecord set CheckStatus=" + OpTypeDo + " where BrandId=" + BrandId + " and TradeMonth='" + date + "' and UserId=" + UserId + " and ProfitType=" + ProfitType);
  524. decimal ProfitMoney = decimal.Parse(dr[2].ToString());
  525. var tran = db.Database.BeginTransaction();
  526. try
  527. {
  528. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  529. if (OpType == 0)
  530. {
  531. ProfitRecord profit = db.ProfitRecord.FirstOrDefault(m => m.UserId == UserId && m.BrandId == BrandId && m.SeoTitle == date);
  532. if (profit == null)
  533. {
  534. profit = db.ProfitRecord.Add(new ProfitRecord()
  535. {
  536. CreateDate = DateTime.Now,
  537. CreateMan = SysUserName,
  538. SeoTitle = date,
  539. ParentNav = user.ParentNav,
  540. BrandId = BrandId,
  541. UserId = UserId,
  542. }).Entity;
  543. db.SaveChanges();
  544. }
  545. profit.ProfitAmount += ProfitMoney;
  546. string IdBrand = UserId + "_" + BrandId;
  547. UserMachineData MachineData = db.UserMachineData.FirstOrDefault(m => m.IdBrand == IdBrand);
  548. if (MachineData != null)
  549. {
  550. MachineData.TradeProfit += ProfitMoney;
  551. }
  552. db.SaveChanges();
  553. }
  554. else if (OpType == 1)
  555. {
  556. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  557. if (account == null)
  558. {
  559. account = db.UserAccount.Add(new UserAccount()
  560. {
  561. Id = UserId,
  562. UserId = UserId,
  563. }).Entity;
  564. db.SaveChanges();
  565. }
  566. decimal BeforeTotalAmount = account.TotalAmount; //变更前总金额
  567. decimal BeforeFreezeAmount = account.FreezeAmount; //变更前冻结金额
  568. decimal BeforeBalanceAmount = account.BalanceAmount; //变更前余额
  569. account.BalanceAmount += ProfitMoney;
  570. account.TotalAmount += ProfitMoney;
  571. decimal AfterTotalAmount = account.TotalAmount; //变更后总金额
  572. decimal AfterFreezeAmount = account.FreezeAmount; //变更后冻结金额
  573. decimal AfterBalanceAmount = account.BalanceAmount; //变更后余额
  574. UserAccountRecord userAccountRecord = db.UserAccountRecord.Add(new UserAccountRecord()
  575. {
  576. CreateDate = DateTime.Now,
  577. UpdateDate = DateTime.Now,
  578. UserId = UserId, //创客
  579. ProductType = BrandId,
  580. ChangeType = 1, //变动类型
  581. ChangeAmount = ProfitMoney, //变更金额
  582. BeforeTotalAmount = BeforeTotalAmount, //变更前总金额
  583. AfterTotalAmount = AfterTotalAmount, //变更后总金额
  584. BeforeFreezeAmount = BeforeFreezeAmount, //变更前冻结金额
  585. AfterFreezeAmount = AfterFreezeAmount, //变更后冻结金额
  586. BeforeBalanceAmount = BeforeBalanceAmount, //变更前余额
  587. AfterBalanceAmount = AfterBalanceAmount, //变更后余额
  588. Remark = ProfitType == 1 ? "直拓商户分润" : "品牌推广服务费",
  589. }).Entity;
  590. db.SaveChanges();
  591. RedisDbconn.Instance.Clear("UserAccount:" + UserId);
  592. RedisDbconn.Instance.Clear("UserAccount:Income:" + UserId + ":" + DateTime.Now.ToString("yyyyMM"));
  593. }
  594. tran.Commit();
  595. }
  596. catch (Exception ex)
  597. {
  598. function.WriteLog(DateTime.Now.ToString() + "\n" + UserId + "," + ProfitType + "," + ProfitMoney + "\n" + ex.ToString(), "同步到余额异常");
  599. tran.Rollback();
  600. }
  601. }
  602. db.Dispose();
  603. }
  604. //分润补贴
  605. private void DoSubsidyProfitByCondi(int Id, int BrandId, string date, int OpType = 0)
  606. {
  607. int OpTypeDo = OpType + 1;
  608. WebCMSEntities db = new WebCMSEntities();
  609. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  610. DataTable dt = OtherMySqlConn.dtable("select SubsidyUserId,sum(SubsidyProfitRate) from ProfitSubsidyDetail where Status=" + OpType + " and BrandId=" + BrandId + " and TradeMonth='" + date + "' and SubsidyUserId=" + Id + " GROUP BY SubsidyUserId");
  611. foreach (DataRow dr in dt.Rows)
  612. {
  613. int UserId = int.Parse(dr["SubsidyUserId"].ToString());
  614. decimal ProfitMoney = decimal.Parse(dr[1].ToString());
  615. OtherMySqlConn.op("update ProfitSubsidyDetail set Status=" + OpTypeDo + " where BrandId=" + BrandId + " and TradeMonth='" + date + "' and SubsidyUserId=" + Id + "");
  616. var tran = db.Database.BeginTransaction();
  617. try
  618. {
  619. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  620. if (OpType == 0)
  621. {
  622. string IdBrand = UserId + "_" + BrandId;
  623. UserMachineData MachineData = db.UserMachineData.FirstOrDefault(m => m.IdBrand == IdBrand);
  624. if (MachineData != null)
  625. {
  626. MachineData.OtherProfit += ProfitMoney;
  627. }
  628. db.SaveChanges();
  629. }
  630. else if (OpType == 1)
  631. {
  632. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  633. if (account == null)
  634. {
  635. account = db.UserAccount.Add(new UserAccount()
  636. {
  637. Id = UserId,
  638. UserId = UserId,
  639. }).Entity;
  640. db.SaveChanges();
  641. }
  642. decimal BeforeTotalAmount = account.TotalAmount; //变更前总金额
  643. decimal BeforeFreezeAmount = account.FreezeAmount; //变更前冻结金额
  644. decimal BeforeBalanceAmount = account.BalanceAmount; //变更前余额
  645. account.BalanceAmount += ProfitMoney;
  646. account.TotalAmount += ProfitMoney;
  647. decimal AfterTotalAmount = account.TotalAmount; //变更后总金额
  648. decimal AfterFreezeAmount = account.FreezeAmount; //变更后冻结金额
  649. decimal AfterBalanceAmount = account.BalanceAmount; //变更后余额
  650. UserAccountRecord userAccountRecord = db.UserAccountRecord.Add(new UserAccountRecord()
  651. {
  652. CreateDate = DateTime.Now,
  653. UpdateDate = DateTime.Now,
  654. UserId = UserId, //创客
  655. ProductType = BrandId,
  656. ChangeType = 111, //变动类型
  657. ChangeAmount = ProfitMoney, //变更金额
  658. BeforeTotalAmount = BeforeTotalAmount, //变更前总金额
  659. AfterTotalAmount = AfterTotalAmount, //变更后总金额
  660. BeforeFreezeAmount = BeforeFreezeAmount, //变更前冻结金额
  661. AfterFreezeAmount = AfterFreezeAmount, //变更后冻结金额
  662. BeforeBalanceAmount = BeforeBalanceAmount, //变更前余额
  663. AfterBalanceAmount = AfterBalanceAmount, //变更后余额
  664. Remark = "直拓商户补贴",
  665. }).Entity;
  666. db.SaveChanges();
  667. RedisDbconn.Instance.Clear("UserAccount:" + UserId);
  668. RedisDbconn.Instance.Clear("UserAccount:Income:" + UserId + ":" + DateTime.Now.ToString("yyyyMM"));
  669. }
  670. tran.Commit();
  671. }
  672. catch (Exception ex)
  673. {
  674. function.WriteLog(DateTime.Now.ToString() + "\n" + UserId + "," + ProfitMoney + "\n" + ex.ToString(), "同步到补贴异常");
  675. tran.Rollback();
  676. }
  677. }
  678. db.Dispose();
  679. }
  680. //直拓商户分润
  681. //品牌推广服务费
  682. //品牌名称(交易分润) 备注:***
  683. #endregion
  684. }
  685. }