SysPosService.cs 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. using Furion.DependencyInjection;
  2. using Furion.DynamicApiController;
  3. using Furion.FriendlyException;
  4. using Mapster;
  5. using Microsoft.AspNetCore.Mvc;
  6. using System.Collections.Generic;
  7. using System.Threading.Tasks;
  8. namespace Admin.NET.Core.Service
  9. {
  10. /// <summary>
  11. /// 系统职位服务
  12. /// </summary>
  13. [ApiDescriptionSettings(Name = "系统职位", Order = 196)]
  14. public class SysPosService : IDynamicApiController, ITransient
  15. {
  16. private readonly SqlSugarRepository<SysPos> _sysPosRep;
  17. private readonly SysUserExtOrgPosService _sysUserExtOrgPosService;
  18. public SysPosService(SqlSugarRepository<SysPos> sysPosRep,
  19. SysUserExtOrgPosService sysUserExtOrgPosService)
  20. {
  21. _sysPosRep = sysPosRep;
  22. _sysUserExtOrgPosService = sysUserExtOrgPosService;
  23. }
  24. /// <summary>
  25. /// 获取职位列表
  26. /// </summary>
  27. /// <param name="input"></param>
  28. /// <returns></returns>
  29. [HttpGet("/sysPos/list")]
  30. public async Task<List<SysPos>> GetPosList([FromQuery] PosInput input)
  31. {
  32. return await _sysPosRep.AsQueryable()
  33. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  34. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
  35. .OrderBy(u => u.Order).ToListAsync();
  36. }
  37. /// <summary>
  38. /// 增加职位
  39. /// </summary>
  40. /// <param name="input"></param>
  41. /// <returns></returns>
  42. [HttpPost("/sysPos/add")]
  43. public async Task AddPos(AddPosInput input)
  44. {
  45. var isExist = await _sysPosRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code);
  46. if (isExist)
  47. throw Oops.Oh(ErrorCodeEnum.D6000);
  48. var pos = input.Adapt<SysPos>();
  49. await _sysPosRep.InsertAsync(pos);
  50. }
  51. /// <summary>
  52. /// 更新职位
  53. /// </summary>
  54. /// <param name="input"></param>
  55. /// <returns></returns>
  56. [HttpPost("/sysPos/update")]
  57. public async Task UpdatePos(UpdatePosInput input)
  58. {
  59. var isExist = await _sysPosRep.IsAnyAsync(u => (u.Name == input.Name || u.Code == input.Code) && u.Id != input.Id);
  60. if (isExist)
  61. throw Oops.Oh(ErrorCodeEnum.D6000);
  62. var pos = input.Adapt<SysPos>();
  63. await _sysPosRep.AsUpdateable(pos).IgnoreColumns(true).ExecuteCommandAsync();
  64. }
  65. /// <summary>
  66. /// 删除职位
  67. /// </summary>
  68. /// <param name="input"></param>
  69. /// <returns></returns>
  70. [HttpPost("/sysPos/delete")]
  71. public async Task DeletePos(DeletePosInput input)
  72. {
  73. // 该职位下是否有用户
  74. var hasPosEmp = await _sysPosRep.ChangeRepository<SqlSugarRepository<SysUser>>()
  75. .IsAnyAsync(u => u.PosId == input.Id);
  76. if (hasPosEmp)
  77. throw Oops.Oh(ErrorCodeEnum.D6001);
  78. // 该附属职位下是否有用户
  79. var hasExtPosEmp = await _sysUserExtOrgPosService.HasExtPosEmp(input.Id);
  80. if (hasExtPosEmp)
  81. throw Oops.Oh(ErrorCodeEnum.D6001);
  82. await _sysPosRep.DeleteAsync(u => u.Id == input.Id);
  83. }
  84. }
  85. }