Changing to only load vaults on demand

This commit is contained in:
TheXamlGuy
2024-04-27 14:24:28 +01:00
parent 270268cc59
commit 20840cbf9c
12 changed files with 39 additions and 40 deletions
+2
View File
@@ -39,6 +39,8 @@ public partial class App : Application
services.AddHandler<VaultHandler>();
services.AddTemplate<MainViewModel, MainView>("Main");
services.AddTemplate<VaultNavigationViewModel, VaultNavigationView>();
services.AddHandler<VaultNavigationViewModelHandler>();
services.AddTransient<FooterViewModel>();
+1 -2
View File
@@ -9,9 +9,8 @@ public class VaultComponent :
ComponentBuilder.Create()
.AddServices(services =>
{
services.AddInitializer<VaultInitializer>();
// services.AddInitializer<VaultInitializer>();
services.AddTemplate<VaultNavigationViewModel, VaultNavigationView>();
services.AddTemplate<AllNavigationViewModel, AllNavigationView>();
services.AddTemplate<StarredNavigationViewModel, StarredNavigationView>();
services.AddTemplate<CategoriesNavigationViewModel, CategoriesNavigationView>();
+1 -1
View File
@@ -9,4 +9,4 @@ public class AllNavigationViewModel(IServiceProvider provider,
ISubscriber subscriber,
IDisposer disposer) :
ObservableViewModel(provider, factory, mediator, publisher, subscriber, disposer),
IMainNavigationViewModel;
IVaultNavigationViewModel;
+1 -1
View File
@@ -9,4 +9,4 @@ public class ArchiveNavigationViewModel(IServiceProvider provider,
ISubscriber subscriber,
IDisposer disposer) :
ObservableViewModel(provider, factory, mediator, publisher, subscriber, disposer),
IMainNavigationViewModel;
IVaultNavigationViewModel;
+1 -1
View File
@@ -9,4 +9,4 @@ public class CategoriesNavigationViewModel(IServiceProvider provider,
ISubscriber subscriber,
IDisposer disposer) :
ObservableViewModel(provider, factory, mediator, publisher, subscriber, disposer),
IMainNavigationViewModel;
IVaultNavigationViewModel;
+1 -2
View File
@@ -19,7 +19,6 @@ public partial class CreateVaultViewModel(IServiceProvider provider,
public async Task<bool> Confirm()
{
await Publisher.Publish(Create.As(new Vault(Name)));
return true;
return await Mediator.Handle<Create<Vault>, bool>(Create.As(new Vault(Name)));
}
}
+1 -1
View File
@@ -1,3 +1,3 @@
namespace Bitvault;
public interface IMainNavigationViewModel;
public interface IMainNavigationViewModel;
+3
View File
@@ -0,0 +1,3 @@
namespace Bitvault;
public interface IVaultNavigationViewModel;
+1 -1
View File
@@ -9,4 +9,4 @@ public class StarredNavigationViewModel(IServiceProvider provider,
ISubscriber subscriber,
IDisposer disposer) :
ObservableViewModel(provider, factory, mediator, publisher, subscriber, disposer),
IMainNavigationViewModel;
IVaultNavigationViewModel;
+19 -17
View File
@@ -1,35 +1,37 @@
using Toolkit.Foundation;
using LiteDB;
using Toolkit.Foundation;
namespace Bitvault;
public class VaultStorageHandler :
INotificationHandler<Create<VaultStorage>>
IHandler<Create<VaultStorage>, bool>
{
public Task Handle(Create<VaultStorage> args,
CancellationToken cancellationToken = default)
public Task<bool> Handle(Create<VaultStorage> args, CancellationToken cancellationToken)
{
throw new NotImplementedException();
}
}
public class DatabaseFactory
{
}
public record VaultStorage(string Name);
public class VaultHandler(IVaultFactory factory) :
IHandler<Create<Vault>, bool>
{
//public async Task Handle(Create<Vault> args,
// CancellationToken cancellationToken = default)
//{
// if (args.Value is Vault vault)
// {
// if (factory.Create($"Vault:{vault.Name}", new VaultConfiguration { Name = vault.Name }) is IComponentHost host)
// {
// await host.StartAsync(cancellationToken);
// }
// }
//}
public Task<bool> Handle(Create<Vault> args, CancellationToken cancellationToken)
public async Task<bool> Handle(Create<Vault> args, CancellationToken cancellationToken)
{
throw new NotImplementedException();
if (args.Value is Vault vault)
{
if (factory.Create($"Vault:{vault.Name}", new VaultConfiguration { Name = vault.Name }) is IComponentHost host)
{
await host.StartAsync(cancellationToken);
}
}
return true;
}
}
+1 -1
View File
@@ -4,7 +4,7 @@ using Toolkit.Foundation;
namespace Bitvault;
public partial class VaultNavigationViewModel :
ObservableCollectionViewModel<IMainNavigationViewModel>,
ObservableCollectionViewModel<IVaultNavigationViewModel>,
IMainNavigationViewModel,
INotificationHandler<Unlocked>,
INotificationHandler<Locked>
+7 -13
View File
@@ -1,27 +1,21 @@
using Microsoft.Extensions.DependencyInjection;
using Toolkit.Foundation;
using Toolkit.Foundation;
namespace Bitvault;
public class VaultNavigationViewModelHandler(IPublisher publisher,
IVaultHostCollection vaults) :
IServiceFactory factory,
IEnumerable<IConfigurationDescriptor<VaultConfiguration>> descriptors) :
INotificationHandler<Enumerate<IMainNavigationViewModel>>
{
public async Task Handle(Enumerate<IMainNavigationViewModel> args,
CancellationToken cancellationToken = default)
{
foreach (IComponentHost vault in vaults)
foreach (IConfigurationDescriptor<VaultConfiguration> descriptor in descriptors)
{
if (vault.Services.GetRequiredService<VaultConfiguration>() is VaultConfiguration configuration)
if (factory.Create<VaultNavigationViewModel>(descriptor.Value.Name) is VaultNavigationViewModel viewModel)
{
if (vault.Services.GetRequiredService<IServiceFactory>() is IServiceFactory factory)
{
if (factory.Create<VaultNavigationViewModel>(configuration.Name) is VaultNavigationViewModel viewModel)
{
await publisher.Publish(new Create<IMainNavigationViewModel>(viewModel),
nameof(MainViewModel), cancellationToken);
}
}
await publisher.Publish(new Create<IMainNavigationViewModel>(viewModel),
nameof(MainViewModel), cancellationToken);
}
}
}