mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-06-23 15:30:34 -04:00
* Moved the data connection for the Database out of appsettings.json and hardcoded it. This will allow for more customization and cleaner update process. * Removed unneeded code * Updated pdf viewer to 15.0.0 (pdf 2.6), which now supports east-asian fonts * Fixed up some regex parsing for volumes that have a float number. * Fixed a bug where the tooltip for Publication Status wouldn't show * Fixed some weird parsing rules where v1.1 would parse as volume 1 chapter 1 * Fixed a bug where bookmarking button was hidden for admins without bookmark role (due to migration) * Unified the star rating component in series detail to match metadata filter. * Fixed a bug in the bulk selection code when using shift selection, where the inverse of what was selected would be toggled. * Fixed some old code where if on all series page, only English as a language would return. We now return all languages of all libraries. * Updated api/metadata/languages documentation * Refactored some bookmark api names: get-bookmarks -> chapter-bookmarks, get-all-bookmarks -> all-bookmarks, get-series-bookmarks -> series-bookmarks, etc. * Refactored all cases of createSeriesFilter to filterUtiltityService. Added ability to search for a series on Bookmarks page. Fixed a bug where people filters wouldn't respect the disable flag froms ettings. * Cleaned up a bit of the circular downloader code. * Implemented Russian Parsing * Fixed an issue where some users that had a missing theme entry wouldn't be able to update their user preferences. * Refactored normalization to exclude !, thus allowing series with ! to be different from each other. * Fixed a migration exit case * Fixed broken unit test
121 lines
4.3 KiB
C#
121 lines
4.3 KiB
C#
using System;
|
|
using System.ComponentModel.DataAnnotations;
|
|
using API.Data;
|
|
using API.DTOs.Theme;
|
|
using API.Entities;
|
|
using API.Entities.Enums;
|
|
using API.Entities.Enums.UserPreferences;
|
|
|
|
namespace API.DTOs;
|
|
|
|
public class UserPreferencesDto
|
|
{
|
|
/// <summary>
|
|
/// Manga Reader Option: What direction should the next/prev page buttons go
|
|
/// </summary>
|
|
[Required]
|
|
public ReadingDirection ReadingDirection { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: How should the image be scaled to screen
|
|
/// </summary>
|
|
[Required]
|
|
public ScalingOption ScalingOption { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: Which side of a split image should we show first
|
|
/// </summary>
|
|
[Required]
|
|
public PageSplitOption PageSplitOption { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: How the manga reader should perform paging or reading of the file
|
|
/// <example>
|
|
/// Webtoon uses scrolling to page, LeftRight uses paging by clicking left/right side of reader, UpDown uses paging
|
|
/// by clicking top/bottom sides of reader.
|
|
/// </example>
|
|
/// </summary>
|
|
[Required]
|
|
public ReaderMode ReaderMode { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: How many pages to display in the reader at once
|
|
/// </summary>
|
|
[Required]
|
|
public LayoutMode LayoutMode { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: Background color of the reader
|
|
/// </summary>
|
|
[Required]
|
|
public string BackgroundColor { get; set; } = "#000000";
|
|
/// <summary>
|
|
/// Manga Reader Option: Allow the menu to close after 6 seconds without interaction
|
|
/// </summary>
|
|
[Required]
|
|
public bool AutoCloseMenu { get; set; }
|
|
/// <summary>
|
|
/// Manga Reader Option: Show screen hints to the user on some actions, ie) pagination direction change
|
|
/// </summary>
|
|
[Required]
|
|
public bool ShowScreenHints { get; set; } = true;
|
|
/// <summary>
|
|
/// Book Reader Option: Override extra Margin
|
|
/// </summary>
|
|
[Required]
|
|
public int BookReaderMargin { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: Override line-height
|
|
/// </summary>
|
|
[Required]
|
|
public int BookReaderLineSpacing { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: Override font size
|
|
/// </summary>
|
|
[Required]
|
|
public int BookReaderFontSize { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: Maps to the default Kavita font-family (inherit) or an override
|
|
/// </summary>
|
|
[Required]
|
|
public string BookReaderFontFamily { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: Allows tapping on side of screens to paginate
|
|
/// </summary>
|
|
[Required]
|
|
public bool BookReaderTapToPaginate { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: What direction should the next/prev page buttons go
|
|
/// </summary>
|
|
[Required]
|
|
public ReadingDirection BookReaderReadingDirection { get; set; }
|
|
|
|
/// <summary>
|
|
/// UI Site Global Setting: The UI theme the user should use.
|
|
/// </summary>
|
|
/// <remarks>Should default to Dark</remarks>
|
|
public SiteTheme Theme { get; set; }
|
|
[Required]
|
|
public string BookReaderThemeName { get; set; }
|
|
[Required]
|
|
public BookPageLayoutMode BookReaderLayoutMode { get; set; }
|
|
/// <summary>
|
|
/// Book Reader Option: A flag that hides the menu-ing system behind a click on the screen. This should be used with tap to paginate, but the app doesn't enforce this.
|
|
/// </summary>
|
|
/// <remarks>Defaults to false</remarks>
|
|
[Required]
|
|
public bool BookReaderImmersiveMode { get; set; } = false;
|
|
/// <summary>
|
|
/// Global Site Option: If the UI should layout items as Cards or List items
|
|
/// </summary>
|
|
/// <remarks>Defaults to Cards</remarks>
|
|
[Required]
|
|
public PageLayoutMode GlobalPageLayoutMode { get; set; } = PageLayoutMode.Cards;
|
|
/// <summary>
|
|
/// UI Site Global Setting: If unread summaries should be blurred until expanded or unless user has read it already
|
|
/// </summary>
|
|
/// <remarks>Defaults to false</remarks>
|
|
[Required]
|
|
public bool BlurUnreadSummaries { get; set; } = false;
|
|
/// <summary>
|
|
/// UI Site Global Setting: Should Kavita prompt user to confirm downloads that are greater than 100 MB.
|
|
/// </summary>
|
|
[Required]
|
|
public bool PromptForDownloadSize { get; set; } = true;
|
|
}
|