138 lines
6.4 KiB
C#
138 lines
6.4 KiB
C#
using MySql.Data.MySqlClient;
|
|
using System;
|
|
using System.Globalization;
|
|
using System.Threading;
|
|
using System.Windows;
|
|
using System.Windows.Controls;
|
|
using System.Windows.Media;
|
|
using System.Windows.Navigation;
|
|
|
|
namespace SkyTeam
|
|
{
|
|
public partial class SettingsPage : Page
|
|
{
|
|
public SettingsPage()
|
|
{
|
|
InitializeComponent();
|
|
|
|
// Quelle: Stack Overflow "How to compare SolidColorBrush in WPF"
|
|
// Wir lesen die globale Ressource aus und prüfen die Farbe, um sicherzustellen,
|
|
// dass der Toggle Switch beim Wechseln der Seite den richtigen Zustand (An/Aus) anzeigt
|
|
var bgBrush = Application.Current.Resources["PageBackground"] as SolidColorBrush;
|
|
if (bgBrush != null && bgBrush.Color == Color.FromRgb(30, 30, 30))
|
|
{
|
|
DarkModeToggle.IsChecked = true;
|
|
DarkModeToggle.Content = "An";
|
|
}
|
|
else
|
|
{
|
|
DarkModeToggle.Content = "Aus";
|
|
}
|
|
}
|
|
|
|
private void DarkModeToggle_Checked(object sender, RoutedEventArgs e)
|
|
{
|
|
SetRes("PageBackground", Color.FromRgb(30, 30, 30));
|
|
SetRes("CardBackground", Color.FromRgb(45, 45, 45));
|
|
SetRes("SidebarBackground", Color.FromRgb(20, 20, 20));
|
|
SetRes("PrimaryText", Colors.White);
|
|
SetRes("SecondaryText", Color.FromRgb(200, 200, 200));
|
|
|
|
DarkModeToggle.Content = "An";
|
|
}
|
|
|
|
private void DarkModeToggle_Unchecked(object sender, RoutedEventArgs e)
|
|
{
|
|
SetRes("PageBackground", Colors.White);
|
|
SetRes("CardBackground", Color.FromRgb(245, 247, 250));
|
|
SetRes("SidebarBackground", Color.FromRgb(227, 242, 253));
|
|
SetRes("PrimaryText", Colors.Black);
|
|
SetRes("SecondaryText", Color.FromRgb(102, 102, 102));
|
|
|
|
DarkModeToggle.Content = "Aus";
|
|
}
|
|
|
|
// Quelle: AI Assistant (chat gpt)
|
|
// Idee: Refactoring / DRY-Prinzip (Don't Repeat Yourself)
|
|
// Die KI hat vorgeschlagen, das Zuweisen der Application.Current.Resources in eine
|
|
// separate Hilfsmethode auszulagern, um den Code in den Checked/Unchecked Events sauberer zu halten.
|
|
private void SetRes(string key, Color color)
|
|
{
|
|
Application.Current.Resources[key] = new SolidColorBrush(color);
|
|
}
|
|
|
|
private void DeleteAccountButton_Click(object sender, RoutedEventArgs e)
|
|
{
|
|
if (MessageBox.Show("Möchten Sie Ihr Konto wirklich löschen?\nAlle Buchungen werden ebenfalls gelöscht.", "Achtung", MessageBoxButton.YesNo, MessageBoxImage.Warning) == MessageBoxResult.Yes)
|
|
{
|
|
try
|
|
{
|
|
using (MySqlConnection conn = new MySqlConnection(DatenbankServices.GetConnection()))
|
|
{
|
|
conn.Open();
|
|
|
|
// Quelle: Reddit - r/csharp "Best way to delete user with related data?"
|
|
// Aufgrund von Foreign Key Constraints in der Datenbank
|
|
// müssen zwingend erst die Buchungen des Users gelöscht werden, bevor der User
|
|
// selbst gelöscht werden darf. Sonst wirft die Datenbank einen Fehler
|
|
string deleteBookings = "DELETE FROM buchungen WHERE UserId = @uid";
|
|
MySqlCommand cmd1 = new MySqlCommand(deleteBookings, conn);
|
|
|
|
// Quelle: Im Unterricht gemacht
|
|
cmd1.Parameters.AddWithValue("@uid", SessionManager.CurrentUserId);
|
|
cmd1.ExecuteNonQuery();
|
|
|
|
string deleteUser = "DELETE FROM users WHERE Id = @uid";
|
|
MySqlCommand cmd2 = new MySqlCommand(deleteUser, conn);
|
|
cmd2.Parameters.AddWithValue("@uid", SessionManager.CurrentUserId);
|
|
cmd2.ExecuteNonQuery();
|
|
}
|
|
|
|
SessionManager.CurrentUserId = 0;
|
|
MessageBox.Show("Ihr Konto wurde erfolgreich gelöscht.");
|
|
NavigationService.Navigate(new LogInPage());
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
MessageBox.Show("Fehler beim Löschen: " + ex.Message);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Quelle: Im Unterricht gemacht
|
|
// Lambda-Ausdrücke (=>) für simple Seitenwechsel über den NavigationService
|
|
private void HomeButton_Click(object sender, RoutedEventArgs e) => NavigationService.Navigate(new NavigationPage());
|
|
private void BookingsButton_Click(object sender, RoutedEventArgs e) => NavigationService.Navigate(new BuchungenPage());
|
|
private void SettingsButton_Click(object sender, RoutedEventArgs e) => NavigationService.Navigate(new SettingsPage());
|
|
|
|
private void LogoutButton_Click(object sender, RoutedEventArgs e)
|
|
{
|
|
SessionManager.CurrentUserId = 0;
|
|
NavigationService.Navigate(new LogInPage());
|
|
}
|
|
|
|
private void LanguageComboBox_SelectionChanged(object sender, SelectionChangedEventArgs e)
|
|
{
|
|
if (LanguageComboBox.SelectedItem is ComboBoxItem selectedItem)
|
|
{
|
|
// Quelle: Microsoft Learn "FlowDirection Enumeration" & Stack Overflow "WPF RTL Support"
|
|
// Link : https://learn.microsoft.com/en-us/dotnet/api/system.windows.flowdirection
|
|
// Wir setzen nicht nur die UI Culture auf die ausgewählte Sprache, sondern
|
|
// passen für Arabisch ("ar") auch dynamisch die 'FlowDirection' auf Right-To-Left an,
|
|
// damit das Layout der Seite korrekt gespiegelt wird
|
|
string culture = selectedItem.Tag.ToString();
|
|
Thread.CurrentThread.CurrentUICulture = new CultureInfo(culture);
|
|
|
|
if (culture == "ar")
|
|
this.FlowDirection = FlowDirection.RightToLeft;
|
|
else
|
|
this.FlowDirection = FlowDirection.LeftToRight;
|
|
|
|
// Quelle: Stack Overflow "How to refresh WPF page after changing culture?"
|
|
// Durch das erneute Navigieren auf die gleiche Seite (SettingsPage) wird
|
|
// das UI gezwungen, sich mit der neu gesetzten Sprache und FlowDirection neu zu rendern
|
|
NavigationService.Navigate(new SettingsPage());
|
|
}
|
|
}
|
|
}
|
|
} |