jellyfin-server/MediaBrowser.Controller/Entities/Audio/Audio.cs

169 lines
5.1 KiB
C#
Raw Normal View History

2014-02-07 03:10:13 +00:00
using MediaBrowser.Controller.Providers;
using MediaBrowser.Model.Configuration;
2013-12-26 16:53:23 +00:00
using System;
2013-02-21 01:33:05 +00:00
using System.Collections.Generic;
using System.Linq;
2013-02-21 01:33:05 +00:00
using System.Runtime.Serialization;
namespace MediaBrowser.Controller.Entities.Audio
{
/// <summary>
/// Class Audio
/// </summary>
2014-05-18 19:58:42 +00:00
public class Audio : BaseItem, IHasMediaStreams, IHasAlbumArtist, IHasArtist, IHasMusicGenres, IHasLookupInfo<SongInfo>, IHasTags
2013-02-21 01:33:05 +00:00
{
2014-04-18 05:03:01 +00:00
public string FormatName { get; set; }
public long? Size { get; set; }
public string Container { get; set; }
2014-04-22 17:25:54 +00:00
public int? TotalBitrate { get; set; }
2014-05-18 19:58:42 +00:00
public List<string> Tags { get; set; }
2014-04-18 05:03:01 +00:00
public Audio()
{
Artists = new List<string>();
2014-05-18 19:58:42 +00:00
Tags = new List<string>();
}
2013-02-21 01:33:05 +00:00
/// <summary>
2013-12-06 03:39:44 +00:00
/// Gets or sets a value indicating whether this instance has embedded image.
2013-02-21 01:33:05 +00:00
/// </summary>
2013-12-06 03:39:44 +00:00
/// <value><c>true</c> if this instance has embedded image; otherwise, <c>false</c>.</value>
public bool HasEmbeddedImage { get; set; }
2014-02-01 06:18:16 +00:00
2013-02-21 01:33:05 +00:00
/// <summary>
/// Override this to true if class should be grouped under a container in indicies
/// The container class should be defined via IndexContainer
/// </summary>
/// <value><c>true</c> if [group in index]; otherwise, <c>false</c>.</value>
[IgnoreDataMember]
public override bool GroupInIndex
{
get
{
return true;
}
}
/// <summary>
/// Override this to return the folder that should be used to construct a container
/// for this item in an index. GroupInIndex should be true as well.
/// </summary>
/// <value>The index container.</value>
[IgnoreDataMember]
public override Folder IndexContainer
{
get
{
2014-02-01 06:18:16 +00:00
return Parents.OfType<MusicAlbum>().FirstOrDefault() ?? new MusicAlbum { Name = "<Unknown>" };
2013-02-21 01:33:05 +00:00
}
}
/// <summary>
/// Gets or sets the artist.
/// </summary>
/// <value>The artist.</value>
public List<string> Artists { get; set; }
[IgnoreDataMember]
public List<string> AllArtists
{
get
{
var list = new List<string>();
if (!string.IsNullOrEmpty(AlbumArtist))
{
list.Add(AlbumArtist);
}
list.AddRange(Artists);
return list;
}
}
2013-02-21 01:33:05 +00:00
/// <summary>
/// Gets or sets the album.
/// </summary>
/// <value>The album.</value>
public string Album { get; set; }
/// <summary>
/// Gets or sets the album artist.
/// </summary>
/// <value>The album artist.</value>
public string AlbumArtist { get; set; }
/// <summary>
/// Gets the type of the media.
/// </summary>
/// <value>The type of the media.</value>
public override string MediaType
{
get
{
return Model.Entities.MediaType.Audio;
}
}
/// <summary>
/// Creates the name of the sort.
/// </summary>
/// <returns>System.String.</returns>
protected override string CreateSortName()
{
2013-04-23 03:56:11 +00:00
return (ParentIndexNumber != null ? ParentIndexNumber.Value.ToString("0000 - ") : "")
+ (IndexNumber != null ? IndexNumber.Value.ToString("0000 - ") : "") + Name;
}
2013-04-22 04:38:03 +00:00
/// <summary>
/// Determines whether the specified name has artist.
/// </summary>
/// <param name="name">The name.</param>
/// <returns><c>true</c> if the specified name has artist; otherwise, <c>false</c>.</returns>
public bool HasArtist(string name)
{
return Artists.Contains(name, StringComparer.OrdinalIgnoreCase) || string.Equals(AlbumArtist, name, StringComparison.OrdinalIgnoreCase);
2013-04-22 04:38:03 +00:00
}
/// <summary>
/// Gets the user data key.
/// </summary>
/// <returns>System.String.</returns>
public override string GetUserDataKey()
{
2014-01-12 06:31:21 +00:00
var parent = FindParent<MusicAlbum>();
if (parent != null)
{
var parentKey = parent.GetUserDataKey();
if (IndexNumber.HasValue)
{
var songKey = (ParentIndexNumber != null ? ParentIndexNumber.Value.ToString("0000 - ") : "")
+ (IndexNumber.Value.ToString("0000 - "));
return parentKey + songKey;
}
}
return base.GetUserDataKey();
}
2013-12-26 16:53:23 +00:00
protected override bool GetBlockUnratedValue(UserConfiguration config)
{
return config.BlockUnratedItems.Contains(UnratedItem.Music);
2013-12-26 16:53:23 +00:00
}
2014-02-07 03:10:13 +00:00
public SongInfo GetLookupInfo()
{
var info = GetItemLookupInfo<SongInfo>();
info.AlbumArtist = AlbumArtist;
info.Album = Album;
info.Artists = Artists;
return info;
}
2013-02-21 01:33:05 +00:00
}
}