12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using MediaBrowser.Controller.Entities;
- using MediaBrowser.Controller.Entities.TV;
- using MediaBrowser.Controller.Providers;
- using MediaBrowser.Model.Entities;
- using MediaBrowser.Model.IO;
- namespace MediaBrowser.LocalMetadata.Images
- {
- /// <summary>
- /// Episode local image provider.
- /// </summary>
- public class EpisodeLocalImageProvider : ILocalImageProvider, IHasOrder
- {
- private readonly IFileSystem _fileSystem;
- /// <summary>
- /// Initializes a new instance of the <see cref="EpisodeLocalImageProvider"/> class.
- /// </summary>
- /// <param name="fileSystem">Instance of the <see cref="IFileSystem"/> interface.</param>
- public EpisodeLocalImageProvider(IFileSystem fileSystem)
- {
- _fileSystem = fileSystem;
- }
- /// <inheritdoc />
- public string Name => "Local Images";
- /// <inheritdoc />
- public int Order => 0;
- /// <inheritdoc />
- public bool Supports(BaseItem item)
- {
- return item is Episode && item.SupportsLocalMetadata;
- }
- /// <inheritdoc />
- public IEnumerable<LocalImageInfo> GetImages(BaseItem item, IDirectoryService directoryService)
- {
- var parentPath = Path.GetDirectoryName(item.Path);
- if (parentPath == null)
- {
- return Enumerable.Empty<LocalImageInfo>();
- }
- var parentPathFiles = directoryService.GetFiles(parentPath);
- var nameWithoutExtension = Path.GetFileNameWithoutExtension(item.Path);
- return GetFilesFromParentFolder(nameWithoutExtension, parentPathFiles);
- }
- private List<LocalImageInfo> GetFilesFromParentFolder(string filenameWithoutExtension, List<FileSystemMetadata> parentPathFiles)
- {
- var thumbName = filenameWithoutExtension + "-thumb";
- var list = new List<LocalImageInfo>(1);
- foreach (var i in parentPathFiles)
- {
- if (i.IsDirectory)
- {
- continue;
- }
- if (BaseItem.SupportedImageExtensions.Contains(i.Extension, StringComparer.OrdinalIgnoreCase))
- {
- var currentNameWithoutExtension = _fileSystem.GetFileNameWithoutExtension(i);
- if (string.Equals(filenameWithoutExtension, currentNameWithoutExtension, StringComparison.OrdinalIgnoreCase))
- {
- list.Add(new LocalImageInfo { FileInfo = i, Type = ImageType.Primary });
- }
- else if (string.Equals(thumbName, currentNameWithoutExtension, StringComparison.OrdinalIgnoreCase))
- {
- list.Add(new LocalImageInfo { FileInfo = i, Type = ImageType.Primary });
- }
- }
- }
- return list;
- }
- }
- }
|