From 03f1669d98e1fad81bc4832900ae149ac6510ebc Mon Sep 17 00:00:00 2001 From: Rory& Date: Mon, 29 Jul 2024 22:45:36 +0200 Subject: Initial commit --- ModerationClient/Views/ClientView.axaml | 30 ++++++++++ ModerationClient/Views/ClientView.axaml.cs | 33 +++++++++++ ModerationClient/Views/LoginView.axaml | 25 ++++++++ ModerationClient/Views/LoginView.axaml.cs | 33 +++++++++++ ModerationClient/Views/MainWindow.axaml | 42 ++++++++++++++ ModerationClient/Views/MainWindow.axaml.cs | 93 ++++++++++++++++++++++++++++++ 6 files changed, 256 insertions(+) create mode 100644 ModerationClient/Views/ClientView.axaml create mode 100644 ModerationClient/Views/ClientView.axaml.cs create mode 100644 ModerationClient/Views/LoginView.axaml create mode 100644 ModerationClient/Views/LoginView.axaml.cs create mode 100644 ModerationClient/Views/MainWindow.axaml create mode 100644 ModerationClient/Views/MainWindow.axaml.cs (limited to 'ModerationClient/Views') diff --git a/ModerationClient/Views/ClientView.axaml b/ModerationClient/Views/ClientView.axaml new file mode 100644 index 0000000..21ce5d9 --- /dev/null +++ b/ModerationClient/Views/ClientView.axaml @@ -0,0 +1,30 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/ModerationClient/Views/ClientView.axaml.cs b/ModerationClient/Views/ClientView.axaml.cs new file mode 100644 index 0000000..1ca5a89 --- /dev/null +++ b/ModerationClient/Views/ClientView.axaml.cs @@ -0,0 +1,33 @@ +using System; +using System.Linq; +using Avalonia.Controls; +using Avalonia.Markup.Xaml; + +namespace ModerationClient.Views; + +public partial class ClientView : UserControl { + + public ClientView() { + InitializeComponent(); + + // PropertyChanged += (_, e) => { + // switch (e.Property.Name) { + // case nameof(Width): { + // //make sure all columns fit + // var grid = this.LogicalChildren.OfType().FirstOrDefault(); + // if(grid is null) { + // Console.WriteLine("Failed to find Grid in ClientView"); + // return; + // } + // Console.WriteLine($"ClientView width changed to {Width}"); + // var columns = grid.ColumnDefinitions; + // break; + // } + // } + // }; + } + + private void InitializeComponent() { + AvaloniaXamlLoader.Load(this); + } +} diff --git a/ModerationClient/Views/LoginView.axaml b/ModerationClient/Views/LoginView.axaml new file mode 100644 index 0000000..10e97c6 --- /dev/null +++ b/ModerationClient/Views/LoginView.axaml @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/ModerationClient/Views/LoginView.axaml.cs b/ModerationClient/Views/LoginView.axaml.cs new file mode 100644 index 0000000..2e95e80 --- /dev/null +++ b/ModerationClient/Views/LoginView.axaml.cs @@ -0,0 +1,33 @@ +using System; +using Avalonia; +using Avalonia.Controls; +using Avalonia.Interactivity; +using Avalonia.Markup.Xaml; +using Avalonia.VisualTree; +using Microsoft.Extensions.DependencyInjection; +using ModerationClient.Services; +using ModerationClient.ViewModels; + +namespace ModerationClient.Views; + +public partial class LoginView : UserControl { + private MatrixAuthenticationService AuthService { get; set; } + + public LoginView() { + InitializeComponent(); + } + + private void InitializeComponent() { + Console.WriteLine("LoginWindow loaded"); + + AvaloniaXamlLoader.Load(this); + Console.WriteLine("LoginWindow loaded 2"); + } + + // ReSharper disable once AsyncVoidMethod + private async void Login(object? sender, RoutedEventArgs e) { + Console.WriteLine("Login????"); + // await AuthService.LoginAsync(Username, Password); + await ((LoginViewModel)DataContext).LoginAsync(); + } +} diff --git a/ModerationClient/Views/MainWindow.axaml b/ModerationClient/Views/MainWindow.axaml new file mode 100644 index 0000000..1c2b396 --- /dev/null +++ b/ModerationClient/Views/MainWindow.axaml @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/ModerationClient/Views/MainWindow.axaml.cs b/ModerationClient/Views/MainWindow.axaml.cs new file mode 100644 index 0000000..ccabd71 --- /dev/null +++ b/ModerationClient/Views/MainWindow.axaml.cs @@ -0,0 +1,93 @@ +using System; +using System.Threading; +using Avalonia; +using Avalonia.Controls; +using Avalonia.Diagnostics; +using Avalonia.Input; +using CommunityToolkit.Mvvm.Input; +using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Hosting; +using ModerationClient.Services; +using ModerationClient.ViewModels; + +namespace ModerationClient.Views; + +public partial class MainWindow : Window { + //viewmodel + private MainWindowViewModel? _viewModel { get; set; } + + public MainWindow(CommandLineConfiguration cfg, MainWindowViewModel dataContext, IHostApplicationLifetime appLifetime) { + InitializeComponent(); + Console.WriteLine("mainwnd"); +#if DEBUG + this.AttachDevTools(new DevToolsOptions() { + ShowAsChildWindow = true, + LaunchView = DevToolsViewKind.LogicalTree, + }); +#endif + PropertyChanged += (sender, args) => { + // Console.WriteLine($"MainWindow PropertyChanged: {args.Property.Name} ({args.OldValue} -> {args.NewValue})"); + switch (args.Property.Name) { + case nameof(Height): + case nameof(Width): { + if (_viewModel is null) { + Console.WriteLine("WARN: MainWindowViewModel is null, ignoring height/width change!"); + return; + } + + // Console.WriteLine("height/width changed"); + _viewModel.Scale = _viewModel.Scale; + break; + } + } + }; + DataContext = _viewModel = dataContext; + _ = dataContext.AuthService.LoadProfileAsync(); + dataContext.AuthService.PropertyChanged += (sender, args) => { + if (args.PropertyName == nameof(MatrixAuthenticationService.IsLoggedIn)) { + if (dataContext.AuthService.IsLoggedIn) { + // dataContext.CurrentViewModel = new ClientViewModel(dataContext.AuthService); + dataContext.CurrentViewModel = App.Current.Host.Services.GetRequiredService(); + } + else { + dataContext.CurrentViewModel = new LoginViewModel(dataContext.AuthService); + } + } + }; + dataContext.MainWindow = this; + dataContext.Scale = cfg.Scale; + Width *= cfg.Scale; + Height *= cfg.Scale; + + appLifetime.ApplicationStopping.Register(() => { + Console.WriteLine("ApplicationStopping triggered"); + Close(); + }); + } + + protected override void OnKeyDown(KeyEventArgs e) => OnKeyDown(this, e); + + private void OnKeyDown(object? _, KeyEventArgs e) { + if (_viewModel is null) { + Console.WriteLine("WARN: MainWindowViewModel is null, ignoring key press!"); + return; + } + + // Console.WriteLine("MainWindow KeyDown: " + e.Key); + if (e.Key == Key.Escape) { + _viewModel.Scale = 1.0f; + } + else if (e.Key == Key.F1) { + _viewModel.Scale -= 0.1f; + if (_viewModel.Scale < 0.1f) { + _viewModel.Scale = 0.1f; + } + } + else if (e.Key == Key.F2) { + _viewModel.Scale += 0.1f; + if (_viewModel.Scale > 5.0f) { + _viewModel.Scale = 5.0f; + } + } + } +} \ No newline at end of file -- cgit 1.5.1