Display specials within seasons

This commit is contained in:
Luke Pulverenti 2013-11-15 16:31:33 -05:00
parent cc16fd3af8
commit a09e330d4e
12 changed files with 172 additions and 4 deletions

View File

@ -202,6 +202,9 @@ namespace MediaBrowser.Api.UserLibrary
[ApiMember(Name = "MinCriticRating", Description = "Optional filter by minimum critic rating.", IsRequired = false, DataType = "int", ParameterType = "query", Verb = "GET")] [ApiMember(Name = "MinCriticRating", Description = "Optional filter by minimum critic rating.", IsRequired = false, DataType = "int", ParameterType = "query", Verb = "GET")]
public double? MinCriticRating { get; set; } public double? MinCriticRating { get; set; }
[ApiMember(Name = "AiredDuringSeason", Description = "Gets all episodes that aired during a season, including specials.", IsRequired = false, DataType = "int", ParameterType = "query", Verb = "GET")]
public int? AiredDuringSeason { get; set; }
} }
/// <summary> /// <summary>
@ -1000,6 +1003,25 @@ namespace MediaBrowser.Api.UserLibrary
}); });
} }
if (request.AiredDuringSeason.HasValue)
{
var val = request.AiredDuringSeason.Value;
items = items.Where(i =>
{
var episode = i as Episode;
if (episode != null)
{
var seasonNumber = episode.SpecialSeasonNumber ?? episode.ParentIndexNumber;
return seasonNumber.HasValue && seasonNumber.Value == val;
}
return false;
});
}
return items; return items;
} }

View File

@ -796,7 +796,7 @@ namespace MediaBrowser.Controller.Entities
foreach (var tuple in list) foreach (var tuple in list)
{ {
if (tasks.Count > 7) if (tasks.Count > 10)
{ {
await Task.WhenAll(tasks).ConfigureAwait(false); await Task.WhenAll(tasks).ConfigureAwait(false);
} }
@ -873,7 +873,8 @@ namespace MediaBrowser.Controller.Entities
progress.Report((90 * percent) + 10); progress.Report((90 * percent) + 10);
} }
} }
}));
}, cancellationToken));
} }
cancellationToken.ThrowIfCancellationRequested(); cancellationToken.ThrowIfCancellationRequested();

View File

@ -32,6 +32,12 @@ namespace MediaBrowser.Controller.Entities.TV
} }
} }
/// <summary>
/// Gets the season in which it aired.
/// </summary>
/// <value>The aired season.</value>
public int? SpecialSeasonNumber { get; set; }
/// <summary> /// <summary>
/// We want to group into series not show individually in an index /// We want to group into series not show individually in an index
/// </summary> /// </summary>

View File

@ -30,6 +30,12 @@ namespace MediaBrowser.Model.Dto
/// <value>The date created.</value> /// <value>The date created.</value>
public DateTime? DateCreated { get; set; } public DateTime? DateCreated { get; set; }
/// <summary>
/// Gets or sets the special season number.
/// </summary>
/// <value>The special season number.</value>
public int? SpecialSeasonNumber { get; set; }
/// <summary> /// <summary>
/// Gets or sets the name of the sort. /// Gets or sets the name of the sort.
/// </summary> /// </summary>

View File

@ -0,0 +1,23 @@
using System.Collections.Generic;
namespace MediaBrowser.Model.LiveTv
{
public class ChannelGuide
{
/// <summary>
/// Gets or sets the name of the service.
/// </summary>
/// <value>The name of the service.</value>
public string ServiceName { get; set; }
/// <summary>
/// ChannelId for the EPG.
/// </summary>
public string ChannelId { get; set; }
/// <summary>
/// List of all the programs for a specific channel
/// </summary>
public List<ProgramInfo> Programs { get; set; }
}
}

View File

@ -0,0 +1,37 @@
using System;
namespace MediaBrowser.Model.LiveTv
{
public class ProgramInfo
{
/// <summary>
/// Id of the program.
/// </summary>
public string Id { get; set; }
/// <summary>
/// Name of the program
/// </summary>
public string Name { get; set; }
/// <summary>
/// Description of the progam.
/// </summary>
public string Description { get; set; }
/// <summary>
/// The start date of the program, in UTC.
/// </summary>
public DateTime StartDate { get; set; }
/// <summary>
/// The end date of the program, in UTC.
/// </summary>
public DateTime EndDate { get; set; }
/// <summary>
/// Genre of the program.
/// </summary>
public string Genre { get; set; }
}
}

