Change code formatting
This commit is contained in:
@ -19,10 +19,8 @@ using System.Windows.Shapes;
|
||||
using WGneu.Models;
|
||||
|
||||
|
||||
namespace WGneu.Windows
|
||||
{
|
||||
public partial class MemberListWindow : Window
|
||||
{
|
||||
namespace WGneu.Windows {
|
||||
public partial class MemberListWindow : Window {
|
||||
private bool IsEditing = false;
|
||||
private bool IsCreating = false;
|
||||
private List<string> TextFilter = new();
|
||||
@ -30,8 +28,7 @@ namespace WGneu.Windows
|
||||
private static readonly RoutedCommand CtrlF = new();
|
||||
private readonly WgContext Context = new();
|
||||
|
||||
public MemberListWindow()
|
||||
{
|
||||
public MemberListWindow() {
|
||||
InitializeComponent();
|
||||
CtrlF.InputGestures.Add(new KeyGesture(Key.F, ModifierKeys.Control));
|
||||
CommandBindings.Add(new CommandBinding(CtrlF, FocusSearchInput));
|
||||
@ -39,26 +36,22 @@ namespace WGneu.Windows
|
||||
if (tb.Name != "SearchInput") Valid[tb] = true;
|
||||
}
|
||||
|
||||
private void Window_Loaded(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void Window_Loaded(object sender, RoutedEventArgs e) {
|
||||
RefreshMemberList();
|
||||
BranchInput.ItemsSource = Context.Branches.OrderBy(b => b.Name).ToList();
|
||||
DefaultKgInput.ItemsSource = Context.WbKgs.Select(k => k.Kg).OrderBy(k => k.Name).ToList();
|
||||
}
|
||||
|
||||
protected override void OnClosing(CancelEventArgs e)
|
||||
{
|
||||
protected override void OnClosing(CancelEventArgs e) {
|
||||
Context.Dispose();
|
||||
base.OnClosing(e);
|
||||
}
|
||||
|
||||
private int CountMatchesInMember(Member m)
|
||||
{
|
||||
private int CountMatchesInMember(Member m) {
|
||||
if (TextFilter.Count == 0) return 0;
|
||||
string[] check = new string[] { m.MgNr.ToString(), m.FamilyName.ToLower(), m.GivenName.ToLower(), m.DefaultKg.Name.ToLower() };
|
||||
int i = 0;
|
||||
foreach (string c in check)
|
||||
{
|
||||
foreach (string c in check) {
|
||||
if (TextFilter.Any(f => c == f))
|
||||
i += 10;
|
||||
else if (TextFilter.Any(f => c.Contains(f)))
|
||||
@ -67,13 +60,11 @@ namespace WGneu.Windows
|
||||
return i;
|
||||
}
|
||||
|
||||
private void RefreshMemberList()
|
||||
{
|
||||
private void RefreshMemberList() {
|
||||
Context.Members.Load();
|
||||
List<Member> members = Context.Members.OrderBy(m => m.FamilyName + " " + m.GivenName).ToList();
|
||||
|
||||
if (TextFilter.Count > 0)
|
||||
{
|
||||
if (TextFilter.Count > 0) {
|
||||
members = members
|
||||
.ToDictionary(m => m, m => CountMatchesInMember(m))
|
||||
.OrderByDescending(a => a.Value)
|
||||
@ -88,38 +79,30 @@ namespace WGneu.Windows
|
||||
RefreshInputs();
|
||||
}
|
||||
|
||||
private void RefreshInputs()
|
||||
{
|
||||
private void RefreshInputs() {
|
||||
Member m = (Member)MemberList.SelectedItem;
|
||||
if (m != null)
|
||||
{
|
||||
if (m != null) {
|
||||
EditMemberButton.IsEnabled = true;
|
||||
DeleteMemberButton.IsEnabled = true;
|
||||
FillInputs(m);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
EditMemberButton.IsEnabled = false;
|
||||
DeleteMemberButton.IsEnabled = false;
|
||||
ClearInputs();
|
||||
}
|
||||
}
|
||||
|
||||
private void InitInputs()
|
||||
{
|
||||
private void InitInputs() {
|
||||
ClearInputs();
|
||||
MgNrInput.Text = NextMgNr().ToString();
|
||||
}
|
||||
|
||||
private void MemberList_SelectionChanged(object sender, SelectionChangedEventArgs e)
|
||||
{
|
||||
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))
|
||||
{
|
||||
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;
|
||||
@ -127,8 +110,7 @@ namespace WGneu.Windows
|
||||
}
|
||||
}
|
||||
|
||||
private void NewMemberButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void NewMemberButton_Click(object sender, RoutedEventArgs e) {
|
||||
IsCreating = true;
|
||||
MemberList.IsEnabled = false;
|
||||
InitInputs();
|
||||
@ -137,8 +119,7 @@ namespace WGneu.Windows
|
||||
UnlockInputs();
|
||||
}
|
||||
|
||||
private void EditMemberButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void EditMemberButton_Click(object sender, RoutedEventArgs e) {
|
||||
if (MemberList.SelectedItem == null)
|
||||
return;
|
||||
|
||||
@ -150,24 +131,21 @@ namespace WGneu.Windows
|
||||
UnlockInputs();
|
||||
}
|
||||
|
||||
private void DeleteMemberButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
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)
|
||||
{
|
||||
if (r == MessageBoxResult.Yes) {
|
||||
Context.Remove(m);
|
||||
Context.SaveChanges();
|
||||
RefreshMemberList();
|
||||
}
|
||||
}
|
||||
|
||||
private void SaveButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void SaveButton_Click(object sender, RoutedEventArgs e) {
|
||||
// TODO only allow to click button, if values were checked
|
||||
|
||||
Member? m = new();
|
||||
@ -214,8 +192,7 @@ namespace WGneu.Windows
|
||||
if (ContactEmailInput.IsChecked ?? false) m.DefaultContact = "email";
|
||||
// TODO Buchhaltungskonto
|
||||
|
||||
try
|
||||
{
|
||||
try {
|
||||
if (IsEditing)
|
||||
Context.Update(m);
|
||||
else if (IsCreating)
|
||||
@ -224,9 +201,7 @@ namespace WGneu.Windows
|
||||
|
||||
if (newMgNr != m.MgNr)
|
||||
Context.Database.ExecuteSql($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {m.MgNr}");
|
||||
}
|
||||
catch (Exception exc)
|
||||
{
|
||||
} catch (Exception exc) {
|
||||
var str = "Der Eintrag konnte nicht in der Datenbank aktualisiert werden!\n\n" + exc.Message;
|
||||
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||
MessageBox.Show(str, "Mitglied aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||
@ -241,16 +216,14 @@ namespace WGneu.Windows
|
||||
RefreshMemberList();
|
||||
}
|
||||
|
||||
private void ResetButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void ResetButton_Click(object sender, RoutedEventArgs e) {
|
||||
if (IsEditing)
|
||||
RefreshInputs();
|
||||
else if (IsCreating)
|
||||
InitInputs();
|
||||
}
|
||||
|
||||
private void CancelButton_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void CancelButton_Click(object sender, RoutedEventArgs e) {
|
||||
IsEditing = false;
|
||||
IsCreating = false;
|
||||
MemberList.IsEnabled = true;
|
||||
@ -260,30 +233,25 @@ namespace WGneu.Windows
|
||||
LockInputs();
|
||||
}
|
||||
|
||||
private void SearchInput_TextChanged(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void SearchInput_TextChanged(object sender, RoutedEventArgs e) {
|
||||
TextFilter = SearchInput.Text.ToLower().Split(" ").ToList().FindAll(s => s != "");
|
||||
RefreshMemberList();
|
||||
}
|
||||
|
||||
private void FocusSearchInput(object sender, RoutedEventArgs e)
|
||||
{
|
||||
if (!IsEditing && !IsCreating)
|
||||
{
|
||||
private void FocusSearchInput(object sender, RoutedEventArgs e) {
|
||||
if (!IsEditing && !IsCreating) {
|
||||
SearchInput.Focus();
|
||||
SearchInput.SelectAll();
|
||||
}
|
||||
}
|
||||
|
||||
private int NextMgNr()
|
||||
{
|
||||
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()
|
||||
{
|
||||
private void ShowSaveResetCancelButtons() {
|
||||
SaveButton.IsEnabled = true;
|
||||
ResetButton.IsEnabled = false;
|
||||
CancelButton.IsEnabled = true;
|
||||
@ -292,8 +260,7 @@ namespace WGneu.Windows
|
||||
CancelButton.Visibility = Visibility.Visible;
|
||||
}
|
||||
|
||||
private void HideSaveResetCancelButtons()
|
||||
{
|
||||
private void HideSaveResetCancelButtons() {
|
||||
SaveButton.IsEnabled = false;
|
||||
ResetButton.IsEnabled = false;
|
||||
CancelButton.IsEnabled = false;
|
||||
@ -302,8 +269,7 @@ namespace WGneu.Windows
|
||||
CancelButton.Visibility = Visibility.Hidden;
|
||||
}
|
||||
|
||||
private void ShowNewEditDeleteButtons()
|
||||
{
|
||||
private void ShowNewEditDeleteButtons() {
|
||||
NewMemberButton.IsEnabled = true;
|
||||
EditMemberButton.IsEnabled = MemberList.SelectedItem != null;
|
||||
DeleteMemberButton.IsEnabled = MemberList.SelectedItem != null;
|
||||
@ -312,8 +278,7 @@ namespace WGneu.Windows
|
||||
DeleteMemberButton.Visibility = Visibility.Visible;
|
||||
}
|
||||
|
||||
private void HideNewEditDeleteButtons()
|
||||
{
|
||||
private void HideNewEditDeleteButtons() {
|
||||
NewMemberButton.IsEnabled = false;
|
||||
EditMemberButton.IsEnabled = false;
|
||||
DeleteMemberButton.IsEnabled = false;
|
||||
@ -322,8 +287,7 @@ namespace WGneu.Windows
|
||||
DeleteMemberButton.Visibility = Visibility.Hidden;
|
||||
}
|
||||
|
||||
private void LockInputs()
|
||||
{
|
||||
private void LockInputs() {
|
||||
foreach (var tb in Utils.FindVisualChilds<TextBox>(this))
|
||||
if (tb.Name != "SearchInput") tb.IsReadOnly = true;
|
||||
foreach (var cb in Utils.FindVisualChilds<ComboBox>(this))
|
||||
@ -334,8 +298,7 @@ namespace WGneu.Windows
|
||||
rb.IsEnabled = false;
|
||||
}
|
||||
|
||||
private void UnlockInputs()
|
||||
{
|
||||
private void UnlockInputs() {
|
||||
foreach (var tb in Utils.FindVisualChilds<TextBox>(this))
|
||||
if (tb.Name != "SearchInput") tb.IsReadOnly = false;
|
||||
foreach (var cb in Utils.FindVisualChilds<ComboBox>(this))
|
||||
@ -346,8 +309,7 @@ namespace WGneu.Windows
|
||||
rb.IsEnabled = true;
|
||||
}
|
||||
|
||||
private void FillInputs(Member m)
|
||||
{
|
||||
private void FillInputs(Member m) {
|
||||
MgNrInput.Text = m.MgNr.ToString();
|
||||
PredecessorMgNrInput.Text = m.PredecessorMgNr.ToString();
|
||||
PrefixInput.Text = m.Prefix;
|
||||
@ -357,14 +319,11 @@ namespace WGneu.Windows
|
||||
BirthdayInput.Text = (m.Birthday != null) ? string.Join(".", m.Birthday.Split("-").Reverse()) : null;
|
||||
AddressInput.Text = m.Address;
|
||||
AT_Plz? p = m.PostalDest.Plz(Context);
|
||||
if (p != null)
|
||||
{
|
||||
if (p != null) {
|
||||
PlzInput.Text = p.Plz.ToString();
|
||||
OrtInput.ItemsSource = p.Orte(Context);
|
||||
OrtInput.SelectedItem = p;
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
PlzInput.Text = null;
|
||||
OrtInput.ItemsSource = null;
|
||||
OrtInput.SelectedItem = null;
|
||||
@ -393,15 +352,13 @@ namespace WGneu.Windows
|
||||
ActiveInput.IsChecked = m.Active;
|
||||
VollLieferantInput.IsChecked = m.VollLieferant;
|
||||
FunkionärInput.IsChecked = m.Funktionär;
|
||||
switch (m.DefaultContact)
|
||||
{
|
||||
switch (m.DefaultContact) {
|
||||
case "post": ContactPostInput.IsChecked = true; break;
|
||||
case "email": ContactEmailInput.IsChecked = true; break;
|
||||
}
|
||||
}
|
||||
|
||||
private void ClearInputs()
|
||||
{
|
||||
private void ClearInputs() {
|
||||
foreach (var tb in Utils.FindVisualChilds<TextBox>(this))
|
||||
if (tb.Name != "SearchInput") tb.Text = "";
|
||||
foreach (var cb in Utils.FindVisualChilds<ComboBox>(this))
|
||||
@ -412,27 +369,23 @@ namespace WGneu.Windows
|
||||
rb.IsChecked = false;
|
||||
}
|
||||
|
||||
private bool IsValid()
|
||||
{
|
||||
private bool IsValid() {
|
||||
return Valid.All(kv => kv.Value) &&
|
||||
Utils.FindVisualChilds<ComboBox>(this).All(cb => cb.ItemsSource == null || cb.SelectedItem != null);
|
||||
}
|
||||
|
||||
private void UpdateButtons()
|
||||
{
|
||||
private void UpdateButtons() {
|
||||
if (!IsEditing && !IsCreating) return;
|
||||
bool ch = HasChanged(), v = IsValid();
|
||||
ResetButton.IsEnabled = (ch);
|
||||
SaveButton.IsEnabled = (v && ch);
|
||||
}
|
||||
|
||||
private bool HasChanged()
|
||||
{
|
||||
private bool HasChanged() {
|
||||
return true; // TODO
|
||||
}
|
||||
|
||||
private void InputTextChanged(TextBox input, Func<TextBox, ValidationResult> checker)
|
||||
{
|
||||
private void InputTextChanged(TextBox input, Func<TextBox, ValidationResult> checker) {
|
||||
var res = checker(input);
|
||||
Valid[input] = res.IsValid;
|
||||
if (res.IsValid)
|
||||
@ -442,45 +395,37 @@ namespace WGneu.Windows
|
||||
UpdateButtons();
|
||||
}
|
||||
|
||||
private void InputLostFocus(TextBox input, Func<TextBox, ValidationResult> checker, string? msg)
|
||||
{
|
||||
private void InputLostFocus(TextBox input, Func<TextBox, ValidationResult> checker, string? msg) {
|
||||
var res = checker(input);
|
||||
if (!res.IsValid)
|
||||
MessageBox.Show(res.ErrorContent.ToString(), msg ?? res.ErrorContent.ToString(), MessageBoxButton.OK, MessageBoxImage.Warning);
|
||||
}
|
||||
|
||||
private void ComboBox_SelectionChanged(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void ComboBox_SelectionChanged(object sender, RoutedEventArgs e) {
|
||||
UpdateButtons();
|
||||
}
|
||||
|
||||
private void PhoneNrInput_TextChanged(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void PhoneNrInput_TextChanged(object sender, RoutedEventArgs e) {
|
||||
InputTextChanged((TextBox)sender, Validator.CheckPhoneNumber);
|
||||
}
|
||||
|
||||
private void PhoneNrInput_LostFocus(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void PhoneNrInput_LostFocus(object sender, RoutedEventArgs e) {
|
||||
InputLostFocus((TextBox)sender, Validator.CheckPhoneNumber, null);
|
||||
}
|
||||
|
||||
private void EmailInput_TextChanged(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void EmailInput_TextChanged(object sender, RoutedEventArgs e) {
|
||||
InputTextChanged((TextBox)sender, Validator.CheckEmailAddress);
|
||||
}
|
||||
|
||||
private void EmailInput_LostFocus(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void EmailInput_LostFocus(object sender, RoutedEventArgs e) {
|
||||
InputLostFocus((TextBox)sender, Validator.CheckEmailAddress, null);
|
||||
}
|
||||
|
||||
private void LfbisNrInput_TextChanged(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void LfbisNrInput_TextChanged(object sender, RoutedEventArgs e) {
|
||||
InputTextChanged((TextBox)sender, Validator.CheckLfbisNr);
|
||||
}
|
||||
|
||||
private void LfbisNrInput_LostFocus(object sender, RoutedEventArgs e)
|
||||
{
|
||||
private void LfbisNrInput_LostFocus(object sender, RoutedEventArgs e) {
|
||||
InputLostFocus((TextBox)sender, Validator.CheckLfbisNr, "Betriebsnummer ungültig");
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user