足力健后端,使用.netcore版本,合并1个项目使用

SetDutyNumberController.cs 7.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Common;
  4. using System.IRepositories;
  5. using System.Linq;
  6. using System.Model;
  7. using System.Security.Claims;
  8. using System.Threading.Tasks;
  9. using Microsoft.AspNetCore.Authorization;
  10. using Microsoft.AspNetCore.Mvc;
  11. using SqlSugar;
  12. using TVShoppingCallCenter_ZLJ.Models.Inputs;
  13. namespace TVShoppingCallCenter_ZLJ.Controllers.Traffic
  14. {
  15. [Authorize]
  16. [Produces("application/json")]
  17. [Route("api/[controller]")]
  18. public class SetDutyNumberController : BaseController
  19. {
  20. private readonly ISys_CallDutyNumberRepository _sys_calldutynumberRepository;
  21. private readonly ISys_SeatGroupRepository _sys_seatgroupRepository;
  22. public SetDutyNumberController(ISys_CallDutyNumberRepository sys_calldutynumberRepository, ISys_SeatGroupRepository sys_seatgroupRepository)
  23. {
  24. _sys_calldutynumberRepository = sys_calldutynumberRepository;
  25. _sys_seatgroupRepository = sys_seatgroupRepository;
  26. }
  27. /// <summary>
  28. /// 获取列表
  29. /// </summary>
  30. /// <param name="filter"></param>
  31. /// <returns></returns>
  32. [HttpGet("getlistbypage")]
  33. public async Task<IActionResult> GetListsByPage(string key, int groupid=0, int pageindex = 1, int pagesize = 20)
  34. {
  35. List<IConditionalModel> conModels = new List<IConditionalModel>();
  36. #region 条件筛选
  37. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  38. if (groupid>0)
  39. conModels.Add(new ConditionalModel() { FieldName = "F_GroupId", ConditionalType = ConditionalType.Equal, FieldValue = groupid.ToString() });
  40. if (!string.IsNullOrEmpty(key))
  41. {
  42. conModels.Add(new ConditionalCollections()
  43. {
  44. ConditionalList = new List<KeyValuePair<WhereType, ConditionalModel>>()
  45. {
  46. new KeyValuePair<WhereType, ConditionalModel>(WhereType.And, new ConditionalModel() { FieldName = "F_DutyNumber", ConditionalType = ConditionalType.Like, FieldValue = key }),
  47. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or, new ConditionalModel() { FieldName = "F_Remark", ConditionalType = ConditionalType.Like, FieldValue = key })
  48. }
  49. });
  50. }
  51. #endregion
  52. int recordCount = 0;
  53. var list = await _sys_calldutynumberRepository.GetListViewByPage(conModels, new MyPageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount }, "F_CreateOn desc");
  54. return Success("成功", list);
  55. }
  56. /// <summary>
  57. /// 获取实体
  58. /// </summary>
  59. [HttpGet("getdetails")]
  60. public async Task<IActionResult> GetDetails(int id)
  61. {
  62. if (id <= 0)
  63. return Error("获取参数失败");
  64. var dModel = await _sys_calldutynumberRepository.GetSingle(x => x.F_ID == id && x.F_State == (int)EnumDelState.Enabled);
  65. if (dModel != null)
  66. {
  67. return Success("获取成功", dModel);
  68. }
  69. else
  70. {
  71. return Error("获取失败");
  72. }
  73. }
  74. /// <summary>
  75. /// 添加
  76. /// </summary>
  77. [HttpPost("add")]
  78. public async Task<IActionResult> Add(CallDutyNumberInput input)
  79. {
  80. #region 验证
  81. if (string.IsNullOrWhiteSpace(input.dutynumber))
  82. {
  83. return Error("值班电话不能为空");
  84. }
  85. if (input.groupid <= 0)
  86. {
  87. return Error("请选择坐席组");
  88. }
  89. DateTime st = new DateTime();
  90. if (!DateTime.TryParse(input.dutytime, out st))
  91. return Error("值班时间格式不正确");
  92. #endregion
  93. T_Sys_CallDutyNumber clmodel = new T_Sys_CallDutyNumber();
  94. clmodel.F_DutyNumber = input.dutynumber;
  95. clmodel.F_Groupid = input.groupid;
  96. clmodel.F_ZBTime = input.dutytime;
  97. clmodel.F_Remark = input.remark;
  98. clmodel.F_CreateBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value; //"8000";
  99. clmodel.F_CreateOn = DateTime.Now;
  100. clmodel.F_State = (int)EnumDelState.Enabled;
  101. var res = await _sys_calldutynumberRepository.Add(clmodel);
  102. if (res > 0)
  103. return Success("保存成功");
  104. else
  105. {
  106. return Error("保存失败");
  107. }
  108. }
  109. /// <summary>
  110. /// 修改
  111. /// </summary>
  112. [HttpPost("update")]
  113. public async Task<IActionResult> Edit(CallDutyNumberInput input)
  114. {
  115. #region
  116. if (input.id <= 0)
  117. return Error("请选择要编辑的数据");
  118. if (string.IsNullOrWhiteSpace(input.dutynumber))
  119. {
  120. return Error("值班电话不能为空");
  121. }
  122. if (input.groupid<=0)
  123. {
  124. return Error("请选择坐席组");
  125. }
  126. DateTime st = new DateTime();
  127. if (!DateTime.TryParse(input.dutytime, out st))
  128. return Error("值班时间格式不正确");
  129. #endregion
  130. var clmodel = await _sys_calldutynumberRepository.GetSingle(x => x.F_ID == input.id && x.F_State == (int)EnumDelState.Enabled);
  131. if (clmodel == null)
  132. return Error("信息获取失败");
  133. clmodel.F_DutyNumber = input.dutynumber;
  134. clmodel.F_Groupid = input.groupid;
  135. clmodel.F_ZBTime = input.dutytime;
  136. clmodel.F_Remark = input.remark;
  137. clmodel.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  138. clmodel.F_LastModifyOn = DateTime.Now;
  139. var res = await _sys_calldutynumberRepository.Update(clmodel);
  140. if (res)
  141. return Success("保存成功");
  142. else
  143. {
  144. return Error("保存失败");
  145. }
  146. }
  147. [HttpPost("delete")]
  148. public async Task<IActionResult> Remove(int[] ids)
  149. {
  150. //使用逻辑删除
  151. //物理删除的数据无法恢复
  152. var res = 0;
  153. if (ids != null && ids.Length > 0)
  154. {
  155. foreach (var item in ids)
  156. {
  157. var ml = await _sys_calldutynumberRepository.GetSingle(x => x.F_ID == item);
  158. ml.F_State = (int)EnumDelState.Delete;
  159. ml.F_DeleteBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  160. ml.F_DeleteOn = DateTime.Now;
  161. if (await _sys_calldutynumberRepository.Update(ml))
  162. res += 1;
  163. }
  164. if (res == ids.Length)
  165. return Success("删除成功");
  166. else if (res > 0 && res < ids.Length)
  167. return Error("部分删除失败,请查看后重新操作");
  168. else
  169. return Error("删除失败,请查看后重新操作");
  170. }
  171. else
  172. return Error("请选择要删除的记录");
  173. }
  174. }
  175. }