View File

@ -0,0 +1,14 @@
namespace MediaBrowser.Model.LiveTv
{
/// <summary>
/// Class RecordingQuery.
/// </summary>
public class RecordingQuery
{
/// <summary>
/// Gets or sets a value indicating whether this instance has recorded.
/// </summary>
/// <value><c>null</c> if [has recorded] contains no value, <c>true</c> if [has recorded]; otherwise, <c>false</c>.</value>
public bool? HasRecorded { get; set; }
}
}

View File

@ -265,6 +265,8 @@ namespace MediaBrowser.Model.Querying
public double? MinCommunityRating { get; set; } public double? MinCommunityRating { get; set; }
public double? MinCriticRating { get; set; } public double? MinCriticRating { get; set; }
public int? AiredDuringSeason { get; set; }
/// <summary> /// <summary>
/// Initializes a new instance of the <see cref="ItemQuery" /> class. /// Initializes a new instance of the <see cref="ItemQuery" /> class.
/// </summary> /// </summary>

View File

@ -75,6 +75,11 @@ namespace MediaBrowser.Providers.Savers
{ {
builder.Append("<EpisodeNumberEnd>" + SecurityElement.Escape(episode.IndexNumberEnd.Value.ToString(_usCulture)) + "</EpisodeNumberEnd>"); builder.Append("<EpisodeNumberEnd>" + SecurityElement.Escape(episode.IndexNumberEnd.Value.ToString(_usCulture)) + "</EpisodeNumberEnd>");
} }
if (episode.SpecialSeasonNumber.HasValue)
{
builder.Append("<SpecialSeasonNumber>" + SecurityElement.Escape(episode.SpecialSeasonNumber.Value.ToString(_usCulture)) + "</SpecialSeasonNumber>");
}
if (episode.ParentIndexNumber.HasValue) if (episode.ParentIndexNumber.HasValue)
{ {
@ -99,7 +104,8 @@ namespace MediaBrowser.Providers.Savers
"SeasonNumber", "SeasonNumber",
"EpisodeNumber", "EpisodeNumber",
"EpisodeName", "EpisodeName",
"EpisodeNumberEnd" "EpisodeNumberEnd",
"SpecialSeasonNumber"
}); });
// Set last refreshed so that the provider doesn't trigger after the file save // Set last refreshed so that the provider doesn't trigger after the file save

View File

@ -139,6 +139,22 @@ namespace MediaBrowser.Providers.TV
break; break;
} }
case "SpecialSeasonNumber":
{
var number = reader.ReadElementContentAsString();
if (!string.IsNullOrWhiteSpace(number))
{
int num;
if (int.TryParse(number, out num))
{
item.SpecialSeasonNumber = num;
}
}
break;
}
case "EpisodeName": case "EpisodeName":
{ {
var name = reader.ReadElementContentAsString(); var name = reader.ReadElementContentAsString();

View File

@ -113,7 +113,7 @@ namespace MediaBrowser.Providers.TV
{ {
get get
{ {
return "1"; return "3";
} }
} }
@ -404,6 +404,40 @@ namespace MediaBrowser.Providers.TV
break; break;
} }
case "airsafter_season":
{
var val = reader.ReadElementContentAsString();
if (!string.IsNullOrWhiteSpace(val))
{
int rval;
// int.TryParse is local aware, so it can be probamatic, force us culture
if (int.TryParse(val, NumberStyles.Integer, _usCulture, out rval))
{
item.SpecialSeasonNumber = rval;
}
}
break;
}
case "airsbefore_season":
{
var val = reader.ReadElementContentAsString();
if (!string.IsNullOrWhiteSpace(val))
{
int rval;
// int.TryParse is local aware, so it can be probamatic, force us culture
if (int.TryParse(val, NumberStyles.Integer, _usCulture, out rval))
{
item.SpecialSeasonNumber = rval;
}
}
break;
}
case "EpisodeName": case "EpisodeName":
{ {
if (!item.LockedFields.Contains(MetadataFields.Name)) if (!item.LockedFields.Contains(MetadataFields.Name))

View File

@ -1029,6 +1029,7 @@ namespace MediaBrowser.Server.Implementations.Dto
if (episode != null) if (episode != null)
{ {
dto.IndexNumberEnd = episode.IndexNumberEnd; dto.IndexNumberEnd = episode.IndexNumberEnd;
dto.SpecialSeasonNumber = episode.SpecialSeasonNumber;
} }
// Add SeriesInfo // Add SeriesInfo