Handler.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. using Application.Abstractions.Data;
  2. using SharedKernel;
  3. using SharedKernel.Extensions;
  4. using MediatR;
  5. using Microsoft.EntityFrameworkCore;
  6. using Microsoft.Extensions.Options;
  7. namespace Application.Features.Faq.Item.Search
  8. {
  9. public sealed class Handler(IAppDbContext db, IOptions<AppSettings> settings) : IRequestHandler<Query, Response>
  10. {
  11. public async Task<Response> Handle(Query request, CancellationToken ct)
  12. {
  13. var query = db.FaqItem.AsNoTracking().Include(i => i.FaqCategory).AsQueryable();
  14. if (request.CategoryID.HasValue)
  15. {
  16. query = query.Where(i => i.CategoryID == request.CategoryID.Value);
  17. }
  18. if (!string.IsNullOrWhiteSpace(request.Keyword))
  19. {
  20. var keyword = request.Keyword!.Trim();
  21. query = query.Where(i =>
  22. EF.Functions.Like(i.Question, $"%{keyword}%") ||
  23. EF.Functions.Like(i.Answer, $"%{keyword}%"));
  24. }
  25. var total = await query.CountAsync(ct);
  26. var list = await query
  27. .OrderBy(i => i.Order)
  28. .ThenByDescending(i => i.ID)
  29. .Skip((request.Page - 1) * request.PerPage)
  30. .Take(request.PerPage)
  31. .Select(c => new
  32. {
  33. c.ID,
  34. c.CategoryID,
  35. CategoryCode = c.FaqCategory.Code,
  36. CategorySubject = c.FaqCategory.Subject,
  37. c.Question,
  38. c.Answer,
  39. c.Order,
  40. c.IsActive,
  41. c.UpdatedAt,
  42. c.CreatedAt
  43. })
  44. .OrderByDescending(c => c.ID)
  45. .ToListAsync(ct);
  46. return new Response
  47. {
  48. Total = total,
  49. List = [..list.Select((c, i) => new Response.Item
  50. {
  51. Num = total - ((request.Page - 1) * request.PerPage) - i,
  52. ID = c.ID,
  53. CategoryID = c.CategoryID,
  54. CategoryCode = c.CategoryCode,
  55. CategorySubject = c.CategorySubject,
  56. Question = c.Question,
  57. Answer = c.Answer,
  58. Order = c.Order,
  59. IsActive = c.IsActive,
  60. UpdatedAt = c.UpdatedAt.GetDateAt(),
  61. CreatedAt = c.CreatedAt.GetDateAt()
  62. })]
  63. };
  64. }
  65. }
  66. }