mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-05-24 00:52:23 -04:00
* Fixed an issue where sometimes when loading the next page, the pagination area wouldn't be properly setup due to a missed rendering cycle * Refactored BookController to thin it out and refactor some of the functions to apply IOC. Added some split query statements on a few queries. * Added Split Query to many queries * Added a visual indicator for loading state of PDF. Will spruce up css later. * Added back in logic * Fixed flash of white when refreshing browser * Hooked in a loading progress bar for the pdf reader * Close the pdf reader when pressing ESC
96 lines
2.7 KiB
C#
96 lines
2.7 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using API.DTOs.Metadata;
|
|
using API.Entities;
|
|
using AutoMapper;
|
|
using AutoMapper.QueryableExtensions;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace API.Data.Repositories;
|
|
|
|
public interface IGenreRepository
|
|
{
|
|
void Attach(Genre genre);
|
|
void Remove(Genre genre);
|
|
Task<Genre> FindByNameAsync(string genreName);
|
|
Task<IList<Genre>> GetAllGenresAsync();
|
|
Task<IList<GenreTagDto>> GetAllGenreDtosAsync();
|
|
Task RemoveAllGenreNoLongerAssociated(bool removeExternal = false);
|
|
Task<IList<GenreTagDto>> GetAllGenreDtosForLibrariesAsync(IList<int> libraryIds);
|
|
Task<int> GetCountAsync();
|
|
}
|
|
|
|
public class GenreRepository : IGenreRepository
|
|
{
|
|
private readonly DataContext _context;
|
|
private readonly IMapper _mapper;
|
|
|
|
public GenreRepository(DataContext context, IMapper mapper)
|
|
{
|
|
_context = context;
|
|
_mapper = mapper;
|
|
}
|
|
|
|
public void Attach(Genre genre)
|
|
{
|
|
_context.Genre.Attach(genre);
|
|
}
|
|
|
|
public void Remove(Genre genre)
|
|
{
|
|
_context.Genre.Remove(genre);
|
|
}
|
|
|
|
public async Task<Genre> FindByNameAsync(string genreName)
|
|
{
|
|
var normalizedName = Parser.Parser.Normalize(genreName);
|
|
return await _context.Genre
|
|
.FirstOrDefaultAsync(g => g.NormalizedTitle.Equals(normalizedName));
|
|
}
|
|
|
|
public async Task RemoveAllGenreNoLongerAssociated(bool removeExternal = false)
|
|
{
|
|
var genresWithNoConnections = await _context.Genre
|
|
.Include(p => p.SeriesMetadatas)
|
|
.Include(p => p.Chapters)
|
|
.Where(p => p.SeriesMetadatas.Count == 0 && p.Chapters.Count == 0 && p.ExternalTag == removeExternal)
|
|
.AsSplitQuery()
|
|
.ToListAsync();
|
|
|
|
_context.Genre.RemoveRange(genresWithNoConnections);
|
|
|
|
await _context.SaveChangesAsync();
|
|
}
|
|
|
|
public async Task<IList<GenreTagDto>> GetAllGenreDtosForLibrariesAsync(IList<int> libraryIds)
|
|
{
|
|
return await _context.Series
|
|
.Where(s => libraryIds.Contains(s.LibraryId))
|
|
.SelectMany(s => s.Metadata.Genres)
|
|
.AsSplitQuery()
|
|
.Distinct()
|
|
.OrderBy(p => p.Title)
|
|
.ProjectTo<GenreTagDto>(_mapper.ConfigurationProvider)
|
|
.ToListAsync();
|
|
}
|
|
|
|
public async Task<int> GetCountAsync()
|
|
{
|
|
return await _context.Genre.CountAsync();
|
|
}
|
|
|
|
public async Task<IList<Genre>> GetAllGenresAsync()
|
|
{
|
|
return await _context.Genre.ToListAsync();
|
|
}
|
|
|
|
public async Task<IList<GenreTagDto>> GetAllGenreDtosAsync()
|
|
{
|
|
return await _context.Genre
|
|
.AsNoTracking()
|
|
.ProjectTo<GenreTagDto>(_mapper.ConfigurationProvider)
|
|
.ToListAsync();
|
|
}
|
|
}
|