Configutation writer fixed

This commit is contained in:
Daniel Clark
2022-12-17 17:58:42 +00:00
parent b6bb5d5b0f
commit ea4b96886b
11 changed files with 27 additions and 23 deletions
@@ -15,16 +15,20 @@ public class ContentTemplateSelector : IDataTemplate, IContentTemplateSelector
this.templateFactory = templateFactory; this.templateFactory = templateFactory;
} }
public IControl? Build(object? item) public IControl? Build(object? content)
{ {
if (item is not null) if (content is not null)
{ {
if (dataTracking.TryGetValue(item, out IControl? control)) if (dataTracking.TryGetValue(content, out IControl? control))
{ {
return control; return control;
} }
else
{
control = (IControl?)templateFactory.Create(content);
}
return (IControl?)templateFactory.Create(item); return control;
} }
return null; return null;
@@ -1,7 +1,6 @@
using Avalonia.Controls; using Avalonia.Controls;
using FluentAvalonia.UI.Controls; using FluentAvalonia.UI.Controls;
using Mediator; using Mediator;
using System.Diagnostics;
using Toolkit.Framework.Foundation; using Toolkit.Framework.Foundation;
namespace Toolkit.Framework.Avalonia; namespace Toolkit.Framework.Avalonia;
@@ -92,14 +91,6 @@ public class NavigateHandler : IRequestHandler<Navigate>
{ {
hasNavigated = await mediator.Send(new ContentControlNavigation(contentControl, content, template, keyedParameters)); hasNavigated = await mediator.Send(new ContentControlNavigation(contentControl, content, template, keyedParameters));
} }
if (hasNavigated)
{
if (content is INavigated navigated)
{
await navigated.Navigated();
}
}
} }
else else
{ {
@@ -1,17 +1,22 @@
using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Options;
using System.Diagnostics;
namespace Toolkit.Framework.Foundation; namespace Toolkit.Framework.Foundation;
public class ConfigurationWriter<TConfiguration> : IConfigurationWriter<TConfiguration> where TConfiguration : class, new() public class ConfigurationWriter<TConfiguration> : IConfigurationWriter<TConfiguration> where TConfiguration : class, new()
{ {
private readonly IConfiguration rootConfiguration; private readonly IConfiguration rootConfiguration;
private readonly string section;
public ConfigurationWriter(IConfiguration rootConfiguration) public ConfigurationWriter(IConfiguration rootConfiguration, string section)
{ {
Trace.WriteLine(section);
this.rootConfiguration = rootConfiguration; this.rootConfiguration = rootConfiguration;
this.section = section;
} }
public void Write(string section, TConfiguration configuration) public void Write(TConfiguration configuration)
{ {
if (rootConfiguration is IConfigurationRoot root) if (rootConfiguration is IConfigurationRoot root)
{ {
@@ -2,5 +2,5 @@
public interface IConfigurationWriter<TConfiguration> where TConfiguration : class public interface IConfigurationWriter<TConfiguration> where TConfiguration : class
{ {
void Write(string section, TConfiguration args); void Write(TConfiguration args);
} }
@@ -9,6 +9,7 @@ public class WritableJsonConfigurationProvider : JsonConfigurationProvider, IWri
{ {
public WritableJsonConfigurationProvider(JsonConfigurationSource source) : base(source) public WritableJsonConfigurationProvider(JsonConfigurationSource source) : base(source)
{ {
} }
public void Write<TValue>(string section, TValue value) where TValue : class, new() public void Write<TValue>(string section, TValue value) where TValue : class, new()
@@ -20,7 +20,7 @@ public class WritableJsonConfigurationSource : JsonConfigurationSource
if (FileProvider is PhysicalFileProvider physicalFileProvider) if (FileProvider is PhysicalFileProvider physicalFileProvider)
{ {
string? outputFile = System.IO.Path.Combine(physicalFileProvider.Root, Path); string? outputFile = System.IO.Path.Combine(physicalFileProvider.Root, Path!);
Factory?.Build(outputFile); Factory?.Build(outputFile);
} }
} }
+1 -1
View File
@@ -2,4 +2,4 @@
namespace Toolkit.Framework.Foundation; namespace Toolkit.Framework.Foundation;
public abstract record Write<TConfiguration>(string Section, Action<TConfiguration> UpdateDelegate) : IRequest where TConfiguration : class; public record Write<TConfiguration>(Action<TConfiguration> UpdateDelegate) : IRequest where TConfiguration : class;
@@ -20,7 +20,7 @@ public class WriteHandler<TConfiguration> : IRequestHandler<Write<TConfiguration
public async ValueTask<Unit> Handle(Write<TConfiguration> request, CancellationToken cancellationToken) public async ValueTask<Unit> Handle(Write<TConfiguration> request, CancellationToken cancellationToken)
{ {
request.UpdateDelegate.Invoke(configuration); request.UpdateDelegate.Invoke(configuration);
writer.Write(request.Section, configuration); writer.Write(configuration);
await mediator.Send(new ConfigurationChanged<TConfiguration>(configuration), cancellationToken); await mediator.Send(new ConfigurationChanged<TConfiguration>(configuration), cancellationToken);
@@ -105,7 +105,7 @@ public static class IServiceCollectionExtensions
public static IServiceCollection AddWritableConfiguration<TConfiguration>(this IServiceCollection serviceCollection, IConfiguration configuration) where TConfiguration : class, new() public static IServiceCollection AddWritableConfiguration<TConfiguration>(this IServiceCollection serviceCollection, IConfiguration configuration) where TConfiguration : class, new()
{ {
serviceCollection.Configure<TConfiguration>(configuration); serviceCollection.Configure<TConfiguration>(configuration);
serviceCollection.AddTransient<IConfigurationWriter<TConfiguration>, ConfigurationWriter<TConfiguration>>(); serviceCollection.AddTransient<IConfigurationWriter<TConfiguration>>(provider => provider.GetService<IServiceFactory>()?.Create< ConfigurationWriter<TConfiguration>>(configuration is IConfigurationSection section ? section.Path : "")!);
serviceCollection.AddTransient(provider => provider.GetService<IOptionsMonitor<TConfiguration>>()!.CurrentValue); serviceCollection.AddTransient(provider => provider.GetService<IOptionsMonitor<TConfiguration>>()!.CurrentValue);
serviceCollection.AddHandler<WriteHandler<TConfiguration>>(); serviceCollection.AddHandler<WriteHandler<TConfiguration>>();
serviceCollection.AddTransient<ConfigurationInitializer<TConfiguration>>(); serviceCollection.AddTransient<ConfigurationInitializer<TConfiguration>>();
@@ -1,5 +1,6 @@
using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.FileProviders; using Microsoft.Extensions.FileProviders;
using Microsoft.Extensions.Hosting;
namespace Toolkit.Framework.Foundation; namespace Toolkit.Framework.Foundation;
@@ -38,7 +39,7 @@ public static class WritableJsonConfigurationExtensions
bool optional, bool optional,
bool reloadOnChange) bool reloadOnChange)
{ {
return builder.AddWritableJsonFile(null, path, optional, reloadOnChange, null); return builder.AddWritableJsonFile( null, path, optional, reloadOnChange, null);
} }
public static IConfigurationBuilder AddWritableJsonFile(this IConfigurationBuilder builder, public static IConfigurationBuilder AddWritableJsonFile(this IConfigurationBuilder builder,
+2
View File
@@ -9,6 +9,8 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="JsonCons.JsonPath" Version="1.1.0" />
<PackageReference Include="JsonCons.Utilities" Version="1.0.0" />
<PackageReference Include="JsonPatch.Net" Version="2.0.4" /> <PackageReference Include="JsonPatch.Net" Version="2.0.4" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="7.0.0" /> <PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="7.0.0" />
<PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="7.0.0" /> <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="7.0.0" />