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

DictionaryController.cs 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  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.System
  14. {
  15. [Authorize]
  16. [Produces("application/json")]
  17. [Route("api/[controller]")]
  18. public class DictionaryController : BaseController
  19. {
  20. private readonly ISys_DictionaryValueRepository _sys_dictionaryRepository;
  21. public DictionaryController(ISys_DictionaryValueRepository sys_dictionaryRepository)
  22. {
  23. _sys_dictionaryRepository = sys_dictionaryRepository;
  24. }
  25. /// <summary>
  26. /// 获取字典下拉列表
  27. /// </summary>
  28. /// <returns></returns>
  29. [HttpGet("getlistdrop")]
  30. public async Task<IActionResult> GetListDropAsync(string code, bool isleaf = false)
  31. {
  32. List<IConditionalModel> conModels = new List<IConditionalModel>();
  33. #region 条件筛选
  34. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  35. conModels.Add(new ConditionalModel() { FieldName = "F_IsLeaf", ConditionalType = ConditionalType.Equal, FieldValue = isleaf.ToString() });
  36. if (!string.IsNullOrEmpty(code))
  37. conModels.Add(new ConditionalModel() { FieldName = "F_ValueCode", ConditionalType = ConditionalType.Equal, FieldValue = code });
  38. #endregion
  39. var list = await _sys_dictionaryRepository.GetListALL(conModels, "F_Sort Asc");
  40. var result = list.Select(x => new {
  41. x.F_ValueId,
  42. x.F_ValueCode,
  43. x.F_Value,
  44. x.F_Sort
  45. });
  46. return Success("获取下拉数据成功", result);
  47. }
  48. /// <summary>
  49. /// 获取字典列表 by page
  50. /// </summary>
  51. /// <param name="keyword"></param>
  52. /// <param name="pageindex"></param>
  53. /// <param name="pagesize"></param>
  54. /// <returns></returns>
  55. [HttpGet("getlistbypage")]
  56. public async Task<IActionResult> GetListsByPageAsync(string keyword,string code, bool isleaf = false, int pageindex = 1, int pagesize = 20)
  57. {
  58. List<IConditionalModel> conModels = new List<IConditionalModel>();
  59. #region 条件筛选
  60. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  61. conModels.Add(new ConditionalModel() { FieldName = "F_IsLeaf", ConditionalType = ConditionalType.Equal, FieldValue = isleaf==true?"1":"0" });
  62. if(!string.IsNullOrEmpty(code))
  63. conModels.Add(new ConditionalModel() { FieldName = "F_ValueCode", ConditionalType = ConditionalType.Equal, FieldValue = code });
  64. if (!string.IsNullOrEmpty(keyword))
  65. {
  66. conModels.Add(new ConditionalCollections()
  67. {
  68. ConditionalList = new List<KeyValuePair<WhereType, ConditionalModel>>()
  69. {
  70. new KeyValuePair<WhereType, ConditionalModel>(WhereType.And, new ConditionalModel() { FieldName = "F_ValueCode", ConditionalType = ConditionalType.Like, FieldValue = keyword }),
  71. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or , new ConditionalModel() { FieldName = "F_Value", ConditionalType = ConditionalType.Like, FieldValue = keyword })
  72. }
  73. });
  74. }
  75. #endregion
  76. int recordCount = 0;
  77. var list = await _sys_dictionaryRepository.GetListByPage(conModels, new MyPageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount }, "F_Sort desc");
  78. return Success("获取列表成功", list);
  79. }
  80. /// <summary>
  81. /// 获取字典详情 by id
  82. /// </summary>
  83. /// <param name="id">id</param>
  84. /// <returns></returns>
  85. [HttpGet("getdetails")]
  86. public async Task<IActionResult> GetDetailsAsync(int id,bool isleaf = false)
  87. {
  88. if (id <= 0)
  89. return Error("参数错误");
  90. var model = await _sys_dictionaryRepository.GetSingle(x => x.F_ValueId == id && x.F_State == (int)EnumDelState.Enabled && x.F_IsLeaf == isleaf);
  91. if (model == null)
  92. return Success("获取失败", null);
  93. var result = new
  94. {
  95. id=model.F_ValueId,
  96. code=model.F_ValueCode,
  97. name=model.F_Value,
  98. des=model.F_Remark,
  99. sort=model.F_Sort,
  100. pid=model.F_ParentId,
  101. isleaf=model.F_IsLeaf
  102. };
  103. return Success("获取成功!", result);
  104. }
  105. /// <summary>
  106. /// 获取字段详情 by name
  107. /// </summary>
  108. /// <param name="name"></param>
  109. /// <param name="isleaf"></param>
  110. /// <returns></returns>
  111. [HttpGet("getdetailsbyname")]
  112. public async Task<IActionResult> GetDetailsByNameAsync(string name, bool isleaf = false)
  113. {
  114. if (string.IsNullOrEmpty(name))
  115. return Error("参数错误");
  116. var model = await _sys_dictionaryRepository.GetSingle(x => x.F_Value == name && x.F_State == (int)EnumDelState.Enabled && x.F_IsLeaf == isleaf);
  117. if (model == null)
  118. return Success("获取失败", null);
  119. var result = new
  120. {
  121. id = model.F_ValueId,
  122. code = model.F_ValueCode,
  123. name = model.F_Value,
  124. des = model.F_Remark,
  125. sort = model.F_Sort,
  126. pid = model.F_ParentId,
  127. isleaf = model.F_IsLeaf
  128. };
  129. return Success("获取成功!", result);
  130. }
  131. /// <summary>
  132. /// 添加字典信息
  133. /// </summary>
  134. /// <param name="input"></param>
  135. /// <returns></returns>
  136. [HttpPost("add")]
  137. public async Task<IActionResult> AddAsync(DictionaryInput input)
  138. {
  139. if (string.IsNullOrEmpty(input.code))
  140. return Error("字典标识不能为空");
  141. if (string.IsNullOrEmpty(input.name))
  142. return Error("字典名称不能为空");
  143. if (input.isleaf)
  144. {
  145. long n = await _sys_dictionaryRepository.GetCount(x => x.F_State == (int)EnumDelState.Enabled && x.F_ValueCode == input.code && x.F_Value==input.name && x.F_IsLeaf == input.isleaf);
  146. if (n > 0)
  147. return Error("字典名称已存在");
  148. }
  149. else
  150. {
  151. long n = await _sys_dictionaryRepository.GetCount(x => x.F_State == (int)EnumDelState.Enabled && x.F_ValueCode == input.code && x.F_IsLeaf == input.isleaf);
  152. if (n > 0)
  153. return Error("字典标识已存在");
  154. }
  155. var model = new T_Sys_DictionaryValue();
  156. model.F_ValueCode = input.code;
  157. model.F_Value = input.name;
  158. model.F_IsLeaf = input.isleaf;
  159. if(input.isleaf)
  160. {
  161. model.F_ParentCode = input.code;
  162. }
  163. model.F_ParentId = input.pid;
  164. model.F_Remark = input.describe;
  165. model.F_Sort = input.sort;
  166. model.F_State = (int)EnumDelState.Enabled;
  167. model.F_CreateOn = DateTime.Now;
  168. model.F_CreateBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  169. int b = await _sys_dictionaryRepository.Add(model);
  170. if (b > 0)
  171. return Success("字典添加成功");
  172. else
  173. return Error("字典添加失败");
  174. }
  175. /// <summary>
  176. /// 修改字典信息
  177. /// </summary>
  178. /// <param name="input"></param>
  179. /// <returns></returns>
  180. [HttpPost("update")]
  181. public async Task<IActionResult> UpdateAsync(DictionaryInput input)
  182. {
  183. if (string.IsNullOrEmpty(input.code))
  184. return Error("字典标识不能为空");
  185. if (string.IsNullOrEmpty(input.name))
  186. return Error("字典名称不能为空");
  187. if (input.id <= 0)
  188. return Error("参数错误");
  189. var model = new T_Sys_DictionaryValue();
  190. model = await _sys_dictionaryRepository.GetSingle(x => x.F_ValueId == input.id && x.F_State == (int)EnumDelState.Enabled);
  191. if (model == null)
  192. return Error("操作失败");
  193. model.F_Value = input.name;
  194. model.F_Sort = input.sort;
  195. model.F_Remark = input.describe;
  196. model.F_LastModifyOn = DateTime.Now;
  197. model.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  198. bool b = await _sys_dictionaryRepository.Update(model);
  199. if (b)
  200. return Success("字典修改成功");
  201. else
  202. return Error("字典修改失败");
  203. }
  204. /// <summary>
  205. /// 删除字典信息 by ids
  206. /// </summary>
  207. /// <param name="ids">string[] id</param>
  208. /// <returns></returns>
  209. [HttpPost("delete")]
  210. public async Task<IActionResult> DeleteAsync(int[] ids)
  211. {
  212. int num = 0;
  213. if (ids == null && ids.Length <= 0)
  214. return Error("请选择要删除的记录");
  215. var leafcount = await _sys_dictionaryRepository.GetCount(x => x.F_State == (int)EnumDelState.Enabled && ids.Contains(x.F_ParentId.Value));
  216. if (leafcount > 0)
  217. return Error("请先清理子节点");
  218. foreach (var item in ids)
  219. {
  220. var model = await _sys_dictionaryRepository.GetSingle(x => x.F_ValueId == item);
  221. model.F_State = (int)EnumDelState.Delete;
  222. model.F_DeleteOn = DateTime.Now;
  223. model.F_DeleteBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  224. if (await _sys_dictionaryRepository.Update(model))
  225. num += 1;
  226. }
  227. if (num == ids.Length)
  228. return Success("删除成功");
  229. if (num > 0 && num < ids.Length)
  230. return Error("部分删除失败,请查看后重新操作");
  231. return Error("删除失败,请查看后重新操作");
  232. }
  233. }
  234. }