jellyfin/MediaBrowser.Controller/Entities/Audio/MusicAlbum.cs

102 lines
3.1 KiB
C#
Raw Normal View History

2013-08-03 13:24:23 +00:00
using MediaBrowser.Model.Entities;
using System.Collections.Generic;
2013-02-21 01:33:05 +00:00
using System.Linq;
using System.Runtime.Serialization;
namespace MediaBrowser.Controller.Entities.Audio
{
/// <summary>
/// Class MusicAlbum
/// </summary>
public class MusicAlbum : Folder
{
/// <summary>
/// Songs will group into us so don't also include us in the index
/// </summary>
/// <value><c>true</c> if [include in index]; otherwise, <c>false</c>.</value>
[IgnoreDataMember]
public override bool IncludeInIndex
{
get
{
return false;
}
}
/// <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>
/// The unknwon artist
/// </summary>
2013-04-22 04:38:03 +00:00
private static readonly MusicArtist UnknwonArtist = new MusicArtist { Name = "<Unknown>" };
2013-02-21 01:33:05 +00:00
/// <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 { return Parent as MusicArtist ?? UnknwonArtist; }
}
/// <summary>
/// Gets or sets the images.
/// </summary>
/// <value>The images.</value>
public override Dictionary<ImageType, string> Images
{
get
{
var images = base.Images;
string primaryImagePath;
if (!images.TryGetValue(ImageType.Primary, out primaryImagePath))
{
var image = Children.Select(c => c.PrimaryImagePath).FirstOrDefault(c => !string.IsNullOrEmpty(c));
if (!string.IsNullOrEmpty(image))
{
images[ImageType.Primary] = image;
}
}
return images;
}
set
{
base.Images = value;
}
}
2013-04-24 14:05:47 +00:00
/// <summary>
/// Determines whether the specified artist has artist.
/// </summary>
/// <param name="artist">The artist.</param>
/// <returns><c>true</c> if the specified artist has artist; otherwise, <c>false</c>.</returns>
public bool HasArtist(string artist)
{
2013-04-27 13:05:33 +00:00
return RecursiveChildren.OfType<Audio>().Any(i => i.HasArtist(artist));
}
2013-05-03 01:35:50 +00:00
/// <summary>
/// Gets or sets the music brainz release group id.
/// </summary>
/// <value>The music brainz release group id.</value>
public string MusicBrainzReleaseGroupId { get; set; }
2013-02-21 01:33:05 +00:00
}
}