AnalyzeService.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. using System.Linq;
  2. using System.Threading.Tasks;
  3. using AutoMapper;
  4. using Datory;
  5. using GxPress.Common.Exceptions;
  6. using GxPress.Common.Page;
  7. using GxPress.Common.Tools;
  8. using GxPress.Repository.Interface;
  9. using GxPress.Repository.Interface.Analyze;
  10. using GxPress.Request.Analyze;
  11. using GxPress.Request.App.Analyze;
  12. using GxPress.Result.App.Analyze;
  13. using GxPress.Service.Interface.Analyze;
  14. using GxPress.Service.Interface.Praise;
  15. namespace GxPress.Service.Implement.Analyze
  16. {
  17. public class AnalyzeService : IAnalyzeService
  18. {
  19. private readonly IUserRepository _userRepository;
  20. private readonly IAnalyzeRepository _repository;
  21. private readonly ICommentRepository _commentRepository;
  22. private readonly IDepartmentRepository _departmentRepository;
  23. private readonly IMapper _mapper;
  24. private readonly IPraiseService praiseService;
  25. public AnalyzeService(IUserRepository userRepository,
  26. IAnalyzeRepository analyzeRepository,
  27. ICommentRepository commentRepository,
  28. IMapper mapper, IDepartmentRepository departmentRepository,
  29. IPraiseService praiseService)
  30. {
  31. _userRepository = userRepository;
  32. _repository = analyzeRepository;
  33. _commentRepository = commentRepository;
  34. _departmentRepository = departmentRepository;
  35. _mapper = mapper;
  36. this.praiseService = praiseService;
  37. }
  38. /// <summary>
  39. /// 设置 点赞 转发 收藏
  40. /// </summary>
  41. /// <param name="request"></param>
  42. /// <returns></returns>
  43. public async Task<bool> SetAnalyzeAsync(AnalyzeRequest request)
  44. {
  45. var user = await _userRepository.GetAsync(request.UserId);
  46. if (user == null) throw new BusinessException("不存在该账号");
  47. //查询该用户是否存在记录
  48. var query = new SqlKata.Query();
  49. query
  50. .Where(nameof(Entity.Analyze.Analyze.AnalyzeType), request.AnalyzeType)
  51. .Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId)
  52. .Where(nameof(Entity.Analyze.Analyze.UserId), request.UserId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue);
  53. if (request.SourceUserId > 0)
  54. query.Where(nameof(Entity.Analyze.Analyze.SourceUserId), request.SourceUserId);
  55. var analyze = await _repository.GetAsync(query);
  56. if (analyze != null && analyze.Id > 0 && analyze.AnalyzeType != 4)
  57. {
  58. return await _repository.DeleteAsync(analyze.Id);
  59. }
  60. //添加
  61. var analyzeDto = new Entity.Analyze.Analyze();
  62. analyzeDto.SourceId = request.SourceId;
  63. analyzeDto.UserId = request.UserId;
  64. analyzeDto.AnalyzeType = request.AnalyzeType;
  65. analyzeDto.TypeValue = request.TypeValue;
  66. analyzeDto.CommentId = request.CommentId;
  67. analyzeDto.SourceUserId = request.SourceUserId;
  68. var commit = new Entity.Comment();
  69. //修改文章评论的点赞数量
  70. if (request.CommentId > 0)
  71. {
  72. query = Q.NewQuery();
  73. query.Where(nameof(Entity.Comment.TypeValue), request.TypeValue);
  74. query.Where(nameof(Entity.Comment.ArticleId), request.SourceId);
  75. query.Where(nameof(Entity.Comment.Id), request.CommentId);
  76. //查询评论
  77. commit = await _commentRepository.GetAsync(query);
  78. commit.Laud = await _repository.CountAsync(Q.Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue).Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId));
  79. await _commentRepository.UpdateAsync(commit);
  80. }
  81. return await _repository.InsertAsync(analyzeDto) > 0;
  82. }
  83. /// <summary>
  84. /// 获取点赞数据
  85. /// </summary>
  86. /// <param name="request"></param>
  87. /// <returns></returns>
  88. public async Task<PagedList<PraisePageResult>> GetPraisePageAsync(PraisePageSearchRequest request)
  89. {
  90. var query = Q.NewQuery();
  91. query.Where(nameof(Entity.Analyze.Analyze.AnalyzeType), 1).Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue);
  92. if (request.Sort == "desc")
  93. query.OrderByDesc(nameof(Entity.Analyze.Analyze.CreatedDate));
  94. var pagedList = new PagedList<PraisePageResult>
  95. {
  96. Total = await _repository.CountAsync(query)
  97. };
  98. var list = await _repository.GetAllAsync(query.ForPage(request.Page, request.PerPage));
  99. var items = list.Select(user => _mapper.Map<PraisePageResult>(user)).ToList();
  100. for (int i = 0; i < items.Count; i++)
  101. {
  102. //获取用户
  103. var user = await _userRepository.GetAsync(items[i].UserId);
  104. if (user == null)
  105. {
  106. items.Remove(items[i]);
  107. continue;
  108. }
  109. items[i].UserName = user.Name;
  110. items[i].Signature = user.Signature;
  111. items[i].AvatarUrl = StringUtils.AddDomainMin(user.AvatarUrl);
  112. //获取部门
  113. var department = await _departmentRepository.GetAsync(user.DepartmentId);
  114. items[i].DepartmentName = department != null ? department.Name : "";
  115. }
  116. // foreach (var item in items)
  117. // {
  118. // //获取用户
  119. // var user = await _userRepository.GetAsync(item.UserId);
  120. // item.UserName = user.Name;
  121. // item.Signature = user.Signature;
  122. // item.AvatarUrl = StringUtils.AddDomainMin(user.AvatarUrl);
  123. // //获取部门
  124. // var department = await _departmentRepository.GetAsync(user.DepartmentId);
  125. // item.DepartmentName = department != null ? department.Name : "";
  126. // }
  127. pagedList.Items = items;
  128. return pagedList;
  129. }
  130. /// <summary>
  131. /// 是否存在
  132. /// </summary>
  133. /// <param name="request"></param>
  134. /// <returns></returns>
  135. public async Task<bool> ExistsAsync(AnalyzeRequest request)
  136. {
  137. return await _repository.ExistsAsync(Q.Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue).Where(nameof(Entity.Analyze.Analyze.UserId), request.UserId).Where(nameof(Entity.Analyze.Analyze.AnalyzeType), request.AnalyzeType).Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId));
  138. }
  139. /// <summary>
  140. /// 是否存在
  141. /// </summary>
  142. /// <param name="request"></param>
  143. /// <returns></returns>
  144. public async Task<bool> ExistsSourceUserAsync(AnalyzeRequest request)
  145. {
  146. return await _repository.ExistsAsync(Q.Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue).Where(nameof(Entity.Analyze.Analyze.UserId), request.UserId).Where(nameof(Entity.Analyze.Analyze.AnalyzeType), request.AnalyzeType).Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId).Where(nameof(Entity.Analyze.Analyze.SourceUserId), request.SourceUserId));
  147. }
  148. /// <summary>
  149. /// 条数
  150. /// </summary>
  151. /// <param name="request"></param>
  152. /// <returns></returns>
  153. public async Task<int> CountAsync(AnalyzeRequest request)
  154. {
  155. var query = new SqlKata.Query("tede_analyze");
  156. query.Join("tede_user", "tede_user.Id", "tede_analyze.UserId");
  157. query.Where("tede_analyze.SourceId", request.SourceId);
  158. query.Where("tede_analyze.TypeValue", request.TypeValue);
  159. query.Where("tede_analyze.AnalyzeType", request.AnalyzeType);
  160. query.Where("tede_analyze.CommentId", request.CommentId);
  161. query.Where("tede_user.IsDelete", false);
  162. return await _repository.CountAsync(query);
  163. }
  164. /// <summary>
  165. /// 转发数量
  166. /// </summary>
  167. /// <param name="request"></param>
  168. /// <returns></returns>
  169. public async Task<int> RetransmissionCountAsync(AnalyzeRequest request)
  170. {
  171. return await _repository.CountAsync(Q.Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId).Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue).Where(nameof(Entity.Analyze.Analyze.AnalyzeType), request.AnalyzeType).Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId).Where(nameof(Entity.Analyze.Analyze.SourceUserId), request.SourceUserId));
  172. }
  173. /// <summary>
  174. /// 获取
  175. /// </summary>
  176. /// <param name="request"></param>
  177. /// <returns></returns>
  178. public async Task<Entity.Analyze.Analyze> GetAnalyzeAsync(AnalyzeRequest request)
  179. {
  180. var query = new SqlKata.Query();
  181. query.Where(nameof(Entity.Analyze.Analyze.SourceId), request.SourceId);
  182. query.Where(nameof(Entity.Analyze.Analyze.TypeValue), request.TypeValue);
  183. query.Where(nameof(Entity.Analyze.Analyze.AnalyzeType), request.AnalyzeType);
  184. query.Where(nameof(Entity.Analyze.Analyze.CommentId), request.CommentId);
  185. query.Where(nameof(Entity.Analyze.Analyze.UserId), request.UserId);
  186. if (request.SourceUserId > 0)
  187. query.Where(nameof(Entity.Analyze.Analyze.SourceUserId), request.SourceUserId);
  188. return await _repository.GetAsync(query);
  189. }
  190. public async Task<bool> DeleteAsync(int id)
  191. {
  192. return await _repository.DeleteAsync(id);
  193. }
  194. }
  195. }