mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-25 15:52:29 -04:00 
			
		
		
		
	* Added a reoccuring task to cleanup db entries that might be abandoned. On library page, the Library in question will be prepoulated. * Laid out the foundation for customized sorting. Added all series page to the UI when clicking on Libraries section header on home page so user can apply any filtering they like. * When filtering, the current library filter will now automatically filter out the options for people and genres. * Implemented Sorting controls * Clear now clears sorting and read progress. Sorting is disabled on deck and recently added. * Fixed an issue where all-series page couldn't click to open series * Don't let the user unselect the last read progress. Added new comicinfo v2.1 draft tags. * Hooked in Translator tag into backend and UI. * Fixed an issue where you could open multiple typeaheads at the same time * Integrated Translator and Tags ComicInfo extension fields. Started work on a badge expander. * Reworked a bit more on badge expander. Added the UI code for Age Rating and Tags * Integrated backend for Tags, Translator, and Age Rating * Metadata tags now collapse if more than 4 present * Some code cleanup * Made the not read badge slightly smaller
		
			
				
	
	
		
			127 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using API.Data.Metadata;
 | |
| using API.Entities;
 | |
| using API.Entities.Enums;
 | |
| using API.Entities.Metadata;
 | |
| using API.Extensions;
 | |
| using API.Parser;
 | |
| using API.Services.Tasks;
 | |
| 
 | |
| namespace API.Data
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Responsible for creating Series, Volume, Chapter, MangaFiles for use in <see cref="ScannerService"/>
 | |
|     /// </summary>
 | |
|     public static class DbFactory
 | |
|     {
 | |
|         public static Series Series(string name)
 | |
|         {
 | |
|             return new ()
 | |
|             {
 | |
|                 Name = name,
 | |
|                 OriginalName = name,
 | |
|                 LocalizedName = name,
 | |
|                 NormalizedName = Parser.Parser.Normalize(name),
 | |
|                 SortName = name,
 | |
|                 Volumes = new List<Volume>(),
 | |
|                 Metadata = SeriesMetadata(Array.Empty<CollectionTag>())
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static SeriesMetadata SeriesMetadata(ComicInfo info)
 | |
|         {
 | |
|             return SeriesMetadata(Array.Empty<CollectionTag>());
 | |
|         }
 | |
| 
 | |
|         public static Volume Volume(string volumeNumber)
 | |
|         {
 | |
|             return new Volume()
 | |
|             {
 | |
|                 Name = volumeNumber,
 | |
|                 Number = (int) Parser.Parser.MinimumNumberFromRange(volumeNumber),
 | |
|                 Chapters = new List<Chapter>()
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static Chapter Chapter(ParserInfo info)
 | |
|         {
 | |
|             var specialTreatment = info.IsSpecialInfo();
 | |
|             var specialTitle = specialTreatment ? info.Filename : info.Chapters;
 | |
|             return new Chapter()
 | |
|             {
 | |
|                 Number = specialTreatment ? "0" : Parser.Parser.MinimumNumberFromRange(info.Chapters) + string.Empty,
 | |
|                 Range = specialTreatment ? info.Filename : info.Chapters,
 | |
|                 Title = (specialTreatment && info.Format == MangaFormat.Epub)
 | |
|                     ? info.Title
 | |
|                     : specialTitle,
 | |
|                 Files = new List<MangaFile>(),
 | |
|                 IsSpecial = specialTreatment,
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static SeriesMetadata SeriesMetadata(ICollection<CollectionTag> collectionTags)
 | |
|         {
 | |
|             return new SeriesMetadata()
 | |
|             {
 | |
|                 CollectionTags = collectionTags,
 | |
|                 Summary = string.Empty
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static CollectionTag CollectionTag(int id, string title, string summary, bool promoted)
 | |
|         {
 | |
|             return new CollectionTag()
 | |
|             {
 | |
|                 Id = id,
 | |
|                 NormalizedTitle = API.Parser.Parser.Normalize(title?.Trim()).ToUpper(),
 | |
|                 Title = title?.Trim(),
 | |
|                 Summary = summary?.Trim(),
 | |
|                 Promoted = promoted
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static Genre Genre(string name, bool external)
 | |
|         {
 | |
|             return new Genre()
 | |
|             {
 | |
|                 Title = name.Trim().SentenceCase(),
 | |
|                 NormalizedTitle = Parser.Parser.Normalize(name),
 | |
|                 ExternalTag = external
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static Tag Tag(string name, bool external)
 | |
|         {
 | |
|             return new Tag()
 | |
|             {
 | |
|                 Title = name.Trim().SentenceCase(),
 | |
|                 NormalizedTitle = Parser.Parser.Normalize(name),
 | |
|                 ExternalTag = external
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static Person Person(string name, PersonRole role)
 | |
|         {
 | |
|             return new Person()
 | |
|             {
 | |
|                 Name = name.Trim(),
 | |
|                 NormalizedName = Parser.Parser.Normalize(name),
 | |
|                 Role = role
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         public static MangaFile MangaFile(string filePath, MangaFormat format, int pages)
 | |
|         {
 | |
|             return new MangaFile()
 | |
|             {
 | |
|                 FilePath = filePath,
 | |
|                 Format = format,
 | |
|                 Pages = pages,
 | |
|                 LastModified = DateTime.Now //File.GetLastWriteTime(filePath)
 | |
|             };
 | |
|         }
 | |
| 
 | |
|     }
 | |
| }
 |