Handler.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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.PostReaction.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.PostReaction.AsNoTracking()
  11. .Include(c => c.Board)
  12. .Include(c => c.Post)
  13. .Include(c => c.Member)
  14. .AsQueryable();
  15. if (request.BoardID.HasValue)
  16. {
  17. query = query.Where(c => c.BoardID == request.BoardID.Value);
  18. }
  19. if (request.PostID.HasValue)
  20. {
  21. query = query.Where(c => c.PostID == request.PostID.Value);
  22. }
  23. if (request.Reaction.HasValue)
  24. {
  25. query = query.Where(c => c.Reaction == (Reaction)request.Reaction.Value);
  26. }
  27. if (!string.IsNullOrWhiteSpace(request.StartAt) && DateTime.TryParse(request.StartAt, out var startDate))
  28. {
  29. query = query.Where(c => c.CreatedAt >= startDate);
  30. }
  31. if (!string.IsNullOrWhiteSpace(request.EndAt) && DateTime.TryParse(request.EndAt, out var endDate))
  32. {
  33. query = query.Where(c => c.CreatedAt <= endDate.AddDays(1));
  34. }
  35. query = query.OrderByDescending(c => c.ID);
  36. var total = await query.CountAsync(ct);
  37. var list = await query
  38. .Skip((request.PageNum - 1) * request.PerPage)
  39. .Take(request.PerPage)
  40. .Select(c => new
  41. {
  42. c.ID,
  43. c.BoardID,
  44. BoardName = c.Board.Name,
  45. c.PostID,
  46. PostSubject = c.Post.Subject,
  47. c.MemberID,
  48. MemberName = c.Member.Name,
  49. c.Reaction,
  50. c.IpAddress,
  51. c.CreatedAt
  52. })
  53. .ToListAsync(ct);
  54. var startNum = total - ((request.PageNum - 1) * request.PerPage);
  55. return new Response(
  56. total,
  57. [..list.Select((c, i) => new Response.Row(
  58. Num: startNum - i,
  59. c.ID,
  60. c.BoardID,
  61. c.BoardName,
  62. c.PostID,
  63. c.PostSubject,
  64. c.MemberID,
  65. c.MemberName,
  66. c.Reaction,
  67. c.IpAddress,
  68. c.CreatedAt
  69. ))]
  70. );
  71. }
  72. }