Handler.cs 2.3 KB

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