Episode.cs 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. using MediaBrowser.Common.Extensions;
  2. using MediaBrowser.Model.Entities;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Runtime.Serialization;
  7. namespace MediaBrowser.Controller.Entities.TV
  8. {
  9. /// <summary>
  10. /// Class Episode
  11. /// </summary>
  12. public class Episode : Video
  13. {
  14. /// <summary>
  15. /// Episodes have a special Metadata folder
  16. /// </summary>
  17. /// <value>The meta location.</value>
  18. [IgnoreDataMember]
  19. public override string MetaLocation
  20. {
  21. get
  22. {
  23. return System.IO.Path.Combine(Parent.Path, "metadata");
  24. }
  25. }
  26. /// <summary>
  27. /// We want to group into series not show individually in an index
  28. /// </summary>
  29. /// <value><c>true</c> if [group in index]; otherwise, <c>false</c>.</value>
  30. [IgnoreDataMember]
  31. public override bool GroupInIndex
  32. {
  33. get { return true; }
  34. }
  35. /// <summary>
  36. /// We roll up into series
  37. /// </summary>
  38. /// <value>The index container.</value>
  39. [IgnoreDataMember]
  40. public override Folder IndexContainer
  41. {
  42. get
  43. {
  44. return Season;
  45. }
  46. }
  47. /// <summary>
  48. /// Gets the user data key.
  49. /// </summary>
  50. /// <returns>System.String.</returns>
  51. public override string GetUserDataKey()
  52. {
  53. if (Series != null && ParentIndexNumber.HasValue && IndexNumber.HasValue)
  54. {
  55. return Series.GetUserDataKey() + ParentIndexNumber.Value.ToString("000") + IndexNumber.Value.ToString("000");
  56. }
  57. return base.GetUserDataKey();
  58. }
  59. /// <summary>
  60. /// Override this if you need to combine/collapse person information
  61. /// </summary>
  62. /// <value>All people.</value>
  63. [IgnoreDataMember]
  64. public override IEnumerable<PersonInfo> AllPeople
  65. {
  66. get
  67. {
  68. if (People == null) return Series != null ? Series.People : People;
  69. return Series != null && Series.People != null ? People.Concat(Series.People) : base.AllPeople;
  70. }
  71. }
  72. /// <summary>
  73. /// Gets or sets the studios.
  74. /// </summary>
  75. /// <value>The studios.</value>
  76. [IgnoreDataMember]
  77. public override List<string> Studios
  78. {
  79. get
  80. {
  81. return Series != null ? Series.Studios : null;
  82. }
  83. set
  84. {
  85. base.Studios = value;
  86. }
  87. }
  88. /// <summary>
  89. /// Gets or sets the genres.
  90. /// </summary>
  91. /// <value>The genres.</value>
  92. [IgnoreDataMember]
  93. public override List<string> Genres
  94. {
  95. get { return Series != null ? Series.Genres : null; }
  96. set
  97. {
  98. base.Genres = value;
  99. }
  100. }
  101. /// <summary>
  102. /// Our rating comes from our series
  103. /// </summary>
  104. public override string OfficialRating
  105. {
  106. get { return Series != null ? Series.OfficialRating : base.OfficialRating; }
  107. set
  108. {
  109. base.OfficialRating = value;
  110. }
  111. }
  112. /// <summary>
  113. /// Our rating comes from our series
  114. /// </summary>
  115. public override string CustomRating
  116. {
  117. get { return Series != null ? Series.CustomRating : base.CustomRating; }
  118. set
  119. {
  120. base.CustomRating = value;
  121. }
  122. }
  123. /// <summary>
  124. /// We persist the MB Id of our series object so we can always find it no matter
  125. /// what context we happen to be loaded from.
  126. /// </summary>
  127. /// <value>The series item id.</value>
  128. public Guid SeriesItemId { get; set; }
  129. /// <summary>
  130. /// We persist the MB Id of our season object so we can always find it no matter
  131. /// what context we happen to be loaded from.
  132. /// </summary>
  133. /// <value>The season item id.</value>
  134. public Guid SeasonItemId { get; set; }
  135. /// <summary>
  136. /// The _series
  137. /// </summary>
  138. private Series _series;
  139. /// <summary>
  140. /// This Episode's Series Instance
  141. /// </summary>
  142. /// <value>The series.</value>
  143. [IgnoreDataMember]
  144. public Series Series
  145. {
  146. get { return _series ?? (_series = FindParent<Series>()); }
  147. }
  148. /// <summary>
  149. /// The _season
  150. /// </summary>
  151. private Season _season;
  152. /// <summary>
  153. /// This Episode's Season Instance
  154. /// </summary>
  155. /// <value>The season.</value>
  156. [IgnoreDataMember]
  157. public Season Season
  158. {
  159. get { return _season ?? (_season = FindParent<Season>()); }
  160. }
  161. /// <summary>
  162. /// This is the ending episode number for double episodes.
  163. /// </summary>
  164. /// <value>The index number.</value>
  165. public int? IndexNumberEnd { get; set; }
  166. /// <summary>
  167. /// Creates the name of the sort.
  168. /// </summary>
  169. /// <returns>System.String.</returns>
  170. protected override string CreateSortName()
  171. {
  172. return (ParentIndexNumber != null ? ParentIndexNumber.Value.ToString("000-") : "")
  173. + (IndexNumber != null ? IndexNumber.Value.ToString("0000 - ") : "") + Name;
  174. }
  175. }
  176. }