mirror of
https://github.com/jellyfin/jellyfin.git
synced 2026-06-04 06:48:35 +01:00
Convert CollectionType, SpecialFolderType to enum (#9764)
* Convert CollectionType, SpecialFolderType to enum * Hide internal enum CollectionType values * Apply suggestions from code review Co-authored-by: Shadowghost <Shadowghost@users.noreply.github.com> * Fix recent change * Update Jellyfin.Data/Attributes/OpenApiIgnoreEnumAttribute.cs Co-authored-by: Patrick Barron <barronpm@gmail.com> --------- Co-authored-by: Shadowghost <Shadowghost@users.noreply.github.com> Co-authored-by: Patrick Barron <barronpm@gmail.com>
This commit is contained in:
@@ -724,7 +724,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
if (this is IHasCollectionType view)
|
||||
{
|
||||
if (string.Equals(view.CollectionType, CollectionType.LiveTv, StringComparison.OrdinalIgnoreCase))
|
||||
if (view.CollectionType == CollectionType.LiveTv)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
#pragma warning disable CS1591
|
||||
|
||||
using System.Text.Json.Serialization;
|
||||
using Jellyfin.Data.Enums;
|
||||
|
||||
namespace MediaBrowser.Controller.Entities
|
||||
{
|
||||
@@ -11,7 +12,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
public abstract class BasePluginFolder : Folder, ICollectionFolder
|
||||
{
|
||||
[JsonIgnore]
|
||||
public virtual string? CollectionType => null;
|
||||
public virtual CollectionType? CollectionType => null;
|
||||
|
||||
[JsonIgnore]
|
||||
public override bool SupportsInheritedParentImages => false;
|
||||
|
||||
@@ -11,6 +11,7 @@ using System.Text.Json;
|
||||
using System.Text.Json.Serialization;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Jellyfin.Data.Enums;
|
||||
using Jellyfin.Extensions.Json;
|
||||
using MediaBrowser.Controller.IO;
|
||||
using MediaBrowser.Controller.Library;
|
||||
@@ -69,7 +70,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
[JsonIgnore]
|
||||
public override bool SupportsInheritedParentImages => false;
|
||||
|
||||
public string CollectionType { get; set; }
|
||||
public CollectionType? CollectionType { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the item's children.
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
#pragma warning disable CA1819, CS1591
|
||||
|
||||
using System;
|
||||
using Jellyfin.Data.Enums;
|
||||
|
||||
namespace MediaBrowser.Controller.Entities
|
||||
{
|
||||
@@ -27,6 +28,6 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
public interface IHasCollectionType
|
||||
{
|
||||
string CollectionType { get; }
|
||||
CollectionType? CollectionType { get; }
|
||||
}
|
||||
}
|
||||
|
||||
@@ -42,7 +42,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
OrderBy = Array.Empty<(ItemSortBy, SortOrder)>();
|
||||
PersonIds = Array.Empty<Guid>();
|
||||
PersonTypes = Array.Empty<string>();
|
||||
PresetViews = Array.Empty<string>();
|
||||
PresetViews = Array.Empty<CollectionType?>();
|
||||
SeriesStatuses = Array.Empty<SeriesStatus>();
|
||||
SourceTypes = Array.Empty<SourceType>();
|
||||
StudioIds = Array.Empty<Guid>();
|
||||
@@ -248,7 +248,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
public Guid[] TopParentIds { get; set; }
|
||||
|
||||
public string[] PresetViews { get; set; }
|
||||
public CollectionType?[] PresetViews { get; set; }
|
||||
|
||||
public TrailerType[] TrailerTypes { get; set; }
|
||||
|
||||
|
||||
@@ -8,6 +8,7 @@ using System.Linq;
|
||||
using System.Text.Json.Serialization;
|
||||
using System.Threading.Tasks;
|
||||
using Jellyfin.Data.Entities;
|
||||
using Jellyfin.Data.Enums;
|
||||
using Jellyfin.Extensions;
|
||||
using MediaBrowser.Controller.TV;
|
||||
using MediaBrowser.Model.Querying;
|
||||
@@ -16,21 +17,21 @@ namespace MediaBrowser.Controller.Entities
|
||||
{
|
||||
public class UserView : Folder, IHasCollectionType
|
||||
{
|
||||
private static readonly string[] _viewTypesEligibleForGrouping = new string[]
|
||||
private static readonly CollectionType?[] _viewTypesEligibleForGrouping =
|
||||
{
|
||||
Model.Entities.CollectionType.Movies,
|
||||
Model.Entities.CollectionType.TvShows,
|
||||
string.Empty
|
||||
Jellyfin.Data.Enums.CollectionType.Movies,
|
||||
Jellyfin.Data.Enums.CollectionType.TvShows,
|
||||
null
|
||||
};
|
||||
|
||||
private static readonly string[] _originalFolderViewTypes = new string[]
|
||||
private static readonly CollectionType?[] _originalFolderViewTypes =
|
||||
{
|
||||
Model.Entities.CollectionType.Books,
|
||||
Model.Entities.CollectionType.MusicVideos,
|
||||
Model.Entities.CollectionType.HomeVideos,
|
||||
Model.Entities.CollectionType.Photos,
|
||||
Model.Entities.CollectionType.Music,
|
||||
Model.Entities.CollectionType.BoxSets
|
||||
Jellyfin.Data.Enums.CollectionType.Books,
|
||||
Jellyfin.Data.Enums.CollectionType.MusicVideos,
|
||||
Jellyfin.Data.Enums.CollectionType.HomeVideos,
|
||||
Jellyfin.Data.Enums.CollectionType.Photos,
|
||||
Jellyfin.Data.Enums.CollectionType.Music,
|
||||
Jellyfin.Data.Enums.CollectionType.BoxSets
|
||||
};
|
||||
|
||||
public static ITVSeriesManager TVSeriesManager { get; set; }
|
||||
@@ -38,7 +39,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
/// <summary>
|
||||
/// Gets or sets the view type.
|
||||
/// </summary>
|
||||
public string ViewType { get; set; }
|
||||
public CollectionType? ViewType { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets or sets the display parent id.
|
||||
@@ -52,7 +53,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
/// <inheritdoc />
|
||||
[JsonIgnore]
|
||||
public string CollectionType => ViewType;
|
||||
public CollectionType? CollectionType => ViewType;
|
||||
|
||||
/// <inheritdoc />
|
||||
[JsonIgnore]
|
||||
@@ -160,7 +161,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
return true;
|
||||
}
|
||||
|
||||
return string.Equals(Model.Entities.CollectionType.Playlists, collectionFolder.CollectionType, StringComparison.OrdinalIgnoreCase);
|
||||
return collectionFolder.CollectionType == Jellyfin.Data.Enums.CollectionType.Playlists;
|
||||
}
|
||||
|
||||
public static bool IsEligibleForGrouping(Folder folder)
|
||||
@@ -169,14 +170,14 @@ namespace MediaBrowser.Controller.Entities
|
||||
&& IsEligibleForGrouping(collectionFolder.CollectionType);
|
||||
}
|
||||
|
||||
public static bool IsEligibleForGrouping(string viewType)
|
||||
public static bool IsEligibleForGrouping(CollectionType? viewType)
|
||||
{
|
||||
return _viewTypesEligibleForGrouping.Contains(viewType ?? string.Empty, StringComparison.OrdinalIgnoreCase);
|
||||
return _viewTypesEligibleForGrouping.Contains(viewType);
|
||||
}
|
||||
|
||||
public static bool EnableOriginalFolder(string viewType)
|
||||
public static bool EnableOriginalFolder(CollectionType? viewType)
|
||||
{
|
||||
return _originalFolderViewTypes.Contains(viewType ?? string.Empty, StringComparison.OrdinalIgnoreCase);
|
||||
return _originalFolderViewTypes.Contains(viewType);
|
||||
}
|
||||
|
||||
protected override Task ValidateChildrenInternal(IProgress<double> progress, bool recursive, bool refreshChildMetadata, Providers.MetadataRefreshOptions refreshOptions, Providers.IDirectoryService directoryService, System.Threading.CancellationToken cancellationToken)
|
||||
|
||||
@@ -42,7 +42,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
_tvSeriesManager = tvSeriesManager;
|
||||
}
|
||||
|
||||
public QueryResult<BaseItem> GetUserItems(Folder queryParent, Folder displayParent, string viewType, InternalItemsQuery query)
|
||||
public QueryResult<BaseItem> GetUserItems(Folder queryParent, Folder displayParent, CollectionType? viewType, InternalItemsQuery query)
|
||||
{
|
||||
var user = query.User;
|
||||
|
||||
@@ -67,49 +67,49 @@ namespace MediaBrowser.Controller.Entities
|
||||
case CollectionType.Movies:
|
||||
return GetMovieFolders(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.TvShowSeries:
|
||||
case CollectionType.TvShowSeries:
|
||||
return GetTvSeries(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.TvGenres:
|
||||
case CollectionType.TvGenres:
|
||||
return GetTvGenres(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.TvGenre:
|
||||
case CollectionType.TvGenre:
|
||||
return GetTvGenreItems(queryParent, displayParent, user, query);
|
||||
|
||||
case SpecialFolder.TvResume:
|
||||
case CollectionType.TvResume:
|
||||
return GetTvResume(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.TvNextUp:
|
||||
case CollectionType.TvNextUp:
|
||||
return GetTvNextUp(queryParent, query);
|
||||
|
||||
case SpecialFolder.TvLatest:
|
||||
case CollectionType.TvLatest:
|
||||
return GetTvLatest(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieFavorites:
|
||||
case CollectionType.MovieFavorites:
|
||||
return GetFavoriteMovies(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieLatest:
|
||||
case CollectionType.MovieLatest:
|
||||
return GetMovieLatest(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieGenres:
|
||||
case CollectionType.MovieGenres:
|
||||
return GetMovieGenres(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieGenre:
|
||||
case CollectionType.MovieGenre:
|
||||
return GetMovieGenreItems(queryParent, displayParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieResume:
|
||||
case CollectionType.MovieResume:
|
||||
return GetMovieResume(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieMovies:
|
||||
case CollectionType.MovieMovies:
|
||||
return GetMovieMovies(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.MovieCollections:
|
||||
case CollectionType.MovieCollections:
|
||||
return GetMovieCollections(user, query);
|
||||
|
||||
case SpecialFolder.TvFavoriteEpisodes:
|
||||
case CollectionType.TvFavoriteEpisodes:
|
||||
return GetFavoriteEpisodes(queryParent, user, query);
|
||||
|
||||
case SpecialFolder.TvFavoriteSeries:
|
||||
case CollectionType.TvFavoriteSeries:
|
||||
return GetFavoriteSeries(queryParent, user, query);
|
||||
|
||||
default:
|
||||
@@ -146,12 +146,12 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
var list = new List<BaseItem>
|
||||
{
|
||||
GetUserView(SpecialFolder.MovieResume, "HeaderContinueWatching", "0", parent),
|
||||
GetUserView(SpecialFolder.MovieLatest, "Latest", "1", parent),
|
||||
GetUserView(SpecialFolder.MovieMovies, "Movies", "2", parent),
|
||||
GetUserView(SpecialFolder.MovieCollections, "Collections", "3", parent),
|
||||
GetUserView(SpecialFolder.MovieFavorites, "Favorites", "4", parent),
|
||||
GetUserView(SpecialFolder.MovieGenres, "Genres", "5", parent)
|
||||
GetUserView(CollectionType.MovieResume, "HeaderContinueWatching", "0", parent),
|
||||
GetUserView(CollectionType.MovieLatest, "Latest", "1", parent),
|
||||
GetUserView(CollectionType.MovieMovies, "Movies", "2", parent),
|
||||
GetUserView(CollectionType.MovieCollections, "Collections", "3", parent),
|
||||
GetUserView(CollectionType.MovieFavorites, "Favorites", "4", parent),
|
||||
GetUserView(CollectionType.MovieGenres, "Genres", "5", parent)
|
||||
};
|
||||
|
||||
return GetResult(list, query);
|
||||
@@ -264,7 +264,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
}
|
||||
})
|
||||
.Where(i => i is not null)
|
||||
.Select(i => GetUserViewWithName(SpecialFolder.MovieGenre, i.SortName, parent));
|
||||
.Select(i => GetUserViewWithName(CollectionType.MovieGenre, i.SortName, parent));
|
||||
|
||||
return GetResult(genres, query);
|
||||
}
|
||||
@@ -303,13 +303,13 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
var list = new List<BaseItem>
|
||||
{
|
||||
GetUserView(SpecialFolder.TvResume, "HeaderContinueWatching", "0", parent),
|
||||
GetUserView(SpecialFolder.TvNextUp, "HeaderNextUp", "1", parent),
|
||||
GetUserView(SpecialFolder.TvLatest, "Latest", "2", parent),
|
||||
GetUserView(SpecialFolder.TvShowSeries, "Shows", "3", parent),
|
||||
GetUserView(SpecialFolder.TvFavoriteSeries, "HeaderFavoriteShows", "4", parent),
|
||||
GetUserView(SpecialFolder.TvFavoriteEpisodes, "HeaderFavoriteEpisodes", "5", parent),
|
||||
GetUserView(SpecialFolder.TvGenres, "Genres", "6", parent)
|
||||
GetUserView(CollectionType.TvResume, "HeaderContinueWatching", "0", parent),
|
||||
GetUserView(CollectionType.TvNextUp, "HeaderNextUp", "1", parent),
|
||||
GetUserView(CollectionType.TvLatest, "Latest", "2", parent),
|
||||
GetUserView(CollectionType.TvShowSeries, "Shows", "3", parent),
|
||||
GetUserView(CollectionType.TvFavoriteSeries, "HeaderFavoriteShows", "4", parent),
|
||||
GetUserView(CollectionType.TvFavoriteEpisodes, "HeaderFavoriteEpisodes", "5", parent),
|
||||
GetUserView(CollectionType.TvGenres, "Genres", "6", parent)
|
||||
};
|
||||
|
||||
return GetResult(list, query);
|
||||
@@ -330,7 +330,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
private QueryResult<BaseItem> GetTvNextUp(Folder parent, InternalItemsQuery query)
|
||||
{
|
||||
var parentFolders = GetMediaFolders(parent, query.User, new[] { CollectionType.TvShows, string.Empty });
|
||||
var parentFolders = GetMediaFolders(parent, query.User, new[] { CollectionType.TvShows });
|
||||
|
||||
var result = _tvSeriesManager.GetNextUp(
|
||||
new NextUpQuery
|
||||
@@ -392,7 +392,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
}
|
||||
})
|
||||
.Where(i => i is not null)
|
||||
.Select(i => GetUserViewWithName(SpecialFolder.TvGenre, i.SortName, parent));
|
||||
.Select(i => GetUserViewWithName(CollectionType.TvGenre, i.SortName, parent));
|
||||
|
||||
return GetResult(genres, query);
|
||||
}
|
||||
@@ -943,7 +943,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
.Where(i => user.IsFolderGrouped(i.Id) && UserView.IsEligibleForGrouping(i));
|
||||
}
|
||||
|
||||
private BaseItem[] GetMediaFolders(User user, IEnumerable<string> viewTypes)
|
||||
private BaseItem[] GetMediaFolders(User user, IEnumerable<CollectionType> viewTypes)
|
||||
{
|
||||
if (user is null)
|
||||
{
|
||||
@@ -952,7 +952,7 @@ namespace MediaBrowser.Controller.Entities
|
||||
{
|
||||
var folder = i as ICollectionFolder;
|
||||
|
||||
return folder is not null && viewTypes.Contains(folder.CollectionType ?? string.Empty, StringComparison.OrdinalIgnoreCase);
|
||||
return folder?.CollectionType is not null && viewTypes.Contains(folder.CollectionType.Value);
|
||||
}).ToArray();
|
||||
}
|
||||
|
||||
@@ -961,11 +961,11 @@ namespace MediaBrowser.Controller.Entities
|
||||
{
|
||||
var folder = i as ICollectionFolder;
|
||||
|
||||
return folder is not null && viewTypes.Contains(folder.CollectionType ?? string.Empty, StringComparison.OrdinalIgnoreCase);
|
||||
return folder?.CollectionType is not null && viewTypes.Contains(folder.CollectionType.Value);
|
||||
}).ToArray();
|
||||
}
|
||||
|
||||
private BaseItem[] GetMediaFolders(Folder parent, User user, IEnumerable<string> viewTypes)
|
||||
private BaseItem[] GetMediaFolders(Folder parent, User user, IEnumerable<CollectionType> viewTypes)
|
||||
{
|
||||
if (parent is null || parent is UserView)
|
||||
{
|
||||
@@ -975,12 +975,12 @@ namespace MediaBrowser.Controller.Entities
|
||||
return new BaseItem[] { parent };
|
||||
}
|
||||
|
||||
private UserView GetUserViewWithName(string type, string sortName, BaseItem parent)
|
||||
private UserView GetUserViewWithName(CollectionType? type, string sortName, BaseItem parent)
|
||||
{
|
||||
return _userViewManager.GetUserSubView(parent.Id, parent.Id.ToString("N", CultureInfo.InvariantCulture), type, sortName);
|
||||
return _userViewManager.GetUserSubView(parent.Id, type, parent.Id.ToString("N", CultureInfo.InvariantCulture), sortName);
|
||||
}
|
||||
|
||||
private UserView GetUserView(string type, string localizationKey, string sortName, BaseItem parent)
|
||||
private UserView GetUserView(CollectionType? type, string localizationKey, string sortName, BaseItem parent)
|
||||
{
|
||||
return _userViewManager.GetUserSubView(parent.Id, type, localizationKey, sortName);
|
||||
}
|
||||
|
||||
@@ -79,7 +79,7 @@ namespace MediaBrowser.Controller.Library
|
||||
IDirectoryService directoryService,
|
||||
Folder parent,
|
||||
LibraryOptions libraryOptions,
|
||||
string collectionType = null);
|
||||
CollectionType? collectionType = null);
|
||||
|
||||
/// <summary>
|
||||
/// Gets a Person.
|
||||
@@ -256,28 +256,28 @@ namespace MediaBrowser.Controller.Library
|
||||
/// </summary>
|
||||
/// <param name="item">The item.</param>
|
||||
/// <returns>System.String.</returns>
|
||||
string GetContentType(BaseItem item);
|
||||
CollectionType? GetContentType(BaseItem item);
|
||||
|
||||
/// <summary>
|
||||
/// Gets the type of the inherited content.
|
||||
/// </summary>
|
||||
/// <param name="item">The item.</param>
|
||||
/// <returns>System.String.</returns>
|
||||
string GetInheritedContentType(BaseItem item);
|
||||
CollectionType? GetInheritedContentType(BaseItem item);
|
||||
|
||||
/// <summary>
|
||||
/// Gets the type of the configured content.
|
||||
/// </summary>
|
||||
/// <param name="item">The item.</param>
|
||||
/// <returns>System.String.</returns>
|
||||
string GetConfiguredContentType(BaseItem item);
|
||||
CollectionType? GetConfiguredContentType(BaseItem item);
|
||||
|
||||
/// <summary>
|
||||
/// Gets the type of the configured content.
|
||||
/// </summary>
|
||||
/// <param name="path">The path.</param>
|
||||
/// <returns>System.String.</returns>
|
||||
string GetConfiguredContentType(string path);
|
||||
CollectionType? GetConfiguredContentType(string path);
|
||||
|
||||
/// <summary>
|
||||
/// Normalizes the root path list.
|
||||
@@ -329,7 +329,7 @@ namespace MediaBrowser.Controller.Library
|
||||
User user,
|
||||
string name,
|
||||
Guid parentId,
|
||||
string viewType,
|
||||
CollectionType? viewType,
|
||||
string sortName);
|
||||
|
||||
/// <summary>
|
||||
@@ -343,7 +343,7 @@ namespace MediaBrowser.Controller.Library
|
||||
UserView GetNamedView(
|
||||
User user,
|
||||
string name,
|
||||
string viewType,
|
||||
CollectionType? viewType,
|
||||
string sortName);
|
||||
|
||||
/// <summary>
|
||||
@@ -355,7 +355,7 @@ namespace MediaBrowser.Controller.Library
|
||||
/// <returns>The named view.</returns>
|
||||
UserView GetNamedView(
|
||||
string name,
|
||||
string viewType,
|
||||
CollectionType viewType,
|
||||
string sortName);
|
||||
|
||||
/// <summary>
|
||||
@@ -370,7 +370,7 @@ namespace MediaBrowser.Controller.Library
|
||||
UserView GetNamedView(
|
||||
string name,
|
||||
Guid parentId,
|
||||
string viewType,
|
||||
CollectionType? viewType,
|
||||
string sortName,
|
||||
string uniqueId);
|
||||
|
||||
@@ -383,7 +383,7 @@ namespace MediaBrowser.Controller.Library
|
||||
/// <returns>The shadow view.</returns>
|
||||
UserView GetShadowView(
|
||||
BaseItem parent,
|
||||
string viewType,
|
||||
CollectionType? viewType,
|
||||
string sortName);
|
||||
|
||||
/// <summary>
|
||||
|
||||
@@ -4,6 +4,7 @@
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using Jellyfin.Data.Enums;
|
||||
using MediaBrowser.Controller.Dto;
|
||||
using MediaBrowser.Controller.Entities;
|
||||
using MediaBrowser.Model.Library;
|
||||
@@ -28,7 +29,7 @@ namespace MediaBrowser.Controller.Library
|
||||
/// <param name="localizationKey">Localization key to use.</param>
|
||||
/// <param name="sortName">Sort to use.</param>
|
||||
/// <returns>User view.</returns>
|
||||
UserView GetUserSubView(Guid parentId, string type, string localizationKey, string sortName);
|
||||
UserView GetUserSubView(Guid parentId, CollectionType? type, string localizationKey, string sortName);
|
||||
|
||||
/// <summary>
|
||||
/// Gets latest items.
|
||||
|
||||
@@ -5,6 +5,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using Jellyfin.Data.Enums;
|
||||
using MediaBrowser.Controller.Entities;
|
||||
using MediaBrowser.Model.Configuration;
|
||||
using MediaBrowser.Model.IO;
|
||||
@@ -120,7 +121,7 @@ namespace MediaBrowser.Controller.Library
|
||||
}
|
||||
}
|
||||
|
||||
public string CollectionType { get; set; }
|
||||
public CollectionType? CollectionType { get; set; }
|
||||
|
||||
public bool HasParent<T>()
|
||||
where T : Folder
|
||||
@@ -220,7 +221,7 @@ namespace MediaBrowser.Controller.Library
|
||||
return GetFileSystemEntryByName(name) is not null;
|
||||
}
|
||||
|
||||
public string GetCollectionType()
|
||||
public CollectionType? GetCollectionType()
|
||||
{
|
||||
return CollectionType;
|
||||
}
|
||||
@@ -229,7 +230,7 @@ namespace MediaBrowser.Controller.Library
|
||||
/// Gets the configured content type for the path.
|
||||
/// </summary>
|
||||
/// <returns>The configured content type.</returns>
|
||||
public string GetConfiguredContentType()
|
||||
public CollectionType? GetConfiguredContentType()
|
||||
{
|
||||
return _libraryManager.GetConfiguredContentType(Path);
|
||||
}
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
#pragma warning disable CS1591
|
||||
|
||||
using System.Collections.Generic;
|
||||
using Jellyfin.Data.Enums;
|
||||
using MediaBrowser.Controller.Entities;
|
||||
using MediaBrowser.Controller.Library;
|
||||
using MediaBrowser.Controller.Providers;
|
||||
@@ -32,7 +33,7 @@ namespace MediaBrowser.Controller.Resolvers
|
||||
MultiItemResolverResult ResolveMultiple(
|
||||
Folder parent,
|
||||
List<FileSystemMetadata> files,
|
||||
string collectionType,
|
||||
CollectionType? collectionType,
|
||||
IDirectoryService directoryService);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user