mirror of https://github.com/ErsatzTV/ErsatzTV.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.5 KiB
38 lines
1.5 KiB
using System.Globalization; |
|
using ErsatzTV.Application.MediaItems; |
|
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Infrastructure.Data; |
|
using Microsoft.EntityFrameworkCore; |
|
|
|
namespace ErsatzTV.Application.Search; |
|
|
|
public class SearchTelevisionShowsHandler : IRequestHandler<SearchTelevisionShows, List<NamedMediaItemViewModel>> |
|
{ |
|
private readonly IDbContextFactory<TvContext> _dbContextFactory; |
|
|
|
public SearchTelevisionShowsHandler(IDbContextFactory<TvContext> dbContextFactory) => |
|
_dbContextFactory = dbContextFactory; |
|
|
|
public async Task<List<NamedMediaItemViewModel>> Handle( |
|
SearchTelevisionShows request, |
|
CancellationToken cancellationToken) |
|
{ |
|
await using TvContext dbContext = await _dbContextFactory.CreateDbContextAsync(cancellationToken); |
|
return await dbContext.ShowMetadata |
|
.AsNoTracking() |
|
.Where( |
|
s => EF.Functions.Like( |
|
EF.Functions.Collate(s.Title + " " + s.Year, TvContext.CaseInsensitiveCollation), |
|
$"%{request.Query}%")) |
|
.OrderBy(s => EF.Functions.Collate(s.Title, TvContext.CaseInsensitiveCollation)) |
|
.ThenBy(s => s.Year) |
|
.Take(10) |
|
.ToListAsync(cancellationToken) |
|
.Map(list => list.Map(ToNamedMediaItem).ToList()); |
|
} |
|
|
|
private static NamedMediaItemViewModel ToNamedMediaItem(ShowMetadata show) => |
|
new( |
|
show.ShowId, |
|
$"{show.Title} ({(show.Year.HasValue ? show.Year.Value.ToString(CultureInfo.InvariantCulture) : "???")})"); |
|
}
|
|
|