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

SeatGroupController.cs 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Common;
  4. using System.IRepositories;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Model;
  8. using System.Security.Claims;
  9. using System.Threading.Tasks;
  10. using Microsoft.AspNetCore.Authorization;
  11. using Microsoft.AspNetCore.Mvc;
  12. using SqlSugar;
  13. using TVShoppingCallCenter_ZLJ.Models.Inputs;
  14. namespace TVShoppingCallCenter_ZLJ.Controllers.System
  15. {
  16. [Authorize]
  17. [Produces("application/json")]
  18. [Route("api/[controller]")]
  19. public class SeatGroupController : BaseController
  20. {
  21. private readonly ISys_SeatGroupRepository _sys_seatgroupRepository;
  22. public SeatGroupController(ISys_SeatGroupRepository sys_seatgroupRepository)
  23. {
  24. _sys_seatgroupRepository = sys_seatgroupRepository;
  25. }
  26. /// <summary>
  27. /// 获取坐席组列表
  28. /// </summary>
  29. /// <param name="filter"></param>
  30. /// <returns></returns>
  31. [Authorize]
  32. [HttpGet("getlistbypage")]
  33. public async Task<IActionResult> GetListsByPage(string key, 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. List<IConditionalModel> conModels1 = new List<IConditionalModel>();
  39. if (!string.IsNullOrEmpty(key))
  40. {
  41. conModels.Add(new ConditionalCollections()
  42. {
  43. ConditionalList = new List<KeyValuePair<WhereType, ConditionalModel>>()
  44. {
  45. new KeyValuePair<WhereType, ConditionalModel>(WhereType.And, new ConditionalModel() { FieldName = "F_ZXZName", ConditionalType = ConditionalType.Like, FieldValue = key }),
  46. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or , new ConditionalModel() { FieldName = "F_ZXZCode", ConditionalType = ConditionalType.Like, FieldValue = key }),
  47. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or, new ConditionalModel() { FieldName = "F_ZXAtt", ConditionalType = ConditionalType.Like, FieldValue = key })
  48. }
  49. });
  50. }
  51. #endregion
  52. int recordCount = 0;
  53. var list = await _sys_seatgroupRepository.GetListByPage(conModels, new MyPageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount }, "F_CreateOn desc");
  54. return Success("成功", list);
  55. }
  56. [Authorize]
  57. [HttpGet("getlist")]
  58. public async Task<IActionResult> GetList(string key)
  59. {
  60. List<IConditionalModel> conModels = new List<IConditionalModel>();
  61. #region 条件筛选
  62. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  63. if (!string.IsNullOrEmpty(key))
  64. {
  65. conModels.Add(new ConditionalCollections()
  66. {
  67. ConditionalList = new List<KeyValuePair<WhereType, ConditionalModel>>()
  68. {
  69. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or , new ConditionalModel() { FieldName = "F_ZXZCode", ConditionalType = ConditionalType.Like, FieldValue = key }),
  70. new KeyValuePair<WhereType, ConditionalModel>(WhereType.Or, new ConditionalModel() { FieldName = "F_ZXZName", ConditionalType = ConditionalType.Like, FieldValue = key }),
  71. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or, new ConditionalModel() { FieldName = "F_ZXAtt", ConditionalType = ConditionalType.Like, FieldValue = key })
  72. }
  73. });
  74. }
  75. #endregion
  76. var list = await _sys_seatgroupRepository.GetListALL(conModels, "F_CreateOn desc");
  77. return Success("根据条件获取数据成功", list);
  78. }
  79. /// <summary>
  80. /// 获取实体
  81. /// </summary>
  82. [Authorize]
  83. [HttpGet("getdetails")]
  84. public async Task<IActionResult> GetDetails(int id)
  85. {
  86. if (id > 0)
  87. {
  88. var dModel = await _sys_seatgroupRepository.GetSingle(x => x.F_ZXZID == id);
  89. if (dModel != null)
  90. {
  91. return Success("获取坐席组成功", dModel);
  92. }
  93. else
  94. {
  95. return Error("获取坐席组失败");
  96. }
  97. }
  98. else
  99. {
  100. return Error("获取参数失败");
  101. }
  102. }
  103. /// <summary>
  104. /// 添加坐席组
  105. /// </summary>
  106. [Authorize]
  107. [HttpPost("add")]
  108. public async Task<IActionResult> Add(SeatGroupInput input)
  109. {
  110. #region 验证
  111. if (string.IsNullOrWhiteSpace(input.zxzcode))
  112. {
  113. return Error("编号不能为空");
  114. }
  115. if (string.IsNullOrWhiteSpace(input.zxzname))
  116. {
  117. return Error("名称不能为空");
  118. }
  119. if (string.IsNullOrWhiteSpace(input.zxatt))
  120. {
  121. return Error("坐席地区号不能为空");
  122. }
  123. if (string.IsNullOrWhiteSpace(input.whwdkey))
  124. {
  125. return Error("外呼外地前缀不能为空");
  126. }
  127. if (string.IsNullOrWhiteSpace(input.whbdkey))
  128. {
  129. return Error("外呼本地前缀不能为空");
  130. }
  131. if (!ValidateString.IsNumberStr(input.whwdkey.Trim().ToString()))
  132. {
  133. return Error("外呼外地前缀必须为数字");
  134. }
  135. if (!ValidateString.IsNumberStr(input.whbdkey.Trim().ToString()))
  136. {
  137. return Error("外呼本地前缀必须为数字");
  138. }
  139. if (await GetExistByCodeAsync(input.zxzcode, 0) || await GetExistByNameAsync(input.zxzname, 0))
  140. {
  141. return Error("坐席组编号和名称必须唯一,请重新输入!");
  142. }
  143. #endregion
  144. T_Sys_SeatGroup clmodel = new T_Sys_SeatGroup();
  145. clmodel.F_ZXZCode = input.zxzcode.Trim();
  146. clmodel.F_IVRKey = input.ivrkey;
  147. clmodel.F_ZXZName = input.zxzname.Trim();
  148. clmodel.F_ZXAtt = input.zxatt.Trim();
  149. clmodel.F_WHWDKey = input.whwdkey.Trim();
  150. clmodel.F_WHBDKey = input.whbdkey.Trim();
  151. clmodel.F_Des = input.des;
  152. clmodel.F_CreateBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value; //"8000";
  153. clmodel.F_CreateOn = DateTime.Now;
  154. clmodel.F_State = (int)EnumDelState.Enabled;
  155. var res = await _sys_seatgroupRepository.Add(clmodel);
  156. if (res > 0)
  157. return Success("坐席组保存成功");
  158. else
  159. {
  160. return Error("坐席组保存失败");
  161. }
  162. }
  163. /// <summary>
  164. /// 修改坐席组
  165. /// </summary>
  166. [Authorize]
  167. [HttpPost("update")]
  168. public async Task<IActionResult> Edit(SeatGroupInput input)
  169. {
  170. #region
  171. if (input.id <= 0)
  172. return Error("请选择要编辑的坐席组");
  173. if (string.IsNullOrWhiteSpace(input.whwdkey))
  174. return Error("外呼外地前缀不能为空");
  175. if (string.IsNullOrWhiteSpace(input.whbdkey))
  176. return Error("外呼本地前缀不能为空");
  177. if (!ValidateString.IsNumberStr(input.whwdkey.Trim().ToString()))
  178. {
  179. return Error("外呼外地前缀必须为数字");
  180. }
  181. if (!ValidateString.IsNumberStr(input.whbdkey.Trim().ToString()))
  182. {
  183. return Error("外呼本地前缀必须为数字");
  184. }
  185. if (await GetExistByCodeAsync(input.zxzcode, input.id) || await GetExistByNameAsync(input.zxzname, input.id))
  186. {
  187. return Error("坐席组编号和名称必须唯一,请重新输入!");
  188. }
  189. #endregion
  190. var res = false;
  191. var clmodel = await _sys_seatgroupRepository.GetSingle(x => x.F_ZXZID == input.id);
  192. if (clmodel != null)
  193. {
  194. clmodel.F_ZXZCode = input.zxzcode.Trim();
  195. clmodel.F_ZXZName = input.zxzname.Trim();
  196. clmodel.F_ZXAtt = input.zxatt.Trim();
  197. clmodel.F_WHWDKey = input.whwdkey.Trim();
  198. clmodel.F_WHBDKey = input.whbdkey.Trim();
  199. clmodel.F_IVRKey = input.ivrkey;
  200. clmodel.F_Des = input.des;
  201. clmodel.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  202. clmodel.F_LastModifyOn = DateTime.Now;
  203. res = await _sys_seatgroupRepository.Update(clmodel);
  204. }
  205. if (res)
  206. return Success("坐席组保存成功");
  207. else
  208. {
  209. return Error("坐席组保存失败");
  210. }
  211. }
  212. [Authorize]
  213. [HttpPost("delete")]
  214. public async Task<IActionResult> Remove(int[] ids)
  215. {
  216. //使用逻辑删除
  217. //物理删除的数据无法恢复
  218. var res = 0;
  219. if (ids != null && ids.Length > 0)
  220. {
  221. foreach (var item in ids)
  222. {
  223. var ml = await _sys_seatgroupRepository.GetSingle(x => x.F_ZXZID == item);
  224. ml.F_State = (int)EnumDelState.Delete;
  225. if (await _sys_seatgroupRepository.Update(ml))
  226. res += 1;
  227. }
  228. if (res == ids.Length)
  229. return Success("删除成功");
  230. else if (res > 0 && res < ids.Length)
  231. return Error("部分删除失败,请查看后重新操作");
  232. else
  233. return Error("删除失败,请查看后重新操作");
  234. }
  235. else
  236. return Error("请选择要删除的记录");
  237. }
  238. #region 私有方法
  239. /// <summary>
  240. /// 根据坐席组编号查询是否存在此坐席组编号
  241. /// </summary>
  242. /// <param name="code"></param>
  243. /// <returns></returns>
  244. private async Task<bool> GetExistByCodeAsync(string code, int id)
  245. {
  246. long c = 0;
  247. if (id > 0)
  248. c = await _sys_seatgroupRepository.GetCount(x => x.F_ZXZCode.Equals(code) && x.F_ZXZID != id);
  249. else
  250. c = await _sys_seatgroupRepository.GetCount(x => x.F_ZXZCode.Equals(code));
  251. return c > 0;
  252. }
  253. /// <summary>
  254. /// 根据坐席组名称查询是否存在此坐席组编号
  255. /// </summary>
  256. /// <param name="code"></param>
  257. /// <returns></returns>
  258. private async Task<bool> GetExistByNameAsync(string name, int id)
  259. {
  260. long c = 0;
  261. if (id > 0)
  262. c = await _sys_seatgroupRepository.GetCount(x => x.F_ZXZName.Equals(name) && x.F_ZXZID != id);
  263. else
  264. c = await _sys_seatgroupRepository.GetCount(x => x.F_ZXZName.Equals(name));
  265. return c > 0;
  266. }
  267. #endregion
  268. }
  269. }