aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Controller/Entities/Movies/BoxSet.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Controller/Entities/Movies/BoxSet.cs')
-rw-r--r--MediaBrowser.Controller/Entities/Movies/BoxSet.cs69
1 files changed, 55 insertions, 14 deletions
diff --git a/MediaBrowser.Controller/Entities/Movies/BoxSet.cs b/MediaBrowser.Controller/Entities/Movies/BoxSet.cs
index 3999c3e076..8216937cad 100644
--- a/MediaBrowser.Controller/Entities/Movies/BoxSet.cs
+++ b/MediaBrowser.Controller/Entities/Movies/BoxSet.cs
@@ -37,9 +37,7 @@ namespace MediaBrowser.Controller.Entities.Movies
/// <inheritdoc />
[JsonIgnore]
- public IReadOnlyList<BaseItem> LocalTrailers => GetExtras()
- .Where(extra => extra.ExtraType == Model.Entities.ExtraType.Trailer)
- .ToArray();
+ public IReadOnlyList<BaseItem> LocalTrailers => GetExtras([Model.Entities.ExtraType.Trailer]).ToArray();
/// <summary>
/// Gets or sets the display order.
@@ -160,25 +158,68 @@ namespace MediaBrowser.Controller.Entities.Movies
return base.IsVisible(user, skipAllowedTagsCheck);
}
- if (base.IsVisible(user, skipAllowedTagsCheck))
+ if (!IsParentalAllowed(user, skipAllowedTagsCheck))
{
- if (LinkedChildren.Length == 0)
- {
- return true;
- }
+ return false;
+ }
+
+ if (LinkedChildren.Length == 0)
+ {
+ return true;
+ }
+
+ var userLibraryFolderIds = GetLibraryFolderIds(user);
+ var libraryFolderIds = LibraryFolderIds ?? GetLibraryFolderIds();
+
+ if (libraryFolderIds.Length == 0)
+ {
+ return true;
+ }
- var userLibraryFolderIds = GetLibraryFolderIds(user);
- var libraryFolderIds = LibraryFolderIds ?? GetLibraryFolderIds();
+ if (!userLibraryFolderIds.Any(i => libraryFolderIds.Contains(i)))
+ {
+ return false;
+ }
- if (libraryFolderIds.Length == 0)
+ // If user has parental controls, hide the BoxSet when all children are restricted
+ if (user.MaxParentalRatingScore.HasValue)
+ {
+ var linkedItems = GetLinkedChildren();
+ if (linkedItems.Count > 0 && linkedItems.All(child => !child.IsParentalAllowed(user, true)))
{
- return true;
+ return false;
}
+ }
+
+ return true;
+ }
+
+ public override void MarkPlayed(User user, DateTime? datePlayed, bool resetPosition)
+ {
+ if (IsLegacyBoxSet)
+ {
+ base.MarkPlayed(user, datePlayed, resetPosition);
+ return;
+ }
+
+ foreach (var item in GetLinkedChildren(user))
+ {
+ item.MarkPlayed(user, datePlayed, resetPosition);
+ }
+ }
- return userLibraryFolderIds.Any(i => libraryFolderIds.Contains(i));
+ public override void MarkUnplayed(User user)
+ {
+ if (IsLegacyBoxSet)
+ {
+ base.MarkUnplayed(user);
+ return;
}
- return false;
+ foreach (var item in GetLinkedChildren(user))
+ {
+ item.MarkUnplayed(user);
+ }
}
public override bool IsVisibleStandalone(User user)