Handler.cs 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. using Application.Abstractions.Messaging;
  2. using Application.Abstractions.Data;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Admin.Crypto.Curation.Get;
  5. public sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Response>
  6. {
  7. public async Task<Response> Handle(Query request, CancellationToken ct)
  8. {
  9. var items = await db.Coin
  10. .AsNoTracking()
  11. .Where(c => c.IsActive && !c.IsDelisted)
  12. .OrderByDescending(c => c.IsFeatured)
  13. .ThenBy(c => c.DisplayOrder)
  14. .ThenBy(c => c.Symbol)
  15. .Select(c => new
  16. {
  17. c.ID,
  18. c.Symbol,
  19. c.KorName,
  20. c.EngName,
  21. c.LogoImage,
  22. c.IsFeatured,
  23. c.DisplayOrder,
  24. c.IsActive
  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. c.Symbol,
  33. c.KorName,
  34. c.EngName,
  35. c.LogoImage,
  36. c.IsFeatured,
  37. c.DisplayOrder,
  38. c.IsActive
  39. ))]);
  40. }
  41. }