UserAccountRecordController.cs 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522
  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 UserAccountRecordController : BaseController
  24. {
  25. public UserAccountRecordController(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(UserAccountRecord data, string right, int UserId = 0)
  35. {
  36. ViewBag.RightInfo = RightInfo;
  37. ViewBag.right = right;
  38. ViewBag.UserId = UserId.ToString();
  39. List<Users> TopUsers = db.Users.Where(m => m.ParentUserId == 0).ToList();
  40. ViewBag.TopUsers = TopUsers;
  41. List<KqProducts> Brands = db.KqProducts.OrderBy(m => m.Id).ToList();
  42. ViewBag.Brands = Brands;
  43. return View();
  44. }
  45. #endregion
  46. #region 根据条件查询创客账户变动记录列表
  47. /// <summary>
  48. /// 创客账户变动记录列表
  49. /// </summary>
  50. /// <returns></returns>
  51. public JsonResult IndexData(UserAccountRecord data, string MakerCode, string RealName, int TopUserId, string CreateDateData, int UserId = 0, int page = 1, int limit = 30)
  52. {
  53. Dictionary<string, string> Fields = new Dictionary<string, string>();
  54. Fields.Add("ChangeType", "1"); //交易类型
  55. Fields.Add("ProductType", "1"); //产品类型
  56. Fields.Add("TransRecordNo", "3"); //交易流水编号
  57. string condition = condition = " and Status>-1";
  58. //创客编号
  59. if (!string.IsNullOrEmpty(MakerCode))
  60. {
  61. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  62. }
  63. //创客名称
  64. if (!string.IsNullOrEmpty(RealName))
  65. {
  66. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  67. }
  68. //顶级创客
  69. if (TopUserId > 0)
  70. {
  71. condition += " and UserId in (select Id from Users where ParentNav like '," + TopUserId + ",%')";
  72. }
  73. if (UserId > 0)
  74. {
  75. condition += " and UserId=" + UserId;
  76. }
  77. if (!string.IsNullOrEmpty(CreateDateData))
  78. {
  79. string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None);
  80. // string start = datelist[0];
  81. // string end = datelist[1];
  82. // condition += " and CreateDate>='" + start + " 00:00:00' and CreateDate<='" + end + " 23:59:59'";
  83. var start = Convert.ToDateTime(Convert.ToDateTime(datelist[0]).ToString("yyyy-MM-dd"));
  84. var end = Convert.ToDateTime(Convert.ToDateTime(datelist[1]).ToString("yyyy-MM-dd") + " 23:59:59");
  85. var check = db.UserAccountRecord.Any(m => m.CreateDate >= start);
  86. var checks = db.UserAccountRecord.Any(m => m.CreateDate <= end);
  87. if (check)
  88. {
  89. var sId = db.UserAccountRecord.Where(m => m.CreateDate >= start).Min(m => m.Id);
  90. condition += " and Id >=" + sId;
  91. }
  92. if (checks)
  93. {
  94. var eId = db.UserAccountRecord.Where(m => m.CreateDate <= end).Max(m => m.Id);
  95. condition += " and Id <=" + eId;
  96. }
  97. }
  98. else
  99. {
  100. var start = Convert.ToDateTime(DateTime.Now.AddMonths(-1).ToString("yyyy-MM") + "-01");
  101. var check = db.UserAccountRecord.Any(m => m.CreateDate >= start);
  102. if (check)
  103. {
  104. var minId = db.UserAccountRecord.Where(m => m.CreateDate >= start).Min(m => m.Id);
  105. var Info = function.ReadInstance("/WritePage/UsersAccountRecord/UsersAccountRecord.txt");
  106. if (string.IsNullOrEmpty(Info.ToString()))
  107. {
  108. function.WritePage("/WritePage/UsersAccountRecord/", "UsersAccountRecord.txt", minId.ToString());
  109. condition += " and Id >=" + minId;
  110. }
  111. else
  112. {
  113. condition += " and Id >=" + Convert.ToInt32(Info);
  114. }
  115. }
  116. else
  117. {
  118. condition += " and Id =0";
  119. }
  120. }
  121. if (data.ChangeType > 0)
  122. {
  123. condition += " and ChangeType=" + data.ChangeType;
  124. }
  125. if (data.ProductType > 0)
  126. {
  127. condition += " and ProductType=" + data.ProductType;
  128. }
  129. if (!string.IsNullOrEmpty(data.TransRecordNo))
  130. {
  131. condition += " and TransRecordNo='" + data.TransRecordNo + "'";
  132. }
  133. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("UserAccountRecord", 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. int UId = int.Parse(dic["UserId"].ToString());
  138. Users user = db.Users.FirstOrDefault(m => m.Id == UId) ?? new Users();
  139. dic["MakerCode"] = user.MakerCode;
  140. dic["RealName"] = user.RealName;
  141. if (!string.IsNullOrEmpty(user.ParentNav))
  142. {
  143. int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]);
  144. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users();
  145. dic["TopMakerCode"] = tuser.MakerCode;
  146. dic["TopRealName"] = tuser.RealName;
  147. }
  148. int ProductType = int.Parse(dic["ProductType"].ToString());
  149. dic["ProductTypeName"] = RelationClass.GetKqProductBrandInfo(ProductType);
  150. int ChangeType = int.Parse(dic["ChangeType"].ToString());
  151. dic["ChangeTypeName"] = RelationClassForConst.GetChangeTypeInfo(ChangeType);
  152. //获得盟主5元奖励的机具Sn
  153. int SnId = int.Parse(dic["QueryCount"].ToString());
  154. PosMachinesTwo pos = db.PosMachinesTwo.FirstOrDefault(m => m.Id == SnId) ?? new PosMachinesTwo();
  155. dic["PosSn"] = pos.PosSn;
  156. }
  157. Dictionary<string, object> other = new Dictionary<string, object>();
  158. string ChangeTypeAmount0 = "0.00", ChangeTypeAmount1 = "0.00", ChangeTypeAmount2 = "0.00", ChangeTypeAmount3 = "0.00", ChangeTypeAmount4 = "0.00", ChangeTypeAmount5 = "0.00", ChangeTypeAmount6 = "0.00", ChangeTypeAmount61 = "0.00", ChangeTypeAmount62 = "0.00", ChangeTypeAmount63 = "0.00", ChangeTypeAmount64 = "0.00", ChangeTypeAmount50 = "0.00", ChangeTypeAmount111 = "0.00", ChangeTypeAmount112 = "0.00", ChangeTypeAmount60 = "0.00", ChangeTypeAmount31 = "0.00", ChangeTypeAmount31s = "0.00", ChangeTypeAmount124 = "0.00", ChangeTypeAmount125 = "0.00";
  159. DataTable dt = OtherMySqlConn.dtable("select sum(if(ChangeType=0, ChangeAmount, 0)),sum(if(ChangeType=1, ChangeAmount, 0)) + sum(if(ChangeType=112 and ProductType=101, ChangeAmount, 0)),sum(if(ChangeType=2, ChangeAmount, 0)),sum(if(ChangeType=6, ChangeAmount, 0)),sum(if(ChangeType=61, ChangeAmount, 0)),sum(if(ChangeType=62, ChangeAmount, 0)),sum(if(ChangeType=63, ChangeAmount, 0)),sum(if(ChangeType=64, ChangeAmount, 0)),sum(if(ChangeType=50, ChangeAmount, 0)),sum(if(ChangeType=111, ChangeAmount, 0)),sum(if(ChangeType=112, ChangeAmount, 0)),sum(if(ChangeType=60, ChangeAmount, 0)),sum(if(ChangeType=31 and Remark='开机抢红包活动', ChangeAmount, 0)),sum(if(ChangeType=3, ChangeAmount, 0)),sum(if(ChangeType=4, ChangeAmount, 0)),sum(if(ChangeType=5, ChangeAmount, 0)),sum(if(ChangeType=124, ChangeAmount, 0)),sum(if(ChangeType=125, ChangeAmount, 0)),sum(if(ChangeType=31 and (Remark!='开机抢红包活动' or Remark IS NULL), ChangeAmount, 0)) from UserAccountRecord where 1=1" + condition);
  160. if (dt.Rows.Count > 0)
  161. {
  162. ChangeTypeAmount0 = dt.Rows[0][0].ToString();
  163. ChangeTypeAmount1 = dt.Rows[0][1].ToString();
  164. ChangeTypeAmount2 = dt.Rows[0][2].ToString();
  165. ChangeTypeAmount3 = dt.Rows[0][13].ToString();
  166. ChangeTypeAmount4 = dt.Rows[0][14].ToString();
  167. ChangeTypeAmount5 = dt.Rows[0][15].ToString();
  168. ChangeTypeAmount6 = dt.Rows[0][3].ToString();
  169. ChangeTypeAmount61 = dt.Rows[0][4].ToString();
  170. ChangeTypeAmount62 = dt.Rows[0][5].ToString();
  171. ChangeTypeAmount63 = dt.Rows[0][6].ToString();
  172. ChangeTypeAmount64 = dt.Rows[0][7].ToString();
  173. ChangeTypeAmount50 = dt.Rows[0][8].ToString();
  174. ChangeTypeAmount111 = dt.Rows[0][9].ToString();
  175. ChangeTypeAmount112 = dt.Rows[0][10].ToString();
  176. ChangeTypeAmount60 = dt.Rows[0][11].ToString();
  177. ChangeTypeAmount31 = dt.Rows[0][12].ToString();
  178. ChangeTypeAmount124 = dt.Rows[0][16].ToString();
  179. ChangeTypeAmount125 = dt.Rows[0][17].ToString();
  180. ChangeTypeAmount31s = dt.Rows[0][18].ToString();
  181. }
  182. other.Add("ChangeTypeAmount0", ChangeTypeAmount0); //激活奖励
  183. other.Add("ChangeTypeAmount1", ChangeTypeAmount1); //交易分润
  184. other.Add("ChangeTypeAmount2", ChangeTypeAmount2); //提现申请
  185. other.Add("ChangeTypeAmount3", ChangeTypeAmount3); //提现代付
  186. other.Add("ChangeTypeAmount4", ChangeTypeAmount4); //提现手续费
  187. other.Add("ChangeTypeAmount5", ChangeTypeAmount5); //提现税点扣除
  188. other.Add("ChangeTypeAmount6", ChangeTypeAmount6); //提现失败,解冻
  189. other.Add("ChangeTypeAmount61", ChangeTypeAmount61); //人工冻结
  190. other.Add("ChangeTypeAmount62", ChangeTypeAmount62); //人工解冻
  191. other.Add("ChangeTypeAmount63", ChangeTypeAmount63); //人工扣减
  192. other.Add("ChangeTypeAmount64", ChangeTypeAmount64); //人工增加
  193. other.Add("ChangeTypeAmount50", ChangeTypeAmount50); //开机奖励
  194. other.Add("ChangeTypeAmount111", ChangeTypeAmount111); //分润补贴
  195. other.Add("ChangeTypeAmount112", ChangeTypeAmount112); //推荐奖励
  196. other.Add("ChangeTypeAmount60", ChangeTypeAmount60); //流量卡分佣
  197. other.Add("ChangeTypeAmount31", ChangeTypeAmount31); //红包奖励
  198. other.Add("ChangeTypeAmount31s", ChangeTypeAmount31s); //红包奖励
  199. other.Add("ChangeTypeAmount124", ChangeTypeAmount124); //机具过期
  200. other.Add("ChangeTypeAmount125", ChangeTypeAmount125); //软件服务费
  201. obj.Add("other", other);
  202. return Json(obj);
  203. }
  204. #endregion
  205. #region 增加创客账户变动记录
  206. /// <summary>
  207. /// 增加或修改创客账户变动记录信息
  208. /// </summary>
  209. /// <returns></returns>
  210. public IActionResult Add(string right)
  211. {
  212. ViewBag.RightInfo = RightInfo;
  213. ViewBag.right = right;
  214. return View();
  215. }
  216. #endregion
  217. #region 增加创客账户变动记录
  218. /// <summary>
  219. /// 增加或修改创客账户变动记录信息
  220. /// </summary>
  221. /// <returns></returns>
  222. [HttpPost]
  223. public string Add(UserAccountRecord data)
  224. {
  225. Dictionary<string, object> Fields = new Dictionary<string, object>();
  226. Fields.Add("SeoTitle", data.SeoTitle);
  227. Fields.Add("SeoKeyword", data.SeoKeyword);
  228. Fields.Add("SeoDescription", data.SeoDescription);
  229. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("UserAccountRecord", Fields, 0);
  230. AddSysLog(data.Id.ToString(), "UserAccountRecord", "add");
  231. db.SaveChanges();
  232. return "success";
  233. }
  234. #endregion
  235. #region 修改创客账户变动记录
  236. /// <summary>
  237. /// 增加或修改创客账户变动记录信息
  238. /// </summary>
  239. /// <returns></returns>
  240. public IActionResult Edit(string right, int Id = 0)
  241. {
  242. ViewBag.RightInfo = RightInfo;
  243. ViewBag.right = right;
  244. UserAccountRecord editData = db.UserAccountRecord.FirstOrDefault(m => m.Id == Id) ?? new UserAccountRecord();
  245. ViewBag.data = editData;
  246. return View();
  247. }
  248. #endregion
  249. #region 修改创客账户变动记录
  250. /// <summary>
  251. /// 增加或修改创客账户变动记录信息
  252. /// </summary>
  253. /// <returns></returns>
  254. [HttpPost]
  255. public string Edit(UserAccountRecord data)
  256. {
  257. Dictionary<string, object> Fields = new Dictionary<string, object>();
  258. Fields.Add("SeoTitle", data.SeoTitle);
  259. Fields.Add("SeoKeyword", data.SeoKeyword);
  260. Fields.Add("SeoDescription", data.SeoDescription);
  261. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("UserAccountRecord", Fields, data.Id);
  262. AddSysLog(data.Id.ToString(), "UserAccountRecord", "update");
  263. db.SaveChanges();
  264. return "success";
  265. }
  266. #endregion
  267. #region 删除创客账户变动记录信息
  268. /// <summary>
  269. /// 删除创客账户变动记录信息
  270. /// </summary>
  271. /// <returns></returns>
  272. public string Delete(string Id)
  273. {
  274. string[] idlist = Id.Split(new char[] { ',' });
  275. AddSysLog(Id, "UserAccountRecord", "del");
  276. foreach (string subid in idlist)
  277. {
  278. int id = int.Parse(subid);
  279. Dictionary<string, object> Fields = new Dictionary<string, object>();
  280. Fields.Add("Status", -1);
  281. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("UserAccountRecord", Fields, id);
  282. }
  283. db.SaveChanges();
  284. return "success";
  285. }
  286. #endregion
  287. #region 开启
  288. /// <summary>
  289. /// 开启
  290. /// </summary>
  291. /// <returns></returns>
  292. public string Open(string Id)
  293. {
  294. string[] idlist = Id.Split(new char[] { ',' });
  295. AddSysLog(Id, "UserAccountRecord", "open");
  296. foreach (string subid in idlist)
  297. {
  298. int id = int.Parse(subid);
  299. Dictionary<string, object> Fields = new Dictionary<string, object>();
  300. Fields.Add("Status", 1);
  301. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("UserAccountRecord", Fields, id);
  302. }
  303. db.SaveChanges();
  304. return "success";
  305. }
  306. #endregion
  307. #region 关闭
  308. /// <summary>
  309. /// 关闭
  310. /// </summary>
  311. /// <returns></returns>
  312. public string Close(string Id)
  313. {
  314. string[] idlist = Id.Split(new char[] { ',' });
  315. AddSysLog(Id, "UserAccountRecord", "close");
  316. foreach (string subid in idlist)
  317. {
  318. int id = int.Parse(subid);
  319. Dictionary<string, object> Fields = new Dictionary<string, object>();
  320. Fields.Add("Status", 0);
  321. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("UserAccountRecord", Fields, id);
  322. }
  323. db.SaveChanges();
  324. return "success";
  325. }
  326. #endregion
  327. #region 排序
  328. /// <summary>
  329. /// 排序
  330. /// </summary>
  331. /// <param name="Id"></param>
  332. public string Sort(int Id, int Sort)
  333. {
  334. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("UserAccountRecord", Sort, Id);
  335. AddSysLog(Id.ToString(), "UserAccountRecord", "sort");
  336. return "success";
  337. }
  338. #endregion
  339. #region 导入数据
  340. /// <summary>
  341. /// 导入数据
  342. /// </summary>
  343. /// <param name="ExcelData"></param>
  344. public string Import(string ExcelData)
  345. {
  346. ExcelData = HttpUtility.UrlDecode(ExcelData);
  347. JsonData list = JsonMapper.ToObject(ExcelData);
  348. for (int i = 1; i < list.Count; i++)
  349. {
  350. JsonData dr = list[i];
  351. db.UserAccountRecord.Add(new UserAccountRecord()
  352. {
  353. CreateDate = DateTime.Now,
  354. UpdateDate = DateTime.Now,
  355. });
  356. db.SaveChanges();
  357. }
  358. AddSysLog("0", "UserAccountRecord", "Import");
  359. return "success";
  360. }
  361. #endregion
  362. #region 导出Excel
  363. /// <summary>
  364. /// 导出Excel
  365. /// </summary>
  366. /// <returns></returns>
  367. public JsonResult ExportExcel(UserAccountRecord data, string MakerCode, string RealName, string CreateDateData, int TopUserId, int UserId)
  368. {
  369. Dictionary<string, string> Fields = new Dictionary<string, string>();
  370. Fields.Add("ChangeType", "1"); //交易类型
  371. Fields.Add("ProductType", "1"); //产品类型
  372. Fields.Add("TransRecordNo", "3"); //交易流水编号
  373. // Fields.Add("CreateDate", "3"); //交易时间
  374. string condition = " and Status>-1";
  375. //创客编号
  376. if (!string.IsNullOrEmpty(MakerCode))
  377. {
  378. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  379. }
  380. //创客名称
  381. if (!string.IsNullOrEmpty(RealName))
  382. {
  383. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  384. }
  385. //顶级创客
  386. if (TopUserId > 0)
  387. {
  388. condition += " and UserId in (select Id from Users where ParentNav like '," + TopUserId + ",%')";
  389. }
  390. if (UserId > 0)
  391. {
  392. condition += " and UserId=" + UserId;
  393. }
  394. if (!string.IsNullOrEmpty(CreateDateData))
  395. {
  396. string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None);
  397. var start = Convert.ToDateTime(Convert.ToDateTime(datelist[0]).ToString("yyyy-MM-dd"));
  398. var end = Convert.ToDateTime(Convert.ToDateTime(datelist[1]).ToString("yyyy-MM-dd") + " 23:59:59");
  399. var check = db.UserAccountRecord.Any(m => m.CreateDate >= start);
  400. var checks = db.UserAccountRecord.Any(m => m.CreateDate <= end);
  401. if (check)
  402. {
  403. var sId = db.UserAccountRecord.Where(m => m.CreateDate >= start).Min(m => m.Id);
  404. condition += " and Id >=" + sId;
  405. }
  406. if (checks)
  407. {
  408. var eId = db.UserAccountRecord.Where(m => m.CreateDate <= end).Max(m => m.Id);
  409. condition += " and Id <=" + eId;
  410. }
  411. }
  412. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("UserAccountRecord", Fields, "Id desc", "0", 1, 20000, condition, "UserId,ProductType,TransRecordNo,ChangeType,ChangeAmount,Remark,BeforeTotalAmount,AfterTotalAmount,BeforeFreezeAmount,AfterFreezeAmount,BeforeBalanceAmount,AfterBalanceAmount,CreateDate", false);
  413. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  414. foreach (Dictionary<string, object> dic in diclist)
  415. {
  416. int UId = int.Parse(dic["UserId"].ToString());
  417. Users user = db.Users.FirstOrDefault(m => m.Id == UId) ?? new Users();
  418. dic["MakerCode"] = user.MakerCode;
  419. dic["RealName"] = user.RealName;
  420. if (!string.IsNullOrEmpty(user.ParentNav))
  421. {
  422. int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]);
  423. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users();
  424. dic["TopMakerCode"] = tuser.MakerCode;
  425. dic["TopRealName"] = tuser.RealName;
  426. }
  427. int ProductType = int.Parse(dic["ProductType"].ToString());
  428. dic["ProductTypeName"] = RelationClass.GetKqProductBrandInfo(ProductType);
  429. int ChangeType = int.Parse(dic["ChangeType"].ToString());
  430. dic["ChangeTypeName"] = RelationClassForConst.GetChangeTypeInfo(ChangeType);
  431. dic.Remove("UserId");
  432. dic.Remove("ChangeType");
  433. dic.Remove("ProductType");
  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("MakerCode", "创客编号");
  441. ReturnFields.Add("RealName", "创客姓名");
  442. ReturnFields.Add("TopMakerCode", "顶级创客编号");
  443. ReturnFields.Add("TopRealName", "顶级创客名称");
  444. ReturnFields.Add("ProductTypeName", "产品类型");
  445. ReturnFields.Add("TransRecordNo", "交易流水编号");
  446. ReturnFields.Add("ChangeTypeName", "交易类型");
  447. ReturnFields.Add("ChangeAmount", "交易金额");
  448. ReturnFields.Add("Remark", "备注");
  449. ReturnFields.Add("BeforeTotalAmount", "交易前总金额");
  450. ReturnFields.Add("AfterTotalAmount", "交易后总金额");
  451. ReturnFields.Add("BeforeFreezeAmount", "交易前冻结金额");
  452. ReturnFields.Add("AfterFreezeAmount", "交易后冻结金额");
  453. ReturnFields.Add("BeforeBalanceAmount", "交易前余额");
  454. ReturnFields.Add("AfterBalanceAmount", "交易后余额");
  455. ReturnFields.Add("CreateDate", "交易时间");
  456. result.Add("Fields", ReturnFields);
  457. AddSysLog("0", "UserAccountRecord", "ExportExcel");
  458. return Json(result);
  459. }
  460. #endregion
  461. }
  462. }