mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-31 02:27:04 -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>
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Collections.Generic;
 | |
| using System.Linq;
 | |
| using API.Entities;
 | |
| using API.Helpers;
 | |
| using API.Services.Tasks.Scanner.Parser;
 | |
| 
 | |
| namespace API.Extensions;
 | |
| 
 | |
| public static class ChapterListExtensions
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Returns first chapter in the list with at least one file
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <returns></returns>
 | |
|     public static Chapter? GetFirstChapterWithFiles(this IEnumerable<Chapter> chapters)
 | |
|     {
 | |
|         return chapters.FirstOrDefault(c => c.Files.Any());
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Gets a single chapter (or null if doesn't exist) where Range matches the info.Chapters property. If the info
 | |
|     /// is <see cref="ParserInfo.IsSpecial"/> then, the filename is used to search against Range or if filename exists within Files of said Chapter.
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <param name="info"></param>
 | |
|     /// <returns></returns>
 | |
|     public static Chapter? GetChapterByRange(this IEnumerable<Chapter> chapters, ParserInfo info)
 | |
|     {
 | |
|         var specialTreatment = info.IsSpecialInfo();
 | |
|         return specialTreatment
 | |
|             ? chapters.FirstOrDefault(c => c.Range == info.Filename || (c.Files.Select(f => f.FilePath).Contains(info.FullFilePath)))
 | |
|             : chapters.FirstOrDefault(c => c.Range == info.Chapters);
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Returns the minimum Release Year from all Chapters that meets the year requirement (>= 1000)
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <returns></returns>
 | |
|     public static int MinimumReleaseYear(this IList<Chapter> chapters)
 | |
|     {
 | |
|         return chapters.Select(v => v.ReleaseDate.Year).Where(y => NumberHelper.IsValidYear(y)).DefaultIfEmpty().Min();
 | |
|     }
 | |
| }
 |