MsgPlacardController.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420
  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 MsgPlacardController : BaseController
  23. {
  24. public MsgPlacardController(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(MsgPlacard data, string right)
  34. {
  35. ViewBag.RightInfo = RightInfo;
  36. ViewBag.right = right;
  37. return View();
  38. }
  39. #endregion
  40. #region 根据条件查询公告消息列表
  41. /// <summary>
  42. /// 公告消息列表
  43. /// </summary>
  44. /// <returns></returns>
  45. public JsonResult IndexData(MsgPlacard data, string MsgTypeSelect, string StatusSelect, string PushTypeSelect, string PushFlagSelect, string CreateDateData, int page = 1, int limit = 30)
  46. {
  47. Dictionary<string, string> Fields = new Dictionary<string, string>();
  48. Fields.Add("Title", "2"); //标题
  49. string condition = " and Status>-1";
  50. //消息类型
  51. if(!string.IsNullOrEmpty(MsgTypeSelect))
  52. {
  53. condition += " and MsgType=" + MsgTypeSelect;
  54. }
  55. //状态
  56. if(!string.IsNullOrEmpty(StatusSelect))
  57. {
  58. condition += " and Status=" + StatusSelect;
  59. }
  60. //推送类型
  61. if(!string.IsNullOrEmpty(PushTypeSelect))
  62. {
  63. condition += " and PushType=" + PushTypeSelect;
  64. }
  65. //推送标记
  66. if(!string.IsNullOrEmpty(PushFlagSelect))
  67. {
  68. condition += " and PushFlag=" + PushFlagSelect;
  69. }
  70. if (!string.IsNullOrEmpty(CreateDateData))
  71. {
  72. string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None);
  73. string start = datelist[0];
  74. string end = datelist[1];
  75. condition += " and CreateDate>='" + start + " 00:00:00' and CreateDate<='" + end + " 23:59:59'";
  76. }
  77. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("MsgPlacard", Fields, "Id desc", "0", page, limit, condition);
  78. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  79. foreach (Dictionary<string, object> dic in diclist)
  80. {
  81. //消息类型
  82. int MsgType = int.Parse(dic["MsgType"].ToString());
  83. if(MsgType == 0) dic["MsgType"] = "html页面";
  84. if(MsgType == 1) dic["MsgType"] = "指定url";
  85. if(MsgType == 2) dic["MsgType"] = "简单中文描述";
  86. //推送类型
  87. int PushType = int.Parse(dic["PushType"].ToString());
  88. if(PushType == 0) dic["PushType"] = "不推送";
  89. if(PushType == 1) dic["PushType"] = "立即推送";
  90. if(PushType == 2) dic["PushType"] = "定时推送";
  91. //推送标记
  92. int PushFlag = int.Parse(dic["PushFlag"].ToString());
  93. if(PushFlag == 0) dic["PushFlag"] = "不推送";
  94. if(PushFlag == 1) dic["PushFlag"] = "未推送";
  95. if(PushFlag == 2) dic["PushFlag"] = "已推送";
  96. }
  97. return Json(obj);
  98. }
  99. #endregion
  100. #region 增加公告消息
  101. /// <summary>
  102. /// 增加或修改公告消息信息
  103. /// </summary>
  104. /// <returns></returns>
  105. public IActionResult Add(string right)
  106. {
  107. ViewBag.RightInfo = RightInfo;
  108. ViewBag.right = right;
  109. return View();
  110. }
  111. #endregion
  112. #region 增加公告消息
  113. /// <summary>
  114. /// 增加或修改公告消息信息
  115. /// </summary>
  116. /// <returns></returns>
  117. [HttpPost]
  118. public string Add(MsgPlacard data)
  119. {
  120. Dictionary<string, object> Fields = new Dictionary<string, object>();
  121. Fields.Add("MsgType", data.MsgType); //消息类型
  122. Fields.Add("Title", data.Title); //标题
  123. Fields.Add("Summary", data.Summary); //简介
  124. Fields.Add("Content", data.Content); //内容
  125. Fields.Add("ShowType", data.ShowType); //展示类型
  126. Fields.Add("EffectStartDate", data.EffectStartDate); //有效开始时间
  127. Fields.Add("EffectEndDate", data.EffectEndDate); //有效结束时间
  128. Fields.Add("BgPic", data.BgPic); //背景图片
  129. Fields.Add("PushType", data.PushType); //推送类型
  130. Fields.Add("PushFlag", data.PushFlag); //推送标记
  131. Fields.Add("PushParam", data.PushParam); //推送参数
  132. Fields.Add("PushTime", data.PushTime); //推送时间
  133. Fields.Add("ExtendColumn", data.ExtendColumn); //扩展字段
  134. Fields.Add("Remark", data.Remark); //备注
  135. Fields.Add("Url", data.Url); //跳转Url
  136. Fields.Add("SeoTitle", data.SeoTitle);
  137. Fields.Add("SeoKeyword", data.SeoKeyword);
  138. Fields.Add("SeoDescription", data.SeoDescription);
  139. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("MsgPlacard", Fields, 0);
  140. AddSysLog(Id.ToString(), "MsgPlacard", "add");
  141. db.SaveChanges();
  142. return "success";
  143. }
  144. #endregion
  145. #region 修改公告消息
  146. /// <summary>
  147. /// 增加或修改公告消息信息
  148. /// </summary>
  149. /// <returns></returns>
  150. public IActionResult Edit(string right, int Id = 0)
  151. {
  152. ViewBag.RightInfo = RightInfo;
  153. ViewBag.right = right;
  154. MsgPlacard editData = db.MsgPlacard.FirstOrDefault(m => m.Id == Id) ?? new MsgPlacard();
  155. ViewBag.data = editData;
  156. return View();
  157. }
  158. #endregion
  159. #region 修改公告消息
  160. /// <summary>
  161. /// 增加或修改公告消息信息
  162. /// </summary>
  163. /// <returns></returns>
  164. [HttpPost]
  165. public string Edit(MsgPlacard data)
  166. {
  167. Dictionary<string, object> Fields = new Dictionary<string, object>();
  168. Fields.Add("MsgType", data.MsgType); //消息类型
  169. Fields.Add("Title", data.Title); //标题
  170. Fields.Add("Summary", data.Summary); //简介
  171. Fields.Add("Content", data.Content); //内容
  172. Fields.Add("ShowType", data.ShowType); //展示类型
  173. Fields.Add("EffectStartDate", data.EffectStartDate); //有效开始时间
  174. Fields.Add("EffectEndDate", data.EffectEndDate); //有效结束时间
  175. Fields.Add("BgPic", data.BgPic); //背景图片
  176. Fields.Add("PushType", data.PushType); //推送类型
  177. Fields.Add("PushFlag", data.PushFlag); //推送标记
  178. Fields.Add("PushParam", data.PushParam); //推送参数
  179. Fields.Add("PushTime", data.PushTime); //推送时间
  180. Fields.Add("ExtendColumn", data.ExtendColumn); //扩展字段
  181. Fields.Add("Remark", data.Remark); //备注
  182. Fields.Add("Url", data.Url); //跳转Url
  183. Fields.Add("SeoTitle", data.SeoTitle);
  184. Fields.Add("SeoKeyword", data.SeoKeyword);
  185. Fields.Add("SeoDescription", data.SeoDescription);
  186. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MsgPlacard", Fields, data.Id);
  187. AddSysLog(data.Id.ToString(), "MsgPlacard", "update");
  188. db.SaveChanges();
  189. SetRedis(data.Id, true);
  190. return "success";
  191. }
  192. #endregion
  193. #region 详情
  194. public IActionResult Detail(string right, int Id = 0)
  195. {
  196. ViewBag.RightInfo = RightInfo;
  197. ViewBag.right = right;
  198. MsgPlacard editData = db.MsgPlacard.FirstOrDefault(m => m.Id == Id) ?? new MsgPlacard();
  199. ViewBag.data = editData;
  200. return View();
  201. }
  202. #endregion
  203. #region 删除公告消息信息
  204. /// <summary>
  205. /// 删除公告消息信息
  206. /// </summary>
  207. /// <returns></returns>
  208. public string Delete(string Id)
  209. {
  210. string[] idlist = Id.Split(new char[] { ',' });
  211. AddSysLog(Id, "MsgPlacard", "del");
  212. foreach (string subid in idlist)
  213. {
  214. int id = int.Parse(subid);
  215. Dictionary<string, object> Fields = new Dictionary<string, object>();
  216. Fields.Add("Status", -1);
  217. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MsgPlacard", Fields, id);
  218. SetRedis(0, true);
  219. }
  220. db.SaveChanges();
  221. return "success";
  222. }
  223. #endregion
  224. #region 开启
  225. /// <summary>
  226. /// 开启
  227. /// </summary>
  228. /// <returns></returns>
  229. public string Open(string Id)
  230. {
  231. string[] idlist = Id.Split(new char[] { ',' });
  232. AddSysLog(Id, "MsgPlacard", "open");
  233. foreach (string subid in idlist)
  234. {
  235. int id = int.Parse(subid);
  236. Dictionary<string, object> Fields = new Dictionary<string, object>();
  237. Fields.Add("Status", 1);
  238. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MsgPlacard", Fields, id);
  239. }
  240. db.SaveChanges();
  241. return "success";
  242. }
  243. #endregion
  244. #region 关闭
  245. /// <summary>
  246. /// 关闭
  247. /// </summary>
  248. /// <returns></returns>
  249. public string Close(string Id)
  250. {
  251. string[] idlist = Id.Split(new char[] { ',' });
  252. AddSysLog(Id, "MsgPlacard", "close");
  253. foreach (string subid in idlist)
  254. {
  255. int id = int.Parse(subid);
  256. Dictionary<string, object> Fields = new Dictionary<string, object>();
  257. Fields.Add("Status", 0);
  258. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("MsgPlacard", Fields, id);
  259. }
  260. db.SaveChanges();
  261. return "success";
  262. }
  263. #endregion
  264. #region 排序
  265. /// <summary>
  266. /// 排序
  267. /// </summary>
  268. /// <param name="Id"></param>
  269. public string Sort(int Id, int Sort)
  270. {
  271. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("MsgPlacard", Sort, Id);
  272. AddSysLog(Id.ToString(), "MsgPlacard", "sort");
  273. return "success";
  274. }
  275. #endregion
  276. #region 导入数据
  277. /// <summary>
  278. /// 导入数据
  279. /// </summary>
  280. /// <param name="ExcelData"></param>
  281. public string Import(string ExcelData)
  282. {
  283. ExcelData = HttpUtility.UrlDecode(ExcelData);
  284. JsonData list = JsonMapper.ToObject(ExcelData);
  285. for (int i = 1; i < list.Count; i++)
  286. {
  287. JsonData dr = list[i];
  288. db.MsgPlacard.Add(new MsgPlacard()
  289. {
  290. CreateDate = DateTime.Now,
  291. UpdateDate = DateTime.Now,
  292. });
  293. db.SaveChanges();
  294. }
  295. AddSysLog("0", "MsgPlacard", "Import");
  296. return "success";
  297. }
  298. #endregion
  299. #region 导出Excel
  300. /// <summary>
  301. /// 导出Excel
  302. /// </summary>
  303. /// <returns></returns>
  304. public JsonResult ExportExcel(MsgPlacard data)
  305. {
  306. Dictionary<string, string> Fields = new Dictionary<string, string>();
  307. Fields.Add("MsgType", "1"); //消息类型
  308. Fields.Add("CreateDate", "3"); //时间
  309. Fields.Add("Title", "2"); //标题
  310. Fields.Add("PushType", "1"); //推送类型
  311. Fields.Add("PushFlag", "1"); //推送标记
  312. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("MsgPlacard", Fields, "Id desc", "0", 1, 20000, "", "", false);
  313. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  314. foreach (Dictionary<string, object> dic in diclist)
  315. {
  316. }
  317. Dictionary<string, object> result = new Dictionary<string, object>();
  318. result.Add("Status", "1");
  319. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  320. result.Add("Obj", diclist);
  321. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  322. result.Add("Fields", ReturnFields);
  323. AddSysLog("0", "MsgPlacard", "ExportExcel");
  324. return Json(result);
  325. }
  326. #endregion
  327. #region 设置缓存
  328. private void SetRedis(int Id, bool All)
  329. {
  330. if (All)
  331. {
  332. RedisDbconn.Instance.Clear("MsgPlacardList");
  333. var msgs = db.MsgPlacard.Select(m => new { m.Id, m.Status, m.Sort }).Where(m => m.Status > -1).OrderByDescending(m => m.Sort).ThenByDescending(m => m.Id).ToList();
  334. foreach (var msg in msgs)
  335. {
  336. RedisDbconn.Instance.AddList("MsgPlacardList", msg.Id);
  337. }
  338. }
  339. if (Id > 0)
  340. {
  341. MsgPlacard edit = db.MsgPlacard.FirstOrDefault(m => m.Id == Id);
  342. if (edit != null)
  343. {
  344. RedisDbconn.Instance.Set("MsgPlacard:" + Id, edit);
  345. }
  346. }
  347. }
  348. #endregion
  349. }
  350. }