aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Providers/Manager
diff options
context:
space:
mode:
authorJoe Rogers <1337joe@gmail.com>2021-12-05 21:33:31 +0100
committerJoe Rogers <1337joe@gmail.com>2022-04-03 23:34:48 +0200
commit8515e8fbd111278cad95430e50904d6721be3a63 (patch)
treeabf0c437870d5b1876c753d4e8ea2b6a5e53ad75 /MediaBrowser.Providers/Manager
parent785cc1bb6ed1cbd3d0c300b9842af6e15167e715 (diff)
Improve image provider sorting
Remove irrelevant check for ILocalImageProvider Providers that are not IHasOrder default to middle, not beginning
Diffstat (limited to 'MediaBrowser.Providers/Manager')
-rw-r--r--MediaBrowser.Providers/Manager/ProviderManager.cs60
1 files changed, 25 insertions, 35 deletions
diff --git a/MediaBrowser.Providers/Manager/ProviderManager.cs b/MediaBrowser.Providers/Manager/ProviderManager.cs
index 1b73574774..855c467208 100644
--- a/MediaBrowser.Providers/Manager/ProviderManager.cs
+++ b/MediaBrowser.Providers/Manager/ProviderManager.cs
@@ -310,31 +310,25 @@ namespace MediaBrowser.Providers.Manager
private IEnumerable<IImageProvider> GetImageProviders(BaseItem item, LibraryOptions libraryOptions, MetadataOptions options, ImageRefreshOptions refreshOptions, bool includeDisabled)
{
- // Avoid implicitly captured closure
- var currentOptions = options;
-
var typeOptions = libraryOptions.GetTypeOptions(item.GetType().Name);
- var typeFetcherOrder = typeOptions?.ImageFetcherOrder;
+ var fetcherOrder = typeOptions?.ImageFetcherOrder ?? options.ImageFetcherOrder;
return ImageProviders.Where(i => CanRefresh(i, item, libraryOptions, refreshOptions, includeDisabled))
- .OrderBy(i =>
- {
- // See if there's a user-defined order
- if (i is not ILocalImageProvider)
- {
- var fetcherOrder = typeFetcherOrder ?? currentOptions.ImageFetcherOrder;
- var index = Array.IndexOf(fetcherOrder, i.Name);
+ .OrderBy(i => GetConfiguredOrder(fetcherOrder, i.Name))
+ .ThenBy(GetOrder);
+ }
- if (index != -1)
- {
- return index;
- }
- }
+ private static int GetConfiguredOrder(string[] order, string providerName)
+ {
+ var index = Array.IndexOf(order, providerName);
- // Not configured. Just return some high number to put it at the end.
- return 100;
- })
- .ThenBy(GetOrder);
+ if (index != -1)
+ {
+ return index;
+ }
+
+ // default to end
+ return int.MaxValue;
}
/// <inheritdoc />
@@ -450,21 +444,6 @@ namespace MediaBrowser.Providers.Manager
}
}
- /// <summary>
- /// Gets the order.
- /// </summary>
- /// <param name="provider">The provider.</param>
- /// <returns>System.Int32.</returns>
- private int GetOrder(IImageProvider provider)
- {
- if (provider is not IHasOrder hasOrder)
- {
- return 0;
- }
-
- return hasOrder.Order;
- }
-
private int GetConfiguredOrder(BaseItem item, IMetadataProvider provider, LibraryOptions libraryOptions, MetadataOptions globalMetadataOptions)
{
// See if there's a user-defined order
@@ -500,6 +479,17 @@ namespace MediaBrowser.Providers.Manager
return 100;
}
+ private static int GetOrder(object provider)
+ {
+ if (provider is IHasOrder hasOrder)
+ {
+ return hasOrder.Order;
+ }
+
+ // after items that want to be first (~0) but before items that want to be last (~100)
+ return 50;
+ }
+
private int GetDefaultOrder(IMetadataProvider provider)
{
if (provider is IHasOrder hasOrder)