mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-11-04 03:27:05 -05:00 
			
		
		
		
	* Cleaned up a ton of warnings/suggestions from the IDE. * Fixed a bug when clearing the filters some presets could be undone. * Renamed a class in the OPDS spec * Simplified logic for when Fit To Screen rendering logic occurs. It now works always rather than only on cover images. * Give some additional info to the user on what the differences between Library Types are * Don't scan .qpkg folders (QNAP devices) * Refactored some code to enable ability to test CoverImage Test. This is a broken test, test.zip is waiting on an issue in NetVips. * Fixed an issue where Extra might get flagged as special too early, if in a word like Extraordinary * Cleaned up the regex for the extra issue to be more flexible
		
			
				
	
	
		
			108 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using API.Entities.Enums;
 | 
						|
using API.Entities.Interfaces;
 | 
						|
using API.Parser;
 | 
						|
 | 
						|
namespace API.Entities
 | 
						|
{
 | 
						|
    public class Chapter : IEntityDate
 | 
						|
    {
 | 
						|
        public int Id { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Range of numbers. Chapter 2-4 -> "2-4". Chapter 2 -> "2".
 | 
						|
        /// </summary>
 | 
						|
        public string Range { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Smallest number of the Range. Can be a partial like Chapter 4.5
 | 
						|
        /// </summary>
 | 
						|
        public string Number { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// The files that represent this Chapter
 | 
						|
        /// </summary>
 | 
						|
        public ICollection<MangaFile> Files { get; set; }
 | 
						|
        public DateTime Created { get; set; }
 | 
						|
        public DateTime LastModified { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Absolute path to the (managed) image file
 | 
						|
        /// </summary>
 | 
						|
        /// <remarks>The file is managed internally to Kavita's APPDIR</remarks>
 | 
						|
        public string CoverImage { get; set; }
 | 
						|
        public bool CoverImageLocked { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Total number of pages in all MangaFiles
 | 
						|
        /// </summary>
 | 
						|
        public int Pages { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// If this Chapter contains files that could only be identified as Series or has Special Identifier from filename
 | 
						|
        /// </summary>
 | 
						|
        public bool IsSpecial { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Used for books/specials to display custom title. For non-specials/books, will be set to <see cref="Range"/>
 | 
						|
        /// </summary>
 | 
						|
        public string Title { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Age Rating for the issue/chapter
 | 
						|
        /// </summary>
 | 
						|
        public AgeRating AgeRating { get; set; }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Chapter title
 | 
						|
        /// </summary>
 | 
						|
        /// <remarks>This should not be confused with Title which is used for special filenames.</remarks>
 | 
						|
        public string TitleName { get; set; } = string.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// Date which chapter was released
 | 
						|
        /// </summary>
 | 
						|
        public DateTime ReleaseDate { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Summary for the Chapter/Issue
 | 
						|
        /// </summary>
 | 
						|
        public string Summary { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Language for the Chapter/Issue
 | 
						|
        /// </summary>
 | 
						|
        public string Language { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// Total number of issues in the series
 | 
						|
        /// </summary>
 | 
						|
        public int TotalCount { get; set; } = 0;
 | 
						|
        /// <summary>
 | 
						|
        /// Number in the Total Count
 | 
						|
        /// </summary>
 | 
						|
        public int Count { get; set; } = 0;
 | 
						|
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// All people attached at a Chapter level. Usually Comics will have different people per issue.
 | 
						|
        /// </summary>
 | 
						|
        public ICollection<Person> People { get; set; } = new List<Person>();
 | 
						|
        /// <summary>
 | 
						|
        /// Genres for the Chapter
 | 
						|
        /// </summary>
 | 
						|
        public ICollection<Genre> Genres { get; set; } = new List<Genre>();
 | 
						|
        public ICollection<Tag> Tags { get; set; } = new List<Tag>();
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
        // Relationships
 | 
						|
        public Volume Volume { get; set; }
 | 
						|
        public int VolumeId { get; set; }
 | 
						|
 | 
						|
        public void UpdateFrom(ParserInfo info)
 | 
						|
        {
 | 
						|
            Files ??= new List<MangaFile>();
 | 
						|
            IsSpecial = info.IsSpecialInfo();
 | 
						|
            if (IsSpecial)
 | 
						|
            {
 | 
						|
                Number = "0";
 | 
						|
            }
 | 
						|
            Title = (IsSpecial && info.Format == MangaFormat.Epub)
 | 
						|
                ? info.Title
 | 
						|
                : Range;
 | 
						|
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |