@ -125,13 +125,13 @@ namespace MediaBrowser.Controller.Entities
case CollectionType . HomeVideos :
case CollectionType . Games :
case CollectionType . MusicVideos :
{
if ( query . Recursive )
{
return GetResult ( queryParent . GetRecursiveChildren ( user , true ) , queryParent , query ) ;
if ( query . Recursive )
{
return GetResult ( queryParent . GetRecursiveChildren ( user , true ) , queryParent , query ) ;
}
return GetResult ( queryParent . GetChildren ( user , true ) , queryParent , query ) ;
}
return GetResult ( queryParent . GetChildren ( user , true ) , queryParent , query ) ;
}
case CollectionType . Folders :
return GetResult ( user . RootFolder . GetChildren ( user , true ) , queryParent , query ) ;
@ -140,7 +140,7 @@ namespace MediaBrowser.Controller.Entities
return await GetPlaylistsView ( queryParent , user , query ) . ConfigureAwait ( false ) ;
case CollectionType . BoxSets :
return await GetBoxsetView ( queryParent , user , query ) . ConfigureAwait ( false ) ;
return GetBoxsetView ( queryParent , user , query ) ;
case CollectionType . TvShows :
return await GetTvView ( queryParent , user , query ) . ConfigureAwait ( false ) ;
@ -206,7 +206,7 @@ namespace MediaBrowser.Controller.Entities
return GetMusicLatest ( queryParent , user , query ) ;
case SpecialFolder . MusicPlaylists :
return await GetMusicPlaylists ( queryParent , user , query ) . ConfigureAwait ( false ) ;
return GetMusicPlaylists ( queryParent , user , query ) ;
case SpecialFolder . MusicAlbums :
return GetMusicAlbums ( queryParent , user , query ) ;
@ -310,14 +310,14 @@ namespace MediaBrowser.Controller.Entities
private async Task < QueryResult < BaseItem > > GetMusicGenreItems ( Folder queryParent , Folder displayParent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( queryParent , user , new [ ] { CollectionType . Music , CollectionType . MusicVideos } )
. Where ( i = > ! i . IsFolder )
. Where ( i = > i . Genres . Contains ( displayParent . Name , StringComparer . OrdinalIgnoreCase ) )
. OfType < IHasAlbumArtist > ( ) ;
query . Recursive = true ;
query . ParentId = queryParent . Id ;
query . Genres = new [ ] { displayParent . Name } ;
query . SetUser ( user ) ;
var artists = _libraryManager . GetAlbumArtists ( items ) ;
query . IncludeItemTypes = new [ ] { typeof ( MusicAlbum ) . Name } ;
return GetResult( artists , queryParent , query ) ;
return _libraryManager. GetItems Result( query ) ;
}
private QueryResult < BaseItem > GetMusicAlbumArtists ( Folder parent , User user , InternalItemsQuery query )
@ -353,26 +353,36 @@ namespace MediaBrowser.Controller.Entities
return GetResult ( artists , parent , query ) ;
}
private Task< QueryResult< BaseItem > > GetMusicPlaylists ( Folder parent , User user , InternalItemsQuery query )
private QueryResult< BaseItem > GetMusicPlaylists ( Folder parent , User user , InternalItemsQuery query )
{
query . IncludeItemTypes = new [ ] { "Playlist" } ;
query . ParentId = null ;
query . IncludeItemTypes = new [ ] { typeof ( Playlist ) . Name } ;
query . SetUser ( user ) ;
query . Recursive = true ;
return parent. GetItems ( query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMusicAlbums ( Folder parent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Music , CollectionType . MusicVideos } , i = > i is MusicAlbum & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
query . IncludeItemTypes = new [ ] { typeof ( MusicAlbum ) . Name } ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMusicSongs ( Folder parent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Music , CollectionType . MusicVideos } , i = > i is Audio . Audio & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
query . IncludeItemTypes = new [ ] { typeof ( Audio . Audio ) . Name } ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMusicLatest ( Folder parent , User user , InternalItemsQuery query )
@ -389,27 +399,29 @@ namespace MediaBrowser.Controller.Entities
query . SortBy = new string [ ] { } ;
//var items = GetRecursiveChildren(parent, user, new[] { CollectionType.Music, CollectionType.MusicVideos }, i => i is MusicVideo || i is Audio.Audio && FilterItem(i, query));
return PostFilterAndSort ( items , parent , null , query ) ;
}
private QueryResult < BaseItem > GetFavoriteSongs ( Folder parent , User user , InternalItemsQuery query )
{
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . IsFavorite = true ;
query . IncludeItemTypes = new [ ] { typeof ( Audio . Audio ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Music } , i = > i is Audio . Audio & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetFavoriteAlbums ( Folder parent , User user , InternalItemsQuery query )
{
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . IsFavorite = true ;
query . IncludeItemTypes = new [ ] { typeof ( MusicAlbum ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Music } , i = > i is MusicAlbum & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private async Task < QueryResult < BaseItem > > FindPlaylists ( Folder parent , User user , InternalItemsQuery query )
@ -428,19 +440,13 @@ namespace MediaBrowser.Controller.Entities
{
if ( query . Recursive )
{
var recursiveItems = GetRecursiveChildren ( parent , user ,
new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } )
. Where ( i = > i is Movie | | i is BoxSet ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
//var collections = _collectionManager.CollapseItemsWithinBoxSets(recursiveItems, user).ToList() ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name , typeof ( BoxSet ) . Name } ;
//if (collections.Count > 0)
//{
// recursiveItems.AddRange(_collectionManager.CollapseItemsWithinBoxSets(recursiveItems, user));
// recursiveItems = recursiveItems.DistinctBy(i => i.Id).ToList();
//}
return GetResult ( recursiveItems , parent , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
var list = new List < BaseItem > ( ) ;
@ -457,43 +463,51 @@ namespace MediaBrowser.Controller.Entities
private QueryResult < BaseItem > GetFavoriteMovies ( Folder parent , User user , InternalItemsQuery query )
{
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . IsFavorite = true ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } , i = > i is Movie & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetFavoriteSeries ( Folder parent , User user , InternalItemsQuery query )
{
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . IsFavorite = true ;
query . IncludeItemTypes = new [ ] { typeof ( Series ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > i is Series & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetFavoriteEpisodes ( Folder parent , User user , InternalItemsQuery query )
{
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . IsFavorite = true ;
query . IncludeItemTypes = new [ ] { typeof ( Episode ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > i is Episode & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMovieMovies ( Folder parent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } , i = > i is Movie & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name } ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMovieCollections ( Folder parent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } , i = > i is BoxSet & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
return GetBoxsetView ( parent , user , query ) ;
}
private QueryResult < BaseItem > GetMovieLatest ( Folder parent , User user , InternalItemsQuery query )
@ -501,9 +515,13 @@ namespace MediaBrowser.Controller.Entities
query . SortBy = new [ ] { ItemSortBy . DateCreated , ItemSortBy . SortName } ;
query . SortOrder = SortOrder . Descending ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } , i = > i is Movie & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . Limit = GetSpecialItemsLimit ( ) ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name } ;
return PostFilterAndSort ( items , parent , GetSpecialItemsLimit ( ) , query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetMovieResume ( Folder parent , User user , InternalItemsQuery query )
@ -511,10 +529,13 @@ namespace MediaBrowser.Controller.Entities
query . SortBy = new [ ] { ItemSortBy . DatePlayed , ItemSortBy . SortName } ;
query . SortOrder = SortOrder . Descending ;
query . IsResumable = true ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . Limit = GetSpecialItemsLimit ( ) ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } , i = > i is Movie & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , GetSpecialItemsLimit ( ) , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private async Task < QueryResult < BaseItem > > GetMovieGenres ( Folder parent , User user , InternalItemsQuery query )
@ -547,11 +568,14 @@ namespace MediaBrowser.Controller.Entities
private async Task < QueryResult < BaseItem > > GetMovieGenreItems ( Folder queryParent , Folder displayParent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( queryParent , user , new [ ] { CollectionType . Movies , CollectionType . BoxSets , string . Empty } )
. Where ( i = > i is Movie )
. Where ( i = > i . Genres . Contains ( displayParent . Name , StringComparer . OrdinalIgnoreCase ) ) ;
query . Recursive = true ;
query . ParentId = queryParent . Id ;
query . Genres = new [ ] { displayParent . Name } ;
query . SetUser ( user ) ;
query . IncludeItemTypes = new [ ] { typeof ( Movie ) . Name } ;
return GetResult ( items , queryParent , query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private async Task < QueryResult < BaseItem > > GetPlaylistsView ( Folder parent , User user , InternalItemsQuery query )
@ -559,20 +583,27 @@ namespace MediaBrowser.Controller.Entities
return GetResult ( _playlistManager . GetPlaylists ( user . Id . ToString ( "N" ) ) , parent , query ) ;
}
private async Task < QueryResult < BaseItem > > GetBoxsetView ( Folder parent , User user , InternalItemsQuery query )
private QueryResult < BaseItem > GetBoxsetView ( Folder parent , User user , InternalItemsQuery query )
{
var collections = _collectionManager . GetCollections ( user ) ;
query . ParentId = null ;
query . IncludeItemTypes = new [ ] { typeof ( BoxSet ) . Name } ;
query . SetUser ( user ) ;
query . Recursive = true ;
return GetResult ( collections , parent , query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private async Task < QueryResult < BaseItem > > GetTvView ( Folder parent , User user , InternalItemsQuery query )
{
if ( query . Recursive )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > ( i is Series | | i is Season | | i is Episode ) & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
query . IncludeItemTypes = new [ ] { typeof ( Series ) . Name , typeof ( Season ) . Name , typeof ( Episode ) . Name } ;
return _libraryManager . GetItemsResult ( query ) ;
}
var list = new List < BaseItem > ( ) ;
@ -593,9 +624,13 @@ namespace MediaBrowser.Controller.Entities
query . SortBy = new [ ] { ItemSortBy . DateCreated , ItemSortBy . SortName } ;
query . SortOrder = SortOrder . Descending ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > i is Episode & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . Limit = GetSpecialItemsLimit ( ) ;
query . IncludeItemTypes = new [ ] { typeof ( Episode ) . Name } ;
return PostFilterAndSort ( items , parent , GetSpecialItemsLimit ( ) , query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetTvNextUp ( Folder parent , InternalItemsQuery query )
@ -618,17 +653,24 @@ namespace MediaBrowser.Controller.Entities
query . SortBy = new [ ] { ItemSortBy . DatePlayed , ItemSortBy . SortName } ;
query . SortOrder = SortOrder . Descending ;
query . IsResumable = true ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
query . Limit = GetSpecialItemsLimit ( ) ;
query . IncludeItemTypes = new [ ] { typeof ( Episode ) . Name } ;
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > i is Episode & & FilterItem ( i , query ) ) ;
return PostFilterAndSort ( items , parent , GetSpecialItemsLimit ( ) , query ) ;
return _libraryManager . GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetTvSeries ( Folder parent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( parent , user , new [ ] { CollectionType . TvShows , string . Empty } , i = > i is Series & & FilterItem ( i , query ) ) ;
query . Recursive = true ;
query . ParentId = parent . Id ;
query . SetUser ( user ) ;
return PostFilterAndSort ( items , parent , null , query ) ;
query . IncludeItemTypes = new [ ] { typeof ( Series ) . Name } ;
return _libraryManager . GetItemsResult ( query ) ;
}
private async Task < QueryResult < BaseItem > > GetTvGenres ( Folder parent , User user , InternalItemsQuery query )
@ -661,11 +703,14 @@ namespace MediaBrowser.Controller.Entities
private async Task < QueryResult < BaseItem > > GetTvGenreItems ( Folder queryParent , Folder displayParent , User user , InternalItemsQuery query )
{
var items = GetRecursiveChildren ( queryParent , user , new [ ] { CollectionType . TvShows , string . Empty } )
. Where ( i = > i is Series )
. Where ( i = > i . Genres . Contains ( displayParent . Name , StringComparer . OrdinalIgnoreCase ) ) ;
query . Recursive = true ;
query . ParentId = queryParent . Id ;
query . Genres = new [ ] { displayParent . Name } ;
query . SetUser ( user ) ;
query . IncludeItemTypes = new [ ] { typeof ( Series ) . Name } ;
return GetResult ( items , queryParent , query ) ;
return _libraryManager. GetItemsResult ( query ) ;
}
private QueryResult < BaseItem > GetResult < T > ( QueryResult < T > result )
@ -1735,7 +1780,7 @@ namespace MediaBrowser.Controller.Entities
if ( query . SeriesStatuses . Length > 0 )
{
var ok = new [ ] { item } . OfType < Series > ( ) . Any ( p = > p . Status . HasValue & & query . SeriesStatuses . Contains ( p . Status . Value ) ) ;
var ok = new [ ] { item } . OfType < Series > ( ) . Any ( p = > p . Status . HasValue & & query . SeriesStatuses . Contains ( p . Status . Value ) ) ;
if ( ! ok )
{
return false ;