using System;
using API.Entities.Enums;
using API.Entities.Interfaces;
using API.Services.Plus;
namespace API.DTOs.Collection;
#nullable enable
public sealed record AppUserCollectionDto : IHasCoverImage
{
    public int Id { get; init; }
    public string Title { get; init; } = default!;
    public string? Summary { get; init; } = default!;
    public bool Promoted { get; init; }
    public AgeRating AgeRating { get; init; }
    /// 
    /// This is used to tell the UI if it should request a Cover Image or not. If null or empty, it has not been set.
    /// 
    public string? CoverImage { get; set; } = string.Empty;
    public string? PrimaryColor { get; set; } = string.Empty;
    public string? SecondaryColor { get; set; } = string.Empty;
    public bool CoverImageLocked { get; init; }
    /// 
    /// Number of Series in the Collection
    /// 
    public int ItemCount { get; init; }
    /// 
    /// Owner of the Collection
    /// 
    public string? Owner { get; init; }
    /// 
    /// Last time Kavita Synced the Collection with an upstream source (for non Kavita sourced collections)
    /// 
    public DateTime LastSyncUtc { get; init; }
    /// 
    /// Who created/manages the list. Non-Kavita lists are not editable by the user, except to promote
    /// 
    public ScrobbleProvider Source { get; init; } = ScrobbleProvider.Kavita;
    /// 
    /// For Non-Kavita sourced collections, the url to sync from
    /// 
    public string? SourceUrl { get; init; }
    /// 
    /// Total number of items as of the last sync. Not applicable for Kavita managed collections.
    /// 
    public int TotalSourceCount { get; init; }
    /// 
    /// A 
 separated string of all missing series
    /// 
    public string? MissingSeriesFromSource { get; init; }
    public void ResetColorScape()
    {
        PrimaryColor = string.Empty;
        SecondaryColor = string.Empty;
    }
}