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

SysConfigController.cs 7.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  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 SysConfigController : BaseController
  19. {
  20. private readonly ISys_SystemConfigRepository _sys_sysconfigRepository;
  21. public SysConfigController(ISys_SystemConfigRepository sys_sysconfigRepository)
  22. {
  23. _sys_sysconfigRepository = sys_sysconfigRepository;
  24. }
  25. /// <summary>
  26. /// 获取基础数据列表
  27. /// </summary>
  28. /// <param name="filter"></param>
  29. /// <returns></returns>
  30. [HttpGet("getlistbypage")]
  31. public async Task<IActionResult> GetListsByPage(string key, int pageindex = 1, int pagesize = 20)
  32. {
  33. List<IConditionalModel> conModels = new List<IConditionalModel>();
  34. #region 条件筛选
  35. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  36. if (!string.IsNullOrEmpty(key))
  37. {
  38. conModels.Add(new ConditionalCollections()
  39. {
  40. ConditionalList = new List<KeyValuePair<WhereType, ConditionalModel>>()
  41. {
  42. new KeyValuePair<WhereType, ConditionalModel>(WhereType.And, new ConditionalModel() { FieldName = "F_ParamCode", ConditionalType = ConditionalType.Like, FieldValue = key }),
  43. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or , new ConditionalModel() { FieldName = "F_ParamValue", ConditionalType = ConditionalType.Like, FieldValue = key }),
  44. new KeyValuePair<WhereType, ConditionalModel>( WhereType.Or, new ConditionalModel() { FieldName = "F_ParamDes", ConditionalType = ConditionalType.Like, FieldValue = key })
  45. }
  46. });
  47. }
  48. #endregion
  49. int recordCount = 0;
  50. var list = await _sys_sysconfigRepository.GetListByPage(conModels, new MyPageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount }, "F_CreateOn desc");
  51. return Success("成功", list);
  52. }
  53. /// <summary>
  54. /// 获取实体
  55. /// </summary>
  56. [HttpGet("getdetails")]
  57. public async Task<IActionResult> GetDetails(int id)
  58. {
  59. if (id > 0)
  60. {
  61. var dModel = await _sys_sysconfigRepository.GetSingle(x => x.F_ParamId == id && x.F_State == (int)EnumDelState.Enabled);
  62. if (dModel != null)
  63. {
  64. return Success("获取基础数据成功", dModel);
  65. }
  66. else
  67. {
  68. return Error("获取基础数据失败");
  69. }
  70. }
  71. else
  72. {
  73. return Error("获取参数失败");
  74. }
  75. }
  76. /// <summary>
  77. /// 添加基础数据
  78. /// </summary>
  79. [HttpPost("add")]
  80. public async Task<IActionResult> Add(SysConfigInput input)
  81. {
  82. #region 验证
  83. if (string.IsNullOrWhiteSpace(input.code))
  84. {
  85. return Error("编号不能为空");
  86. }
  87. if (string.IsNullOrWhiteSpace(input.value))
  88. {
  89. return Error("参数值不能为空");
  90. }
  91. if (await GetExistByCodeAsync(input.code, input.id))
  92. return Error("基础数据编号必须唯一,请重新输入!");
  93. #endregion
  94. T_Sys_SystemConfig clmodel = new T_Sys_SystemConfig();
  95. clmodel.F_ParamCode = input.code.Trim();
  96. clmodel.F_ParamValue = input.value.Trim();
  97. clmodel.F_ParamDes = input.des;
  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_sysconfigRepository.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(SysConfigInput input)
  114. {
  115. #region
  116. if (input.id <= 0)
  117. return Error("请选择要编辑的数据");
  118. if (string.IsNullOrWhiteSpace(input.code))
  119. {
  120. return Error("编号不能为空");
  121. }
  122. if (string.IsNullOrWhiteSpace(input.value))
  123. {
  124. return Error("参数值不能为空");
  125. }
  126. if (await GetExistByCodeAsync(input.code, input.id))
  127. return Error("基础数据编号必须唯一,请重新输入!");
  128. #endregion
  129. var clmodel = await _sys_sysconfigRepository.GetSingle(x => x.F_ParamId == input.id && x.F_State == (int)EnumDelState.Enabled);
  130. if (clmodel == null)
  131. return Error("信息获取失败");
  132. clmodel.F_ParamCode = input.code.Trim();
  133. clmodel.F_ParamValue = input.value.Trim();
  134. clmodel.F_ParamDes = input.des;
  135. clmodel.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  136. clmodel.F_LastModifyOn = DateTime.Now;
  137. var res = await _sys_sysconfigRepository.Update(clmodel);
  138. if (res)
  139. return Success("基础数据保存成功");
  140. else
  141. {
  142. return Error("基础数据保存失败");
  143. }
  144. }
  145. [HttpPost("delete")]
  146. public async Task<IActionResult> Remove(int[] ids)
  147. {
  148. //使用逻辑删除
  149. //物理删除的数据无法恢复
  150. var res = 0;
  151. if (ids != null && ids.Length > 0)
  152. {
  153. foreach (var item in ids)
  154. {
  155. var ml = await _sys_sysconfigRepository.GetSingle(x => x.F_ParamId == item);
  156. ml.F_State = (int)EnumDelState.Delete;
  157. ml.F_DeleteBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  158. ml.F_DeleteOn = DateTime.Now;
  159. if (await _sys_sysconfigRepository.Update(ml))
  160. res += 1;
  161. }
  162. if (res == ids.Length)
  163. return Success("删除成功");
  164. else if (res > 0 && res < ids.Length)
  165. return Error("部分删除失败,请查看后重新操作");
  166. else
  167. return Error("删除失败,请查看后重新操作");
  168. }
  169. else
  170. return Error("请选择要删除的记录");
  171. }
  172. #region 私有方法
  173. /// <summary>
  174. /// 根据基础数据编号查询是否存在此基础数据编号
  175. /// </summary>
  176. /// <param name="code"></param>
  177. /// <returns></returns>
  178. private async Task<bool> GetExistByCodeAsync(string code, int id)
  179. {
  180. long c = 0;
  181. if (id > 0)
  182. c = await _sys_sysconfigRepository.GetCount(x => x.F_ParamCode.Equals(code) && x.F_ParamId != id && x.F_State == (int)EnumDelState.Enabled);
  183. else
  184. c = await _sys_sysconfigRepository.GetCount(x => x.F_ParamCode.Equals(code) && x.F_State == (int)EnumDelState.Enabled);
  185. return c > 0;
  186. }
  187. #endregion
  188. }
  189. }