2013-10-01 16:33:50 -07:00
|
|
|
|
using MediaBrowser.Model.Entities;
|
|
|
|
|
using System;
|
2013-09-11 10:54:59 -07:00
|
|
|
|
using System.Collections.Generic;
|
2013-09-10 11:56:00 -07:00
|
|
|
|
using System.Linq;
|
2013-02-20 18:33:05 -07:00
|
|
|
|
using System.Runtime.Serialization;
|
|
|
|
|
|
|
|
|
|
namespace MediaBrowser.Controller.Entities.Audio
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class MusicAlbum
|
|
|
|
|
/// </summary>
|
2013-12-05 09:50:21 -07:00
|
|
|
|
public class MusicAlbum : Folder, IHasAlbumArtist, IHasArtist, IHasMusicGenres, IHasTags
|
2013-02-20 18:33:05 -07:00
|
|
|
|
{
|
2013-11-12 08:36:08 -07:00
|
|
|
|
public List<Guid> SoundtrackIds { get; set; }
|
|
|
|
|
|
2013-09-10 11:56:00 -07:00
|
|
|
|
public MusicAlbum()
|
|
|
|
|
{
|
2013-09-11 10:54:59 -07:00
|
|
|
|
Artists = new List<string>();
|
2013-11-12 08:36:08 -07:00
|
|
|
|
SoundtrackIds = new List<Guid>();
|
2013-12-05 09:50:21 -07:00
|
|
|
|
Tags = new List<string>();
|
2013-09-10 11:56:00 -07:00
|
|
|
|
}
|
|
|
|
|
|
2013-09-06 08:38:22 -07:00
|
|
|
|
public string LastFmImageUrl { get; set; }
|
2013-11-06 09:29:20 -07:00
|
|
|
|
public string LastFmImageSize { get; set; }
|
2013-09-10 11:56:00 -07:00
|
|
|
|
|
2013-12-05 09:50:21 -07:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the tags.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The tags.</value>
|
|
|
|
|
public List<string> Tags { get; set; }
|
|
|
|
|
|
2013-02-20 18:33:05 -07:00
|
|
|
|
/// <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-21 21:38:03 -07:00
|
|
|
|
private static readonly MusicArtist UnknwonArtist = new MusicArtist { Name = "<Unknown>" };
|
2013-02-20 18:33:05 -07: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; }
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-24 07:05:47 -07: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-09-10 11:56:00 -07:00
|
|
|
|
return string.Equals(AlbumArtist, artist, StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| Artists.Contains(artist, StringComparer.OrdinalIgnoreCase);
|
2013-04-27 06:05:33 -07:00
|
|
|
|
}
|
2013-09-06 12:17:15 -07:00
|
|
|
|
|
2013-09-10 11:56:00 -07:00
|
|
|
|
public string AlbumArtist { get; set; }
|
|
|
|
|
|
2013-09-11 10:54:59 -07:00
|
|
|
|
public List<string> Artists { get; set; }
|
2013-10-01 16:33:50 -07:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the user data key.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>System.String.</returns>
|
|
|
|
|
public override string GetUserDataKey()
|
|
|
|
|
{
|
|
|
|
|
var id = this.GetProviderId(MetadataProviders.MusicBrainzReleaseGroup);
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(id))
|
|
|
|
|
{
|
2013-10-04 17:44:43 -07:00
|
|
|
|
return "MusicAlbum-MusicBrainzReleaseGroup-" + id;
|
2013-10-01 16:33:50 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
id = this.GetProviderId(MetadataProviders.Musicbrainz);
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(id))
|
|
|
|
|
{
|
2013-10-04 17:44:43 -07:00
|
|
|
|
return "MusicAlbum-Musicbrainz-" + id;
|
2013-10-01 16:33:50 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return base.GetUserDataKey();
|
|
|
|
|
}
|
2013-02-20 18:33:05 -07:00
|
|
|
|
}
|
2013-09-01 06:13:11 -07:00
|
|
|
|
|
|
|
|
|
public class MusicAlbumDisc : Folder
|
|
|
|
|
{
|
2013-09-10 11:56:00 -07:00
|
|
|
|
|
2013-09-01 06:13:11 -07:00
|
|
|
|
}
|
2013-02-20 18:33:05 -07:00
|
|
|
|
}
|