From df5fe7c86e41235f99a9b0d69519a18581eddd5e Mon Sep 17 00:00:00 2001 From: Rory& Date: Thu, 8 Aug 2024 02:57:34 +0200 Subject: Further work --- ModerationClient/App.axaml.cs | 33 +++++++++++---------------------- 1 file changed, 11 insertions(+), 22 deletions(-) (limited to 'ModerationClient/App.axaml.cs') diff --git a/ModerationClient/App.axaml.cs b/ModerationClient/App.axaml.cs index db584de..c44b5a2 100644 --- a/ModerationClient/App.axaml.cs +++ b/ModerationClient/App.axaml.cs @@ -2,7 +2,6 @@ using System; using System.IO; using Avalonia; using Avalonia.Controls.ApplicationLifetimes; -using Avalonia.Data.Core; using Avalonia.Data.Core.Plugins; using Avalonia.Markup.Xaml; using LibMatrix.Services; @@ -13,18 +12,12 @@ using Microsoft.Extensions.Hosting; using ModerationClient.Services; using ModerationClient.ViewModels; using ModerationClient.Views; +using ModerationClient.Views.MainWindow; namespace ModerationClient; public partial class App : Application { - /// - /// Gets the current instance in use - /// - public new static App Current => (App)Application.Current; - - /// - /// Gets the instance to resolve application services. - /// + public new static App Current => Application.Current as App ?? throw new InvalidOperationException("Application.Current is null"); public IServiceProvider Services => Host.Services; public IHost Host { get; private set; } @@ -38,16 +31,10 @@ public partial class App : Application { var builder = Microsoft.Extensions.Hosting.Host.CreateApplicationBuilder(Environment.GetCommandLineArgs()); builder.Services.AddTransient(); ConfigureServices(builder.Services); - // builder.Services.AddHostedService(); Host = builder.Build(); if (ApplicationLifetime is IClassicDesktopStyleApplicationLifetime desktop) { - // Line below is needed to remove Avalonia data validation. - // Without this line you will get duplicate validations from both Avalonia and CT BindingPlugins.DataValidators.RemoveAt(0); - // desktop.MainWindow = new MainWindow { - // DataContext = Host.Services.GetRequiredService() - // }; desktop.MainWindow = Host.Services.GetRequiredService(); desktop.Exit += (sender, args) => { Host.StopAsync(TimeSpan.FromSeconds(5)).GetAwaiter().GetResult(); @@ -59,19 +46,16 @@ public partial class App : Application { await Host.StartAsync(); } - /// - /// Configures the services for the application. - /// private static IServiceProvider ConfigureServices(IServiceCollection services) { services.AddRoryLibMatrixServices(new() { AppName = "ModerationClient", }); - services.AddSingleton(); + services.AddSingleton(CommandLineConfiguration.FromProcessArgs()); services.AddSingleton(); services.AddSingleton(); - services.AddSingleton(x => { - var cmdLine = x.GetRequiredService(); + services.AddSingleton(s => { + var cmdLine = s.GetRequiredService(); return new TieredStorageService( cacheStorageProvider: new FileStorageProvider(Directory.CreateTempSubdirectory($"modcli-{cmdLine.Profile}").FullName), dataStorageProvider: new FileStorageProvider(Directory.CreateTempSubdirectory($"modcli-{cmdLine.Profile}").FullName) @@ -79,12 +63,17 @@ public partial class App : Application { } ); - // Register views + // Register windows services.AddSingleton(); + services.AddTransient(); + + // Register views services.AddTransient(); services.AddTransient(); + // Register ViewModels services.AddTransient(); + services.AddTransient(); return services.BuildServiceProvider(); } -- cgit 1.5.1