diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2013-07-27 14:24:48 -0400 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2013-07-27 14:24:48 -0400 |
| commit | 898d55d8663d4426ee03a3f72b2f566585e489c8 (patch) | |
| tree | 5b11a6706951ada619ecd773c426d8e90d6cf795 | |
| parent | a4142e87647cadda1b3a157935e500ade683cc38 (diff) | |
factor collection type in resolving process
4 files changed, 68 insertions, 0 deletions
diff --git a/MediaBrowser.Model/ApiClient/IApiClient.cs b/MediaBrowser.Model/ApiClient/IApiClient.cs index b15d1c1d5..b99773e4d 100644 --- a/MediaBrowser.Model/ApiClient/IApiClient.cs +++ b/MediaBrowser.Model/ApiClient/IApiClient.cs @@ -241,6 +241,22 @@ namespace MediaBrowser.Model.ApiClient Task<BaseItemDto> GetGenreAsync(string name, string userId); /// <summary> + /// Gets the music genre async. + /// </summary> + /// <param name="name">The name.</param> + /// <param name="userId">The user id.</param> + /// <returns>Task{BaseItemDto}.</returns> + Task<BaseItemDto> GetMusicGenreAsync(string name, string userId); + + /// <summary> + /// Gets the game genre async. + /// </summary> + /// <param name="name">The name.</param> + /// <param name="userId">The user id.</param> + /// <returns>Task{BaseItemDto}.</returns> + Task<BaseItemDto> GetGameGenreAsync(string name, string userId); + + /// <summary> /// Gets the artist async. /// </summary> /// <param name="name">The name.</param> diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs index 209ae0e45..0ac0f0533 100644 --- a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs +++ b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs @@ -1,6 +1,8 @@ using MediaBrowser.Controller.Entities.Audio; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Resolvers; +using MediaBrowser.Model.Entities; +using System; using System.Collections.Generic; using System.IO; using System.Linq; @@ -12,6 +14,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio /// </summary> public class MusicAlbumResolver : ItemResolver<MusicAlbum> { + private readonly ILibraryManager _libraryManager; + + public MusicAlbumResolver(ILibraryManager libraryManager) + { + _libraryManager = libraryManager; + } + /// <summary> /// Gets the priority. /// </summary> @@ -35,6 +44,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio if (args.Parent.IsRoot) return null; if (args.Parent is MusicAlbum) return null; + var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent); + + // If there's a collection type and it's not music, it can't be a series + if (!string.IsNullOrEmpty(collectionType) && + !string.Equals(collectionType, CollectionType.Music, StringComparison.OrdinalIgnoreCase)) + { + return null; + } + return IsMusicAlbum(args) ? new MusicAlbum { DisplayMediaType = "Album" diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs index fa34a6a2e..e2c71f613 100644 --- a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs +++ b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs @@ -1,6 +1,8 @@ using MediaBrowser.Controller.Entities.Audio; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Resolvers; +using MediaBrowser.Model.Entities; +using System; using System.IO; using System.Linq; @@ -11,6 +13,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio /// </summary> public class MusicArtistResolver : ItemResolver<MusicArtist> { + private readonly ILibraryManager _libraryManager; + + public MusicArtistResolver(ILibraryManager libraryManager) + { + _libraryManager = libraryManager; + } + /// <summary> /// Gets the priority. /// </summary> @@ -39,6 +48,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio return null; } + var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent); + + // If there's a collection type and it's not music, it can't be a series + if (!string.IsNullOrEmpty(collectionType) && + !string.Equals(collectionType, CollectionType.Music, StringComparison.OrdinalIgnoreCase)) + { + return null; + } + // If we contain an album assume we are an artist folder return args.FileSystemChildren.Where(i => (i.Attributes & FileAttributes.Directory) == FileAttributes.Directory).Any(i => MusicAlbumResolver.IsMusicAlbum(i.FullName)) ? new MusicArtist() : null; } diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs index 10e73b288..9c8f4dceb 100644 --- a/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs +++ b/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs @@ -13,6 +13,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.TV /// </summary> public class SeriesResolver : FolderResolver<Series> { + private readonly ILibraryManager _libraryManager; + + public SeriesResolver(ILibraryManager libraryManager) + { + _libraryManager = libraryManager; + } + /// <summary> /// Gets the priority. /// </summary> @@ -46,6 +53,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.TV return null; } + var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent); + + // If there's a collection type and it's not tv, it can't be a series + if (!string.IsNullOrEmpty(collectionType) && + !string.Equals(collectionType, CollectionType.TvShows, StringComparison.OrdinalIgnoreCase)) + { + return null; + } + // It's a Series if any of the following conditions are met: // series.xml exists // [tvdbid= is present in the path |
