Handler.cs 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using Application.Abstractions.Data;
  2. using MediatR;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Faq.Category.GetAll
  5. {
  6. public sealed class Handler(IAppDbContext db) : IRequestHandler<Query, Response>
  7. {
  8. public async Task<Response> Handle(Query request, CancellationToken ct)
  9. {
  10. var items = await db.FaqCategory
  11. .AsNoTracking()
  12. .Include(c => c.FaqItems)
  13. .OrderBy(c => c.Order)
  14. .ThenByDescending(c => c.ID)
  15. .Select(c => new
  16. {
  17. c.ID,
  18. c.Code,
  19. c.Subject,
  20. c.Order,
  21. c.IsActive,
  22. FaqItemCount = c.FaqItems.Count,
  23. c.UpdatedAt,
  24. c.CreatedAt
  25. })
  26. .ToListAsync(ct);
  27. return new Response(
  28. items.Count,
  29. [..items.Select((c, i) => new Response.Row(
  30. i + 1,
  31. c.ID,
  32. i,
  33. c.Code,
  34. c.Subject,
  35. c.Order,
  36. c.IsActive,
  37. (ushort)c.FaqItemCount,
  38. c.UpdatedAt,
  39. c.CreatedAt
  40. ))]);
  41. }
  42. }
  43. }