aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/UserViews/DynamicImageProvider.cs
diff options
context:
space:
mode:
authordkanada <dkanada@users.noreply.github.com>2019-12-14 15:20:19 +0900
committerdkanada <dkanada@users.noreply.github.com>2020-06-04 21:32:20 +0900
commitc9c6fe02ab2ddf478bb1fde7cc4b0bf574b2d2b2 (patch)
treeba924906734ef0aef854f034ae87ce7694625151 /Emby.Server.Implementations/UserViews/DynamicImageProvider.cs
parentaa66444264fe0f76349316496fd5a6e8d3431b7d (diff)
move most of the image providers to a single directory
Diffstat (limited to 'Emby.Server.Implementations/UserViews/DynamicImageProvider.cs')
-rw-r--r--Emby.Server.Implementations/UserViews/DynamicImageProvider.cs131
1 files changed, 0 insertions, 131 deletions
diff --git a/Emby.Server.Implementations/UserViews/DynamicImageProvider.cs b/Emby.Server.Implementations/UserViews/DynamicImageProvider.cs
deleted file mode 100644
index e7888595f..000000000
--- a/Emby.Server.Implementations/UserViews/DynamicImageProvider.cs
+++ /dev/null
@@ -1,131 +0,0 @@
-#pragma warning disable CS1591
-
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using Emby.Server.Implementations.Images;
-using MediaBrowser.Common.Configuration;
-using MediaBrowser.Controller.Drawing;
-using MediaBrowser.Controller.Dto;
-using MediaBrowser.Controller.Entities;
-using MediaBrowser.Controller.Entities.Audio;
-using MediaBrowser.Controller.Entities.TV;
-using MediaBrowser.Controller.Library;
-using MediaBrowser.Controller.Providers;
-using MediaBrowser.Model.Entities;
-using MediaBrowser.Model.IO;
-
-namespace Emby.Server.Implementations.UserViews
-{
- public class DynamicImageProvider : BaseDynamicImageProvider<UserView>
- {
- private readonly IUserManager _userManager;
-
- public DynamicImageProvider(IFileSystem fileSystem, IProviderManager providerManager, IApplicationPaths applicationPaths, IImageProcessor imageProcessor, IUserManager userManager)
- : base(fileSystem, providerManager, applicationPaths, imageProcessor)
- {
- _userManager = userManager;
- }
-
- protected override IReadOnlyList<BaseItem> GetItemsWithImages(BaseItem item)
- {
- var view = (UserView)item;
-
- var isUsingCollectionStrip = IsUsingCollectionStrip(view);
- var recursive = isUsingCollectionStrip && !new[] { CollectionType.BoxSets, CollectionType.Playlists }.Contains(view.ViewType ?? string.Empty, StringComparer.OrdinalIgnoreCase);
-
- var result = view.GetItemList(new InternalItemsQuery
- {
- User = view.UserId.HasValue ? _userManager.GetUserById(view.UserId.Value) : null,
- CollapseBoxSetItems = false,
- Recursive = recursive,
- ExcludeItemTypes = new[] { "UserView", "CollectionFolder", "Person" },
- DtoOptions = new DtoOptions(false)
- });
-
- var items = result.Select(i =>
- {
- if (i is Episode episode)
- {
- var series = episode.Series;
- if (series != null)
- {
- return series;
- }
-
- return episode;
- }
-
- if (i is Season season)
- {
- var series = season.Series;
- if (series != null)
- {
- return series;
- }
-
- return season;
- }
-
- if (i is Audio audio)
- {
- var album = audio.AlbumEntity;
- if (album != null && album.HasImage(ImageType.Primary))
- {
- return album;
- }
- }
-
- return i;
-
- }).GroupBy(x => x.Id)
- .Select(x => x.First());
-
- if (isUsingCollectionStrip)
- {
- return items
- .Where(i => i.HasImage(ImageType.Primary) || i.HasImage(ImageType.Thumb))
- .ToList();
- }
-
- return items
- .Where(i => i.HasImage(ImageType.Primary))
- .ToList();
- }
-
- protected override bool Supports(BaseItem item)
- {
- if (item is UserView view)
- {
- return IsUsingCollectionStrip(view);
- }
-
- return false;
- }
-
- private static bool IsUsingCollectionStrip(UserView view)
- {
- string[] collectionStripViewTypes =
- {
- CollectionType.Movies,
- CollectionType.TvShows,
- CollectionType.Playlists
- };
-
- return collectionStripViewTypes.Contains(view.ViewType ?? string.Empty);
- }
-
- protected override string CreateImage(BaseItem item, IReadOnlyCollection<BaseItem> itemsWithImages, string outputPathWithoutExtension, ImageType imageType, int imageIndex)
- {
- if (itemsWithImages.Count == 0)
- {
- return null;
- }
-
- var outputPath = Path.ChangeExtension(outputPathWithoutExtension, ".png");
-
- return CreateThumbCollage(item, itemsWithImages, outputPath, 960, 540);
- }
- }
-}