mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-06-22 15:00:34 -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>
100 lines
4.3 KiB
C#
100 lines
4.3 KiB
C#
using API.Data.Metadata;
|
|
using API.Entities.Enums;
|
|
|
|
namespace API.Services.Tasks.Scanner.Parser;
|
|
|
|
/// <summary>
|
|
/// This represents all parsed information from a single file
|
|
/// </summary>
|
|
public class ParserInfo
|
|
{
|
|
/// <summary>
|
|
/// Represents the parsed chapters from a file. By default, will be 0 which means nothing could be parsed.
|
|
/// <remarks>The chapters can only be a single float or a range of float ie) 1-2. Mainly floats should be multiples of 0.5 representing specials</remarks>
|
|
/// </summary>
|
|
public string Chapters { get; set; } = "";
|
|
/// <summary>
|
|
/// Represents the parsed series from the file or folder
|
|
/// </summary>
|
|
public required string Series { get; set; } = string.Empty;
|
|
/// <summary>
|
|
/// This can be filled in from ComicInfo.xml/Epub during scanning. Will update the SortName field on <see cref="Entities.Series"/>
|
|
/// </summary>
|
|
public string SeriesSort { get; set; } = string.Empty;
|
|
/// <summary>
|
|
/// This can be filled in from ComicInfo.xml/Epub during scanning. Will update the LocalizedName field on <see cref="Entities.Series"/>
|
|
/// </summary>
|
|
public string LocalizedSeries { get; set; } = string.Empty;
|
|
/// <summary>
|
|
/// Represents the parsed volumes from a file. By default, will be 0 which means that nothing could be parsed.
|
|
/// If Volumes is 0 and Chapters is 0, the file is a special. If Chapters is non-zero, then no volume could be parsed.
|
|
/// <example>Beastars Vol 3-4 will map to "3-4"</example>
|
|
/// <remarks>The volumes can only be a single int or a range of ints ie) 1-2. Float based volumes are not supported.</remarks>
|
|
/// </summary>
|
|
public string Volumes { get; set; } = "";
|
|
/// <summary>
|
|
/// Filename of the underlying file
|
|
/// <example>Beastars v01 (digital).cbz</example>
|
|
/// </summary>
|
|
public string Filename { get; init; } = "";
|
|
/// <summary>
|
|
/// Full filepath of the underlying file
|
|
/// <example>C:/Manga/Beastars v01 (digital).cbz</example>
|
|
/// </summary>
|
|
public string FullFilePath { get; set; } = "";
|
|
|
|
/// <summary>
|
|
/// <see cref="MangaFormat"/> that represents the type of the file
|
|
/// <remarks>Mainly used to show in the UI and so caching service knows how to cache for reading.</remarks>
|
|
/// </summary>
|
|
public MangaFormat Format { get; set; } = MangaFormat.Unknown;
|
|
|
|
/// <summary>
|
|
/// This can potentially story things like "Omnibus, Color, Full Contact Edition, Extra, Final, etc"
|
|
/// </summary>
|
|
/// <remarks>Not Used in Database</remarks>
|
|
public string Edition { get; set; } = "";
|
|
|
|
/// <summary>
|
|
/// If the file contains no volume/chapter information or contains Special Keywords <see cref="Parser.MangaSpecialRegex"/>
|
|
/// </summary>
|
|
public bool IsSpecial { get; set; }
|
|
|
|
/// <summary>
|
|
/// Used for specials or books, stores what the UI should show.
|
|
/// <remarks>Manga does not use this field</remarks>
|
|
/// </summary>
|
|
public string Title { get; set; } = string.Empty;
|
|
|
|
/// <summary>
|
|
/// If the ParserInfo has the IsSpecial tag or both volumes and chapters are default aka 0
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public bool IsSpecialInfo()
|
|
{
|
|
return (IsSpecial || (Volumes == "0" && Chapters == "0"));
|
|
}
|
|
|
|
/// <summary>
|
|
/// This will contain any EXTRA comicInfo information parsed from the epub or archive. If there is an archive with comicInfo.xml AND it contains
|
|
/// series, volume information, that will override what we parsed.
|
|
/// </summary>
|
|
public ComicInfo? ComicInfo { get; set; }
|
|
|
|
/// <summary>
|
|
/// Merges non empty/null properties from info2 into this entity.
|
|
/// </summary>
|
|
/// <remarks>This does not merge ComicInfo as they should always be the same</remarks>
|
|
/// <param name="info2"></param>
|
|
public void Merge(ParserInfo? info2)
|
|
{
|
|
if (info2 == null) return;
|
|
Chapters = string.IsNullOrEmpty(Chapters) || Chapters == "0" ? info2.Chapters: Chapters;
|
|
Volumes = string.IsNullOrEmpty(Volumes) || Volumes == "0" ? info2.Volumes : Volumes;
|
|
Edition = string.IsNullOrEmpty(Edition) ? info2.Edition : Edition;
|
|
Title = string.IsNullOrEmpty(Title) ? info2.Title : Title;
|
|
Series = string.IsNullOrEmpty(Series) ? info2.Series : Series;
|
|
IsSpecial = IsSpecial || info2.IsSpecial;
|
|
}
|
|
}
|