jellyfin/MediaBrowser.Controller/Entities/UserItemData.cs

130 lines
3.7 KiB
C#
Raw Normal View History

#nullable disable
#pragma warning disable CS1591
using System;
2019-10-15 11:49:49 -04:00
using System.Text.Json.Serialization;
2018-12-27 18:27:57 -05:00
namespace MediaBrowser.Controller.Entities
{
/// <summary>
/// Class UserItemData.
2018-12-27 18:27:57 -05:00
/// </summary>
public class UserItemData
{
2021-08-15 13:32:18 -04:00
public const double MinLikeValue = 6.5;
/// <summary>
/// The _rating.
/// </summary>
private double? _rating;
2018-12-27 18:27:57 -05:00
/// <summary>
/// Gets or sets the user id.
/// </summary>
/// <value>The user id.</value>
public Guid UserId { get; set; }
/// <summary>
/// Gets or sets the key.
/// </summary>
/// <value>The key.</value>
public string Key { get; set; }
/// <summary>
/// Gets or sets the users 0-10 rating.
2018-12-27 18:27:57 -05:00
/// </summary>
/// <value>The rating.</value>
2019-01-13 15:37:13 -05:00
/// <exception cref="ArgumentOutOfRangeException">Rating;A 0 to 10 rating is required for UserItemData.</exception>
2018-12-27 18:27:57 -05:00
public double? Rating
{
get => _rating;
2018-12-27 18:27:57 -05:00
set
{
if (value.HasValue)
{
if (value.Value < 0 || value.Value > 10)
{
throw new ArgumentOutOfRangeException(nameof(value), "A 0 to 10 rating is required for UserItemData.");
2018-12-27 18:27:57 -05:00
}
}
_rating = value;
}
}
/// <summary>
/// Gets or sets the playback position ticks.
/// </summary>
/// <value>The playback position ticks.</value>
public long PlaybackPositionTicks { get; set; }
/// <summary>
/// Gets or sets the play count.
/// </summary>
/// <value>The play count.</value>
public int PlayCount { get; set; }
/// <summary>
/// Gets or sets a value indicating whether this instance is favorite.
/// </summary>
/// <value><c>true</c> if this instance is favorite; otherwise, <c>false</c>.</value>
public bool IsFavorite { get; set; }
/// <summary>
/// Gets or sets the last played date.
/// </summary>
/// <value>The last played date.</value>
public DateTime? LastPlayedDate { get; set; }
/// <summary>
/// Gets or sets a value indicating whether this <see cref="UserItemData" /> is played.
/// </summary>
/// <value><c>true</c> if played; otherwise, <c>false</c>.</value>
public bool Played { get; set; }
2018-12-27 18:27:57 -05:00
/// <summary>
/// Gets or sets the index of the audio stream.
/// </summary>
/// <value>The index of the audio stream.</value>
public int? AudioStreamIndex { get; set; }
2018-12-27 18:27:57 -05:00
/// <summary>
/// Gets or sets the index of the subtitle stream.
/// </summary>
/// <value>The index of the subtitle stream.</value>
public int? SubtitleStreamIndex { get; set; }
/// <summary>
/// Gets or sets a value indicating whether the item is liked or not.
2018-12-27 18:27:57 -05:00
/// This should never be serialized.
/// </summary>
/// <value><c>null</c> if [likes] contains no value, <c>true</c> if [likes]; otherwise, <c>false</c>.</value>
2019-10-15 11:49:49 -04:00
[JsonIgnore]
2018-12-27 18:27:57 -05:00
public bool? Likes
{
get
{
2022-12-05 09:01:13 -05:00
if (Rating is not null)
2018-12-27 18:27:57 -05:00
{
return Rating >= MinLikeValue;
}
return null;
}
2020-06-15 17:43:52 -04:00
2018-12-27 18:27:57 -05:00
set
{
if (value.HasValue)
{
Rating = value.Value ? 10 : 1;
}
else
{
Rating = null;
}
}
}
}
}