Handler.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. using Application.Abstractions.Messaging;
  2. using Application.Abstractions.Data;
  3. using Domain.Entities.Wallets.ValueObject;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Admin.Member.Wallet.List.Search;
  6. public sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Response>
  7. {
  8. public async Task<Response> Handle(Query request, CancellationToken ct)
  9. {
  10. var query = db.Wallet.AsNoTracking().Include(x => x.Member).Include(x => x.Balances).AsQueryable();
  11. // 키워드 검색
  12. if (!string.IsNullOrWhiteSpace(request.Keyword))
  13. {
  14. query = request.Search switch
  15. {
  16. 1 => query.Where(x => x.MemberID.ToString().Contains(request.Keyword)),
  17. 2 => query.Where(x => x.Member.Name != null && x.Member.Name.Contains(request.Keyword)),
  18. 3 => query.Where(x => x.Member.Email.Contains(request.Keyword)),
  19. 4 => query.Where(x => x.ID.ToString().Contains(request.Keyword)),
  20. _ => query
  21. };
  22. }
  23. // 날짜 필터
  24. if (!string.IsNullOrWhiteSpace(request.StartAt) && DateTime.TryParse(request.StartAt, out var startAt))
  25. {
  26. query = query.Where(x => x.CreatedAt >= startAt);
  27. }
  28. if (!string.IsNullOrWhiteSpace(request.EndAt) && DateTime.TryParse(request.EndAt, out var endAt))
  29. {
  30. query = query.Where(x => x.CreatedAt <= endAt);
  31. }
  32. var total = await query.CountAsync(ct);
  33. var skip = (request.PageNum - 1) * request.PerPage;
  34. var list = await query.OrderByDescending(x => x.ID).Skip(skip).Take(request.PerPage).Select(x => new
  35. {
  36. x.ID, x.MemberID,
  37. MemberEmail = x.Member.Email,
  38. MemberName = x.Member.Name,
  39. Balances = x.Balances,
  40. x.UpdatedAt, x.CreatedAt
  41. }).ToListAsync(ct);
  42. var rows = list.Select((x, idx) => new Response.Row
  43. {
  44. Num = total - skip - idx,
  45. ID = x.ID,
  46. MemberID = x.MemberID,
  47. MemberEmail = x.MemberEmail,
  48. MemberName = x.MemberName,
  49. Balance = (long)x.Balances.Where(b => b.Type != WalletBalanceType.Locked).Sum(b => b.Amount.Value),
  50. DonationBalance = (long)(x.Balances.FirstOrDefault(b => b.Type == WalletBalanceType.Donation)?.Amount.Value ?? 0),
  51. UpdatedAt = x.UpdatedAt,
  52. CreatedAt = x.CreatedAt
  53. }).ToList();
  54. return new Response
  55. {
  56. Total = total,
  57. List = rows
  58. };
  59. }
  60. }