ActivityPrizeDetailController.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  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.Threading.Tasks;
  10. using Microsoft.AspNetCore.Mvc;
  11. using Microsoft.AspNetCore.Http;
  12. using Microsoft.Extensions.Logging;
  13. using Microsoft.Extensions.Options;
  14. using MySystem.Models;
  15. using Library;
  16. using LitJson;
  17. using MySystemLib;
  18. namespace MySystem.Areas.Admin.Controllers
  19. {
  20. [Area("Admin")]
  21. [Route("Admin/[controller]/[action]")]
  22. public class ActivityPrizeDetailController : BaseController
  23. {
  24. public ActivityPrizeDetailController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  25. {
  26. OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  27. }
  28. #region 活动奖励明细列表
  29. /// <summary>
  30. /// 根据条件查询活动奖励明细列表
  31. /// </summary>
  32. /// <returns></returns>
  33. public IActionResult Index(ActivityPrizeDetail data, string right)
  34. {
  35. ViewBag.RightInfo = RightInfo;
  36. ViewBag.right = right;
  37. List<KqProducts> Brands = db.KqProducts.OrderBy(m => m.Id).ToList();
  38. ViewBag.Brands = Brands;
  39. return View();
  40. }
  41. #endregion
  42. #region 根据条件查询活动奖励明细列表
  43. /// <summary>
  44. /// 活动奖励明细列表
  45. /// </summary>
  46. /// <returns></returns>
  47. public JsonResult IndexData(ActivityPrizeDetail data, string MakerCode, string RealName, string TopMakerCode, string TopRealName, string ActivityName, string TradeMonthSelect, string CheckStatusSelect, int page = 1, int limit = 30)
  48. {
  49. Dictionary<string, string> Fields = new Dictionary<string, string>();
  50. Fields.Add("BrandId", "0"); //产品类型
  51. string condition = " and Status>-1";
  52. //创客编号
  53. if (!string.IsNullOrEmpty(MakerCode))
  54. {
  55. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  56. }
  57. //创客名称
  58. if (!string.IsNullOrEmpty(RealName))
  59. {
  60. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  61. }
  62. //顶级创客编号
  63. if (!string.IsNullOrEmpty(TopMakerCode))
  64. {
  65. condition += " and TopUserId in (select UserId from UserForMakerCode where MakerCode='" + TopMakerCode + "')";
  66. }
  67. //顶级创客名称
  68. if (!string.IsNullOrEmpty(TopRealName))
  69. {
  70. condition += " and TopUserId in (select UserId from UserForRealName where RealName='" + TopRealName + "')";
  71. }
  72. //活动名称
  73. if (!string.IsNullOrEmpty(ActivityName))
  74. {
  75. condition += " and ActivityId in (select ActivityId from ProfitObjectsActivesForId where Name='" + ActivityName + "')";
  76. }
  77. //交易月份
  78. if(!string.IsNullOrEmpty(TradeMonthSelect))
  79. {
  80. condition += " and TradeMonth=" + TradeMonthSelect.Replace("-", "");
  81. }
  82. //同步状态
  83. if(!string.IsNullOrEmpty(CheckStatusSelect))
  84. {
  85. condition += " and CheckStatus=" + CheckStatusSelect;
  86. }
  87. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ActivityPrizeDetail", Fields, "Id desc", "0", page, limit, condition);
  88. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  89. foreach (Dictionary<string, object> dic in diclist)
  90. {
  91. dic["ActivityName"] = RelationClass.GetProfitObjectsActivesInfo(int.Parse(dic["ActivityId"].ToString()));
  92. dic["BrandId"] = RelationClass.GetKqProductBrandInfo(int.Parse(dic["BrandId"].ToString()));
  93. int UserId = int.Parse(dic["UserId"].ToString());
  94. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  95. dic["MakerCode"] = user.MakerCode;
  96. dic["RealName"] = user.RealName;
  97. if (!string.IsNullOrEmpty(user.ParentNav))
  98. {
  99. int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]);
  100. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users();
  101. dic["TopMakerCode"] = tuser.MakerCode;
  102. dic["TopRealName"] = tuser.RealName;
  103. }
  104. dic["CheckStatus"] = dic["CheckStatus"].ToString() == "1" ? "已验证和同步" : "初始";
  105. }
  106. return Json(obj);
  107. }
  108. #endregion
  109. #region 增加活动奖励明细
  110. /// <summary>
  111. /// 增加或修改活动奖励明细信息
  112. /// </summary>
  113. /// <returns></returns>
  114. public IActionResult Add(string right)
  115. {
  116. ViewBag.RightInfo = RightInfo;
  117. ViewBag.right = right;
  118. return View();
  119. }
  120. #endregion
  121. #region 增加活动奖励明细
  122. /// <summary>
  123. /// 增加或修改活动奖励明细信息
  124. /// </summary>
  125. /// <returns></returns>
  126. [HttpPost]
  127. public string Add(ActivityPrizeDetail data)
  128. {
  129. Dictionary<string, object> Fields = new Dictionary<string, object>();
  130. Fields.Add("SeoTitle", data.SeoTitle);
  131. Fields.Add("SeoKeyword", data.SeoKeyword);
  132. Fields.Add("SeoDescription", data.SeoDescription);
  133. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("ActivityPrizeDetail", Fields, 0);
  134. AddSysLog(data.Id.ToString(), "ActivityPrizeDetail", "add");
  135. db.SaveChanges();
  136. return "success";
  137. }
  138. #endregion
  139. #region 修改活动奖励明细
  140. /// <summary>
  141. /// 增加或修改活动奖励明细信息
  142. /// </summary>
  143. /// <returns></returns>
  144. public IActionResult Edit(string right, int Id = 0)
  145. {
  146. ViewBag.RightInfo = RightInfo;
  147. ViewBag.right = right;
  148. ActivityPrizeDetail editData = db.ActivityPrizeDetail.FirstOrDefault(m => m.Id == Id) ?? new ActivityPrizeDetail();
  149. ViewBag.data = editData;
  150. return View();
  151. }
  152. #endregion
  153. #region 修改活动奖励明细
  154. /// <summary>
  155. /// 增加或修改活动奖励明细信息
  156. /// </summary>
  157. /// <returns></returns>
  158. [HttpPost]
  159. public string Edit(ActivityPrizeDetail data)
  160. {
  161. Dictionary<string, object> Fields = new Dictionary<string, object>();
  162. Fields.Add("SeoTitle", data.SeoTitle);
  163. Fields.Add("SeoKeyword", data.SeoKeyword);
  164. Fields.Add("SeoDescription", data.SeoDescription);
  165. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ActivityPrizeDetail", Fields, data.Id);
  166. AddSysLog(data.Id.ToString(), "ActivityPrizeDetail", "update");
  167. db.SaveChanges();
  168. return "success";
  169. }
  170. #endregion
  171. #region 删除活动奖励明细信息
  172. /// <summary>
  173. /// 删除活动奖励明细信息
  174. /// </summary>
  175. /// <returns></returns>
  176. public string Delete(string Id)
  177. {
  178. string[] idlist = Id.Split(new char[] { ',' });
  179. AddSysLog(Id, "ActivityPrizeDetail", "del");
  180. foreach (string subid in idlist)
  181. {
  182. int id = int.Parse(subid);
  183. Dictionary<string, object> Fields = new Dictionary<string, object>();
  184. Fields.Add("Status", -1);
  185. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ActivityPrizeDetail", Fields, id);
  186. }
  187. db.SaveChanges();
  188. return "success";
  189. }
  190. #endregion
  191. #region 开启
  192. /// <summary>
  193. /// 开启
  194. /// </summary>
  195. /// <returns></returns>
  196. public string Open(string Id)
  197. {
  198. string[] idlist = Id.Split(new char[] { ',' });
  199. AddSysLog(Id, "ActivityPrizeDetail", "open");
  200. foreach (string subid in idlist)
  201. {
  202. int id = int.Parse(subid);
  203. Dictionary<string, object> Fields = new Dictionary<string, object>();
  204. Fields.Add("Status", 1);
  205. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ActivityPrizeDetail", Fields, id);
  206. }
  207. db.SaveChanges();
  208. return "success";
  209. }
  210. #endregion
  211. #region 关闭
  212. /// <summary>
  213. /// 关闭
  214. /// </summary>
  215. /// <returns></returns>
  216. public string Close(string Id)
  217. {
  218. string[] idlist = Id.Split(new char[] { ',' });
  219. AddSysLog(Id, "ActivityPrizeDetail", "close");
  220. foreach (string subid in idlist)
  221. {
  222. int id = int.Parse(subid);
  223. Dictionary<string, object> Fields = new Dictionary<string, object>();
  224. Fields.Add("Status", 0);
  225. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ActivityPrizeDetail", Fields, id);
  226. }
  227. db.SaveChanges();
  228. return "success";
  229. }
  230. #endregion
  231. #region 排序
  232. /// <summary>
  233. /// 排序
  234. /// </summary>
  235. /// <param name="Id"></param>
  236. public string Sort(int Id, int Sort)
  237. {
  238. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("ActivityPrizeDetail", Sort, Id);
  239. AddSysLog(Id.ToString(), "ActivityPrizeDetail", "sort");
  240. return "success";
  241. }
  242. #endregion
  243. #region 导入数据
  244. /// <summary>
  245. /// 导入数据
  246. /// </summary>
  247. /// <param name="ExcelData"></param>
  248. public string Import(string ExcelData)
  249. {
  250. ExcelData = HttpUtility.UrlDecode(ExcelData);
  251. JsonData list = JsonMapper.ToObject(ExcelData);
  252. for (int i = 1; i < list.Count; i++)
  253. {
  254. JsonData dr = list[i];
  255. db.ActivityPrizeDetail.Add(new ActivityPrizeDetail()
  256. {
  257. CreateDate = DateTime.Now,
  258. UpdateDate = DateTime.Now,
  259. });
  260. db.SaveChanges();
  261. }
  262. AddSysLog("0", "ActivityPrizeDetail", "Import");
  263. return "success";
  264. }
  265. #endregion
  266. #region 导出Excel
  267. /// <summary>
  268. /// 导出Excel
  269. /// </summary>
  270. /// <returns></returns>
  271. public JsonResult ExportExcel(ActivityPrizeDetail data, string MakerCode, string RealName, string TopMakerCode, string TopRealName, string ActivityName, string CheckStatusSelect)
  272. {
  273. Dictionary<string, string> Fields = new Dictionary<string, string>();
  274. Fields.Add("BrandId", "0"); //产品类型
  275. Fields.Add("TradeMonth", "1"); //交易月份
  276. string condition = " and Status>-1";
  277. //创客编号
  278. if (!string.IsNullOrEmpty(MakerCode))
  279. {
  280. condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')";
  281. }
  282. //创客名称
  283. if (!string.IsNullOrEmpty(RealName))
  284. {
  285. condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')";
  286. }
  287. //顶级创客编号
  288. if (!string.IsNullOrEmpty(TopMakerCode))
  289. {
  290. condition += " and TopUserId in (select UserId from UserForMakerCode where MakerCode='" + TopMakerCode + "')";
  291. }
  292. //顶级创客名称
  293. if (!string.IsNullOrEmpty(TopRealName))
  294. {
  295. condition += " and TopUserId in (select UserId from UserForRealName where RealName='" + TopRealName + "')";
  296. }
  297. //活动名称
  298. if (!string.IsNullOrEmpty(ActivityName))
  299. {
  300. condition += " and ActivityId in (select ActivityId from ProfitObjectsActivesForId where Name='" + ActivityName + "')";
  301. }
  302. //同步状态
  303. if(!string.IsNullOrEmpty(CheckStatusSelect))
  304. {
  305. condition += " and CheckStatus=" + CheckStatusSelect;
  306. }
  307. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ActivityPrizeDetail", Fields, "Id desc", "0", 1, 20000, condition, "UserId,ActivityId,BrandId,TradeMonth,TradeAmt,CreditTradeAmt,ActRewardAmt,OtherProdCreditTradeAmt,ProfitRate,CheckStatus", false);
  308. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  309. foreach (Dictionary<string, object> dic in diclist)
  310. {
  311. dic["ActivityName"] = RelationClass.GetProfitObjectsActivesInfo(int.Parse(dic["ActivityId"].ToString()));
  312. dic["BrandId"] = RelationClass.GetKqProductBrandInfo(int.Parse(dic["BrandId"].ToString()));
  313. int UserId = int.Parse(dic["UserId"].ToString());
  314. Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  315. dic["MakerCode"] = user.MakerCode;
  316. dic["RealName"] = user.RealName;
  317. if (!string.IsNullOrEmpty(user.ParentNav))
  318. {
  319. int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]);
  320. Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users();
  321. dic["TopMakerCode"] = tuser.MakerCode;
  322. dic["TopRealName"] = tuser.RealName;
  323. }
  324. dic["CheckStatus"] = dic["CheckStatus"].ToString() == "1" ? "已验证和同步" : "初始";
  325. dic.Remove("ActivityId");
  326. dic.Remove("UserId");
  327. }
  328. Dictionary<string, object> result = new Dictionary<string, object>();
  329. result.Add("Status", "1");
  330. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  331. result.Add("Obj", diclist);
  332. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  333. ReturnFields.Add("MakerCode", "创客编号");
  334. ReturnFields.Add("RealName", "创客姓名");
  335. ReturnFields.Add("ActivityName", "活动名称");
  336. ReturnFields.Add("TopMakerCode", "顶级创客编号");
  337. ReturnFields.Add("TopRealName", "顶级创客名称");
  338. ReturnFields.Add("BrandId", "产品类型");
  339. ReturnFields.Add("TradeMonth", "交易月份");
  340. ReturnFields.Add("TradeAmt", "团队交易总金额(元)");
  341. ReturnFields.Add("CreditTradeAmt", "团队贷记卡交易总金额(元)");
  342. ReturnFields.Add("ActRewardAmt", "团队交易活动奖励金额(元)");
  343. ReturnFields.Add("OtherProdCreditTradeAmt", "其他产品贷记卡交易总金额(元)");
  344. ReturnFields.Add("ProfitRate", "活动奖励对应分成比例(万)");
  345. ReturnFields.Add("CheckStatus", "同步状态");
  346. result.Add("Fields", ReturnFields);
  347. AddSysLog("0", "ActivityPrizeDetail", "ExportExcel");
  348. return Json(result);
  349. }
  350. #endregion
  351. }
  352. }