Handler.cs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using Domain.Entities.Forum.ValueObject;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Forum.CommentReaction.Search;
  6. public sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Response>
  7. {
  8. public async Task<Response> Handle(Query request, CancellationToken ct)
  9. {
  10. var query = db.CommentReaction.AsNoTracking().Include(c => c.Board).Include(c => c.Post).Include(c => c.Comment).Include(c => c.Member).AsQueryable();
  11. if (request.BoardID.HasValue)
  12. {
  13. query = query.Where(c => c.BoardID == request.BoardID.Value);
  14. }
  15. if (request.PostID.HasValue)
  16. {
  17. query = query.Where(c => c.PostID == request.PostID.Value);
  18. }
  19. if (request.CommentID.HasValue)
  20. {
  21. query = query.Where(c => c.CommentID == request.CommentID.Value);
  22. }
  23. if (!string.IsNullOrWhiteSpace(request.Keyword))
  24. {
  25. var kw = request.Keyword.Trim();
  26. query = request.Search switch
  27. {
  28. 1 => query.Where(c => c.PostID.ToString().Contains(kw)),
  29. 2 => query.Where(c => c.Post.Subject.Contains(kw)),
  30. 3 => query.Where(c => c.Member != null && c.Member.Name != null && c.Member.Name.Contains(kw)),
  31. _ => query.Where(c => c.Post.Subject.Contains(kw))
  32. };
  33. }
  34. if (request.Reaction.HasValue)
  35. {
  36. query = query.Where(c => c.Reaction == (Reaction)request.Reaction.Value);
  37. }
  38. if (!string.IsNullOrWhiteSpace(request.StartAt) && DateTime.TryParse(request.StartAt, out var startDate))
  39. {
  40. query = query.Where(c => c.CreatedAt >= startDate);
  41. }
  42. if (!string.IsNullOrWhiteSpace(request.EndAt) && DateTime.TryParse(request.EndAt, out var endDate))
  43. {
  44. query = query.Where(c => c.CreatedAt <= endDate.AddDays(1));
  45. }
  46. query = query.OrderByDescending(c => c.ID);
  47. var total = await query.CountAsync(ct);
  48. var list = await query
  49. .Skip((request.PageNum - 1) * request.PerPage)
  50. .Take(request.PerPage)
  51. .Select(c => new
  52. {
  53. c.ID,
  54. c.BoardID,
  55. BoardName = c.Board.Name,
  56. c.PostID,
  57. PostSubject = c.Post.Subject,
  58. c.CommentID,
  59. c.MemberID,
  60. MemberName = c.Member.Name,
  61. c.Reaction,
  62. c.IpAddress,
  63. c.CreatedAt
  64. })
  65. .ToListAsync(ct);
  66. var startNum = total - ((request.PageNum - 1) * request.PerPage);
  67. return new Response(
  68. total,
  69. [..list.Select((c, i) => new Response.Row(
  70. Num: startNum - i,
  71. c.ID,
  72. c.BoardID,
  73. c.BoardName,
  74. c.PostID,
  75. c.PostSubject,
  76. c.CommentID,
  77. c.MemberID,
  78. c.MemberName,
  79. c.Reaction,
  80. c.IpAddress,
  81. c.CreatedAt
  82. ))]
  83. );
  84. }
  85. }