鄂尔多斯-招源科技

BanCallOutController.cs 6.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. using CallCenter.Utility;
  2. using CallCenterApi.DB;
  3. using CallCenterApi.Interface.Controllers.Base;
  4. using CallCenterApi.Interface.Models.Filter;
  5. using CallCenterApi.Interface.Models.Input;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Web;
  11. using System.Web.Mvc;
  12. namespace CallCenterApi.Interface.Controllers.callout
  13. {
  14. public class BanCallOutController : BaseController
  15. {
  16. private readonly BLL.T_Call_BanCallOut banCallOutBLL = new BLL.T_Call_BanCallOut();
  17. private readonly BLL.T_Sys_BanCallOutTime banCallOutTimeBLL = new BLL.T_Sys_BanCallOutTime();
  18. private readonly BLL.T_Sys_BanCallOut sysBanCallOutBLL = new BLL.T_Sys_BanCallOut();
  19. private readonly BLL.T_Sys_UserAccount userAccountBLL = new BLL.T_Sys_UserAccount();
  20. #region 禁止外呼号码管理
  21. public ActionResult GetList(FilterBanCallOut filter)
  22. {
  23. StringBuilder sb = new StringBuilder();
  24. if (!string.IsNullOrWhiteSpace(filter.Phone))
  25. {
  26. sb.Append($" and F_Phone='{filter.Phone}'");
  27. }
  28. //if (filter.Start != null && filter.End != null)
  29. //{
  30. // sb.Append($" and F_Phone='{filter.Phone}'");
  31. //}
  32. var recordCount = 0;
  33. var dt = BLL.PagerBLL.GetListPager(
  34. "T_Call_BanCallOut",
  35. "F_Id",
  36. "*",
  37. sb.ToString(),
  38. "ORDER BY F_ID desc",
  39. filter.PageSize,
  40. filter.PageIndex,
  41. true,
  42. out recordCount);
  43. List<Model.T_Call_BanCallOut> modelList = new BLL.T_Call_BanCallOut().DataTableToList(dt);
  44. var userList = userAccountBLL.DataTableToList1(userAccountBLL.GetList("").Tables[0]);
  45. var obj = new
  46. {
  47. rows = modelList.Select(x => new
  48. {
  49. id = x.Id,
  50. phone = x.F_Phone,
  51. settime = x.F_SetTime,
  52. remark = x.F_Remark,
  53. username = userList.SingleOrDefault(m => m.F_UserId == x.F_UserId)?.F_UserName ?? "系统管理"
  54. }),
  55. total = recordCount
  56. };
  57. return Content(obj.ToJson());
  58. }
  59. public ActionResult Export()
  60. {
  61. var rows = new BLL.T_Call_BanCallOut().DataTableToList(DbHelperSQL.Query("SELECT F_Id,F_Phone,F_SetTime,F_Remark,F_UserId FROM T_Call_BanCallOut").Tables[0]);
  62. var userList = userAccountBLL.DataTableToList1(userAccountBLL.GetList("").Tables[0]);
  63. List<List<string>> list = new List<List<string>>();
  64. foreach (var item in rows)
  65. {
  66. List<string> listItem = new List<string>();
  67. list.Add(new List<string>()
  68. {
  69. item.F_Phone.ToString(),
  70. item.F_SetTime.ToString(),
  71. item.F_Remark.ToString(),
  72. userList.SingleOrDefault(m => m.F_UserId == item.F_UserId)?.F_UserName ?? "系统管理"
  73. });
  74. }
  75. NPOIHelper npoi = new NPOIHelper();
  76. var res = npoi.ExportToExcel($"限制号码_{DateTime.Now.ToString("yyyyMMddHHmmss")}", list, new string[] { "号码", "添加时间", "备注", "添加人" });
  77. return !string.IsNullOrWhiteSpace(res) ? Error(res) : Success("导出成功");
  78. }
  79. public ActionResult Add(BanCallOutInput input)
  80. {
  81. if (string.IsNullOrWhiteSpace(input.Phone))
  82. return Error("号码不可为空");
  83. input.Phone = input.Phone.Trim();
  84. string phone = RequestString.ToDBC(RequestString.RemoveNotNumber(WebHelper.NoHtml(input.Phone)));
  85. if (phone.Length != input.Phone.Length)
  86. return Error("号码格式不正确");
  87. if (string.IsNullOrWhiteSpace(input.Remark))
  88. return Error("备注不可以为空");
  89. var model = banCallOutBLL.GetModel(input.Phone);
  90. if (model != null)
  91. return Error("该号码已被限制外呼");
  92. if (banCallOutBLL.Add(new Model.T_Call_BanCallOut()
  93. {
  94. F_Phone = input.Phone,
  95. F_Remark = input.Remark
  96. }) > 0)
  97. return Success("添加成功");
  98. return Error("添加失败");
  99. }
  100. public ActionResult Delete(int[] ids)
  101. {
  102. if (ids == null || ids.Length <= 0)
  103. return Error("请选择需要删除的项");
  104. var idsStr = string.Join(",", ids);
  105. banCallOutBLL.DeleteBatch(idsStr);
  106. return Success("删除成功");
  107. }
  108. #endregion
  109. #region 限制外呼时间管理
  110. public ActionResult GetModel()
  111. {
  112. var deptId = CurrentUser.UserData.F_DeptId;
  113. var model = sysBanCallOutBLL.GetModel(deptId);
  114. return Success("获取成功", new
  115. {
  116. id = model?.F_Id ?? 0,
  117. deptid = model?.F_DeptId ?? 0,
  118. starttime1 = model?.StartTime1.Value.ToString("yyyy-MM-dd HH:mm:ss ") ?? "",
  119. starttime2 = model?.StartTime2.Value.ToString("yyyy-MM-dd HH:mm:ss ") ?? "",
  120. endtime1 = model?.EndTime1.Value.ToString("yyyy-MM-dd HH:mm:ss ") ?? "",
  121. endtime2 = model?.EndTime2.Value.ToString("yyyy-MM-dd HH:mm:ss ") ?? "",
  122. });
  123. }
  124. public ActionResult CreateOrUpdate(SysBanCallOutInput input)
  125. {
  126. Model.T_Sys_BanCallOut model = sysBanCallOutBLL.GetModel(CurrentUser.UserData.F_DeptId);
  127. if (input.F_Id <= 0)
  128. {
  129. if (model != null)
  130. return Error("已经存在该条数据");
  131. model.F_DeptId = CurrentUser.UserData.F_DeptId;
  132. model.StartTime1 = input.StartTime1;
  133. model.EndTime1 = input.EndTime1;
  134. model.StartTime2 = input.StartTime2;
  135. model.EndTime2 = input.EndTime2;
  136. if (sysBanCallOutBLL.Add(model))
  137. return Success("添加成功");
  138. return Error("添加失败");
  139. }
  140. if (model == null)
  141. return Error("该条数据不存在");
  142. model.StartTime1 = input.StartTime1;
  143. model.EndTime1 = input.EndTime1;
  144. model.StartTime2 = input.StartTime2;
  145. model.EndTime2 = input.EndTime2;
  146. if (sysBanCallOutBLL.Update(model))
  147. return Success("修改成功");
  148. return Error("修改失败");
  149. }
  150. #endregion
  151. }
  152. }