mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-06-12 18:14:15 -04:00
* Updated number inputs with a more mobile friendly control * Started writing lots of unit tests on PersonHelper to try and hammer out foreign constraint * Fixes side-nav actionable alignment * Added some unit tests * Buffed out the unit tests * Applied input modes throughout the app * Fixed a small bug in refresh token validation to make it work correctly * Try out a new way to block multithreading from interacting with people during series metadata update. * Fixed the lock code to properly lock, which should help with any constraint issues. * Locking notes * Tweaked locking on people to prevent a constraint issue. This slows down the scanner a bit, but not much. Will tweak after validating on a user's server. * Replaced all DBFactory.Series with SeriesBuilder. * Replaced all DBFactory.Volume() with VolumeBuilder * Replaced SeriesMetadata with Builder * Replaced DBFactory.CollectionTag * Lots of refactoring to streamline entity creation * Fixed one of the unit tests * Refactored all of new Library() * Removed tag and genre * Removed new SeriesMetadata * Refactored new Volume() * MangaFile() * ReadingList() * Refactored all of Chapter and ReadingList * Add title to all event widget flows * Updated Base Url to inform user it doesn't work for docker users with non-root user. * Added unit test coverage to FormatChapterTitle and FormatChapterName. * Started on Unit test for scanner, but need to finish it later. --------- Co-authored-by: Robbie Davis <robbie@therobbiedavis.com>
33 lines
1.1 KiB
C#
33 lines
1.1 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using API.Entities;
|
|
using API.Services.Tasks.Scanner.Parser;
|
|
|
|
namespace API.Extensions;
|
|
|
|
public static class ParserInfoListExtensions
|
|
{
|
|
/// <summary>
|
|
/// Selects distinct volume numbers by the "Volumes" key on the ParserInfo
|
|
/// </summary>
|
|
/// <param name="infos"></param>
|
|
/// <returns></returns>
|
|
public static IList<string> DistinctVolumes(this IList<ParserInfo> infos)
|
|
{
|
|
return infos.Select(p => p.Volumes).Distinct().ToList();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Checks if a list of ParserInfos has a given chapter or not. Lookup occurs on Range property. If a chapter is
|
|
/// special, then the <see cref="ParserInfo.Filename"/> is matched, else the <see cref="ParserInfo.Chapters"/> field is checked.
|
|
/// </summary>
|
|
/// <param name="infos"></param>
|
|
/// <param name="chapter"></param>
|
|
/// <returns></returns>
|
|
public static bool HasInfo(this IList<ParserInfo> infos, Chapter chapter)
|
|
{
|
|
return chapter.IsSpecial ? infos.Any(v => v.Filename == chapter.Range)
|
|
: infos.Any(v => v.Chapters == chapter.Range);
|
|
}
|
|
}
|