Handler.cs 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. using Application.Abstractions.Data;
  2. using MediatR;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Banner.Position.GetAll;
  5. public sealed class Handler(IAppDbContext db) : IRequestHandler<Query, Response>
  6. {
  7. public async Task<Response> Handle(Query request, CancellationToken ct)
  8. {
  9. var rows = await db.BannerPosition
  10. .AsNoTracking()
  11. .OrderByDescending(c => c.ID)
  12. .Select(c => new
  13. {
  14. c.ID,
  15. c.Code,
  16. c.Subject,
  17. BannerItemRows = c.BannerItems.Count,
  18. c.IsActive,
  19. c.UpdatedAt,
  20. c.CreatedAt
  21. })
  22. .ToListAsync(ct);
  23. return new Response(
  24. rows.Count,
  25. [..rows.Select((c, i) => new Response.Row(
  26. i + 1,
  27. c.ID,
  28. i,
  29. c.Code,
  30. c.Subject,
  31. c.BannerItemRows,
  32. c.IsActive,
  33. c.UpdatedAt,
  34. c.CreatedAt
  35. ))]
  36. );
  37. }
  38. }