using Microsoft.Data.Sqlite; using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics.Metrics; using System.Linq; using System.Net; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Shapes; using WGneu.Models; namespace WGneu.Windows { public partial class MemberListWindow : Window { private bool isEditing = false; private bool isCreating = false; private readonly WgContext context = new(); public MemberListWindow() { InitializeComponent(); } private void Window_Loaded(object sender, RoutedEventArgs e) { RefreshMemberList(); BranchInput.ItemsSource = context.Branches.ToList(); DefaultKgInput.ItemsSource = context.WbKgs.Select(k => k.Kg).ToList(); } protected override void OnClosing(CancelEventArgs e) { context.Dispose(); base.OnClosing(e); } private void RefreshMemberList() { context.Members.Load(); MemberList.ItemsSource = context.Members.ToList(); RefreshInputs(); } private void RefreshInputs() { Member m = (Member)MemberList.SelectedItem; if (m != null) { EditMemberButton.IsEnabled = true; DeleteMemberButton.IsEnabled = true; FillInputs(m); } else { EditMemberButton.IsEnabled = false; DeleteMemberButton.IsEnabled = false; ClearInputs(); } } private void InitInputs() { ClearInputs(); MgNrInput.Text = NextMgNr().ToString(); } private void MemberList_SelectionChanged(object sender, SelectionChangedEventArgs e) { RefreshInputs(); } private void PlzInput_TextChanged(object sender, RoutedEventArgs e) { if (PlzInput.Text.Length == 4 && PlzInput.Text.All(char.IsDigit)) { int plz = int.Parse(PlzInput.Text); var o = context.Postleitzahlen.Where(p => p.Plz == plz).ToHashSet(); OrtInput.ItemsSource = o; OrtInput.SelectedItem = null; } } private void NewMemberButton_Click(object sender, RoutedEventArgs e) { isCreating = true; MemberList.IsEnabled = false; InitInputs(); HideNewEditDeleteButtons(); ShowSaveResetCancelButtons(); UnlockInputs(); } private void EditMemberButton_Click(object sender, RoutedEventArgs e) { if (MemberList.SelectedItem == null) return; isEditing = true; MemberList.IsEnabled = false; HideNewEditDeleteButtons(); ShowSaveResetCancelButtons(); UnlockInputs(); } private void DeleteMemberButton_Click(object sender, RoutedEventArgs e) { Member m = (Member)MemberList.SelectedItem; if (m == null) return; var r = MessageBox.Show( $"Soll das Mitglied \"{m.FamilyName} {m.GivenName}\" (MgNr. {m.MgNr}) wirklich unwiderruflich gelöscht werden?", "Mitglied löschen", MessageBoxButton.YesNo, MessageBoxImage.Warning, MessageBoxResult.No); if (r == MessageBoxResult.Yes) { context.Remove(m); context.SaveChanges(); RefreshMemberList(); } } private void SaveButton_Click(object sender, RoutedEventArgs e) { // TODO only allow to click button, if values were checked Member? m = null; if (isEditing) m = (Member)MemberList.SelectedItem; else if (isCreating) m = new(); int newMgNr = int.Parse(MgNrInput.Text); m.GivenName = GivenNameInput.Text; m.FamilyName = FamilyNameInput.Text; m.ZwstId = ((Branch)BranchInput.SelectedItem).ZwstId; m.CountryCode = "AT"; m.PostalDestId = ((AT_Plz)OrtInput.SelectedItem).Id; m.PostalDest = context.PostalDestinations.Find(m.CountryCode, m.PostalDestId); m.Address = AddressInput.Text; m.DefaultKgNr = ((AT_Kg)DefaultKgInput.SelectedItem).KgNr; try { if (isEditing) context.Update(m); else if (isCreating) context.Add(m); context.SaveChanges(); if (newMgNr != m.MgNr) context.Database.ExecuteSql($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {m.MgNr}"); } catch (Exception exc) { MessageBox.Show( "Der Eintrag konnte nicht in der Datenbank aktualisiert werden!\n\n" + exc.Message.ToString(), "Mitglied aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error); } isEditing = false; isCreating = false; MemberList.IsEnabled = true; HideSaveResetCancelButtons(); ShowNewEditDeleteButtons(); LockInputs(); RefreshMemberList(); } private void ResetButton_Click(object sender, RoutedEventArgs e) { if (isEditing) RefreshInputs(); else if (isCreating) InitInputs(); } private void CancelButton_Click(object sender, RoutedEventArgs e) { isEditing = false; isCreating = false; MemberList.IsEnabled = true; HideSaveResetCancelButtons(); ShowNewEditDeleteButtons(); RefreshInputs(); LockInputs(); } private int NextMgNr() { int c = context.Members.Select(m => m.MgNr).Min(); context.Members.OrderBy(m => m.MgNr).Select(m => m.MgNr).ToList().ForEach(a => { if (a <= c + 100) c = a; }); return c + 1; } private void ShowSaveResetCancelButtons() { SaveButton.IsEnabled = true; ResetButton.IsEnabled = false; CancelButton.IsEnabled = true; SaveButton.Visibility = Visibility.Visible; ResetButton.Visibility = Visibility.Visible; CancelButton.Visibility = Visibility.Visible; } private void HideSaveResetCancelButtons() { SaveButton.IsEnabled = false; ResetButton.IsEnabled = false; CancelButton.IsEnabled = false; SaveButton.Visibility = Visibility.Hidden; ResetButton.Visibility = Visibility.Hidden; CancelButton.Visibility = Visibility.Hidden; } private void ShowNewEditDeleteButtons() { NewMemberButton.IsEnabled = true; EditMemberButton.IsEnabled = MemberList.SelectedItem != null; DeleteMemberButton.IsEnabled = MemberList.SelectedItem != null; NewMemberButton.Visibility = Visibility.Visible; EditMemberButton.Visibility = Visibility.Visible; DeleteMemberButton.Visibility = Visibility.Visible; } private void HideNewEditDeleteButtons() { NewMemberButton.IsEnabled = false; EditMemberButton.IsEnabled = false; DeleteMemberButton.IsEnabled = false; NewMemberButton.Visibility = Visibility.Hidden; EditMemberButton.Visibility = Visibility.Hidden; DeleteMemberButton.Visibility = Visibility.Hidden; } private void LockInputs() { MgNrInput.IsReadOnly = true; GivenNameInput.IsReadOnly = true; FamilyNameInput.IsReadOnly = true; AddressInput.IsReadOnly = true; PlzInput.IsReadOnly = true; OrtInput.IsEnabled = false; BranchInput.IsEnabled = false; DefaultKgInput.IsEnabled = false; } private void UnlockInputs() { MgNrInput.IsReadOnly = false; GivenNameInput.IsReadOnly = false; FamilyNameInput.IsReadOnly = false; AddressInput.IsReadOnly = false; PlzInput.IsReadOnly = false; OrtInput.IsEnabled = true; BranchInput.IsEnabled = true; DefaultKgInput.IsEnabled = true; } private void FillInputs(Member m) { MgNrInput.Text = m.MgNr.ToString(); GivenNameInput.Text = m.GivenName; FamilyNameInput.Text = m.FamilyName; BranchInput.SelectedItem = m.Branch; DefaultKgInput.SelectedItem = m.DefaultKg; AddressInput.Text = m.Address; AT_Plz? p = m.PostalDest.Plz(context); if (p != null) { PlzInput.Text = p.Plz.ToString(); OrtInput.ItemsSource = p.Orte(context); OrtInput.SelectedItem = p; } else { OrtInput.ItemsSource = null; OrtInput.SelectedItem = null; } } private void ClearInputs() { MgNrInput.Text = ""; GivenNameInput.Text = ""; FamilyNameInput.Text = ""; BranchInput.SelectedItem = null; PlzInput.Text = ""; OrtInput.SelectedItem = null; AddressInput.Text = ""; DefaultKgInput.SelectedItem = null; } } }