Handler.cs 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. using Application.Abstractions.Messaging;
  2. using Application.Abstractions.Data;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Admin.Faq.Item.Search
  5. {
  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.FaqItem.AsNoTracking().Include(i => i.FaqCategory).AsQueryable();
  11. if (request.CategoryID.HasValue)
  12. {
  13. query = query.Where(i => i.CategoryID == request.CategoryID.Value);
  14. }
  15. if (!string.IsNullOrWhiteSpace(request.Keyword))
  16. {
  17. var keyword = request.Keyword!.Trim();
  18. query = query.Where(i =>
  19. EF.Functions.Like(i.Question, $"%{keyword}%") ||
  20. EF.Functions.Like(i.Answer, $"%{keyword}%")
  21. );
  22. }
  23. var total = await query.CountAsync(ct);
  24. var list = await query
  25. .OrderBy(i => i.Order)
  26. .ThenByDescending(i => i.ID)
  27. .Skip((request.Page - 1) * request.PerPage)
  28. .Take(request.PerPage)
  29. .Select(c => new
  30. {
  31. c.ID,
  32. c.CategoryID,
  33. CategoryCode = c.FaqCategory.Code,
  34. CategorySubject = c.FaqCategory.Subject,
  35. c.Question,
  36. c.Answer,
  37. c.Order,
  38. c.IsActive,
  39. c.UpdatedAt,
  40. c.CreatedAt
  41. })
  42. .ToListAsync(ct);
  43. return new Response
  44. {
  45. Total = total,
  46. List = [..list.Select((c, i) => new Response.Item
  47. {
  48. Num = total - ((request.Page - 1) * request.PerPage) - i,
  49. ID = c.ID,
  50. CategoryID = c.CategoryID,
  51. CategoryCode = c.CategoryCode,
  52. CategorySubject = c.CategorySubject,
  53. Question = c.Question,
  54. Answer = c.Answer,
  55. Order = c.Order,
  56. IsActive = c.IsActive,
  57. UpdatedAt = c.UpdatedAt,
  58. CreatedAt = c.CreatedAt
  59. })]
  60. };
  61. }
  62. }
  63. }