|
@@ -402,47 +402,31 @@ namespace MediaBrowser.Controller.Entities.TV
|
|
public static IEnumerable<Episode> FilterEpisodesBySeason(IEnumerable<Episode> episodes, Season parentSeason, bool includeSpecials)
|
|
public static IEnumerable<Episode> FilterEpisodesBySeason(IEnumerable<Episode> episodes, Season parentSeason, bool includeSpecials)
|
|
{
|
|
{
|
|
var seasonNumber = parentSeason.IndexNumber;
|
|
var seasonNumber = parentSeason.IndexNumber;
|
|
- if (!includeSpecials || (seasonNumber.HasValue && seasonNumber.Value == 0))
|
|
|
|
- {
|
|
|
|
- var seasonPresentationKey = parentSeason.PresentationUniqueKey;
|
|
|
|
|
|
+ var seasonPresentationKey = parentSeason.PresentationUniqueKey;
|
|
|
|
|
|
- return episodes.Where(i =>
|
|
|
|
- {
|
|
|
|
- if ((i.ParentIndexNumber ?? -1) == seasonNumber)
|
|
|
|
- {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
- if (!i.ParentIndexNumber.HasValue)
|
|
|
|
- {
|
|
|
|
- var season = i.Season;
|
|
|
|
- return season != null && string.Equals(season.PresentationUniqueKey, seasonPresentationKey, StringComparison.OrdinalIgnoreCase);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- return false;
|
|
|
|
- });
|
|
|
|
- }
|
|
|
|
- else
|
|
|
|
- {
|
|
|
|
- var seasonPresentationKey = parentSeason.PresentationUniqueKey;
|
|
|
|
|
|
+ var supportSpecialsInSeason = includeSpecials && seasonNumber.HasValue && seasonNumber.Value != 0;
|
|
|
|
|
|
- return episodes.Where(episode =>
|
|
|
|
|
|
+ return episodes.Where(episode =>
|
|
|
|
+ {
|
|
|
|
+ var currentSeasonNumber = supportSpecialsInSeason ? episode.AiredSeasonNumber : episode.ParentIndexNumber;
|
|
|
|
+ if (currentSeasonNumber.HasValue && seasonNumber.HasValue && currentSeasonNumber.Value == seasonNumber.Value)
|
|
{
|
|
{
|
|
- var currentSeasonNumber = episode.AiredSeasonNumber;
|
|
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
|
|
- if (currentSeasonNumber.HasValue && seasonNumber.HasValue && currentSeasonNumber.Value == seasonNumber.Value)
|
|
|
|
- {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
|
|
+ if (!currentSeasonNumber.HasValue && !seasonNumber.HasValue && parentSeason.LocationType == LocationType.Virtual)
|
|
|
|
+ {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
|
|
- if (!episode.ParentIndexNumber.HasValue)
|
|
|
|
- {
|
|
|
|
- var season = episode.Season;
|
|
|
|
- return season != null && string.Equals(season.PresentationUniqueKey, seasonPresentationKey, StringComparison.OrdinalIgnoreCase);
|
|
|
|
- }
|
|
|
|
|
|
+ if (!episode.ParentIndexNumber.HasValue)
|
|
|
|
+ {
|
|
|
|
+ var season = episode.Season;
|
|
|
|
+ return season != null && string.Equals(season.PresentationUniqueKey, seasonPresentationKey, StringComparison.OrdinalIgnoreCase);
|
|
|
|
+ }
|
|
|
|
|
|
- return false;
|
|
|
|
- });
|
|
|
|
- }
|
|
|
|
|
|
+ return false;
|
|
|
|
+ });
|
|
}
|
|
}
|
|
|
|
|
|
protected override bool GetBlockUnratedValue(UserPolicy config)
|
|
protected override bool GetBlockUnratedValue(UserPolicy config)
|