SpecialNumberApplication.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. using MapsterMapper;
  2. using SqlSugar;
  3. using XF.Domain.Authentications;
  4. using XF.Domain.Dependency;
  5. using XF.Domain.Exceptions;
  6. using XF.Domain.Repository;
  7. using Hotline.Repository.SqlSugar.Extensions;
  8. using Hotline.Share.Dtos.Special;
  9. using Hotline.Orders;
  10. namespace Hotline.Application.SpecialNumber
  11. {
  12. public class SpecialNumberApplication : ISpecialNumberApplication, IScopeDependency
  13. {
  14. #region 注册
  15. private readonly IRepository<Hotline.Special.SpecialNumber> _specialNumberRepository;
  16. private readonly ISessionContext _sessionContext;
  17. private readonly IMapper _mapper;
  18. public SpecialNumberApplication(
  19. IRepository<Hotline.Special.SpecialNumber> specialNumberRepository,
  20. ISessionContext sessionContext,
  21. IMapper mapper)
  22. {
  23. _specialNumberRepository = specialNumberRepository;
  24. _sessionContext = sessionContext;
  25. _mapper = mapper;
  26. }
  27. #endregion
  28. #region 特殊号码
  29. #region 特殊号码 - 列表
  30. /// <summary>
  31. /// 特殊号码 - 列表
  32. /// </summary>
  33. /// <param name="dto"></param>
  34. /// <returns></returns>
  35. public ISugarQueryable<Hotline.Special.SpecialNumber> QueryAllSpecialNumberListAsync(SpecialNumberDto dto)
  36. {
  37. //单表分页
  38. var query = _specialNumberRepository.Queryable()
  39. .WhereIF(!string.IsNullOrEmpty(dto.PhoneNumber), x => x.PhoneNumber.Contains(dto.PhoneNumber))
  40. .WhereIF(!string.IsNullOrEmpty(dto.Notes), x => x.Notes.Contains(dto.Notes))
  41. .WhereIF(!string.IsNullOrEmpty(dto.PoliticalIdentityValue), x => x.PoliticalIdentityValue == dto.PoliticalIdentityValue)
  42. .WhereIF(!string.IsNullOrEmpty(dto.PoliticalIdentityName), x => x.PoliticalIdentityName == dto.PoliticalIdentityName)
  43. .WhereIF(dto.CreationTimeStart.HasValue, x => x.CreationTime >= dto.CreationTimeStart)
  44. .WhereIF(dto.CreationTimeEnd.HasValue, x => x.CreationTime <= dto.CreationTimeEnd)
  45. .OrderByIF(dto is { SortField: "creationTime", SortRule: 0 }, x => x.CreationTime, OrderByType.Asc) //创建时间升序
  46. .OrderByIF(dto is { SortField: "creationTime", SortRule: 1 }, x => x.CreationTime, OrderByType.Desc) //创建时间降序
  47. .OrderByIF(string.IsNullOrEmpty(dto.SortField), x => x.CreationTime, OrderByType.Desc) //创建时间降序
  48. ;
  49. return query;
  50. }
  51. #endregion
  52. #region 特殊号码 - 新增
  53. /// <summary>
  54. /// 新增
  55. /// </summary>
  56. /// <param name="dto"></param>
  57. /// <param name="cancellationToken"></param>
  58. /// <returns></returns>
  59. public async Task<string> AddSpecialNumberAsync(AddSpecialNumberDto dto, CancellationToken cancellationToken)
  60. {
  61. var data = _mapper.Map<Hotline.Special.SpecialNumber>(dto);
  62. var any = await _specialNumberRepository.Queryable().Where(x => x.PhoneNumber == dto.PhoneNumber).AnyAsync();
  63. if (any)
  64. throw UserFriendlyException.SameMessage("特殊号码已存在!");
  65. data.InitId();
  66. return await _specialNumberRepository.AddAsync(data, cancellationToken);
  67. }
  68. #endregion
  69. #region 特殊号码 - 修改
  70. /// <summary>
  71. /// 修改
  72. /// </summary>
  73. /// <param name="dto"></param>
  74. /// <param name="cancellationToken"></param>
  75. /// <returns></returns>
  76. public async Task UpdateSpecialNumberAsync(UpdateSpecialNumberDto dto, CancellationToken cancellationToken)
  77. {
  78. var data = await _specialNumberRepository.GetAsync(dto.Id);
  79. if (data == null)
  80. throw UserFriendlyException.SameMessage("特殊号码查询失败");
  81. var any = await _specialNumberRepository.Queryable().Where(x => x.PhoneNumber == dto.PhoneNumber && x.Id != dto.Id).AnyAsync();
  82. if (any)
  83. throw UserFriendlyException.SameMessage("特殊号码已存在!");
  84. data.PhoneNumber = dto.PhoneNumber;
  85. data.Notes = dto.Notes;
  86. data.PoliticalIdentityValue = dto.PoliticalIdentityValue;
  87. data.PoliticalIdentityName = dto.PoliticalIdentityName;
  88. await _specialNumberRepository.UpdateAsync(data, cancellationToken);
  89. }
  90. #endregion
  91. #region 特殊号码 - 删除
  92. /// <summary>
  93. /// 删除
  94. /// </summary>
  95. /// <param name="dto"></param>
  96. /// <param name="cancellationToken"></param>
  97. /// <returns></returns>
  98. public async Task RemoveSpecialNumberAsync(DelSpecialNumberDto dto, CancellationToken cancellationToken)
  99. {
  100. var data = await _specialNumberRepository.GetAsync(dto.Id);
  101. if (data == null)
  102. throw UserFriendlyException.SameMessage("特殊号码查询失败");
  103. await _specialNumberRepository.RemoveAsync(data, false, cancellationToken);
  104. }
  105. #endregion
  106. #region 特殊号码 - 详情
  107. /// <summary>
  108. /// 详情
  109. /// </summary>
  110. /// <param name="Id"></param>
  111. /// <returns></returns>
  112. public async Task<SpecialNumberInfoDto> GetSpecialNumberAsync(string Id, CancellationToken cancellationToken)
  113. {
  114. var data = await _specialNumberRepository.Queryable()
  115. .FirstAsync(x => x.Id == Id, cancellationToken);
  116. if (data == null) return new();
  117. return _mapper.Map<SpecialNumberInfoDto>(data);
  118. }
  119. #endregion
  120. #region 特殊号码 - 详情
  121. /// <summary>
  122. /// 详情
  123. /// </summary>
  124. /// <param name="PhoneNumber"></param>
  125. /// <returns></returns>
  126. public async Task<SpecialNumberInfoDto> GetSpecialNumberByAsync(string PhoneNumber, CancellationToken cancellationToken)
  127. {
  128. var data = await _specialNumberRepository.Queryable()
  129. .FirstAsync(x => x.PhoneNumber == PhoneNumber, cancellationToken);
  130. if (data == null) return new();
  131. return _mapper.Map<SpecialNumberInfoDto>(data);
  132. }
  133. #endregion
  134. #endregion
  135. }
  136. }