diff --git a/Elwig/Documents/BusinessDocument.cs b/Elwig/Documents/BusinessDocument.cs
index 2dcbaec..aa71b05 100644
--- a/Elwig/Documents/BusinessDocument.cs
+++ b/Elwig/Documents/BusinessDocument.cs
@@ -156,7 +156,7 @@ namespace Elwig.Documents {
tbl += $"
Gesamtlieferung lt. gez. GA | {FormatRow(
Member.BusinessShares * season.MinKgPerBusinessShare,
Member.BusinessShares * season.MaxKgPerBusinessShare,
- Member.Deliveries.Where(d => d.Year == season.Year).Sum(d => d.Weight),
+ season.Deliveries.Where(d => d.MgNr == Member.MgNr).Sum(d => d.Weight),
isGa: true, showPayment: includePayment, showArea: !includeDelivery
)}
";
if (fbs.Any()) {
diff --git a/Elwig/Documents/MemberDataSheet.cs b/Elwig/Documents/MemberDataSheet.cs
index 7563e46..5ed3679 100644
--- a/Elwig/Documents/MemberDataSheet.cs
+++ b/Elwig/Documents/MemberDataSheet.cs
@@ -11,11 +11,13 @@ namespace Elwig.Documents {
public Season Season;
public Dictionary MemberBuckets;
+ public IEnumerable ActiveAreaCommitments;
public MemberDataSheet(Member m, AppDbContext ctx) : base($"{Name} {m.AdministrativeName}", m) {
DocumentId = $"{Name} {m.MgNr}";
Season = ctx.Seasons.ToList().MaxBy(s => s.Year) ?? throw new ArgumentException("invalid season");
MemberBuckets = ctx.GetMemberBuckets(Utils.CurrentYear, m.MgNr).GetAwaiter().GetResult();
+ ActiveAreaCommitments = m.ActiveAreaCommitments(ctx);
}
}
}
diff --git a/Elwig/Documents/MemberDataSheet.cshtml b/Elwig/Documents/MemberDataSheet.cshtml
index 3f0ec0d..8316721 100644
--- a/Elwig/Documents/MemberDataSheet.cshtml
+++ b/Elwig/Documents/MemberDataSheet.cshtml
@@ -149,7 +149,7 @@
@Raw(Model.PrintBucketTable(Model.Season, Model.MemberBuckets, includeDelivery: false))
@{
- var areaComs = Model.Member.ActiveAreaCommitments.GroupBy(a => a.AreaComType).Select(group => new {
+ var areaComs = Model.ActiveAreaCommitments.GroupBy(a => a.AreaComType).Select(group => new {
AreaComType = group.Key,
AreaComs = group.OrderBy(c => c.Kg.AtKg.Name),
Size = group.Sum(c => c.Area)
@@ -205,7 +205,7 @@
}
Gesamt: |
- @($"{Model.Member.ActiveAreaCommitments.Select(a => a.Area).Sum():N0}") |
+ @($"{Model.ActiveAreaCommitments.Sum(a => a.Area):N0}") |
|
diff --git a/Elwig/Helpers/Validator.cs b/Elwig/Helpers/Validator.cs
index 54b2d11..111405b 100644
--- a/Elwig/Helpers/Validator.cs
+++ b/Elwig/Helpers/Validator.cs
@@ -429,7 +429,7 @@ namespace Elwig.Helpers {
return new(true, null);
}
- public static ValidationResult CheckNewMgNr(TextBox input, bool required, AppDbContext ctx, Member? m) {
+ public static ValidationResult CheckNewMgNr(TextBox input, bool required, Member? m) {
var res = CheckInteger(input, required);
if (!res.IsValid) {
return res;
@@ -437,6 +437,7 @@ namespace Elwig.Helpers {
return new(true, null);
}
+ using var ctx = new AppDbContext();
int nr = int.Parse(input.Text);
if (nr != m?.MgNr && ctx.MgNrExists(nr).GetAwaiter().GetResult()) {
return new(false, "Mitgliedsnummer wird bereits verwendet");
diff --git a/Elwig/Models/Entities/Member.cs b/Elwig/Models/Entities/Member.cs
index 32a9d6a..5ed52a0 100644
--- a/Elwig/Models/Entities/Member.cs
+++ b/Elwig/Models/Entities/Member.cs
@@ -156,9 +156,10 @@ namespace Elwig.Models.Entities {
[InverseProperty("Member")]
public virtual ISet AreaCommitments { get; private set; } = null!;
- [NotMapped]
- public IEnumerable ActiveAreaCommitments => AreaCommitments
- .Where(c => c.YearFrom <= Utils.CurrentYear && (c.YearTo ?? int.MaxValue) >= Utils.CurrentYear);
+ public IEnumerable ActiveAreaCommitments(AppDbContext ctx) {
+ return ctx.AreaCommitments
+ .Where(c => c.MgNr == MgNr && c.YearFrom <= Utils.CurrentYear && (c.YearTo ?? int.MaxValue) >= Utils.CurrentYear);
+ }
[InverseProperty("Member")]
public virtual BillingAddr? BillingAddress { get; private set; }
diff --git a/Elwig/Windows/MemberAdminWindow.xaml.cs b/Elwig/Windows/MemberAdminWindow.xaml.cs
index 6601d7f..19d568e 100644
--- a/Elwig/Windows/MemberAdminWindow.xaml.cs
+++ b/Elwig/Windows/MemberAdminWindow.xaml.cs
@@ -8,7 +8,6 @@ using System.Windows.Input;
using Elwig.Helpers;
using Elwig.Models.Entities;
using System.Threading.Tasks;
-using Microsoft.EntityFrameworkCore.ChangeTracking;
using System.Collections.ObjectModel;
using Elwig.Documents;
using System.Diagnostics;
@@ -77,7 +76,8 @@ namespace Elwig.Windows {
if (IsEditing || IsCreating) return;
var item = MemberList.ItemsSource.Cast().FirstOrDefault(m => m.MgNr == mgnr);
if (item == null) {
- var m = Context.Members.Find(mgnr);
+ using var ctx = new AppDbContext();
+ var m = ctx.Members.Find(mgnr);
if (m == null) return;
if (SearchInput.Text.Length > 0) {
SearchInput.Text = "";
@@ -96,12 +96,12 @@ namespace Elwig.Windows {
}
private async Task RefreshMemberList() {
- await Context.Members.LoadAsync();
await RefreshMemberListQuery();
}
private async Task RefreshMemberListQuery(bool updateSort = false) {
- IQueryable memberQuery = Context.Members;
+ using var ctx = new AppDbContext();
+ IQueryable memberQuery = ctx.Members;
if (ActiveMemberInput.IsChecked == true) memberQuery = memberQuery.Where(m => m.IsActive);
var filterMgNr = new List();
@@ -113,10 +113,10 @@ namespace Elwig.Windows {
var filter = TextFilter.ToList();
if (filter.Count > 0) {
- var branches = await Context.Branches.ToListAsync();
- var mgnr = await Context.Members.ToDictionaryAsync(m => m.MgNr.ToString(), m => m);
- var kgs = await Context.WbKgs.ToDictionaryAsync(k => k.AtKg.Name.ToLower(), k => k.AtKg);
- var areaComs = await Context.AreaCommitmentTypes.ToDictionaryAsync(t => $"{t.SortId}{t.AttrId}", t => t);
+ var branches = await ctx.Branches.ToListAsync();
+ var mgnr = await ctx.Members.ToDictionaryAsync(m => m.MgNr.ToString(), m => m);
+ var kgs = await ctx.WbKgs.ToDictionaryAsync(k => k.AtKg.Name.ToLower(), k => k.AtKg);
+ var areaComs = await ctx.AreaCommitmentTypes.ToDictionaryAsync(t => $"{t.SortId}{t.AttrId}", t => t);
for (int i = 0; i < filter.Count; i++) {
var e = filter[i];
@@ -189,6 +189,15 @@ namespace Elwig.Windows {
if (filterUstIdNr.Count > 0) memberQuery = memberQuery.Where(m => m.UstIdNr != null && filterUstIdNr.Contains(m.UstIdNr));
}
+ memberQuery = memberQuery
+ .Include(m => m.Branch)
+ .Include(m => m.DefaultWbKg.AtKg)
+ .Include(m => m.EmailAddresses)
+ .Include(m => m.TelephoneNumbers)
+ .Include(m => m.PostalDest.AtPlz.Ort)
+ .Include(m => m.PostalDest.AtPlz.Country)
+ .Include(m => m.BillingAddress.PostalDest.AtPlz.Ort)
+ .Include(m => m.BillingAddress.PostalDest.AtPlz.Country);
List members = await memberQuery.ToListAsync();
if (filter.Count > 0 && members.Count > 0) {
@@ -240,13 +249,15 @@ namespace Elwig.Windows {
ClearOriginalValues();
ClearDefaultValues();
- MgNrInput.Text = (await Context.NextMgNr()).ToString();
- EntryDateInput.Text = DateTime.Now.ToString("dd.MM.yyyy");
- if (Context.Branches.Count() == 1)
- BranchInput.SelectedItem = Context.Branches.First();
- ActiveInput.IsChecked = true;
- ContactPostalInput.IsChecked = true;
- MemberReferenceButton.IsEnabled = false;
+ using (var ctx = new AppDbContext()) {
+ MgNrInput.Text = (await ctx.NextMgNr()).ToString();
+ EntryDateInput.Text = DateTime.Now.ToString("dd.MM.yyyy");
+ if (await ctx.Branches.CountAsync() == 1)
+ BranchInput.SelectedIndex = 0;
+ ActiveInput.IsChecked = true;
+ ContactPostalInput.IsChecked = true;
+ MemberReferenceButton.IsEnabled = false;
+ }
SetDefaultValue(MgNrInput);
SetDefaultValue(EntryDateInput);
@@ -256,11 +267,12 @@ namespace Elwig.Windows {
protected override async Task OnRenewContext() {
await base.OnRenewContext();
- ControlUtils.RenewItemsSource(BranchInput, await Context.Branches.OrderBy(b => b.Name).ToListAsync(), i => (i as Branch)?.ZwstId);
- ControlUtils.RenewItemsSource(DefaultKgInput, await Context.WbKgs.Select(k => k.AtKg).OrderBy(k => k.Name).ToListAsync(), i => (i as AT_Kg)?.KgNr);
+ using var ctx = new AppDbContext();
+ ControlUtils.RenewItemsSource(BranchInput, await ctx.Branches.OrderBy(b => b.Name).ToListAsync(), i => (i as Branch)?.ZwstId);
+ ControlUtils.RenewItemsSource(DefaultKgInput, await ctx.WbKgs.Select(k => k.AtKg).OrderBy(k => k.Name).ToListAsync(), i => (i as AT_Kg)?.KgNr);
await RefreshMemberList();
- StatusMembers.Text = $"Mitglieder: {await Context.Members.CountAsync(m => m.IsActive):N0} ({await Context.Members.CountAsync():N0})";
- StatusBusinessShares.Text = $"Geschäftsanteile: {await Context.Members.Where(m => m.IsActive).SumAsync(m => m.BusinessShares):N0} ({await Context.Members.SumAsync(m => m.BusinessShares):N0})";
+ StatusMembers.Text = $"Mitglieder: {await ctx.Members.CountAsync(m => m.IsActive):N0} ({await ctx.Members.CountAsync():N0})";
+ StatusBusinessShares.Text = $"Geschäftsanteile: {await ctx.Members.Where(m => m.IsActive).SumAsync(m => m.BusinessShares):N0} ({await ctx.Members.SumAsync(m => m.BusinessShares):N0})";
}
private void SetPhoneNrInput(int nr, string? type, string? number, string? comment) {
@@ -359,14 +371,15 @@ namespace Elwig.Windows {
$"Sämtliche Lieferungen und Flächenbindungen dieses Mitglieds werden auch gelöscht!",
"Mitglied löschen", MessageBoxButton.YesNo, MessageBoxImage.Warning, MessageBoxResult.No);
if (r == MessageBoxResult.Yes) {
- Context.Remove(m);
- await Context.SaveChangesAsync();
+ using var ctx = new AppDbContext();
+ ctx.Remove(m);
+ await ctx.SaveChangesAsync();
await RefreshMemberList();
}
}
private async void SaveButton_Click(object sender, RoutedEventArgs evt) {
- Member m = await UpdateMember(MemberList.SelectedItem as Member);
+ var mgnr = await UpdateMember((MemberList.SelectedItem as Member)?.MgNr);
IsEditing = false;
IsCreating = false;
MemberList.IsEnabled = true;
@@ -379,7 +392,7 @@ namespace Elwig.Windows {
await RefreshMemberList();
RefreshInputs();
SearchInput.Text = "";
- MemberList.SelectedItem = m;
+ FocusMember(mgnr);
}
private void ResetButton_Click(object sender, RoutedEventArgs evt) {
@@ -446,7 +459,8 @@ namespace Elwig.Windows {
return;
Mouse.OverrideCursor = Cursors.AppStarting;
try {
- using var doc = new MemberDataSheet(m, Context);
+ using var ctx = new AppDbContext();
+ using var doc = new MemberDataSheet(m, ctx);
await doc.Generate();
if (App.Config.Debug) {
doc.Show();
@@ -464,7 +478,8 @@ namespace Elwig.Windows {
return;
Mouse.OverrideCursor = Cursors.AppStarting;
try {
- using var doc = new MemberDataSheet(m, Context);
+ using var ctx = new AppDbContext();
+ using var doc = new MemberDataSheet(m, ctx);
await doc.Generate();
doc.Show();
} catch (Exception exc) {
@@ -548,9 +563,11 @@ namespace Elwig.Windows {
}
}
- private async Task UpdateMember(Member? m) {
- bool memberNew = (m == null);
- m ??= Context.CreateProxy();
+ private async Task UpdateMember(int? mgnr) {
+ using var ctx = new AppDbContext();
+ var m = ctx.CreateProxy();
+ if (mgnr != null)
+ m.MgNr = (int)mgnr;
int newMgNr = int.Parse(MgNrInput.Text);
m.PredecessorMgNr = (PredecessorMgNrInput.Text == "") ? null : int.Parse(PredecessorMgNrInput.Text);
@@ -585,23 +602,22 @@ namespace Elwig.Windows {
m.ContactViaPost = ContactPostalInput.IsChecked ?? false;
m.ContactViaEmail = ContactEmailInput.IsChecked ?? false;
- EntityEntry? tr = null;
try {
if (IsEditing) {
- tr = Context.Update(m);
+ ctx.Update(m);
} else if (IsCreating) {
m.MgNr = newMgNr;
- tr = (await Context.AddAsync(m));
+ await ctx.AddAsync(m);
} else {
throw new Exception();
}
if (BillingOrtInput.SelectedItem == null) {
if (m.BillingAddress != null) {
- Context.Remove(m.BillingAddress);
+ ctx.Remove(m.BillingAddress);
}
} else {
- BillingAddr b = m.BillingAddress ?? Context.CreateProxy();
+ BillingAddr b = m.BillingAddress ?? ctx.CreateProxy();
b.Name = BillingNameInput.Text;
b.Address = BillingAddressInput.Text;
var p = (AT_PlzDest)BillingOrtInput.SelectedItem;
@@ -609,60 +625,52 @@ namespace Elwig.Windows {
b.PostalDestId = p.Id;
if (m.BillingAddress == null) {
b.MgNr = newMgNr;
- await Context.AddAsync(b);
+ await ctx.AddAsync(b);
} else {
- Context.Update(b);
+ ctx.Update(b);
}
}
- Context.RemoveRange(m.TelephoneNumbers);
+ ctx.RemoveRange(m.TelephoneNumbers);
for (int i = 0, j = 0; i < PhoneNrInputs.Length; i++) {
var input = GetPhoneNrInput(i);
if (input != null) {
var pInput = input.Value;
- MemberTelNr p = Context.CreateProxy();
+ MemberTelNr p = ctx.CreateProxy();
p.MgNr = newMgNr;
p.Nr = ++j;
p.Type = pInput.Type;
p.Number = pInput.Number;
p.Comment = pInput.Comment;
- await Context.AddAsync(p);
+ await ctx.AddAsync(p);
}
}
- Context.RemoveRange(m.EmailAddresses);
+ ctx.RemoveRange(m.EmailAddresses);
for (int i = 0, j = 0; i < EmailAddressInputs.Length; i++) {
var input = GetEmailAddressInput(i);
if (input != null && input != "") {
- MemberEmailAddr a = Context.CreateProxy();
+ MemberEmailAddr a = ctx.CreateProxy();
a.MgNr = newMgNr;
a.Nr = ++j;
a.Address = input;
a.Comment = null;
- await Context.AddAsync(a);
+ await ctx.AddAsync(a);
}
}
- await Context.SaveChangesAsync();
+ await ctx.SaveChangesAsync();
if (newMgNr != m.MgNr) {
- await Context.Database.ExecuteSqlAsync($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {m.MgNr}");
- tr.State = EntityState.Detached;
- await Context.SaveChangesAsync();
- await tr.ReloadAsync();
- m = await Context.Members.FindAsync(newMgNr);
+ await ctx.Database.ExecuteSqlAsync($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {m.MgNr}");
}
} catch (Exception exc) {
- if (tr != null) {
- tr.State = EntityState.Detached;
- await tr.ReloadAsync();
- }
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);
}
- return m;
+ return m.MgNr;
}
private void FillInputs(Member m) {
@@ -689,7 +697,7 @@ namespace Elwig.Windows {
AT_PlzDest? p = m.PostalDest.AtPlz;
if (p != null) {
PlzInput.Text = p.Plz.ToString();
- OrtInput.SelectedItem = p;
+ ControlUtils.SelectComboBoxItem(OrtInput, o => (o as AT_PlzDest)?.Okz, p.Okz);
} else {
PlzInput.Text = null;
OrtInput.SelectedItem = null;
@@ -731,7 +739,7 @@ namespace Elwig.Windows {
AT_PlzDest? b = billingAddr.PostalDest.AtPlz;
if (b != null) {
BillingPlzInput.Text = b.Plz.ToString();
- BillingOrtInput.SelectedItem = b;
+ ControlUtils.SelectComboBoxItem(BillingOrtInput, o => (o as AT_PlzDest)?.Okz, b.Okz);
}
} else {
BillingNameInput.Text = "";
@@ -744,8 +752,8 @@ namespace Elwig.Windows {
ExitDateInput.Text = (m.ExitDateString != null) ? string.Join(".", m.ExitDateString.Split("-").Reverse()) : null;
BusinessSharesInput.Text = m.BusinessShares.ToString();
AccountingNrInput.Text = m.AccountingNr;
- BranchInput.SelectedItem = m.Branch;
- DefaultKgInput.SelectedItem = m.DefaultKg;
+ ControlUtils.SelectComboBoxItem(BranchInput, b => (b as Branch)?.ZwstId, m.ZwstId);
+ ControlUtils.SelectComboBoxItem(DefaultKgInput, k => (k as AT_Kg)?.KgNr, m.DefaultKgNr);
CommentInput.Text = m.Comment;
ActiveInput.IsChecked = m.IsActive;
VollLieferantInput.IsChecked = m.IsVollLieferant;
@@ -753,11 +761,13 @@ namespace Elwig.Windows {
ContactPostalInput.IsChecked = m.ContactViaPost;
ContactEmailInput.IsChecked = m.ContactViaEmail;
- var d1 = Context.Deliveries.Where(d => d.Year == Utils.CurrentLastSeason && d.MgNr == m.MgNr);
- var d2 = Context.Deliveries.Where(d => d.Year == Utils.CurrentLastSeason - 1 && d.MgNr == m.MgNr);
- StatusDeliveriesLastSeason.Text = $"Lieferungen ({Utils.CurrentLastSeason - 1}): {d2.Count():N0} ({d2.Sum(d => d.Parts.Count):N0}), {d2.SelectMany(d => d.Parts).Sum(p => p.Weight):N0} kg";
- StatusDeliveriesThisSeason.Text = $"Lieferungen ({Utils.CurrentLastSeason}): {d1.Count():N0} ({d1.Sum(d => d.Parts.Count):N0}), {d1.SelectMany(d => d.Parts).Sum(p => p.Weight):N0} kg";
- StatusAreaCommitment.Text = $"Gebundene Fläche: {m.ActiveAreaCommitments.Select(c => c.Area).Sum():N0} m²";
+ using (var ctx = new AppDbContext()) {
+ var d1 = ctx.Deliveries.Where(d => d.Year == Utils.CurrentLastSeason && d.MgNr == m.MgNr);
+ var d2 = ctx.Deliveries.Where(d => d.Year == Utils.CurrentLastSeason - 1 && d.MgNr == m.MgNr);
+ StatusDeliveriesLastSeason.Text = $"Lieferungen ({Utils.CurrentLastSeason - 1}): {d2.Count():N0} ({d2.Sum(d => d.Parts.Count):N0}), {d2.SelectMany(d => d.Parts).Sum(p => p.Weight):N0} kg";
+ StatusDeliveriesThisSeason.Text = $"Lieferungen ({Utils.CurrentLastSeason}): {d1.Count():N0} ({d1.Sum(d => d.Parts.Count):N0}), {d1.SelectMany(d => d.Parts).Sum(p => p.Weight):N0} kg";
+ StatusAreaCommitment.Text = $"Gebundene Fläche: {m.ActiveAreaCommitments(ctx).Select(c => c.Area).Sum():N0} m²";
+ }
Menu_Member_SendEmail.IsEnabled = m.EmailAddresses.Count > 0;
Menu_Print_Letterhead.IsEnabled = true;
@@ -787,12 +797,12 @@ namespace Elwig.Windows {
SaveButton.IsEnabled = v && ch;
}
- protected void InputTextChanged(TextBox input, Func checker) {
- InputTextChanged(input, checker(input, SenderIsRequired(input), Context, (Member)MemberList.SelectedItem));
+ protected void InputTextChanged(TextBox input, Func checker) {
+ InputTextChanged(input, checker(input, SenderIsRequired(input), (Member)MemberList.SelectedItem));
}
- protected void InputLostFocus(TextBox input, Func checker, string? msg = null) {
- InputLostFocus(input, checker(input, SenderIsRequired(input), Context, (Member)MemberList.SelectedItem), msg);
+ protected void InputLostFocus(TextBox input, Func checker, string? msg = null) {
+ InputLostFocus(input, checker(input, SenderIsRequired(input), (Member)MemberList.SelectedItem), msg);
}
private void MgNrInput_TextChanged(object sender, RoutedEventArgs evt) {