Added ConfigurationValueViewModel and AddValueTemplate extension
This commit is contained in:
@@ -0,0 +1,29 @@
|
||||
namespace Toolkit.Foundation;
|
||||
|
||||
public partial class ConfigurationValueViewModel<TConfiguration, TValue>(IServiceProvider provider,
|
||||
IServiceFactory factory,
|
||||
IMediator mediator,
|
||||
IPublisher publisher,
|
||||
ISubscriber subscriber,
|
||||
IDisposer disposer,
|
||||
TConfiguration configuration,
|
||||
Func<TConfiguration, TValue> valueDelegate) :
|
||||
ValueViewModel<TValue>(provider, factory, mediator, publisher, subscriber, disposer),
|
||||
INotificationHandler<ChangedEventArgs<TConfiguration>>
|
||||
where TConfiguration : class
|
||||
{
|
||||
private readonly TConfiguration configuration = configuration;
|
||||
|
||||
private readonly Func<TConfiguration, TValue> valueDelegate = valueDelegate;
|
||||
|
||||
public Task Handle(ChangedEventArgs<TConfiguration> args)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public override Task OnActivated()
|
||||
{
|
||||
Value = valueDelegate(configuration);
|
||||
return base.OnActivated();
|
||||
}
|
||||
}
|
||||
@@ -4,8 +4,16 @@ namespace Toolkit.Foundation;
|
||||
|
||||
public static class IServiceCollectionExtensions
|
||||
{
|
||||
public static IServiceCollection AddAsyncInitialization<TInitialization>(this IServiceCollection services)
|
||||
where TInitialization : class,
|
||||
IAsyncInitialization
|
||||
{
|
||||
services.AddTransient<IAsyncInitialization, TInitialization>();
|
||||
return services;
|
||||
}
|
||||
|
||||
public static IServiceCollection AddCache<TKey, TValue>(this IServiceCollection services)
|
||||
where TKey : notnull
|
||||
where TKey : notnull
|
||||
where TValue : notnull
|
||||
{
|
||||
services.AddScoped<ICache<TKey, TValue>, Cache<TKey, TValue>>();
|
||||
@@ -97,15 +105,6 @@ public static class IServiceCollectionExtensions
|
||||
services.AddTransient<IInitialization, TInitialization>();
|
||||
return services;
|
||||
}
|
||||
|
||||
public static IServiceCollection AddAsyncInitialization<TInitialization>(this IServiceCollection services)
|
||||
where TInitialization : class,
|
||||
IAsyncInitialization
|
||||
{
|
||||
services.AddTransient<IAsyncInitialization, TInitialization>();
|
||||
return services;
|
||||
}
|
||||
|
||||
public static IServiceCollection AddRange(this IServiceCollection services,
|
||||
IServiceCollection fromServices)
|
||||
{
|
||||
@@ -142,7 +141,7 @@ public static class IServiceCollectionExtensions
|
||||
}
|
||||
else
|
||||
{
|
||||
services.Add(new ServiceDescriptor(viewModelImplementationType, provider =>
|
||||
services.Add(new ServiceDescriptor(viewModelType, provider =>
|
||||
provider.GetRequiredService<IServiceFactory>().Create<TViewModelImplementation>(parameters)!, serviceLifetime));
|
||||
}
|
||||
|
||||
@@ -154,7 +153,7 @@ public static class IServiceCollectionExtensions
|
||||
}
|
||||
else
|
||||
{
|
||||
services.Add(new ServiceDescriptor(viewModelImplementationType, key, (provider, key) =>
|
||||
services.Add(new ServiceDescriptor(viewModelType, key, (provider, key) =>
|
||||
provider.GetRequiredService<IServiceFactory>().Create<TViewModelImplementation>(parameters)!, serviceLifetime));
|
||||
}
|
||||
|
||||
@@ -165,4 +164,24 @@ public static class IServiceCollectionExtensions
|
||||
|
||||
return services;
|
||||
}
|
||||
|
||||
public static IServiceCollection AddValueTemplate<TConfiguration, TValue, TViewModel, TView>(this IServiceCollection services,
|
||||
Func<TConfiguration, TValue> valueDelegate,
|
||||
object? key = null,
|
||||
ServiceLifetime serviceLifetime = ServiceLifetime.Transient,
|
||||
params object[]? parameters)
|
||||
{
|
||||
parameters = [valueDelegate, .. parameters ?? Enumerable.Empty<object?>()];
|
||||
return AddTemplate<TViewModel, TViewModel, TView>(services, key, serviceLifetime, parameters);
|
||||
}
|
||||
|
||||
public static IServiceCollection AddValueTemplate<TConfiguration, TValue, TViewModel, TViewModelImplementation, TView>(this IServiceCollection services,
|
||||
Func<TConfiguration, TValue> valueDelegate,
|
||||
object? key = null,
|
||||
ServiceLifetime serviceLifetime = ServiceLifetime.Transient,
|
||||
params object[]? parameters)
|
||||
{
|
||||
parameters = [valueDelegate, .. parameters ?? Enumerable.Empty<object?>()];
|
||||
return AddTemplate<TViewModel, TViewModelImplementation, TView>(services, key, serviceLifetime, parameters);
|
||||
}
|
||||
}
|
||||
@@ -4,9 +4,6 @@
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Compile Remove="Navigate.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.3.2" />
|
||||
<PackageReference Include="Microsoft.Extensions.Hosting" Version="9.0.0-rc.1.24431.7" />
|
||||
|
||||
Reference in New Issue
Block a user