Handler.cs 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. using Application.Abstractions.Data;
  2. using MediatR;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Banner.Item.Search;
  5. public sealed class Handler(IAppDbContext db) : IRequestHandler<Query, Response>
  6. {
  7. public async Task<Response> Handle(Query request, CancellationToken ct)
  8. {
  9. var query = db.BannerItem.AsNoTracking().Include(c => c.BannerPosition).AsQueryable();
  10. if (request.PositionID.HasValue)
  11. {
  12. query = query.Where(c => c.PositionID == request.PositionID.Value);
  13. }
  14. if (!string.IsNullOrWhiteSpace(request.Keyword))
  15. {
  16. var kw = request.Keyword.Trim();
  17. query = query.Where(c => c.Subject.Contains(kw));
  18. }
  19. var total = await query.CountAsync(ct);
  20. var list = await query
  21. .OrderByDescending(c => c.ID)
  22. .Skip((request.PageNum - 1) * request.PerPage)
  23. .Take(request.PerPage)
  24. .Select(c=> new
  25. {
  26. c.ID,
  27. c.PositionID,
  28. PositionCode = c.BannerPosition.Code,
  29. PositionSubject = c.BannerPosition.Subject,
  30. c.Subject,
  31. c.DesktopImage,
  32. c.MobileImage,
  33. c.Link,
  34. c.Order,
  35. c.IsActive,
  36. c.StartAt,
  37. c.EndAt,
  38. c.UpdatedAt,
  39. c.CreatedAt
  40. })
  41. .ToListAsync(ct);
  42. var startNum = total - ((request.PageNum - 1) * request.PerPage);
  43. return new Response(
  44. total,
  45. [..list.Select((c, i) => new Response.Row(
  46. Num: startNum - i,
  47. c.ID,
  48. c.PositionID,
  49. c.PositionCode,
  50. c.PositionSubject,
  51. c.Subject,
  52. c.DesktopImage,
  53. c.MobileImage,
  54. c.Link,
  55. c.Order,
  56. c.IsActive,
  57. c.StartAt,
  58. c.EndAt,
  59. c.UpdatedAt,
  60. c.CreatedAt
  61. ))]
  62. );
  63. }
  64. }