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.6 KiB
38 lines
1.6 KiB
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Infrastructure.Data; |
|
using Microsoft.EntityFrameworkCore; |
|
using static ErsatzTV.Application.MediaCollections.Mapper; |
|
|
|
namespace ErsatzTV.Application.MediaCollections; |
|
|
|
public class GetPagedMultiCollectionsHandler(IDbContextFactory<TvContext> dbContextFactory) |
|
: IRequestHandler<GetPagedMultiCollections, PagedMultiCollectionsViewModel> |
|
{ |
|
public async Task<PagedMultiCollectionsViewModel> Handle( |
|
GetPagedMultiCollections request, |
|
CancellationToken cancellationToken) |
|
{ |
|
await using TvContext dbContext = await dbContextFactory.CreateDbContextAsync(cancellationToken); |
|
int count = await dbContext.MultiCollections.CountAsync(cancellationToken); |
|
|
|
IQueryable<MultiCollection> query = dbContext.MultiCollections.AsNoTracking(); |
|
|
|
if (!string.IsNullOrWhiteSpace(request.Query)) |
|
{ |
|
query = query.Where(s => EF.Functions.Like( |
|
EF.Functions.Collate(s.Name, TvContext.CaseInsensitiveCollation), |
|
$"%{request.Query}%")); |
|
} |
|
|
|
List<MultiCollectionViewModel> page = await query |
|
.OrderBy(f => EF.Functions.Collate(f.Name, TvContext.CaseInsensitiveCollation)) |
|
.Skip(request.PageNum * request.PageSize) |
|
.Take(request.PageSize) |
|
.Include(mc => mc.MultiCollectionItems) |
|
.ThenInclude(i => i.Collection) |
|
.ToListAsync(cancellationToken) |
|
.Map(list => list.Map(ProjectToViewModel).ToList()); |
|
|
|
return new PagedMultiCollectionsViewModel(count, page); |
|
} |
|
}
|
|
|