Compare commits
1 Commits
itext
...
700e1ec92c
| Author | SHA1 | Date | |
|---|---|---|---|
| 700e1ec92c |
@@ -109,14 +109,14 @@ namespace Elwig.Documents {
|
|||||||
|
|
||||||
var div = new Table(ColsMM(60, 105))
|
var div = new Table(ColsMM(60, 105))
|
||||||
.SetWidth(UnitValue.CreatePercentValue(100)).SetFixedLayout()
|
.SetWidth(UnitValue.CreatePercentValue(100)).SetFixedLayout()
|
||||||
.SetBorderCollapse(BorderCollapsePropertyValue.COLLAPSE);
|
.SetBorderCollapse(BorderCollapsePropertyValue.COLLAPSE)
|
||||||
|
.SetBorderTop(new SolidBorder(BorderThickness));
|
||||||
var hint = new KernedParagraph(8)
|
var hint = new KernedParagraph(8)
|
||||||
.Add(Italic("Hinweis:\n" +
|
.Add(Italic("Hinweis:\n" +
|
||||||
$"Die Summe der Lieferungen und die Summe der anfal\u00adlenden Pönalen werden mit " +
|
$"Die Summe der Lieferungen und die Summe der anfal\u00adlenden Pönalen werden mit " +
|
||||||
$"{Payment?.Variant.Season.Precision} Nach\u00adkomma-stellen berechnent, " +
|
$"{Payment?.Variant.Season.Precision} Nach\u00adkomma-stellen berechnent, " +
|
||||||
$"erst das Ergebnis wird kauf-männisch auf 2 Nach\u00adkomma\u00adstellen gerundet."))
|
$"erst das Ergebnis wird kauf-männisch auf 2 Nach\u00adkomma\u00adstellen gerundet."))
|
||||||
.SetWidth(56 * PtInMM).SetMarginsMM(4, 2, 4, 2);
|
.SetWidth(56 * PtInMM).SetMarginsMM(4, 2, 4, 2);
|
||||||
div.AddCell(new Cell(1, 2).SetPadding(0).SetBorder(Border.NO_BORDER).SetBorderTop(new SolidBorder(BorderThickness)));
|
|
||||||
div.AddCell(new Cell(3, 1).SetPadding(0).SetBorder(Border.NO_BORDER).Add(hint).SetKeepTogether(true));
|
div.AddCell(new Cell(3, 1).SetPadding(0).SetBorder(Border.NO_BORDER).Add(hint).SetKeepTogether(true));
|
||||||
var tbl1 = new Table(ColsMM(70, 5, 5, 25))
|
var tbl1 = new Table(ColsMM(70, 5, 5, 25))
|
||||||
.SetWidth(UnitValue.CreatePercentValue(100)).SetFixedLayout()
|
.SetWidth(UnitValue.CreatePercentValue(100)).SetFixedLayout()
|
||||||
@@ -203,12 +203,12 @@ namespace Elwig.Documents {
|
|||||||
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl1));
|
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl1));
|
||||||
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl2));
|
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl2));
|
||||||
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl3));
|
div.AddCell(new Cell().SetPadding(0).SetBorder(Border.NO_BORDER).Add(tbl3));
|
||||||
doc.Add(div);
|
doc.Add(div.SetMarginBottomMM(10));
|
||||||
|
|
||||||
if (comment != null) {
|
if (comment != null) {
|
||||||
doc.Add(new KernedParagraph($"*{comment}", 12).SetMarginTopMM(10));
|
doc.Add(new KernedParagraph($"*{comment}", 12));
|
||||||
}
|
}
|
||||||
doc.Add(new KernedParagraph($"Überweisung erfolgt auf Konto {Utils.FormatIban(Member.Iban ?? "-")}.", 12).SetPaddingTopMM(10));
|
doc.Add(new KernedParagraph($"Überweisung erfolgt auf Konto {Utils.FormatIban(Member.Iban ?? "-")}.", 12));
|
||||||
if (Text != null) {
|
if (Text != null) {
|
||||||
doc.Add(new KernedParagraph(Text, 12).SetMarginTop(12).SetKeepTogether(true));
|
doc.Add(new KernedParagraph(Text, 12).SetMarginTop(12).SetKeepTogether(true));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,22 +23,22 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="bblanchon.PDFium.Win32" Version="148.0.7734" />
|
<PackageReference Include="bblanchon.PDFium.Win32" Version="147.0.7690" />
|
||||||
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.4.0" />
|
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.4.0" />
|
||||||
<PackageReference Include="itext" Version="9.5.0" />
|
<PackageReference Include="itext" Version="9.5.0" />
|
||||||
<PackageReference Include="itext.bouncy-castle-adapter" Version="9.5.0" />
|
<PackageReference Include="itext.bouncy-castle-adapter" Version="9.5.0" />
|
||||||
<PackageReference Include="LinqKit" Version="1.3.11" />
|
<PackageReference Include="LinqKit" Version="1.3.11" />
|
||||||
<PackageReference Include="MailKit" Version="4.15.1" />
|
<PackageReference Include="MailKit" Version="4.15.0" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Proxies" Version="10.0.5" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Proxies" Version="10.0.3" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="10.0.5" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="10.0.3" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Configuration.Ini" Version="10.0.5" />
|
<PackageReference Include="Microsoft.Extensions.Configuration.Ini" Version="10.0.3" />
|
||||||
<PackageReference Include="Microsoft.Web.WebView2" Version="1.0.3856.49" />
|
<PackageReference Include="Microsoft.Web.WebView2" Version="1.0.3800.47" />
|
||||||
<PackageReference Include="NJsonSchema" Version="11.5.2" />
|
<PackageReference Include="NJsonSchema" Version="11.5.2" />
|
||||||
<PackageReference Include="ScottPlot.WPF" Version="5.1.57" />
|
<PackageReference Include="ScottPlot.WPF" Version="5.1.57" />
|
||||||
<PackageReference Include="SQLitePCLRaw.bundle_e_sqlite3" Version="3.0.2" />
|
<PackageReference Include="SQLitePCLRaw.bundle_e_sqlite3" Version="3.0.2" />
|
||||||
<PackageReference Include="System.IO.Hashing" Version="10.0.5" />
|
<PackageReference Include="System.IO.Hashing" Version="10.0.3" />
|
||||||
<PackageReference Include="System.IO.Ports" Version="10.0.5" />
|
<PackageReference Include="System.IO.Ports" Version="10.0.3" />
|
||||||
<PackageReference Include="System.Management" Version="10.0.5" />
|
<PackageReference Include="System.Management" Version="10.0.3" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -1180,104 +1180,5 @@ namespace Elwig.Services {
|
|||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<(int Year, int DId, int DPNr)[]> GetDidsFromFilters(this DeliveryAdminViewModel vm) {
|
|
||||||
using var ctx = new AppDbContext();
|
|
||||||
var (_, _, parts, _, _) = await vm.GetFilters(ctx);
|
|
||||||
return [.. (await parts.Select(p => new { p.Year, p.DId, p.DPNr }).ToListAsync()).Select(p => (p.Year, p.DId, p.DPNr))];
|
|
||||||
}
|
|
||||||
|
|
||||||
public static async Task BulkSetAttribute(this DeliveryAdminViewModel vm, string? attributeName) {
|
|
||||||
try {
|
|
||||||
string attrid;
|
|
||||||
if (attributeName == null) {
|
|
||||||
attrid = "NULL";
|
|
||||||
} else {
|
|
||||||
using var ctx = new AppDbContext();
|
|
||||||
var attr = await ctx.WineAttributes.Where(a => a.Name == attributeName).SingleAsync();
|
|
||||||
attrid = $"'{attr.AttrId}'";
|
|
||||||
}
|
|
||||||
var dids = await vm.GetDidsFromFilters();
|
|
||||||
var res = MessageBox.Show($"Soll wirklich für {dids.Length:N0} Teillieferung(en) das Attribut\n'{attributeName}' gesetz werden?",
|
|
||||||
"Massenaktion: Attribut setzen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
|
||||||
if (res != MessageBoxResult.OK) return;
|
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.Wait;
|
|
||||||
await Task.Run(async () => {
|
|
||||||
using (var cnx = await AppDbContext.ConnectAsync()) {
|
|
||||||
await cnx.ExecuteBatch($"""
|
|
||||||
UPDATE delivery_part SET attrid = {attrid}
|
|
||||||
WHERE (year, did, dpnr) IN ({string.Join(", ", dids.Select(d => $"({d.Year},{d.DId},{d.DPNr})"))})
|
|
||||||
""");
|
|
||||||
}
|
|
||||||
App.HintContextChange();
|
|
||||||
});
|
|
||||||
} catch (Exception exc) {
|
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static async Task BulkAddModifier(this DeliveryAdminViewModel vm, string modifierName) {
|
|
||||||
try {
|
|
||||||
string modid;
|
|
||||||
using (var ctx = new AppDbContext()) {
|
|
||||||
var attr = await ctx.Modifiers.Where(a => a.Name == modifierName).FirstAsync();
|
|
||||||
modid = $"'{attr.ModId}'";
|
|
||||||
}
|
|
||||||
|
|
||||||
var dids = await vm.GetDidsFromFilters();
|
|
||||||
var res = MessageBox.Show($"Soll wirklich für {dids.Length:N0} Teillieferung(en) der Zu-/Abschlag\n'{modifierName}' hinzugefügt werden?",
|
|
||||||
"Massenaktion: Zu-/Abschlag hinzufügen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
|
||||||
if (res != MessageBoxResult.OK) return;
|
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.Wait;
|
|
||||||
await Task.Run(async () => {
|
|
||||||
using (var cnx = await AppDbContext.ConnectAsync()) {
|
|
||||||
await cnx.ExecuteBatch($"""
|
|
||||||
INSERT INTO delivery_part_modifier (year, did, dpnr, modid)
|
|
||||||
VALUES {string.Join(", ", dids.Select(d => $"({d.Year},{d.DId},{d.DPNr},{modid})"))}
|
|
||||||
ON CONFLICT DO NOTHING
|
|
||||||
""");
|
|
||||||
}
|
|
||||||
App.HintContextChange();
|
|
||||||
});
|
|
||||||
} catch (Exception exc) {
|
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static async Task BulkRemoveModifier(this DeliveryAdminViewModel vm, string modifierName) {
|
|
||||||
try {
|
|
||||||
string modid;
|
|
||||||
using (var ctx = new AppDbContext()) {
|
|
||||||
var attr = await ctx.Modifiers.Where(a => a.Name == modifierName).FirstAsync();
|
|
||||||
modid = $"'{attr.ModId}'";
|
|
||||||
}
|
|
||||||
|
|
||||||
var dids = await vm.GetDidsFromFilters();
|
|
||||||
var res = MessageBox.Show($"Soll wirklich für {dids.Length:N0} Teillieferung(en) der Zu-/Abschlag\n'{modifierName}' entfernt werden?",
|
|
||||||
"Massenaktion: Zu-/Abschlag entfernen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
|
||||||
if (res != MessageBoxResult.OK) return;
|
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.Wait;
|
|
||||||
await Task.Run(async () => {
|
|
||||||
using (var cnx = await AppDbContext.ConnectAsync()) {
|
|
||||||
await cnx.ExecuteBatch($"""
|
|
||||||
DELETE FROM delivery_part_modifier
|
|
||||||
WHERE (year, did, dpnr, modid) IN ({string.Join(", ", dids.Select(d => $"({d.Year},{d.DId},{d.DPNr},{modid})"))})
|
|
||||||
""");
|
|
||||||
}
|
|
||||||
App.HintContextChange();
|
|
||||||
});
|
|
||||||
} catch (Exception exc) {
|
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -131,11 +131,7 @@
|
|||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="Liefermengen" x:Name="Menu_DeliveryDataList">
|
<MenuItem Header="Liefermengen" x:Name="Menu_DeliveryDataList">
|
||||||
<MenuItem x:Name="Menu_DeliveryDataList_SaveFilters" Header="...aus Filtern speichern... (Excel)"
|
<MenuItem x:Name="Menu_DeliveryDataList_SaveFilters" Header="...aus Filtern speichern... (Excel)"
|
||||||
Click="Menu_DeliveryDataList_SaveFilters_Click">
|
Click="Menu_DeliveryDataList_SaveFilters_Click"/>
|
||||||
<MenuItem.Icon>
|
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""/>
|
|
||||||
</MenuItem.Icon>
|
|
||||||
</MenuItem>
|
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="Statistik" x:Name="Menu_Statistics">
|
<MenuItem Header="Statistik" x:Name="Menu_Statistics">
|
||||||
<MenuItem Header="Qualitätsstatistik..." x:Name="Menu_Statistics_WineQuality">
|
<MenuItem Header="Qualitätsstatistik..." x:Name="Menu_Statistics_WineQuality">
|
||||||
@@ -166,11 +162,7 @@
|
|||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem x:Name="Menu_Statistics_Locality" Header="Lieferstatistik pro Ort...">
|
<MenuItem x:Name="Menu_Statistics_Locality" Header="Lieferstatistik pro Ort...">
|
||||||
<MenuItem x:Name="Menu_Statistic_Locality_SaveFilters" Header="...aus Filtern speichern... (Excel)"
|
<MenuItem x:Name="Menu_Statistic_Locality_SaveFilters" Header="...aus Filtern speichern... (Excel)"
|
||||||
Click="Menu_Statistic_Locality_SaveFilters_Click">
|
Click="Menu_Statistic_Locality_SaveFilters_Click"/>
|
||||||
<MenuItem.Icon>
|
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""/>
|
|
||||||
</MenuItem.Icon>
|
|
||||||
</MenuItem>
|
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="BKI">
|
<MenuItem Header="BKI">
|
||||||
@@ -192,23 +184,6 @@
|
|||||||
<MenuItem x:Name="Menu_Export_UploadSeason" Header="...von Saison/Zweigstelle hochladen"
|
<MenuItem x:Name="Menu_Export_UploadSeason" Header="...von Saison/Zweigstelle hochladen"
|
||||||
Click="Menu_Export_UploadSeason_Click"/>
|
Click="Menu_Export_UploadSeason_Click"/>
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="Massenaktion">
|
|
||||||
<MenuItem x:Name="Menu_BulkAction_SetAttribute" Header="Attribut auf Lieferungen aus Filtern setzen...">
|
|
||||||
<MenuItem.Icon>
|
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""/>
|
|
||||||
</MenuItem.Icon>
|
|
||||||
</MenuItem>
|
|
||||||
<MenuItem x:Name="Menu_BulkAction_AddModifier" Header="Zu-/Abschlag auf Lieferungen aus Filtern hinzufügen...">
|
|
||||||
<MenuItem.Icon>
|
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""/>
|
|
||||||
</MenuItem.Icon>
|
|
||||||
</MenuItem>
|
|
||||||
<MenuItem x:Name="Menu_BulkAction_RemoveModifier" Header="Zu-/Abschlag auf Lieferungen aus Filtern entfernen...">
|
|
||||||
<MenuItem.Icon>
|
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""/>
|
|
||||||
</MenuItem.Icon>
|
|
||||||
</MenuItem>
|
|
||||||
</MenuItem>
|
|
||||||
<MenuItem Header="Einstellungen">
|
<MenuItem Header="Einstellungen">
|
||||||
<MenuItem x:Name="Menu_Settings_EnableFreeEditing" Header="Freie Bearbeitung aktivieren"
|
<MenuItem x:Name="Menu_Settings_EnableFreeEditing" Header="Freie Bearbeitung aktivieren"
|
||||||
IsCheckable="True" Checked="Menu_Settings_EnableFreeEditing_Checked" Unchecked="Menu_Settings_EnableFreeEditing_Unchecked"/>
|
IsCheckable="True" Checked="Menu_Settings_EnableFreeEditing_Checked" Unchecked="Menu_Settings_EnableFreeEditing_Unchecked"/>
|
||||||
|
|||||||
@@ -14,7 +14,6 @@ using System.Threading.Tasks;
|
|||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
using System.Windows.Media;
|
|
||||||
using System.Windows.Threading;
|
using System.Windows.Threading;
|
||||||
|
|
||||||
namespace Elwig.Windows {
|
namespace Elwig.Windows {
|
||||||
@@ -284,21 +283,6 @@ namespace Elwig.Windows {
|
|||||||
private async void Menu_DeliveryDataList_SaveFilters_Click(object sender, RoutedEventArgs evt) =>
|
private async void Menu_DeliveryDataList_SaveFilters_Click(object sender, RoutedEventArgs evt) =>
|
||||||
await ViewModel.GenerateDeliveryDataList(DeliveryService.ExportSubject.FromFilters, ExportMode.SaveList);
|
await ViewModel.GenerateDeliveryDataList(DeliveryService.ExportSubject.FromFilters, ExportMode.SaveList);
|
||||||
|
|
||||||
private async void Menu_BulkAction_SetAttribute_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (sender is not MenuItem item) return;
|
|
||||||
await ViewModel.BulkSetAttribute(item.Header as string);
|
|
||||||
}
|
|
||||||
|
|
||||||
private async void Menu_BulkAction_AddModifier_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (sender is not MenuItem item || item.Header is not string name) return;
|
|
||||||
await ViewModel.BulkAddModifier(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
private async void Menu_BulkAction_RemoveModifier_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (sender is not MenuItem item || item.Header is not string name) return;
|
|
||||||
await ViewModel.BulkRemoveModifier(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void Menu_Settings_EnableFreeEditing_Checked(object sender, RoutedEventArgs evt) {
|
private void Menu_Settings_EnableFreeEditing_Checked(object sender, RoutedEventArgs evt) {
|
||||||
if (IsEditing || IsCreating) {
|
if (IsEditing || IsCreating) {
|
||||||
DateInput.IsReadOnly = false;
|
DateInput.IsReadOnly = false;
|
||||||
@@ -484,10 +468,8 @@ namespace Elwig.Windows {
|
|||||||
ViewModel.Title = $"Lieferungen - {ViewModel.FilterMember.AdministrativeName} - Elwig";
|
ViewModel.Title = $"Lieferungen - {ViewModel.FilterMember.AdministrativeName} - Elwig";
|
||||||
}
|
}
|
||||||
|
|
||||||
int year = 0;
|
|
||||||
Menu_Bki_SaveList.Items.Clear();
|
Menu_Bki_SaveList.Items.Clear();
|
||||||
foreach (var s in await ctx.Seasons.OrderByDescending(s => s.Year).ToListAsync()) {
|
foreach (var s in await ctx.Seasons.OrderByDescending(s => s.Year).ToListAsync()) {
|
||||||
if (s.Year > year) year = s.Year;
|
|
||||||
var i = new MenuItem {
|
var i = new MenuItem {
|
||||||
Header = $"Saison {s.Year}",
|
Header = $"Saison {s.Year}",
|
||||||
};
|
};
|
||||||
@@ -495,37 +477,6 @@ namespace Elwig.Windows {
|
|||||||
Menu_Bki_SaveList.Items.Add(i);
|
Menu_Bki_SaveList.Items.Add(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
var font = new FontFamily("Segoe MDL2 Assets");
|
|
||||||
Menu_BulkAction_SetAttribute.Items.Clear();
|
|
||||||
var noAttr = new MenuItem {
|
|
||||||
Header = new TextBlock() { Text = "Kein Attribut", FontStyle = FontStyles.Italic },
|
|
||||||
Icon = new TextBlock() { Text = "\ue75c", FontFamily = font, FontSize = 16 },
|
|
||||||
};
|
|
||||||
noAttr.Click += Menu_BulkAction_SetAttribute_Click;
|
|
||||||
Menu_BulkAction_SetAttribute.Items.Add(noAttr);
|
|
||||||
foreach (var attr in await ctx.WineAttributes.OrderBy(a => a.AttrId).ToListAsync()) {
|
|
||||||
var i = new MenuItem {
|
|
||||||
Header = attr.Name,
|
|
||||||
};
|
|
||||||
i.Click += Menu_BulkAction_SetAttribute_Click;
|
|
||||||
Menu_BulkAction_SetAttribute.Items.Add(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
Menu_BulkAction_AddModifier.Items.Clear();
|
|
||||||
Menu_BulkAction_RemoveModifier.Items.Clear();
|
|
||||||
foreach (var mod in await ctx.Modifiers.Where(m => m.Year == year).OrderBy(m => m.ModId).ToListAsync()) {
|
|
||||||
var i1 = new MenuItem {
|
|
||||||
Header = mod.Name,
|
|
||||||
};
|
|
||||||
i1.Click += Menu_BulkAction_AddModifier_Click;
|
|
||||||
Menu_BulkAction_AddModifier.Items.Add(i1);
|
|
||||||
var i2 = new MenuItem {
|
|
||||||
Header = mod.Name,
|
|
||||||
};
|
|
||||||
i2.Click += Menu_BulkAction_RemoveModifier_Click;
|
|
||||||
Menu_BulkAction_RemoveModifier.Items.Add(i2);
|
|
||||||
}
|
|
||||||
|
|
||||||
await RefreshList();
|
await RefreshList();
|
||||||
var d = DeliveryList.SelectedItem as Delivery;
|
var d = DeliveryList.SelectedItem as Delivery;
|
||||||
var y = d?.Year ?? ViewModel.FilterSeason;
|
var y = d?.Year ?? ViewModel.FilterSeason;
|
||||||
|
|||||||
@@ -19,12 +19,12 @@
|
|||||||
</Target>
|
</Target>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="18.3.0" />
|
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="18.0.1" />
|
||||||
<PackageReference Include="Appium.WebDriver" Version="4.4.5" />
|
<PackageReference Include="Appium.WebDriver" Version="4.4.5" />
|
||||||
<PackageReference Include="NReco.PdfRenderer" Version="1.6.0" />
|
<PackageReference Include="NReco.PdfRenderer" Version="1.6.0" />
|
||||||
<PackageReference Include="NUnit" Version="4.5.1" />
|
<PackageReference Include="NUnit" Version="4.5.0" />
|
||||||
<PackageReference Include="NUnit3TestAdapter" Version="6.1.0" />
|
<PackageReference Include="NUnit3TestAdapter" Version="6.1.0" />
|
||||||
<PackageReference Include="NUnit.Analyzers" Version="4.12.0">
|
<PackageReference Include="NUnit.Analyzers" Version="4.11.2">
|
||||||
<PrivateAssets>all</PrivateAssets>
|
<PrivateAssets>all</PrivateAssets>
|
||||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
|
|||||||
Reference in New Issue
Block a user