Files
2026-05-10 23:39:55 +02:00

49 lines
1.4 KiB
C#

using Events.WebAPI.Contract.DTOs;
using Events.WebAPI.Contract.LookupQueries;
using Events.WebAPI.Handlers.EF.Data.Postgres;
using MediatR;
using Microsoft.EntityFrameworkCore;
namespace Events.WebAPI.Handlers.EF.QueryHandlers;
public class PeopleLookupQueryHandler : IRequestHandler<LookupPeopleQuery, List<IdName<int>>>
{
private readonly EventsContext ctx;
public PeopleLookupQueryHandler(EventsContext ctx)
{
this.ctx = ctx;
}
public async Task<List<IdName<int>>> Handle(LookupPeopleQuery request, CancellationToken cancellationToken)
{
var query = ctx.People.AsNoTracking();
if (!string.IsNullOrWhiteSpace(request.Text))
{
string text = request.Text.Trim();
query = query.Where(p =>
global::Microsoft.EntityFrameworkCore.EF.Functions.ILike(
p.FirstNameTranscription + " " + p.LastNameTranscription,
$"%{text}%"));
}
if (!string.IsNullOrWhiteSpace(request.CountryCode))
{
string countryCode = request.CountryCode.Trim();
query = query.Where(p => p.CountryCode == countryCode);
}
return await query
.OrderBy(p => p.FirstNameTranscription)
.ThenBy(p => p.LastNameTranscription)
.Select(p => new IdName<int>
{
Id = p.Id,
Name = p.FirstName + " " + p.LastName,
Description = p.FirstNameTranscription + " " + p.LastNameTranscription
})
.ToListAsync(cancellationToken);
}
}