Top navigation, search delete
This commit is contained in:
@@ -2,18 +2,24 @@ using System.Reactive.Subjects;
|
||||
using FileTime.Core.ContentAccess;
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Models;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
|
||||
namespace FileTime.Core.Timeline;
|
||||
|
||||
public class TimelessContentProvider : ITimelessContentProvider
|
||||
{
|
||||
private readonly IContentProviderRegistry _contentProviderRegistry;
|
||||
private readonly Lazy<IRootContentProvider> _rootContentProvider;
|
||||
|
||||
public BehaviorSubject<PointInTime> CurrentPointInTime { get; } = new(PointInTime.Present);
|
||||
|
||||
public TimelessContentProvider(IContentProviderRegistry contentProviderRegistry)
|
||||
public TimelessContentProvider(
|
||||
IContentProviderRegistry contentProviderRegistry,
|
||||
IServiceProvider serviceProvider
|
||||
)
|
||||
{
|
||||
_contentProviderRegistry = contentProviderRegistry;
|
||||
_rootContentProvider = new Lazy<IRootContentProvider>(serviceProvider.GetRequiredService<IRootContentProvider>);
|
||||
}
|
||||
|
||||
public async Task<IItem> GetItemByFullNameAsync(FullName fullName, PointInTime? pointInTime,
|
||||
@@ -23,6 +29,8 @@ public class TimelessContentProvider : ITimelessContentProvider
|
||||
{
|
||||
//TODO time modifications
|
||||
var contentProviderName = fullName.Path.Split(Constants.SeparatorChar).FirstOrDefault();
|
||||
if (contentProviderName == "") return _rootContentProvider.Value;
|
||||
|
||||
var contentProvider = _contentProviderRegistry.ContentProviders.FirstOrDefault(p => p.Name == contentProviderName);
|
||||
|
||||
if (contentProvider is null)
|
||||
@@ -37,7 +45,7 @@ public class TimelessContentProvider : ITimelessContentProvider
|
||||
{
|
||||
foreach (var contentProvider in _contentProviderRegistry.ContentProviders)
|
||||
{
|
||||
if(!contentProvider.CanHandlePath(nativePath)) continue;
|
||||
if (!contentProvider.CanHandlePath(nativePath)) continue;
|
||||
|
||||
return await contentProvider.GetItemByNativePathAsync(nativePath, pointInTime ?? PointInTime.Present);
|
||||
}
|
||||
@@ -49,7 +57,7 @@ public class TimelessContentProvider : ITimelessContentProvider
|
||||
{
|
||||
foreach (var contentProvider in _contentProviderRegistry.ContentProviders)
|
||||
{
|
||||
if(!contentProvider.CanHandlePath(nativePath)) continue;
|
||||
if (!contentProvider.CanHandlePath(nativePath)) continue;
|
||||
|
||||
return contentProvider.GetFullName(nativePath);
|
||||
}
|
||||
@@ -61,7 +69,7 @@ public class TimelessContentProvider : ITimelessContentProvider
|
||||
{
|
||||
foreach (var contentProvider in _contentProviderRegistry.ContentProviders)
|
||||
{
|
||||
if(!contentProvider.CanHandlePath(fullName)) continue;
|
||||
if (!contentProvider.CanHandlePath(fullName)) continue;
|
||||
|
||||
return contentProvider.GetNativePath(fullName);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user