Compare commits
5 Commits
Author | SHA1 | Date | |
---|---|---|---|
2ff53c67c3 | |||
3e1f8a910b | |||
ca1fb0f5e8 | |||
39d749ad2d | |||
31c491d956 |
CHANGELOG.md
Elwig
App.xaml.cs
Documents
BusinessDocument.cshtmlCreditNote.cshtmlDeliveryAncmtList.cshtmlDeliveryConfirmation.cshtmlDeliveryDepreciationList.cshtmlDeliveryJournal.cshtmlDeliveryNote.cshtmlDocument.csDocument.cshtmlMemberDataSheet.cshtmlMemberList.cshtmlPaymentVariantSummary.cshtmlWineQualityStatistics.cshtml
Elwig.csprojHelpers
Models
Dtos
Services
Windows
AreaComAdminWindow.xaml.csBaseDataWindow.xaml.Season.csBaseDataWindow.xaml.csDeliveryAdminWindow.xamlDeliveryAdminWindow.xaml.csDeliveryAncmtAdminWindow.xamlDeliveryScheduleAdminWindow.xamlMailWindow.xaml.csMainWindow.xamlMainWindow.xaml.csMemberAdminWindow.xaml.csPaymentVariantsWindow.xaml
fetch-resources.batInstaller
Tests/DocumentTests
13
CHANGELOG.md
13
CHANGELOG.md
@ -3,19 +3,6 @@ Changelog
|
|||||||
=========
|
=========
|
||||||
|
|
||||||
|
|
||||||
[v0.13.9][v0.13.9] (2025-05-05) {#v0.13.9}
|
|
||||||
------------------------------------------
|
|
||||||
|
|
||||||
### Sonstiges {#v0.13.9-misc}
|
|
||||||
|
|
||||||
* Abhängigkeiten aktualisiert. (bf0db37872, 4af2fa256e, d1c07ee92a, 41c5288fc5)
|
|
||||||
* Automatisches Aktualisieren der Synchroisations-URL (`https://elwig.at/clients/` -> `https://sync.elwig.at/`). (e50e7337e6)
|
|
||||||
|
|
||||||
[v0.13.9]: https://git.necronda.net/winzer/elwig/releases/tag/v0.13.9
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[v0.13.8][v0.13.8] (2025-02-21) {#v0.13.8}
|
[v0.13.8][v0.13.8] (2025-02-21) {#v0.13.8}
|
||||||
------------------------------------------
|
------------------------------------------
|
||||||
|
|
||||||
|
@ -25,13 +25,10 @@ namespace Elwig {
|
|||||||
|
|
||||||
private readonly DispatcherTimer _autoUpdateTimer = new() { Interval = TimeSpan.FromHours(1) };
|
private readonly DispatcherTimer _autoUpdateTimer = new() { Interval = TimeSpan.FromHours(1) };
|
||||||
|
|
||||||
public static readonly string DataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData), "Elwig");
|
public static readonly string DataPath = @"C:\ProgramData\Elwig\";
|
||||||
public static readonly string MailsPath = Path.Combine(DataPath, "mails");
|
public static readonly string MailsPath = Path.Combine(DataPath, "mails");
|
||||||
public static readonly string ConfigPath = Path.Combine(DataPath, "config.ini");
|
public static readonly string ConfigPath = Path.Combine(DataPath, "config.ini");
|
||||||
public static readonly string InstallPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ProgramFiles), "Elwig");
|
public static readonly string ExePath = @"C:\Program Files\Elwig\";
|
||||||
public static readonly string DocumentsPath = (Assembly.GetEntryAssembly()?.Location.Contains(@"\bin\") ?? false) ?
|
|
||||||
Path.Combine(Assembly.GetEntryAssembly()!.Location.Split(@"\bin\")[0], "../Elwig/Documents") :
|
|
||||||
Path.Combine(InstallPath, "resources/Documents");
|
|
||||||
public static readonly string TempPath = Path.Combine(Path.GetTempPath(), "Elwig");
|
public static readonly string TempPath = Path.Combine(Path.GetTempPath(), "Elwig");
|
||||||
|
|
||||||
public static Config Config { get; private set; } = new(ConfigPath);
|
public static Config Config { get; private set; } = new(ConfigPath);
|
||||||
@ -200,10 +197,12 @@ namespace Elwig {
|
|||||||
var ch = CurrentLastWrite;
|
var ch = CurrentLastWrite;
|
||||||
if (ch > CurrentApp.LastChanged)
|
if (ch > CurrentApp.LastChanged)
|
||||||
CurrentApp.LastChanged = ch;
|
CurrentApp.LastChanged = ch;
|
||||||
|
MainDispatcher.Invoke(() => {
|
||||||
foreach (Window w in CurrentApp.Windows) {
|
foreach (Window w in CurrentApp.Windows) {
|
||||||
if (w is not ContextWindow c) continue;
|
if (w is not ContextWindow c) continue;
|
||||||
MainDispatcher.BeginInvoke(c.HintContextChange);
|
MainDispatcher.BeginInvoke(c.HintContextChange);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnAutoUpdateTimer(object? sender, EventArgs? evt) {
|
private void OnAutoUpdateTimer(object? sender, EventArgs? evt) {
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.BusinessDocument>
|
@inherits TemplatePage<Elwig.Documents.BusinessDocument>
|
||||||
@model Elwig.Documents.BusinessDocument
|
@model Elwig.Documents.BusinessDocument
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\BusinessDocument.css"/>
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\BusinessDocument.css"/>
|
||||||
<div class="info-wrapper">
|
<div class="info-wrapper">
|
||||||
<div class="address-wrapper">
|
<div class="address-wrapper">
|
||||||
<div class="sender">
|
<div class="sender">
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.CreditNote>
|
@inherits TemplatePage<Elwig.Documents.CreditNote>
|
||||||
@model Elwig.Documents.CreditNote
|
@model Elwig.Documents.CreditNote
|
||||||
@{ Layout = "BusinessDocument"; }
|
@{ Layout = "BusinessDocument"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\CreditNote.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\CreditNote.css"/>
|
||||||
<main>
|
<main>
|
||||||
<h1>@Model.Title</h1>
|
<h1>@Model.Title</h1>
|
||||||
<table class="credit">
|
<table class="credit">
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.DeliveryAncmtList>
|
@inherits TemplatePage<Elwig.Documents.DeliveryAncmtList>
|
||||||
@model Elwig.Documents.DeliveryAncmtList
|
@model Elwig.Documents.DeliveryAncmtList
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\DeliveryAncmtList.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\DeliveryAncmtList.css" />
|
||||||
<main>
|
<main>
|
||||||
<h1>Anmeldeliste</h1>
|
<h1>Anmeldeliste</h1>
|
||||||
<h2>@Model.Filter</h2>
|
<h2>@Model.Filter</h2>
|
||||||
@ -24,7 +24,7 @@
|
|||||||
<th rowspan="2" style="text-align: left;">Ort</th>
|
<th rowspan="2" style="text-align: left;">Ort</th>
|
||||||
<th rowspan="2" style="text-align: left;">Sorte</th>
|
<th rowspan="2" style="text-align: left;">Sorte</th>
|
||||||
<th rowspan="2">Anmldg.</th>
|
<th rowspan="2">Anmldg.</th>
|
||||||
<th>Menge</th>
|
<th>Gewicht</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="unit">[kg]</th>
|
<th class="unit">[kg]</th>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.DeliveryConfirmation>
|
@inherits TemplatePage<Elwig.Documents.DeliveryConfirmation>
|
||||||
@model Elwig.Documents.DeliveryConfirmation
|
@model Elwig.Documents.DeliveryConfirmation
|
||||||
@{ Layout = "BusinessDocument"; }
|
@{ Layout = "BusinessDocument"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\DeliveryConfirmation.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\DeliveryConfirmation.css"/>
|
||||||
<main>
|
<main>
|
||||||
<h1>@Model.Title</h1>
|
<h1>@Model.Title</h1>
|
||||||
<table class="delivery-confirmation">
|
<table class="delivery-confirmation">
|
||||||
@ -30,7 +30,7 @@
|
|||||||
<th rowspan="2" style="text-align: left;">Qualitätsstufe</th>
|
<th rowspan="2" style="text-align: left;">Qualitätsstufe</th>
|
||||||
<th colspan="2">Gradation</th>
|
<th colspan="2">Gradation</th>
|
||||||
<th colspan="2">Flächenbindung</th>
|
<th colspan="2">Flächenbindung</th>
|
||||||
<th>Menge</th>
|
<th>Gewicht</th>
|
||||||
<th rowspan="3" style="padding: 0;">
|
<th rowspan="3" style="padding: 0;">
|
||||||
<svg width="10" height="40" xmlns="http://www.w3.org/2000/svg">
|
<svg width="10" height="40" xmlns="http://www.w3.org/2000/svg">
|
||||||
<text x="-40" y="4" transform="rotate(270)" font-size="8pt" font-style="italic" font-family="Times New Roman"
|
<text x="-40" y="4" transform="rotate(270)" font-size="8pt" font-style="italic" font-family="Times New Roman"
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.DeliveryDepreciationList>
|
@inherits TemplatePage<Elwig.Documents.DeliveryDepreciationList>
|
||||||
@model Elwig.Documents.DeliveryDepreciationList
|
@model Elwig.Documents.DeliveryDepreciationList
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\DeliveryDepreciationList.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\DeliveryDepreciationList.css" />
|
||||||
<main>
|
<main>
|
||||||
<h1>Abwertungsliste</h1>
|
<h1>Abwertungsliste</h1>
|
||||||
<h2>@Model.Filter</h2>
|
<h2>@Model.Filter</h2>
|
||||||
@ -27,7 +27,7 @@
|
|||||||
<th rowspan="2" style="text-align: left;">Sorte</th>
|
<th rowspan="2" style="text-align: left;">Sorte</th>
|
||||||
<th rowspan="2" style="text-align: left;">Attr./Bewirt.</th>
|
<th rowspan="2" style="text-align: left;">Attr./Bewirt.</th>
|
||||||
<th colspan="2">Gradation</th>
|
<th colspan="2">Gradation</th>
|
||||||
<th>Menge</th>
|
<th>Gewicht</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="unit">[°Oe]</th>
|
<th class="unit">[°Oe]</th>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.DeliveryJournal>
|
@inherits TemplatePage<Elwig.Documents.DeliveryJournal>
|
||||||
@model Elwig.Documents.DeliveryJournal
|
@model Elwig.Documents.DeliveryJournal
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\DeliveryJournal.css"/>
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\DeliveryJournal.css"/>
|
||||||
<main>
|
<main>
|
||||||
<h1>Lieferjournal</h1>
|
<h1>Lieferjournal</h1>
|
||||||
<h2>@Model.Filter</h2>
|
<h2>@Model.Filter</h2>
|
||||||
@ -29,7 +29,7 @@
|
|||||||
<th rowspan="2" style="text-align: left;">Mitglied</th>
|
<th rowspan="2" style="text-align: left;">Mitglied</th>
|
||||||
<th rowspan="2" style="text-align: left;">Sorte</th>
|
<th rowspan="2" style="text-align: left;">Sorte</th>
|
||||||
<th colspan="2">Gradation</th>
|
<th colspan="2">Gradation</th>
|
||||||
<th>Menge</th>
|
<th>Gewicht</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="unit">[°Oe]</th>
|
<th class="unit">[°Oe]</th>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.DeliveryNote>
|
@inherits TemplatePage<Elwig.Documents.DeliveryNote>
|
||||||
@model Elwig.Documents.DeliveryNote
|
@model Elwig.Documents.DeliveryNote
|
||||||
@{ Layout = "BusinessDocument"; }
|
@{ Layout = "BusinessDocument"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\DeliveryNote.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\DeliveryNote.css" />
|
||||||
<main>
|
<main>
|
||||||
<h1>@Model.Title</h1>
|
<h1>@Model.Title</h1>
|
||||||
<table class="delivery large">
|
<table class="delivery large">
|
||||||
@ -24,7 +24,7 @@
|
|||||||
<th class="main" rowspan="2" colspan="2">Attribut</th>
|
<th class="main" rowspan="2" colspan="2">Attribut</th>
|
||||||
<th class="main" rowspan="2">Qualitätsstufe</th>
|
<th class="main" rowspan="2">Qualitätsstufe</th>
|
||||||
<th colspan="2">Gradation</th>
|
<th colspan="2">Gradation</th>
|
||||||
<th>Menge</th>
|
<th>Gewicht</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="unit">[°Oe]</th>
|
<th class="unit">[°Oe]</th>
|
||||||
|
@ -23,7 +23,7 @@ namespace Elwig.Documents {
|
|||||||
public bool ShowFoldMarks = App.Config.Debug;
|
public bool ShowFoldMarks = App.Config.Debug;
|
||||||
public bool DoublePaged = false;
|
public bool DoublePaged = false;
|
||||||
|
|
||||||
public string DocumentsPath;
|
public string DataPath;
|
||||||
public int CurrentNextSeason;
|
public int CurrentNextSeason;
|
||||||
public string? DocumentId;
|
public string? DocumentId;
|
||||||
public string Title;
|
public string Title;
|
||||||
@ -34,7 +34,7 @@ namespace Elwig.Documents {
|
|||||||
|
|
||||||
public Document(string title) {
|
public Document(string title) {
|
||||||
var c = App.Client;
|
var c = App.Client;
|
||||||
DocumentsPath = App.DocumentsPath;
|
DataPath = App.DataPath;
|
||||||
CurrentNextSeason = Utils.CurrentNextSeason;
|
CurrentNextSeason = Utils.CurrentNextSeason;
|
||||||
Title = title;
|
Title = title;
|
||||||
Author = c.NameFull;
|
Author = c.NameFull;
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
<title>@Model.Title</title>
|
<title>@Model.Title</title>
|
||||||
<meta name="author" value="@Model.Author"/>
|
<meta name="author" value="@Model.Author"/>
|
||||||
<meta charset="UTF-8"/>
|
<meta charset="UTF-8"/>
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\Document.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\Document.css"/>
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\Document.Page.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\Document.Page.css"/>
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\Document.Table.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\Document.Table.css"/>
|
||||||
@if (Model.DoublePaged) {
|
@if (Model.DoublePaged) {
|
||||||
<style>
|
<style>
|
||||||
@@page :left {
|
@@page :left {
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.MemberDataSheet>
|
@inherits TemplatePage<Elwig.Documents.MemberDataSheet>
|
||||||
@model Elwig.Documents.MemberDataSheet
|
@model Elwig.Documents.MemberDataSheet
|
||||||
@{ Layout = "BusinessDocument"; }
|
@{ Layout = "BusinessDocument"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\MemberDataSheet.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\MemberDataSheet.css" />
|
||||||
<main>
|
<main>
|
||||||
<h1>@Model.Title</h1>
|
<h1>@Model.Title</h1>
|
||||||
<table class="member border">
|
<table class="member border">
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.MemberList>
|
@inherits TemplatePage<Elwig.Documents.MemberList>
|
||||||
@model Elwig.Documents.MemberList
|
@model Elwig.Documents.MemberList
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\MemberList.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\MemberList.css"/>
|
||||||
<main>
|
<main>
|
||||||
<h1>Mitgliederliste</h1>
|
<h1>Mitgliederliste</h1>
|
||||||
<h2>@Model.Filter</h2>
|
<h2>@Model.Filter</h2>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.PaymentVariantSummary>
|
@inherits TemplatePage<Elwig.Documents.PaymentVariantSummary>
|
||||||
@model Elwig.Documents.PaymentVariantSummary
|
@model Elwig.Documents.PaymentVariantSummary
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\PaymentVariantSummary.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\PaymentVariantSummary.css" />
|
||||||
<main>
|
<main>
|
||||||
<h1>Auszahlungsvariante Lese @Model.Variant.Year</h1>
|
<h1>Auszahlungsvariante Lese @Model.Variant.Year</h1>
|
||||||
<h2>@Model.Variant.Name</h2>
|
<h2>@Model.Variant.Name</h2>
|
||||||
@ -111,8 +111,8 @@
|
|||||||
<td class="number"><span class="fleft">@Model.CurrencySymbol</span>@($"{Math.Abs(payed):N2}")</td>
|
<td class="number"><span class="fleft">@Model.CurrencySymbol</span>@($"{Math.Abs(payed):N2}")</td>
|
||||||
@{
|
@{
|
||||||
var weiRows = Model.Data.Rows.Where(r => r.QualityLevel == "Wein");
|
var weiRows = Model.Data.Rows.Where(r => r.QualityLevel == "Wein");
|
||||||
var minWei = weiRows.Min(r => r.Ungeb.MinPrice);
|
var minWei = weiRows.Min(r => r.Ungeb.Price);
|
||||||
var maxWei = weiRows.Max(r => r.Ungeb.MaxPrice);
|
var maxWei = weiRows.Max(r => r.Ungeb.Price);
|
||||||
}
|
}
|
||||||
<th class="lborder tborder">Preis (abgewertet):</th>
|
<th class="lborder tborder">Preis (abgewertet):</th>
|
||||||
<td colspan="2" class="center tborder">@(minWei != maxWei ? $"{minWei:N4}–{maxWei:N4}" : $"{minWei:N4}") @Model.CurrencySymbol/kg</td>
|
<td colspan="2" class="center tborder">@(minWei != maxWei ? $"{minWei:N4}–{maxWei:N4}" : $"{minWei:N4}") @Model.CurrencySymbol/kg</td>
|
||||||
@ -123,8 +123,8 @@
|
|||||||
<td class="number tborder"><span class="fleft">@Model.CurrencySymbol</span>@($"{netSum:N2}")</td>
|
<td class="number tborder"><span class="fleft">@Model.CurrencySymbol</span>@($"{netSum:N2}")</td>
|
||||||
@{
|
@{
|
||||||
var quwRows = Model.Data.Rows.Where(r => r.QualityLevel != "Wein");
|
var quwRows = Model.Data.Rows.Where(r => r.QualityLevel != "Wein");
|
||||||
var minPrice = quwRows.Min(r => r.Ungeb.MinPrice);
|
var minPrice = quwRows.Min(r => r.Ungeb.Price);
|
||||||
var maxPrice = quwRows.Max(r => r.Ungeb.MaxPrice);
|
var maxPrice = quwRows.Max(r => r.Ungeb.Price);
|
||||||
}
|
}
|
||||||
<th class="lborder">Preis (ungeb., nicht abgew.):</th>
|
<th class="lborder">Preis (ungeb., nicht abgew.):</th>
|
||||||
<td colspan="2" class="center">@(minPrice != maxPrice ? $"{minPrice:N4}–{maxPrice:N4}" : $"{minPrice:N4}") @Model.CurrencySymbol/kg</td>
|
<td colspan="2" class="center">@(minPrice != maxPrice ? $"{minPrice:N4}–{maxPrice:N4}" : $"{minPrice:N4}") @Model.CurrencySymbol/kg</td>
|
||||||
@ -135,8 +135,8 @@
|
|||||||
<td class="number"><span class="fleft">@Model.CurrencySymbol</span>@($"{Math.Abs(vat):N2}")</td>
|
<td class="number"><span class="fleft">@Model.CurrencySymbol</span>@($"{Math.Abs(vat):N2}")</td>
|
||||||
@{
|
@{
|
||||||
var gebRows = Model.Data.Rows
|
var gebRows = Model.Data.Rows
|
||||||
.Where(r => r.Geb.MaxPrice != null && r.Ungeb.MinPrice != null)
|
.Where(r => r.Geb.Price != null && r.Ungeb.Price != null)
|
||||||
.Select(r => r.Geb.MaxPrice - r.Ungeb.MinPrice);
|
.Select(r => r.Geb.Price - r.Ungeb.Price);
|
||||||
var minGeb = gebRows.Min();
|
var minGeb = gebRows.Min();
|
||||||
var maxGeb = gebRows.Max();
|
var maxGeb = gebRows.Max();
|
||||||
}
|
}
|
||||||
@ -219,22 +219,19 @@
|
|||||||
</table>
|
</table>
|
||||||
<table class="payment-variant-data">
|
<table class="payment-variant-data">
|
||||||
<colgroup>
|
<colgroup>
|
||||||
|
<col style="width: 30mm;"/>
|
||||||
|
<col style="width: 20mm;"/>
|
||||||
|
<col style="width: 25mm;"/>
|
||||||
|
<col style="width: 20mm;"/>
|
||||||
|
<col style="width: 25mm;"/>
|
||||||
|
<col style="width: 20mm;"/>
|
||||||
<col style="width: 25mm;"/>
|
<col style="width: 25mm;"/>
|
||||||
<col style="width: 19mm;"/>
|
|
||||||
<col style="width: 18mm;"/>
|
|
||||||
<col style="width: 15mm;"/>
|
|
||||||
<col style="width: 18mm;"/>
|
|
||||||
<col style="width: 15mm;"/>
|
|
||||||
<col style="width: 18mm;"/>
|
|
||||||
<col style="width: 15mm;"/>
|
|
||||||
<col style="width: 22mm;"/>
|
|
||||||
</colgroup>
|
</colgroup>
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th rowspan="2" style="text-align: left;">Qualitätsstufe</th>
|
<th rowspan="2" style="text-align: left;">Qualitätsstufe</th>
|
||||||
<th>Gradation</th>
|
<th>Gradation</th>
|
||||||
<th colspan="2">ungebunden</th>
|
<th colspan="2">ungebunden</th>
|
||||||
<th colspan="2">attributlos gebunden</th>
|
|
||||||
<th colspan="2">gebunden</th>
|
<th colspan="2">gebunden</th>
|
||||||
<th>Gesamt</th>
|
<th>Gesamt</th>
|
||||||
</tr>
|
</tr>
|
||||||
@ -244,8 +241,6 @@
|
|||||||
<th>[@(Model.CurrencySymbol)/kg]</th>
|
<th>[@(Model.CurrencySymbol)/kg]</th>
|
||||||
<th>[kg]</th>
|
<th>[kg]</th>
|
||||||
<th>[@(Model.CurrencySymbol)/kg]</th>
|
<th>[@(Model.CurrencySymbol)/kg]</th>
|
||||||
<th>[kg]</th>
|
|
||||||
<th>[@(Model.CurrencySymbol)/kg]</th>
|
|
||||||
<th>[@(Model.CurrencySymbol)]</th>
|
<th>[@(Model.CurrencySymbol)]</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
@ -263,8 +258,6 @@
|
|||||||
<th colspan="2">@hdr</th>
|
<th colspan="2">@hdr</th>
|
||||||
<td class="number">@($"{rows.Sum(r => r.Ungeb.Weight):N0}")</td>
|
<td class="number">@($"{rows.Sum(r => r.Ungeb.Weight):N0}")</td>
|
||||||
<td></td>
|
<td></td>
|
||||||
<td class="number">@($"{rows.Sum(r => r.LowGeb.Weight):N0}")</td>
|
|
||||||
<td></td>
|
|
||||||
<td class="number">@($"{rows.Sum(r => r.Geb.Weight):N0}")</td>
|
<td class="number">@($"{rows.Sum(r => r.Geb.Weight):N0}")</td>
|
||||||
<td></td>
|
<td></td>
|
||||||
<td class="number">@($"{rows.Sum(r => r.Amount):N2}")</td>
|
<td class="number">@($"{rows.Sum(r => r.Amount):N2}")</td>
|
||||||
@ -274,11 +267,9 @@
|
|||||||
<td>@(row.QualityLevel)</td>
|
<td>@(row.QualityLevel)</td>
|
||||||
<td class="center">@($"{row.Oe:N0}")</td>
|
<td class="center">@($"{row.Oe:N0}")</td>
|
||||||
<td class="number">@(row.Ungeb.Weight != 0 ? $"{row.Ungeb.Weight:N0}" : "-")</td>
|
<td class="number">@(row.Ungeb.Weight != 0 ? $"{row.Ungeb.Weight:N0}" : "-")</td>
|
||||||
<td class="number">@(row.Ungeb.MaxPrice != null ? $"{row.Ungeb.MaxPrice:N4}" : "-")</td>
|
<td class="number">@(row.Ungeb.Price != null ? $"{row.Ungeb.Price:N4}" : "-")</td>
|
||||||
<td class="number">@(row.LowGeb.Weight != 0 ? $"{row.LowGeb.Weight:N0}" : "-")</td>
|
|
||||||
<td class="number">@(row.LowGeb.MaxPrice != null ? $"{row.LowGeb.MaxPrice:N4}" : "-")</td>
|
|
||||||
<td class="number">@(row.Geb.Weight != 0 ? $"{row.Geb.Weight:N0}" : "-")</td>
|
<td class="number">@(row.Geb.Weight != 0 ? $"{row.Geb.Weight:N0}" : "-")</td>
|
||||||
<td class="number">@(row.Geb.MaxPrice != null ? $"{row.Geb.MaxPrice:N4}" : "-")</td>
|
<td class="number">@(row.Geb.Price != null ? $"{row.Geb.Price:N4}" : "-")</td>
|
||||||
<td class="number">@($"{row.Amount:N2}")</td>
|
<td class="number">@($"{row.Amount:N2}")</td>
|
||||||
</tr>
|
</tr>
|
||||||
lastHdr = hdr;
|
lastHdr = hdr;
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
@inherits TemplatePage<Elwig.Documents.WineQualityStatistics>
|
@inherits TemplatePage<Elwig.Documents.WineQualityStatistics>
|
||||||
@model Elwig.Documents.WineQualityStatistics
|
@model Elwig.Documents.WineQualityStatistics
|
||||||
@{ Layout = "Document"; }
|
@{ Layout = "Document"; }
|
||||||
<link rel="stylesheet" href="file:///@Raw(Model.DocumentsPath)\WineQualityStatistics.css" />
|
<link rel="stylesheet" href="file:///@Raw(Model.DataPath)\resources\WineQualityStatistics.css"/>
|
||||||
<main>
|
<main>
|
||||||
<h1>Qualitätsstatistik</h1>
|
<h1>Qualitätsstatistik</h1>
|
||||||
<h2>@Model.Filter</h2>
|
<h2>@Model.Filter</h2>
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
<UseWPF>true</UseWPF>
|
<UseWPF>true</UseWPF>
|
||||||
<PreserveCompilationContext>true</PreserveCompilationContext>
|
<PreserveCompilationContext>true</PreserveCompilationContext>
|
||||||
<ApplicationIcon>Resources\Images\Elwig.ico</ApplicationIcon>
|
<ApplicationIcon>Resources\Images\Elwig.ico</ApplicationIcon>
|
||||||
<Version>0.13.9</Version>
|
<Version>0.13.8</Version>
|
||||||
<SatelliteResourceLanguages>de-AT</SatelliteResourceLanguages>
|
<SatelliteResourceLanguages>de-AT</SatelliteResourceLanguages>
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
||||||
<ApplicationManifest>app.manifest</ApplicationManifest>
|
<ApplicationManifest>app.manifest</ApplicationManifest>
|
||||||
@ -20,6 +20,10 @@
|
|||||||
<EmbeddedResource Include="Resources\Sql\*" />
|
<EmbeddedResource Include="Resources\Sql\*" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<Target Name="PreBuild" BeforeTargets="PreBuildEvent">
|
||||||
|
<Exec Command="call fetch-resources.bat" />
|
||||||
|
</Target>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.4.0" />
|
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.4.0" />
|
||||||
<PackageReference Include="LinqKit" Version="1.3.8" />
|
<PackageReference Include="LinqKit" Version="1.3.8" />
|
||||||
|
@ -317,7 +317,7 @@ namespace Elwig.Helpers.Export {
|
|||||||
c = $"<{ct} office:value-type=\"string\" calcext:value-type=\"string\"{add}><text:p>{SecurityElement.Escape(data.ToString())}</text:p></{ct}>";
|
c = $"<{ct} office:value-type=\"string\" calcext:value-type=\"string\"{add}><text:p>{SecurityElement.Escape(data.ToString())}</text:p></{ct}>";
|
||||||
}
|
}
|
||||||
|
|
||||||
return $" {c}\r\n" + (colSpan > 1 ? $" <table:covered-table-cell table:number-columns-repeated=\"{colSpan - 1}\"/>\r\n" : "");
|
return $" {c}\r\n" + (colSpan > 1 ? $" <table:covered-table-cell table:number-rows-repeated=\"{colSpan - 1}\"/>\r\n" : "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ namespace Elwig.Helpers.Printing {
|
|||||||
|
|
||||||
public static async Task Init(Action? evtHandler = null) {
|
public static async Task Init(Action? evtHandler = null) {
|
||||||
var e = new RazorLightEngineBuilder()
|
var e = new RazorLightEngineBuilder()
|
||||||
.UseFileSystemProject(App.DocumentsPath)
|
.UseFileSystemProject(App.DataPath + "resources")
|
||||||
.UseMemoryCachingProvider()
|
.UseMemoryCachingProvider()
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ using System.Drawing.Printing;
|
|||||||
namespace Elwig.Helpers.Printing {
|
namespace Elwig.Helpers.Printing {
|
||||||
public static class Pdf {
|
public static class Pdf {
|
||||||
|
|
||||||
private static readonly string WinziPrint = new string[] { App.InstallPath }
|
private static readonly string WinziPrint = new string[] { App.ExePath }
|
||||||
.Union(Environment.GetEnvironmentVariable("PATH")?.Split(';') ?? [])
|
.Union(Environment.GetEnvironmentVariable("PATH")?.Split(';') ?? [])
|
||||||
.Select(x => Path.Combine(x, "WinziPrint.exe"))
|
.Select(x => Path.Combine(x, "WinziPrint.exe"))
|
||||||
.Where(File.Exists)
|
.Where(File.Exists)
|
||||||
|
@ -499,9 +499,11 @@ namespace Elwig.Helpers {
|
|||||||
if (App.Config.Smtp == null)
|
if (App.Config.Smtp == null)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
|
||||||
|
var success = await Task.Run(async () => {
|
||||||
SmtpClient? client = null;
|
SmtpClient? client = null;
|
||||||
try {
|
try {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
|
||||||
client = await GetSmtpClient();
|
client = await GetSmtpClient();
|
||||||
|
|
||||||
using var msg = new MimeMessage();
|
using var msg = new MimeMessage();
|
||||||
@ -524,9 +526,12 @@ namespace Elwig.Helpers {
|
|||||||
if (client != null)
|
if (client != null)
|
||||||
await client.DisconnectAsync(true);
|
await client.DisconnectAsync(true);
|
||||||
client?.Dispose();
|
client?.Dispose();
|
||||||
Mouse.OverrideCursor = null;
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
});
|
||||||
|
|
||||||
|
Mouse.OverrideCursor = null;
|
||||||
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task ExportDocument(Document doc, ExportMode mode, string? filename = null, (Member, string, string)? emailData = null) {
|
public static async Task ExportDocument(Document doc, ExportMode mode, string? filename = null, (Member, string, string)? emailData = null) {
|
||||||
|
@ -27,14 +27,14 @@ namespace Elwig.Models.Dtos {
|
|||||||
MgNr = mgnr;
|
MgNr = mgnr;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<IDictionary<int, CreditNoteDeliveryData>> ForPaymentVariant(DbSet<CreditNoteDeliveryRowSingle> table, DbSet<PaymentVar> paymentVariants, int year, int avnr) {
|
public static async Task<IDictionary<int, CreditNoteDeliveryData>> ForPaymentVariant(DbSet<CreditNoteDeliveryRowSingle> table, DbSet<Season> seasons, int year, int avnr) {
|
||||||
var variant = await paymentVariants.FindAsync(year, avnr);
|
var variant = (await seasons.FindAsync(year))?.PaymentVariants.Where(v => v.AvNr == avnr).SingleOrDefault();
|
||||||
BillingData? varData = null;
|
BillingData? varData = null;
|
||||||
try { varData = variant != null ? BillingData.FromJson(variant.Data) : null; } catch { }
|
try { varData = variant != null ? BillingData.FromJson(variant.Data) : null; } catch { }
|
||||||
return (await FromDbSet(table, year, avnr))
|
return (await FromDbSet(table, year, avnr))
|
||||||
.GroupBy(
|
.GroupBy(
|
||||||
r => new { r.Year, r.AvNr, r.MgNr, r.TgNr, r.DId, r.DPNr },
|
r => new { r.Year, r.AvNr, r.MgNr, r.TgNr, r.DId, r.DPNr },
|
||||||
(k, g) => new CreditNoteDeliveryRow(g, variant, varData))
|
(k, g) => new CreditNoteDeliveryRow(g, seasons, varData?.NetWeightModifier ?? 0.0, varData?.GrossWeightModifier ?? 0.0))
|
||||||
.GroupBy(
|
.GroupBy(
|
||||||
r => new { r.Year, r.AvNr, r.MgNr, r.TgNr },
|
r => new { r.Year, r.AvNr, r.MgNr, r.TgNr },
|
||||||
(k, g) => new CreditNoteDeliveryData(g, k.Year, k.TgNr, mgnr: k.MgNr))
|
(k, g) => new CreditNoteDeliveryData(g, k.Year, k.TgNr, mgnr: k.MgNr))
|
||||||
@ -86,13 +86,13 @@ namespace Elwig.Models.Dtos {
|
|||||||
public decimal? Amount;
|
public decimal? Amount;
|
||||||
public double WeighingModifier;
|
public double WeighingModifier;
|
||||||
|
|
||||||
public CreditNoteDeliveryRow(IEnumerable<CreditNoteDeliveryRowSingle> rows, PaymentVar paymentVariant, BillingData? varData) {
|
public CreditNoteDeliveryRow(IEnumerable<CreditNoteDeliveryRowSingle> rows, DbSet<Season> seasons, double netWeightModifier, double grossWeightModifier) {
|
||||||
var f = rows.First();
|
var f = rows.First();
|
||||||
Year = f.Year;
|
Year = f.Year;
|
||||||
TgNr = f.TgNr;
|
TgNr = f.TgNr;
|
||||||
AvNr = f.AvNr;
|
AvNr = f.AvNr;
|
||||||
MgNr = f.MgNr;
|
MgNr = f.MgNr;
|
||||||
var season = paymentVariant.Season;
|
var season = seasons.Find(Year);
|
||||||
|
|
||||||
LsNr = f.LsNr;
|
LsNr = f.LsNr;
|
||||||
DPNr = f.DPNr;
|
DPNr = f.DPNr;
|
||||||
@ -115,7 +115,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
b.Price != null ? season?.DecFromDb((long)b.Price) : null,
|
b.Price != null ? season?.DecFromDb((long)b.Price) : null,
|
||||||
b.Amount != null ? season?.DecFromDb((long)b.Amount) : null))
|
b.Amount != null ? season?.DecFromDb((long)b.Amount) : null))
|
||||||
.ToArray();
|
.ToArray();
|
||||||
WeighingModifier = (varData == null || !varData.ConsiderDelieryModifiers) ? 0 : f.NetWeight ? varData.NetWeightModifier : varData.GrossWeightModifier;
|
WeighingModifier = f.NetWeight ? netWeightModifier : grossWeightModifier;
|
||||||
Amount = f.TotalAmount != null ? season?.DecFromDb((long)f.TotalAmount) : null;
|
Amount = f.TotalAmount != null ? season?.DecFromDb((long)f.TotalAmount) : null;
|
||||||
var netAmount = f.NetAmount != null ? season?.DecFromDb((long)f.NetAmount) : null;
|
var netAmount = f.NetAmount != null ? season?.DecFromDb((long)f.NetAmount) : null;
|
||||||
var amt = netAmount * (decimal)(1.0 + WeighingModifier);
|
var amt = netAmount * (decimal)(1.0 + WeighingModifier);
|
||||||
|
@ -17,7 +17,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
("Name2", "Vorname", null, 40),
|
("Name2", "Vorname", null, 40),
|
||||||
("DefaultKg", "Ort", null, 40),
|
("DefaultKg", "Ort", null, 40),
|
||||||
("SortId", "Sorte", null, 10),
|
("SortId", "Sorte", null, 10),
|
||||||
("Weight", "Menge", "kg", 20),
|
("Weight", "Gewicht", "kg", 20),
|
||||||
("CreatedTimestamp", "Angemeldet", null, 35),
|
("CreatedTimestamp", "Angemeldet", null, 35),
|
||||||
("ModifiedTimestamp", "Geändert", null, 35),
|
("ModifiedTimestamp", "Geändert", null, 35),
|
||||||
("Status", "Status", null, 20),
|
("Status", "Status", null, 20),
|
||||||
|
@ -16,7 +16,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
("QualityLevel", "Qualitätsstufe", null, 25),
|
("QualityLevel", "Qualitätsstufe", null, 25),
|
||||||
("Gradation", "Gradation", "°Oe|°KMW", 32),
|
("Gradation", "Gradation", "°Oe|°KMW", 32),
|
||||||
("Buckets", "Flächenbindung", "|kg", 36),
|
("Buckets", "Flächenbindung", "|kg", 36),
|
||||||
("Weight", "Menge", "kg", 16),
|
("Weight", "Gewicht", "kg", 16),
|
||||||
];
|
];
|
||||||
|
|
||||||
private readonly int MgNr;
|
private readonly int MgNr;
|
||||||
|
@ -24,7 +24,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
("CultId", "Bewirt.", null, 15),
|
("CultId", "Bewirt.", null, 15),
|
||||||
("QualId", "Qualität", null, 15),
|
("QualId", "Qualität", null, 15),
|
||||||
("Gradation", "Gradation", "°Oe|°KMW", 40),
|
("Gradation", "Gradation", "°Oe|°KMW", 40),
|
||||||
("Weight", "Menge", "kg", 20),
|
("Weight", "Gewicht", "kg", 20),
|
||||||
("IsNetWeight", "Gerebelt", null, 20),
|
("IsNetWeight", "Gerebelt", null, 20),
|
||||||
("HkId", "Herkunft", null, 20),
|
("HkId", "Herkunft", null, 20),
|
||||||
("Modifiers", "Zu-/Abschläge", null, 40),
|
("Modifiers", "Zu-/Abschläge", null, 40),
|
||||||
|
@ -18,9 +18,8 @@ namespace Elwig.Models.Dtos {
|
|||||||
("Cultivation", "Bewirt.", null, 20),
|
("Cultivation", "Bewirt.", null, 20),
|
||||||
("QualityLevel", "Qualitätsstufe", null, 30),
|
("QualityLevel", "Qualitätsstufe", null, 30),
|
||||||
("Oe", "Gradation", "°Oe", 20),
|
("Oe", "Gradation", "°Oe", 20),
|
||||||
("Ungeb", "ungebunden", "kg|€/kg|€/kg", 60),
|
("Ungeb", "ungebunden", "kg|€/kg", 40),
|
||||||
("LowGeb", "attributlos gebunden", "kg|€/kg|€/kg", 60),
|
("Geb", "gebunden", "kg|€/kg", 40),
|
||||||
("Geb", "gebunden", "kg|€/kg|€/kg", 60),
|
|
||||||
("Amount", "Gesamt", "€", 25),
|
("Amount", "Gesamt", "€", 25),
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -31,9 +30,8 @@ namespace Elwig.Models.Dtos {
|
|||||||
string? Cultivation,
|
string? Cultivation,
|
||||||
string QualityLevel,
|
string QualityLevel,
|
||||||
double Oe,
|
double Oe,
|
||||||
(int Weight, decimal? MinPrice, decimal? MaxPrice) Ungeb,
|
(int Weight, decimal? Price) Ungeb,
|
||||||
(int Weight, decimal? MinPrice, decimal? MaxPrice) LowGeb,
|
(int Weight, decimal? Price) Geb,
|
||||||
(int Weight, decimal? MinPrice, decimal? MaxPrice) Geb,
|
|
||||||
decimal Amount
|
decimal Amount
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -44,9 +42,8 @@ namespace Elwig.Models.Dtos {
|
|||||||
public static async Task<PaymentVariantSummaryData> ForPaymentVariant(PaymentVar v, DbSet<PaymentVariantSummaryRow> table) {
|
public static async Task<PaymentVariantSummaryData> ForPaymentVariant(PaymentVar v, DbSet<PaymentVariantSummaryRow> table) {
|
||||||
return new(v, (await FromDbSet(table, v.Year, v.AvNr))
|
return new(v, (await FromDbSet(table, v.Year, v.AvNr))
|
||||||
.Select(r => new PaymentRow(r.Type, r.Variety, r.Attribute, r.Cultivation, r.QualityLevel, r.Oe,
|
.Select(r => new PaymentRow(r.Type, r.Variety, r.Attribute, r.Cultivation, r.QualityLevel, r.Oe,
|
||||||
(r.WeightUngeb, r.MinPriceUngeb != null ? Utils.DecFromDb(r.MinPriceUngeb.Value, v.Season.Precision) : null, r.MaxPriceUngeb != null ? Utils.DecFromDb(r.MaxPriceUngeb.Value, v.Season.Precision) : null),
|
(r.WeightUngeb, r.PriceUngeb != null ? Utils.DecFromDb(r.PriceUngeb.Value, v.Season.Precision) : null),
|
||||||
(r.WeightLowGeb, r.MinPriceLowGeb != null ? Utils.DecFromDb(r.MinPriceLowGeb.Value, v.Season.Precision) : null, r.MaxPriceLowGeb != null ? Utils.DecFromDb(r.MaxPriceLowGeb.Value, v.Season.Precision) : null),
|
(r.WeightGeb, r.PriceGeb != null ? Utils.DecFromDb(r.PriceGeb.Value, v.Season.Precision) : null),
|
||||||
(r.WeightGeb, r.MinPriceGeb != null ? Utils.DecFromDb(r.MinPriceGeb.Value, v.Season.Precision) : null, r.MaxPriceGeb != null ? Utils.DecFromDb(r.MaxPriceGeb.Value, v.Season.Precision) : null),
|
|
||||||
Utils.DecFromDb(r.Amount, v.Season.Precision)))
|
Utils.DecFromDb(r.Amount, v.Season.Precision)))
|
||||||
.ToArray());
|
.ToArray());
|
||||||
}
|
}
|
||||||
@ -60,23 +57,19 @@ namespace Elwig.Models.Dtos {
|
|||||||
q.name AS quality_level,
|
q.name AS quality_level,
|
||||||
ROUND(kmw * (4.54 + 0.022 * kmw)) AS oe,
|
ROUND(kmw * (4.54 + 0.022 * kmw)) AS oe,
|
||||||
SUM(IIF(w.discr = '_', w.value, 0)) AS weight_ungeb,
|
SUM(IIF(w.discr = '_', w.value, 0)) AS weight_ungeb,
|
||||||
MIN(IIF(w.discr = '_', b.price, NULL)) AS min_price_ungeb,
|
MAX(IIF(w.discr = '_', b.price, NULL)) AS price_ungeb,
|
||||||
MAX(IIF(w.discr = '_', b.price, NULL)) AS max_price_ungeb,
|
SUM(IIF(w.discr != '_', w.value, 0)) AS weight_geb,
|
||||||
SUM(IIF(w.discr NOT IN (COALESCE(p.attrid, ''), '_'), w.value, 0)) AS weight_lowgeb,
|
MAX(IIF(w.discr != '_', b.price, NULL)) AS price_geb,
|
||||||
MIN(IIF(w.discr NOT IN (COALESCE(p.attrid, ''), '_'), b.price, NULL)) AS min_price_lowgeb,
|
|
||||||
MAX(IIF(w.discr NOT IN (COALESCE(p.attrid, ''), '_'), b.price, NULL)) AS max_price_lowgeb,
|
|
||||||
SUM(IIF(w.discr = COALESCE(p.attrid, ''), w.value, 0)) AS weight_geb,
|
|
||||||
MIN(IIF(w.discr = COALESCE(p.attrid, ''), b.price, NULL)) AS min_price_geb,
|
|
||||||
MAX(IIF(w.discr = COALESCE(p.attrid, ''), b.price, NULL)) AS max_price_geb,
|
|
||||||
SUM(b.amount) AS amount
|
SUM(b.amount) AS amount
|
||||||
FROM payment_delivery_part_bucket b
|
FROM payment_delivery_part_bucket b
|
||||||
LEFT JOIN delivery_part_bucket w ON (w.year, w.did, w.dpnr, w.bktnr) = (b.year, b.did, b.dpnr, b.bktnr)
|
LEFT JOIN delivery_part_bucket w ON (w.year, w.did, w.dpnr, w.bktnr) = (b.year, b.did, b.dpnr, b.bktnr)
|
||||||
LEFT JOIN delivery_part p ON (p.year, p.did, p.dpnr) = (b.year, b.did, b.dpnr)
|
LEFT JOIN delivery_part p ON (p.year, p.did, p.dpnr) = (b.year, b.did, b.dpnr)
|
||||||
|
LEFT JOIN delivery d ON (d.year, d.did) = (p.year, p.did)
|
||||||
LEFT JOIN wine_variety v ON v.sortid = p.sortid
|
LEFT JOIN wine_variety v ON v.sortid = p.sortid
|
||||||
LEFT JOIN wine_attribute a ON a.attrid = p.attrid
|
LEFT JOIN wine_attribute a ON a.attrid = p.attrid
|
||||||
LEFT JOIN wine_cultivation c ON c.cultid = p.cultid
|
LEFT JOIN wine_cultivation c ON c.cultid = p.cultid
|
||||||
LEFT JOIN wine_quality_level q ON q.qualid = p.qualid
|
LEFT JOIN wine_quality_level q ON q.qualid = p.qualid
|
||||||
WHERE p.year = {year} AND b.avnr = {avnr}
|
WHERE d.year = {year} AND b.avnr = {avnr}
|
||||||
GROUP BY variety, attribute, cultivation, q.min_kmw, oe
|
GROUP BY variety, attribute, cultivation, q.min_kmw, oe
|
||||||
ORDER BY variety, attribute, cultivation, q.min_kmw, oe
|
ORDER BY variety, attribute, cultivation, q.min_kmw, oe
|
||||||
""").ToListAsync();
|
""").ToListAsync();
|
||||||
@ -99,22 +92,12 @@ namespace Elwig.Models.Dtos {
|
|||||||
public double Oe { get; set; }
|
public double Oe { get; set; }
|
||||||
[Column("weight_ungeb")]
|
[Column("weight_ungeb")]
|
||||||
public int WeightUngeb { get; set; }
|
public int WeightUngeb { get; set; }
|
||||||
[Column("min_price_ungeb")]
|
[Column("price_ungeb")]
|
||||||
public long? MinPriceUngeb { get; set; }
|
public long? PriceUngeb { get; set; }
|
||||||
[Column("max_price_ungeb")]
|
|
||||||
public long? MaxPriceUngeb { get; set; }
|
|
||||||
[Column("weight_lowgeb")]
|
|
||||||
public int WeightLowGeb { get; set; }
|
|
||||||
[Column("min_price_lowgeb")]
|
|
||||||
public long? MinPriceLowGeb { get; set; }
|
|
||||||
[Column("max_price_lowgeb")]
|
|
||||||
public long? MaxPriceLowGeb { get; set; }
|
|
||||||
[Column("weight_geb")]
|
[Column("weight_geb")]
|
||||||
public int WeightGeb { get; set; }
|
public int WeightGeb { get; set; }
|
||||||
[Column("min_price_geb")]
|
[Column("price_geb")]
|
||||||
public long? MinPriceGeb { get; set; }
|
public long? PriceGeb { get; set; }
|
||||||
[Column("max_price_geb")]
|
|
||||||
public long? MaxPriceGeb { get; set; }
|
|
||||||
[Column("amount")]
|
[Column("amount")]
|
||||||
public long Amount { get; set; }
|
public long Amount { get; set; }
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
("CultId", "Bewirt.", null, 15),
|
("CultId", "Bewirt.", null, 15),
|
||||||
("QualId", "Qual.", null, 15),
|
("QualId", "Qual.", null, 15),
|
||||||
("Geb", "gebunden", null, 20),
|
("Geb", "gebunden", null, 20),
|
||||||
("Weight", "Menge", "kg", 20),
|
("Weight", "Gewicht", "kg", 20),
|
||||||
];
|
];
|
||||||
|
|
||||||
public WeightBreakdownData(IEnumerable<WeightBreakdownRow> rows, int year, string name) :
|
public WeightBreakdownData(IEnumerable<WeightBreakdownRow> rows, int year, string name) :
|
||||||
|
@ -17,7 +17,7 @@ namespace Elwig.Models.Dtos {
|
|||||||
("Members", "Mitgl.", "#", 15),
|
("Members", "Mitgl.", "#", 15),
|
||||||
("Deliveries", "Lfrg.", "#", 15),
|
("Deliveries", "Lfrg.", "#", 15),
|
||||||
("Parts", "Teill.", "#", 15),
|
("Parts", "Teill.", "#", 15),
|
||||||
("Weight", "Menge", "kg", 20),
|
("Weight", "Gewicht", "kg", 20),
|
||||||
("Gradation", "Gradation", "°Oe|°KMW", 30),
|
("Gradation", "Gradation", "°Oe|°KMW", 30),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -108,7 +108,8 @@ namespace Elwig.Services {
|
|||||||
public static async Task<int> UpdateAreaCommitment(this AreaComAdminViewModel vm, int? oldFbNr) {
|
public static async Task<int> UpdateAreaCommitment(this AreaComAdminViewModel vm, int? oldFbNr) {
|
||||||
int newFbNr = (int)vm.FbNr!;
|
int newFbNr = (int)vm.FbNr!;
|
||||||
|
|
||||||
using (var ctx = new AppDbContext()) {
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
var a = new AreaCom {
|
var a = new AreaCom {
|
||||||
FbNr = oldFbNr ?? newFbNr,
|
FbNr = oldFbNr ?? newFbNr,
|
||||||
MgNr = (int)vm.MgNr!,
|
MgNr = (int)vm.MgNr!,
|
||||||
@ -140,7 +141,7 @@ namespace Elwig.Services {
|
|||||||
if (newFbNr != a.FbNr) {
|
if (newFbNr != a.FbNr) {
|
||||||
await ctx.Database.ExecuteSqlAsync($"UPDATE area_commitment SET fbnr = {newFbNr} WHERE fbnr = {oldFbNr}");
|
await ctx.Database.ExecuteSqlAsync($"UPDATE area_commitment SET fbnr = {newFbNr} WHERE fbnr = {oldFbNr}");
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
|
||||||
@ -253,5 +254,16 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
return grid;
|
return grid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static async Task DeleteAreaCom(int fbnr) {
|
||||||
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
|
var l = (await ctx.AreaCommitments.FindAsync(fbnr))!;
|
||||||
|
ctx.Remove(l);
|
||||||
|
await ctx.SaveChangesAsync();
|
||||||
|
});
|
||||||
|
|
||||||
|
App.HintContextChange();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -326,7 +326,7 @@ namespace Elwig.Services {
|
|||||||
|
|
||||||
var weight = await deliveryAncmts.SumAsync(p => p.Weight);
|
var weight = await deliveryAncmts.SumAsync(p => p.Weight);
|
||||||
text = $"{weight:N0} kg";
|
text = $"{weight:N0} kg";
|
||||||
AddToolTipRow(grid, 0, "Menge", null, weight, null, weight);
|
AddToolTipRow(grid, 0, "Gewicht", null, weight, null, weight);
|
||||||
|
|
||||||
if (await deliveryAncmts.AnyAsync()) {
|
if (await deliveryAncmts.AnyAsync()) {
|
||||||
var attrGroups = await deliveryAncmts
|
var attrGroups = await deliveryAncmts
|
||||||
|
@ -430,9 +430,10 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<DeliveryPart> UpdateDeliveryPart(this DeliveryAdminViewModel vm, int? oldYear, int? oldDid, int? oldDpnr, bool dateHasChanged, bool timeHasChanged, bool timeIsDefault) {
|
public static async Task<DeliveryPart> UpdateDeliveryPart(this DeliveryAdminViewModel vm, int? oldYear, int? oldDid, int? oldDpnr, bool dateHasChanged, bool timeHasChanged, bool timeIsDefault) {
|
||||||
|
var p = await Task.Run(async () => {
|
||||||
DeliveryPart p;
|
DeliveryPart p;
|
||||||
|
|
||||||
using (var ctx = new AppDbContext()) {
|
using var ctx = new AppDbContext();
|
||||||
int year = oldYear ?? Utils.CurrentYear;
|
int year = oldYear ?? Utils.CurrentYear;
|
||||||
int did = oldDid ?? await ctx.NextDId(year);
|
int did = oldDid ?? await ctx.NextDId(year);
|
||||||
int dpnr = oldDpnr ?? await ctx.NextDPNr(year, did);
|
int dpnr = oldDpnr ?? await ctx.NextDPNr(year, did);
|
||||||
@ -524,7 +525,9 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
}
|
|
||||||
|
return p;
|
||||||
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
|
||||||
@ -532,9 +535,10 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<Delivery> SplitDeliveryToMember(int year, int did, int[] weights, int mgnr) {
|
public static async Task<Delivery> SplitDeliveryToMember(int year, int did, int[] weights, int mgnr) {
|
||||||
|
var n = await Task.Run(async () => {
|
||||||
Delivery n;
|
Delivery n;
|
||||||
|
|
||||||
using (var ctx = new AppDbContext()) {
|
using var ctx = new AppDbContext();
|
||||||
bool anyLeft = false;
|
bool anyLeft = false;
|
||||||
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
||||||
var lnr = await ctx.NextLNr(d.Date, d.ZwstId);
|
var lnr = await ctx.NextLNr(d.Date, d.ZwstId);
|
||||||
@ -577,7 +581,9 @@ namespace Elwig.Services {
|
|||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
if (!anyLeft)
|
if (!anyLeft)
|
||||||
await ctx.Database.ExecuteSqlAsync($"DELETE FROM delivery WHERE (year, did) = ({d.Year}, {d.DId})");
|
await ctx.Database.ExecuteSqlAsync($"DELETE FROM delivery WHERE (year, did) = ({d.Year}, {d.DId})");
|
||||||
}
|
|
||||||
|
return n;
|
||||||
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
|
||||||
@ -585,9 +591,9 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<Delivery> SplitDeliveryToLsNr(int year, int did, int[] weights, string lsnr) {
|
public static async Task<Delivery> SplitDeliveryToLsNr(int year, int did, int[] weights, string lsnr) {
|
||||||
|
var n = await Task.Run(async () => {
|
||||||
Delivery n;
|
Delivery n;
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
using (var ctx = new AppDbContext()) {
|
|
||||||
var anyLeft = false;
|
var anyLeft = false;
|
||||||
n = (await ctx.Deliveries.FirstAsync(d => d.LsNr == lsnr))!;
|
n = (await ctx.Deliveries.FirstAsync(d => d.LsNr == lsnr))!;
|
||||||
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
||||||
@ -616,7 +622,9 @@ namespace Elwig.Services {
|
|||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
if (!anyLeft && n.LsNr != d.LsNr)
|
if (!anyLeft && n.LsNr != d.LsNr)
|
||||||
await ctx.Database.ExecuteSqlAsync($"DELETE FROM delivery WHERE (year, did) = ({d.Year}, {d.DId})");
|
await ctx.Database.ExecuteSqlAsync($"DELETE FROM delivery WHERE (year, did) = ({d.Year}, {d.DId})");
|
||||||
}
|
|
||||||
|
return n;
|
||||||
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
|
||||||
@ -624,7 +632,8 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task DepreciateDelivery(int year, int did, int[] weights) {
|
public static async Task DepreciateDelivery(int year, int did, int[] weights) {
|
||||||
using (var ctx = new AppDbContext()) {
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
||||||
var dpnr = await ctx.NextDPNr(year, did);
|
var dpnr = await ctx.NextDPNr(year, did);
|
||||||
foreach (var (p, w) in d.Parts.ToList().Zip(weights)) {
|
foreach (var (p, w) in d.Parts.ToList().Zip(weights)) {
|
||||||
@ -648,13 +657,14 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
}
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task GenerateDeliveryNote(int year, int did, ExportMode mode) {
|
public static async Task GenerateDeliveryNote(int year, int did, ExportMode mode) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
var d = (await ctx.Deliveries.FindAsync(year, did))!;
|
||||||
@ -663,6 +673,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -707,7 +718,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"{DeliveryJournal.Name} speichern unter - Elwig"
|
Title = $"{DeliveryJournal.Name} speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
||||||
using var ods = new OdsFile(d.FileName);
|
using var ods = new OdsFile(d.FileName);
|
||||||
@ -715,6 +727,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
} else if (mode == ExportMode.Export) {
|
} else if (mode == ExportMode.Export) {
|
||||||
@ -725,7 +738,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"{DeliveryJournal.Name} speichern unter - Elwig"
|
Title = $"{DeliveryJournal.Name} speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
await ElwigData.Export(d.FileName, await query
|
await ElwigData.Export(d.FileName, await query
|
||||||
.Select(p => p.Delivery)
|
.Select(p => p.Delivery)
|
||||||
@ -737,10 +751,12 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
} else if (mode == ExportMode.Upload && App.Config.SyncUrl != null) {
|
} else if (mode == ExportMode.Upload && App.Config.SyncUrl != null) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var filename = $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip";
|
var filename = $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip";
|
||||||
var path = Path.Combine(App.TempPath, filename);
|
var path = Path.Combine(App.TempPath, filename);
|
||||||
@ -767,9 +783,11 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
} else {
|
} else {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
||||||
using var doc = new DeliveryJournal(string.Join(" / ", filterNames), data);
|
using var doc = new DeliveryJournal(string.Join(" / ", filterNames), data);
|
||||||
@ -777,6 +795,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -798,7 +817,8 @@ namespace Elwig.Services {
|
|||||||
throw new ArgumentException("Invalid value for ExportSubject");
|
throw new ArgumentException("Invalid value for ExportSubject");
|
||||||
}
|
}
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await WineQualityStatisticsData.FromQuery(query, App.Client.OrderingMemberList);
|
var data = await WineQualityStatisticsData.FromQuery(query, App.Client.OrderingMemberList);
|
||||||
using var doc = new WineQualityStatistics(string.Join(" / ", filterNames), data);
|
using var doc = new WineQualityStatistics(string.Join(" / ", filterNames), data);
|
||||||
@ -806,6 +826,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -829,7 +850,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"Lieferstatistik pro Ort speichern unter - Elwig"
|
Title = $"Lieferstatistik pro Ort speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
using var ods = new OdsFile(d.FileName);
|
using var ods = new OdsFile(d.FileName);
|
||||||
var tbl = await WineLocalityStatisticsData.FromQuery(query, filterNames);
|
var tbl = await WineLocalityStatisticsData.FromQuery(query, filterNames);
|
||||||
@ -837,6 +859,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -875,7 +898,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"{DeliveryDepreciationList.Name} speichern unter - Elwig"
|
Title = $"{DeliveryDepreciationList.Name} speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
using var ods = new OdsFile(d.FileName);
|
using var ods = new OdsFile(d.FileName);
|
||||||
var tblTotal = await DeliveryJournalData.FromQuery(query, filterNames);
|
var tblTotal = await DeliveryJournalData.FromQuery(query, filterNames);
|
||||||
@ -891,10 +915,12 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
var data = await DeliveryJournalData.FromQuery(query, filterNames);
|
||||||
using var doc = new DeliveryDepreciationList(string.Join(" / ", filterNames), data);
|
using var doc = new DeliveryDepreciationList(string.Join(" / ", filterNames), data);
|
||||||
@ -902,6 +928,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -946,7 +973,7 @@ namespace Elwig.Services {
|
|||||||
|
|
||||||
var weight = await deliveryParts.SumAsync(p => p.Weight);
|
var weight = await deliveryParts.SumAsync(p => p.Weight);
|
||||||
wText = $"{weight:N0} kg";
|
wText = $"{weight:N0} kg";
|
||||||
wGrid.Add(("Menge", null, weight, null, weight));
|
wGrid.Add(("Gewicht", null, weight, null, weight));
|
||||||
|
|
||||||
if (await deliveryParts.AnyAsync()) {
|
if (await deliveryParts.AnyAsync()) {
|
||||||
var kmwMin = await deliveryParts.MinAsync(p => p.Kmw);
|
var kmwMin = await deliveryParts.MinAsync(p => p.Kmw);
|
||||||
@ -1070,10 +1097,12 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task DeleteDelivery(string lsnr) {
|
public static async Task DeleteDelivery(string lsnr) {
|
||||||
using (var ctx = new AppDbContext()) {
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
await ctx.Deliveries.Where(d => d.LsNr == lsnr).ExecuteDeleteAsync();
|
await ctx.Deliveries.Where(d => d.LsNr == lsnr).ExecuteDeleteAsync();
|
||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
}
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -367,7 +367,8 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task GenerateMemberDataSheet(Member m, ExportMode mode) {
|
public static async Task GenerateMemberDataSheet(Member m, ExportMode mode) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
using var doc = new MemberDataSheet(m, ctx);
|
using var doc = new MemberDataSheet(m, ctx);
|
||||||
@ -375,11 +376,13 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task GenerateDeliveryConfirmation(Member m, int year, ExportMode mode) {
|
public static async Task GenerateDeliveryConfirmation(Member m, int year, ExportMode mode) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var b = new Billing(year);
|
var b = new Billing(year);
|
||||||
await b.FinishSeason();
|
await b.FinishSeason();
|
||||||
@ -393,15 +396,17 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task GenerateCreditNote(Member m, int year, int avnr, ExportMode mode) {
|
public static async Task GenerateCreditNote(Member m, int year, int avnr, ExportMode mode) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
var v = (await ctx.PaymentVariants.FindAsync(year, avnr))!;
|
var v = (await ctx.PaymentVariants.FindAsync(year, avnr))!;
|
||||||
var data = await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.PaymentVariants, year, avnr);
|
var data = await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.Seasons, year, avnr);
|
||||||
var p = (await ctx.MemberPayments.FindAsync(year, avnr, m.MgNr))!;
|
var p = (await ctx.MemberPayments.FindAsync(year, avnr, m.MgNr))!;
|
||||||
var b = BillingData.FromJson((await ctx.PaymentVariants.FindAsync(year, avnr))!.Data);
|
var b = BillingData.FromJson((await ctx.PaymentVariants.FindAsync(year, avnr))!.Data);
|
||||||
|
|
||||||
@ -412,6 +417,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -464,7 +470,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"{MemberList.Name} speichern unter - Elwig"
|
Title = $"{MemberList.Name} speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await MemberListData.FromQuery(query, filterNames, filterNames.Where(f => f.StartsWith("Flächenbindung")).Select(f => f.Split(' ')[^1]));
|
var data = await MemberListData.FromQuery(query, filterNames, filterNames.Where(f => f.StartsWith("Flächenbindung")).Select(f => f.Split(' ')[^1]));
|
||||||
using var ods = new OdsFile(d.FileName);
|
using var ods = new OdsFile(d.FileName);
|
||||||
@ -472,6 +479,7 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
} else if (mode == ExportMode.Export) {
|
} else if (mode == ExportMode.Export) {
|
||||||
@ -482,7 +490,8 @@ namespace Elwig.Services {
|
|||||||
Title = $"{MemberList.Name} speichern unter - Elwig"
|
Title = $"{MemberList.Name} speichern unter - Elwig"
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var members = await query
|
var members = await query
|
||||||
.OrderBy(m => m.MgNr)
|
.OrderBy(m => m.MgNr)
|
||||||
@ -499,10 +508,12 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
} else if (mode == ExportMode.Upload && App.Config.SyncUrl != null) {
|
} else if (mode == ExportMode.Upload && App.Config.SyncUrl != null) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var filename = $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip";
|
var filename = $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip";
|
||||||
var path = Path.Combine(App.TempPath, filename);
|
var path = Path.Combine(App.TempPath, filename);
|
||||||
@ -533,9 +544,11 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
} else {
|
} else {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await MemberListData.FromQuery(query, filterNames, filterNames.Where(f => f.StartsWith("Flächenbindung")).Select(f => f.Split(' ')[^1]));
|
var data = await MemberListData.FromQuery(query, filterNames, filterNames.Where(f => f.StartsWith("Flächenbindung")).Select(f => f.Split(' ')[^1]));
|
||||||
using var doc = new MemberList(string.Join(" / ", filterNames), data);
|
using var doc = new MemberList(string.Join(" / ", filterNames), data);
|
||||||
@ -543,14 +556,13 @@ namespace Elwig.Services {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<int> UpdateMember(this MemberAdminViewModel vm, int? oldMgNr) {
|
public static async Task<int> UpdateMember(this MemberAdminViewModel vm, int? oldMgNr) {
|
||||||
var newMgNr = (int)vm.MgNr!;
|
var newMgNr = (int)vm.MgNr!;
|
||||||
|
|
||||||
using (var ctx = new AppDbContext()) {
|
|
||||||
var m = new Member {
|
var m = new Member {
|
||||||
MgNr = oldMgNr ?? newMgNr,
|
MgNr = oldMgNr ?? newMgNr,
|
||||||
PredecessorMgNr = vm.PredecessorMgNr,
|
PredecessorMgNr = vm.PredecessorMgNr,
|
||||||
@ -588,6 +600,8 @@ namespace Elwig.Services {
|
|||||||
ContactViaEmail = vm.ContactViaEmail,
|
ContactViaEmail = vm.ContactViaEmail,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
if (oldMgNr != null) {
|
if (oldMgNr != null) {
|
||||||
ctx.Update(m);
|
ctx.Update(m);
|
||||||
} else {
|
} else {
|
||||||
@ -670,7 +684,7 @@ namespace Elwig.Services {
|
|||||||
if (newMgNr != m.MgNr) {
|
if (newMgNr != m.MgNr) {
|
||||||
await ctx.Database.ExecuteSqlAsync($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {oldMgNr}");
|
await ctx.Database.ExecuteSqlAsync($"UPDATE member SET mgnr = {newMgNr} WHERE mgnr = {oldMgNr}");
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
|
||||||
@ -678,7 +692,8 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static async Task DeleteMember(int mgnr, bool deletePaymentData, bool deleteDeliveries, bool deleteAreaComs) {
|
public static async Task DeleteMember(int mgnr, bool deletePaymentData, bool deleteDeliveries, bool deleteAreaComs) {
|
||||||
using (var ctx = new AppDbContext()) {
|
await Task.Run(async () => {
|
||||||
|
using var ctx = new AppDbContext();
|
||||||
var l = (await ctx.Members.FindAsync(mgnr))!;
|
var l = (await ctx.Members.FindAsync(mgnr))!;
|
||||||
if (deletePaymentData) {
|
if (deletePaymentData) {
|
||||||
ctx.RemoveRange(l.Credits);
|
ctx.RemoveRange(l.Credits);
|
||||||
@ -691,7 +706,8 @@ namespace Elwig.Services {
|
|||||||
}
|
}
|
||||||
ctx.Remove(l);
|
ctx.Remove(l);
|
||||||
await ctx.SaveChangesAsync();
|
await ctx.SaveChangesAsync();
|
||||||
}
|
});
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -203,13 +203,9 @@ namespace Elwig.Windows {
|
|||||||
$"Soll die Flächenbindung {a.GstNr} ({a.Area} m²) wirklich unwiderruflich gelöscht werden?",
|
$"Soll die Flächenbindung {a.GstNr} ({a.Area} m²) wirklich unwiderruflich gelöscht werden?",
|
||||||
"Flächenbindung löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
"Flächenbindung löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
||||||
if (r == MessageBoxResult.OK) {
|
if (r == MessageBoxResult.OK) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
using (var ctx = new AppDbContext()) {
|
await AreaComService.DeleteAreaCom(a.FbNr);
|
||||||
ctx.Remove(a);
|
|
||||||
await ctx.SaveChangesAsync();
|
|
||||||
}
|
|
||||||
App.HintContextChange();
|
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
var str = "Der Eintrag konnte nicht in der Datenbank aktualisiert werden!\n\n" + exc.Message;
|
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;
|
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||||
@ -227,7 +223,7 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
private async void AreaCommitmentSaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
private async void AreaCommitmentSaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
||||||
AreaCommitmentSaveButton.IsEnabled = false;
|
AreaCommitmentSaveButton.IsEnabled = false;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
|
||||||
int fbnr;
|
int fbnr;
|
||||||
try {
|
try {
|
||||||
@ -237,9 +233,8 @@ namespace Elwig.Windows {
|
|||||||
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||||
MessageBox.Show(str, "Flächenbindung aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(str, "Flächenbindung aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
AreaCommitmentSaveButton.IsEnabled = true;
|
AreaCommitmentSaveButton.IsEnabled = true;
|
||||||
return;
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
IsEditing = false;
|
IsEditing = false;
|
||||||
@ -252,6 +247,7 @@ namespace Elwig.Windows {
|
|||||||
FinishInputFilling();
|
FinishInputFilling();
|
||||||
await RefreshList();
|
await RefreshList();
|
||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
|
Mouse.OverrideCursor = null;
|
||||||
ViewModel.SearchQuery = "";
|
ViewModel.SearchQuery = "";
|
||||||
ControlUtils.SelectItem(AreaCommitmentList, AreaCommitmentList.ItemsSource.Cast<AreaCom>().Where(a => a.FbNr == fbnr).FirstOrDefault());
|
ControlUtils.SelectItem(AreaCommitmentList, AreaCommitmentList.ItemsSource.Cast<AreaCom>().Where(a => a.FbNr == fbnr).FirstOrDefault());
|
||||||
}
|
}
|
||||||
|
@ -157,7 +157,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
var d = new NewSeasonDialog(s, currencies);
|
var d = new NewSeasonDialog(s, currencies);
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
ctx.Add(new Season {
|
ctx.Add(new Season {
|
||||||
@ -209,7 +209,7 @@ namespace Elwig.Windows {
|
|||||||
$"Soll die Saison {s.Year} wirklich unwiderruflich gelöscht werden?",
|
$"Soll die Saison {s.Year} wirklich unwiderruflich gelöscht werden?",
|
||||||
"Saison löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
"Saison löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
||||||
if (r == MessageBoxResult.OK) {
|
if (r == MessageBoxResult.OK) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
ctx.Remove(s);
|
ctx.Remove(s);
|
||||||
|
@ -318,8 +318,7 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
||||||
SaveButton.IsEnabled = false;
|
SaveButton.IsEnabled = false;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await Save();
|
await Save();
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
@ -327,9 +326,8 @@ namespace Elwig.Windows {
|
|||||||
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||||
MessageBox.Show(str, "Stammdaten aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(str, "Stammdaten aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
SaveButton.IsEnabled = true;
|
SaveButton.IsEnabled = true;
|
||||||
return;
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
IsEditing = false;
|
IsEditing = false;
|
||||||
@ -349,6 +347,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
App.HintContextChange();
|
App.HintContextChange();
|
||||||
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FillInputs(ClientParameters p, Season? s) {
|
private void FillInputs(ClientParameters p, Season? s) {
|
||||||
|
@ -217,7 +217,7 @@
|
|||||||
<Bold>Zweigstelle</Bold>: z.B. musterort, ...<LineBreak/>
|
<Bold>Zweigstelle</Bold>: z.B. musterort, ...<LineBreak/>
|
||||||
<Bold>Attribut</Bold>: z.B. kabinett, !kabinett (alle außer kabinett), ...<LineBreak/>
|
<Bold>Attribut</Bold>: z.B. kabinett, !kabinett (alle außer kabinett), ...<LineBreak/>
|
||||||
<Bold>Bewirtschaftung</Bold>: z.B. bio, !kip (alle außer KIP), ...<LineBreak/>
|
<Bold>Bewirtschaftung</Bold>: z.B. bio, !kip (alle außer KIP), ...<LineBreak/>
|
||||||
<Bold>Gewicht</Bold>: z.B. <500kg, >6000kg, ... (gilt für Menge der gesamten Lieferung)<LineBreak/>
|
<Bold>Gewicht</Bold>: z.B. <500kg, >6000kg, ... (gilt für Gewicht der gesamten Lieferung)<LineBreak/>
|
||||||
<Bold>Datum</Bold>: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...<LineBreak/>
|
<Bold>Datum</Bold>: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...<LineBreak/>
|
||||||
<Bold>Uhrzeit</Bold>: z.B. 06:00-08:00, 18:00-, ...<LineBreak/>
|
<Bold>Uhrzeit</Bold>: z.B. 06:00-08:00, 18:00-, ...<LineBreak/>
|
||||||
<Bold>Handwiegung</Bold>: handw[iegung], !Handw[iegung] (alle ohne Handwiegung)<LineBreak/>
|
<Bold>Handwiegung</Bold>: handw[iegung], !Handw[iegung] (alle ohne Handwiegung)<LineBreak/>
|
||||||
@ -272,7 +272,7 @@
|
|||||||
</Style>
|
</Style>
|
||||||
</DataGridTextColumn.CellStyle>
|
</DataGridTextColumn.CellStyle>
|
||||||
</DataGridTextColumn>
|
</DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="Menge" Binding="{Binding FilteredWeight, StringFormat='{}{0:N0} kg '}" Width="75">
|
<DataGridTextColumn Header="Gewicht" Binding="{Binding FilteredWeight, StringFormat='{}{0:N0} kg '}" Width="75">
|
||||||
<DataGridTextColumn.CellStyle>
|
<DataGridTextColumn.CellStyle>
|
||||||
<Style>
|
<Style>
|
||||||
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
||||||
@ -516,7 +516,7 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
|
|
||||||
<GroupBox Header="Menge" Grid.Column="1" Grid.Row="2" Margin="5,5,5,5">
|
<GroupBox Header="Gewicht" Grid.Column="1" Grid.Row="2" Margin="5,5,5,5">
|
||||||
<Grid>
|
<Grid>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="70"/>
|
<ColumnDefinition Width="70"/>
|
||||||
@ -669,7 +669,7 @@
|
|||||||
<Separator Grid.Column="5"/>
|
<Separator Grid.Column="5"/>
|
||||||
<StatusBarItem Grid.Column="6">
|
<StatusBarItem Grid.Column="6">
|
||||||
<TextBlock ToolTip="{Binding StatusWeightToolTip}">
|
<TextBlock ToolTip="{Binding StatusWeightToolTip}">
|
||||||
Menge: <Run Text="{Binding StatusWeight}"/>
|
Gewicht: <Run Text="{Binding StatusWeight}"/>
|
||||||
</TextBlock>
|
</TextBlock>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="7"/>
|
<Separator Grid.Column="7"/>
|
||||||
|
@ -719,7 +719,7 @@ namespace Elwig.Windows {
|
|||||||
private async void NewDeliveryPartButton_Click(object sender, RoutedEventArgs evt) {
|
private async void NewDeliveryPartButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
FinishButton.IsEnabled = false;
|
FinishButton.IsEnabled = false;
|
||||||
NewDeliveryPartButton.IsEnabled = false;
|
NewDeliveryPartButton.IsEnabled = false;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
DeliveryPartList.IsEnabled = false;
|
DeliveryPartList.IsEnabled = false;
|
||||||
|
|
||||||
DeliveryPart? p;
|
DeliveryPart? p;
|
||||||
@ -757,7 +757,7 @@ namespace Elwig.Windows {
|
|||||||
private async void FinishButton_Click(object sender, RoutedEventArgs evt) {
|
private async void FinishButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
FinishButton.IsEnabled = false;
|
FinishButton.IsEnabled = false;
|
||||||
NewDeliveryPartButton.IsEnabled = false;
|
NewDeliveryPartButton.IsEnabled = false;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
DeliveryPartList.IsEnabled = false;
|
DeliveryPartList.IsEnabled = false;
|
||||||
|
|
||||||
DeliveryPart? p;
|
DeliveryPart? p;
|
||||||
@ -888,7 +888,7 @@ namespace Elwig.Windows {
|
|||||||
if (res == null)
|
if (res == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
var id = res.Value.Item1;
|
var id = res.Value.Item1;
|
||||||
var weights = res.Value.Item2;
|
var weights = res.Value.Item2;
|
||||||
@ -959,7 +959,7 @@ namespace Elwig.Windows {
|
|||||||
$"Soll die Lieferung {d.LsNr} ({d.Member.AdministrativeName}, MgNr. {d.Member.MgNr}) wirklich unwiderruflich gelöscht werden?",
|
$"Soll die Lieferung {d.LsNr} ({d.Member.AdministrativeName}, MgNr. {d.Member.MgNr}) wirklich unwiderruflich gelöscht werden?",
|
||||||
"Lieferung löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
"Lieferung löschen", MessageBoxButton.OKCancel, MessageBoxImage.Warning, MessageBoxResult.Cancel);
|
||||||
if (r == MessageBoxResult.OK) {
|
if (r == MessageBoxResult.OK) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
await DeliveryService.DeleteDelivery(d.LsNr);
|
await DeliveryService.DeleteDelivery(d.LsNr);
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
@ -979,7 +979,7 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
||||||
SaveButton.IsEnabled = false;
|
SaveButton.IsEnabled = false;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
|
||||||
DeliveryPart? p;
|
DeliveryPart? p;
|
||||||
try {
|
try {
|
||||||
@ -996,9 +996,8 @@ namespace Elwig.Windows {
|
|||||||
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||||
MessageBox.Show(str, "Lieferung aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(str, "Lieferung aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
SaveButton.IsEnabled = true;
|
SaveButton.IsEnabled = true;
|
||||||
return;
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
IsEditing = false;
|
IsEditing = false;
|
||||||
@ -1015,6 +1014,7 @@ namespace Elwig.Windows {
|
|||||||
await RefreshDeliveryParts();
|
await RefreshDeliveryParts();
|
||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
|
|
||||||
|
Mouse.OverrideCursor = null;
|
||||||
DepreciateButton.IsEnabled = true;
|
DepreciateButton.IsEnabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@
|
|||||||
<Bold>Zweigstelle</Bold>: z.B. musterort, ...<LineBreak/>
|
<Bold>Zweigstelle</Bold>: z.B. musterort, ...<LineBreak/>
|
||||||
<Bold>Attribut</Bold>: z.B. kabinett, !kabinett (alle außer kabinett), ...<LineBreak/>
|
<Bold>Attribut</Bold>: z.B. kabinett, !kabinett (alle außer kabinett), ...<LineBreak/>
|
||||||
<Bold>Bewirtschaftung</Bold>: z.B. bio, !kip (alle außer KIP), ...<LineBreak/>
|
<Bold>Bewirtschaftung</Bold>: z.B. bio, !kip (alle außer KIP), ...<LineBreak/>
|
||||||
<Bold>Menge</Bold>: z.B. <500kg, >6000kg, ...<LineBreak/>
|
<Bold>Gewicht</Bold>: z.B. <500kg, >6000kg, ...<LineBreak/>
|
||||||
<Bold>Datum</Bold>: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...
|
<Bold>Datum</Bold>: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...
|
||||||
</TextBlock>
|
</TextBlock>
|
||||||
</TextBox.ToolTip>
|
</TextBox.ToolTip>
|
||||||
@ -191,7 +191,7 @@
|
|||||||
</Style>
|
</Style>
|
||||||
</DataGridTextColumn.CellStyle>
|
</DataGridTextColumn.CellStyle>
|
||||||
</DataGridTextColumn>
|
</DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="Menge" Binding="{Binding Weight, StringFormat='{}{0:N0} kg'}" Width="75">
|
<DataGridTextColumn Header="Gewicht" Binding="{Binding Weight, StringFormat='{}{0:N0} kg'}" Width="75">
|
||||||
<DataGridTextColumn.CellStyle>
|
<DataGridTextColumn.CellStyle>
|
||||||
<Style>
|
<Style>
|
||||||
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
||||||
@ -328,7 +328,7 @@
|
|||||||
</ComboBox.ItemTemplateSelector>
|
</ComboBox.ItemTemplateSelector>
|
||||||
</ComboBox>
|
</ComboBox>
|
||||||
|
|
||||||
<Label Content="Menge:" Margin="10,70,0,0" Grid.Column="0"/>
|
<Label Content="Gewicht:" Margin="10,70,0,0" Grid.Column="0"/>
|
||||||
<ctrl:UnitTextBox x:Name="WeightInput" Unit="kg" Text="{Binding WeightString, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"
|
<ctrl:UnitTextBox x:Name="WeightInput" Unit="kg" Text="{Binding WeightString, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"
|
||||||
Grid.Column="1" Margin="0,70,10,10" Width="61" HorizontalAlignment="Left"
|
Grid.Column="1" Margin="0,70,10,10" Width="61" HorizontalAlignment="Left"
|
||||||
TextChanged="WeightInput_TextChanged" KeyUp="Input_KeyUp"/>
|
TextChanged="WeightInput_TextChanged" KeyUp="Input_KeyUp"/>
|
||||||
@ -364,7 +364,7 @@
|
|||||||
<Separator Grid.Column="1"/>
|
<Separator Grid.Column="1"/>
|
||||||
<StatusBarItem Grid.Column="2">
|
<StatusBarItem Grid.Column="2">
|
||||||
<TextBlock ToolTip="{Binding StatusWeightToolTip}">
|
<TextBlock ToolTip="{Binding StatusWeightToolTip}">
|
||||||
Menge: <Run Text="{Binding StatusWeight}"/>
|
Gewicht: <Run Text="{Binding StatusWeight}"/>
|
||||||
</TextBlock>
|
</TextBlock>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="3"/>
|
<Separator Grid.Column="3"/>
|
||||||
|
@ -127,7 +127,7 @@
|
|||||||
</DataGridTextColumn.CellStyle>
|
</DataGridTextColumn.CellStyle>
|
||||||
</DataGridTextColumn>
|
</DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="Beschreibung" Binding="{Binding Description}" Width="200"/>
|
<DataGridTextColumn Header="Beschreibung" Binding="{Binding Description}" Width="200"/>
|
||||||
<DataGridTextColumn Header="Max. Mg." Binding="{Binding MaxWeight, StringFormat='{}{0:N0} kg'}" Width="80">
|
<DataGridTextColumn Header="Max. Gew." Binding="{Binding MaxWeight, StringFormat='{}{0:N0} kg'}" Width="80">
|
||||||
<DataGridTextColumn.CellStyle>
|
<DataGridTextColumn.CellStyle>
|
||||||
<Style>
|
<Style>
|
||||||
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
||||||
@ -211,7 +211,7 @@
|
|||||||
Margin="0,40,10,10" Grid.Column="1" Grid.ColumnSpan="2"
|
Margin="0,40,10,10" Grid.Column="1" Grid.ColumnSpan="2"
|
||||||
TextChanged="TextBox_TextChanged"/>
|
TextChanged="TextBox_TextChanged"/>
|
||||||
|
|
||||||
<Label Content="Max. Menge:" Margin="10,70,0,10"/>
|
<Label Content="Max. Gewicht:" Margin="10,70,0,10"/>
|
||||||
<ctrl:UnitTextBox x:Name="MaxWeightInput" Unit="kg" Text="{Binding MaxWeightString, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"
|
<ctrl:UnitTextBox x:Name="MaxWeightInput" Unit="kg" Text="{Binding MaxWeightString, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"
|
||||||
Margin="0,70,10,10" Grid.Column="1" Grid.ColumnSpan="2" Width="68" HorizontalAlignment="Left"
|
Margin="0,70,10,10" Grid.Column="1" Grid.ColumnSpan="2" Width="68" HorizontalAlignment="Left"
|
||||||
TextChanged="MaxWeightInput_TextChanged"/>
|
TextChanged="MaxWeightInput_TextChanged"/>
|
||||||
|
@ -671,7 +671,7 @@ namespace Elwig.Windows {
|
|||||||
var avnr = details.Item2;
|
var avnr = details.Item2;
|
||||||
try {
|
try {
|
||||||
cnData[(year, avnr)] = (
|
cnData[(year, avnr)] = (
|
||||||
await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.PaymentVariants, year, avnr),
|
await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.Seasons, year, avnr),
|
||||||
await ctx.MemberPayments.Where(p => p.Year == year && p.AvNr == avnr).ToDictionaryAsync(c => c.MgNr),
|
await ctx.MemberPayments.Where(p => p.Year == year && p.AvNr == avnr).ToDictionaryAsync(c => c.MgNr),
|
||||||
BillingData.FromJson((await ctx.PaymentVariants.FindAsync(year, avnr))!.Data)
|
BillingData.FromJson((await ctx.PaymentVariants.FindAsync(year, avnr))!.Data)
|
||||||
);
|
);
|
||||||
|
@ -207,7 +207,7 @@
|
|||||||
<Button x:Name="BreakdownButton"
|
<Button x:Name="BreakdownButton"
|
||||||
Click="BreakdownButton_Click"
|
Click="BreakdownButton_Click"
|
||||||
Margin="195,90,0,10" Width="190" Padding="3,5,5,5"
|
Margin="195,90,0,10" Width="190" Padding="3,5,5,5"
|
||||||
ToolTip="Aufschlüsselung der Menge nach Zweigstelle, Mitglied, Sorte, Attribut/Bewirt., Qualitätsstufe, gebunden/ungebunden">
|
ToolTip="Aufschlüsselung des Gewichts nach Zweigstelle, Mitglied, Sorte, Attribut/Bewirt., Qualitätsstufe, gebunden/ungebunden">
|
||||||
<Grid>
|
<Grid>
|
||||||
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""
|
<TextBlock FontFamily="Segoe MDL2 Assets" FontSize="16" Text=""
|
||||||
TextAlignment="Left" HorizontalAlignment="Left" Padding="6.5,0.5,0,0"/>
|
TextAlignment="Left" HorizontalAlignment="Left" Padding="6.5,0.5,0,0"/>
|
||||||
@ -252,7 +252,7 @@
|
|||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<TextBlock Grid.Row="0" Grid.Column="1" TextAlignment="Right"><Bold>Mitglieder</Bold></TextBlock>
|
<TextBlock Grid.Row="0" Grid.Column="1" TextAlignment="Right"><Bold>Mitglieder</Bold></TextBlock>
|
||||||
<TextBlock Grid.Row="0" Grid.Column="2" TextAlignment="Right"><Bold>Menge</Bold></TextBlock>
|
<TextBlock Grid.Row="0" Grid.Column="2" TextAlignment="Right"><Bold>Gewicht</Bold></TextBlock>
|
||||||
<TextBlock Grid.Row="0" Grid.Column="3" TextAlignment="Right"><Bold>Fläche</Bold></TextBlock>
|
<TextBlock Grid.Row="0" Grid.Column="3" TextAlignment="Right"><Bold>Fläche</Bold></TextBlock>
|
||||||
|
|
||||||
<TextBlock Grid.Row="1" Grid.Column="0">Gesamt:</TextBlock>
|
<TextBlock Grid.Row="1" Grid.Column="0">Gesamt:</TextBlock>
|
||||||
|
@ -62,7 +62,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private async void Menu_Help_Smtp_Click(object sender, RoutedEventArgs evt) {
|
private async void Menu_Help_Smtp_Click(object sender, RoutedEventArgs evt) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
using var client = await Utils.GetSmtpClient();
|
using var client = await Utils.GetSmtpClient();
|
||||||
await client!.DisconnectAsync(true);
|
await client!.DisconnectAsync(true);
|
||||||
@ -133,8 +133,10 @@ namespace Elwig.Windows {
|
|||||||
Multiselect = true,
|
Multiselect = true,
|
||||||
};
|
};
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
await ElwigData.Import(d.FileNames, ElwigData.ImportMode.Interactively);
|
await ElwigData.Import(d.FileNames, ElwigData.ImportMode.Interactively);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
@ -145,7 +147,8 @@ namespace Elwig.Windows {
|
|||||||
private async void DownloadButton_Click(object sender, RoutedEventArgs evt) {
|
private async void DownloadButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
if (App.Config.SyncUrl == null)
|
if (App.Config.SyncUrl == null)
|
||||||
return;
|
return;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var data = await Utils.GetExportMetaData(App.Config.SyncUrl, App.Config.SyncUsername, App.Config.SyncPassword);
|
var data = await Utils.GetExportMetaData(App.Config.SyncUrl, App.Config.SyncUsername, App.Config.SyncPassword);
|
||||||
var files = data
|
var files = data
|
||||||
@ -181,13 +184,15 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void UploadButton_Click(object sender, RoutedEventArgs evt) {
|
private async void UploadButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
if (App.Config.SyncUrl == null)
|
if (App.Config.SyncUrl == null)
|
||||||
return;
|
return;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var path = Path.Combine(App.TempPath, $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip");
|
var path = Path.Combine(App.TempPath, $"{DateTime.Now:yyyy-MM-dd_HH-mm-ss}_{App.ZwstId}.elwig.zip");
|
||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
@ -216,6 +221,7 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Lieferungen hochladen", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Lieferungen hochladen", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -270,24 +276,31 @@ namespace Elwig.Windows {
|
|||||||
AreaCommitmentsButton.IsEnabled = valid;
|
AreaCommitmentsButton.IsEnabled = valid;
|
||||||
BreakdownMemberVarietyButton.IsEnabled = valid;
|
BreakdownMemberVarietyButton.IsEnabled = valid;
|
||||||
|
|
||||||
if (valid) {
|
|
||||||
var areaComs = Utils.ActiveAreaCommitments(ctx.AreaCommitments, year!.Value);
|
|
||||||
var weightTotal = await ctx.DeliveryParts.Where(p => p.Year == year).SumAsync(p => p.Weight);
|
|
||||||
var gebWeight = await ctx.DeliveryPartBuckets.Where(b => b.Year == year && b.Discr != "_").SumAsync(b => b.Value);
|
|
||||||
SeasonStatMembersTotal.Text = $"{await ctx.Deliveries.Where(d => d.Year == year).Select(d => d.Member).Distinct().CountAsync():N0}";
|
|
||||||
SeasonStatMembersGeb.Text = $"{await areaComs.Select(c => c.Member).Distinct().CountAsync():N0}";
|
|
||||||
SeasonStatWeightTotal.Text = $"{weightTotal:N0} kg";
|
|
||||||
SeasonStatWeightGeb.Text = $"{gebWeight:N0} kg";
|
|
||||||
SeasonStatWeightUngeb.Text = $"{weightTotal - gebWeight:N0} kg";
|
|
||||||
SeasonStatArea.Text = $"{await areaComs.SumAsync(c => c.Area):N0} m²";
|
|
||||||
} else {
|
|
||||||
SeasonStatMembersTotal.Text = "-";
|
SeasonStatMembersTotal.Text = "-";
|
||||||
SeasonStatMembersGeb.Text = "-";
|
SeasonStatMembersGeb.Text = "-";
|
||||||
SeasonStatWeightTotal.Text = "-";
|
SeasonStatWeightTotal.Text = "-";
|
||||||
SeasonStatWeightGeb.Text = "-";
|
SeasonStatWeightGeb.Text = "-";
|
||||||
SeasonStatWeightUngeb.Text = "-";
|
SeasonStatWeightUngeb.Text = "-";
|
||||||
SeasonStatArea.Text = "-";
|
SeasonStatArea.Text = "-";
|
||||||
}
|
if (valid) {
|
||||||
|
await Task.Run(async () => {
|
||||||
|
var membersTotal = await ctx.Deliveries.Where(d => d.Year == year).Select(d => d.Member).Distinct().CountAsync();
|
||||||
|
var areaComs = Utils.ActiveAreaCommitments(ctx.AreaCommitments, year!.Value);
|
||||||
|
var membersGeb = await areaComs.Select(c => c.Member).Distinct().CountAsync();
|
||||||
|
var weightTotal = await ctx.DeliveryParts.Where(p => p.Year == year).SumAsync(p => p.Weight);
|
||||||
|
var gebWeight = await ctx.DeliveryPartBuckets.Where(b => b.Year == year && b.Discr != "_").SumAsync(b => b.Value);
|
||||||
|
var area = await areaComs.SumAsync(c => c.Area);
|
||||||
|
await App.MainDispatcher.BeginInvoke(() => {
|
||||||
|
if (year != SeasonInput.Value) return;
|
||||||
|
SeasonStatMembersTotal.Text = $"{membersTotal:N0}";
|
||||||
|
SeasonStatMembersGeb.Text = $"{membersGeb:N0}";
|
||||||
|
SeasonStatWeightTotal.Text = $"{weightTotal:N0} kg";
|
||||||
|
SeasonStatWeightGeb.Text = $"{gebWeight:N0} kg";
|
||||||
|
SeasonStatWeightUngeb.Text = $"{weightTotal - gebWeight:N0} kg";
|
||||||
|
SeasonStatArea.Text = $"{area:N0} m²";
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private void DeliveryConfirmationButton_Click(object sender, RoutedEventArgs evt) {
|
private void DeliveryConfirmationButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
@ -315,7 +328,8 @@ namespace Elwig.Windows {
|
|||||||
if (d.ShowDialog() == false)
|
if (d.ShowDialog() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var b = new Billing(year);
|
var b = new Billing(year);
|
||||||
await b.FinishSeason();
|
await b.FinishSeason();
|
||||||
@ -331,6 +345,7 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -346,7 +361,8 @@ namespace Elwig.Windows {
|
|||||||
if (d.ShowDialog() == false)
|
if (d.ShowDialog() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var b = new Billing(year);
|
var b = new Billing(year);
|
||||||
await b.FinishSeason();
|
await b.FinishSeason();
|
||||||
@ -364,6 +380,7 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -379,7 +396,8 @@ namespace Elwig.Windows {
|
|||||||
if (d.ShowDialog() == false)
|
if (d.ShowDialog() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var b = new Billing(year);
|
var b = new Billing(year);
|
||||||
await b.FinishSeason();
|
await b.FinishSeason();
|
||||||
@ -393,6 +411,7 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -408,7 +427,8 @@ namespace Elwig.Windows {
|
|||||||
if (d.ShowDialog() == false)
|
if (d.ShowDialog() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
|
await Task.Run(async () => {
|
||||||
try {
|
try {
|
||||||
var b = new Billing(year);
|
var b = new Billing(year);
|
||||||
await b.FinishSeason();
|
await b.FinishSeason();
|
||||||
@ -422,6 +442,7 @@ namespace Elwig.Windows {
|
|||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -389,7 +389,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
var d = new DeleteMemberDialog(m.MgNr, m.AdministrativeName, areaComs, deliveries, credits);
|
var d = new DeleteMemberDialog(m.MgNr, m.AdministrativeName, areaComs, deliveries, credits);
|
||||||
if (d.ShowDialog() == true) {
|
if (d.ShowDialog() == true) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
await MemberService.DeleteMember(m.MgNr, d.DeletePaymentData, d.DeleteDeliveries, d.DeleteAreaComs);
|
await MemberService.DeleteMember(m.MgNr, d.DeletePaymentData, d.DeleteDeliveries, d.DeleteAreaComs);
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
@ -408,7 +408,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
private async void SaveButton_Click(object? sender, RoutedEventArgs? evt) {
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
SaveButton.IsEnabled = false;
|
SaveButton.IsEnabled = false;
|
||||||
|
|
||||||
int mgnr;
|
int mgnr;
|
||||||
@ -419,9 +419,8 @@ namespace Elwig.Windows {
|
|||||||
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
if (exc.InnerException != null) str += "\n\n" + exc.InnerException.Message;
|
||||||
MessageBox.Show(str, "Mitglied aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(str, "Mitglied aktualisieren", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
SaveButton.IsEnabled = true;
|
SaveButton.IsEnabled = true;
|
||||||
return;
|
|
||||||
} finally {
|
|
||||||
Mouse.OverrideCursor = null;
|
Mouse.OverrideCursor = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
IsEditing = false;
|
IsEditing = false;
|
||||||
@ -436,6 +435,7 @@ namespace Elwig.Windows {
|
|||||||
await RefreshList();
|
await RefreshList();
|
||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
ViewModel.SearchQuery = "";
|
ViewModel.SearchQuery = "";
|
||||||
|
Mouse.OverrideCursor = null;
|
||||||
if (mgnr is int m)
|
if (mgnr is int m)
|
||||||
FocusMember(m);
|
FocusMember(m);
|
||||||
}
|
}
|
||||||
@ -491,8 +491,9 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
private async void Menu_Contact_Letterhead_Click(object sender, RoutedEventArgs evt) {
|
private async void Menu_Contact_Letterhead_Click(object sender, RoutedEventArgs evt) {
|
||||||
if (ViewModel.SelectedMember is not Member m) return;
|
if (ViewModel.SelectedMember is not Member m) return;
|
||||||
Mouse.OverrideCursor = Cursors.AppStarting;
|
Mouse.OverrideCursor = Cursors.Wait;
|
||||||
try {
|
try {
|
||||||
|
await Task.Run(async () => {
|
||||||
using var doc = new Letterhead(m);
|
using var doc = new Letterhead(m);
|
||||||
await doc.Generate();
|
await doc.Generate();
|
||||||
if (!App.Config.Debug) {
|
if (!App.Config.Debug) {
|
||||||
@ -500,6 +501,7 @@ namespace Elwig.Windows {
|
|||||||
} else {
|
} else {
|
||||||
doc.Show();
|
doc.Show();
|
||||||
}
|
}
|
||||||
|
});
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:local="clr-namespace:Elwig.Windows"
|
xmlns:local="clr-namespace:Elwig.Windows"
|
||||||
xmlns:ctrl="clr-namespace:Elwig.Controls"
|
xmlns:ctrl="clr-namespace:Elwig.Controls"
|
||||||
Title="Auszahlungsvarianten - Elwig" Height="480" Width="850" MinHeight="400" MinWidth="850">
|
Title="Auszahlungsvarianten - Elwig" Height="480" Width="850" MinHeight="400" MinWidth="830">
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
<Style TargetType="Label">
|
<Style TargetType="Label">
|
||||||
<Setter Property="HorizontalAlignment" Value="Left"/>
|
<Setter Property="HorizontalAlignment" Value="Left"/>
|
||||||
@ -160,7 +160,7 @@
|
|||||||
</TextBlock>
|
</TextBlock>
|
||||||
|
|
||||||
<Label Content="Berücksichtigen:" Margin="90,70,10,10" Grid.Column="1"/>
|
<Label Content="Berücksichtigen:" Margin="90,70,10,10" Grid.Column="1"/>
|
||||||
<CheckBox x:Name="ConsiderModifiersInput" Content="Zu-/Abschläge bei Lieferungen (inkl. Rebelzuschl.)"
|
<CheckBox x:Name="ConsiderModifiersInput" Content="Zu-/Abschläge bei Lieferungen"
|
||||||
Margin="110,95,10,10" Grid.Column="1" HorizontalAlignment="Left" VerticalAlignment="Top"
|
Margin="110,95,10,10" Grid.Column="1" HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
Checked="ConsiderModifiersInput_Changed" Unchecked="ConsiderModifiersInput_Changed"/>
|
Checked="ConsiderModifiersInput_Changed" Unchecked="ConsiderModifiersInput_Changed"/>
|
||||||
<CheckBox x:Name="ConsiderPenaltiesInput" Content="Pönalen bei Unterlieferungen (FB)"
|
<CheckBox x:Name="ConsiderPenaltiesInput" Content="Pönalen bei Unterlieferungen (FB)"
|
||||||
|
5
Elwig/fetch-resources.bat
Normal file
5
Elwig/fetch-resources.bat
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
::mkdir "C:\Program Files\Elwig"
|
||||||
|
mkdir "C:\ProgramData\Elwig\resources"
|
||||||
|
copy /b /y Documents\*.css "C:\ProgramData\Elwig\resources"
|
||||||
|
copy /b /y Documents\*.cshtml "C:\ProgramData\Elwig\resources"
|
||||||
|
::copy /b /y ..\Installer\Files\*.exe "C:\Program Files\Elwig\"
|
@ -1,18 +1,15 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Wix xmlns="http://wixtoolset.org/schemas/v4/wxs">
|
<Wix xmlns="http://wixtoolset.org/schemas/v4/wxs">
|
||||||
<Fragment>
|
<Fragment>
|
||||||
<!-- C:\Program Files (x86)\Elwig oder C:\Program Files\Elwig -->
|
<!-- C:\Program Files (x86)\Elwig oder C:\Program Files\Elwig -->
|
||||||
<StandardDirectory Id="ProgramFiles64Folder">
|
<StandardDirectory Id="ProgramFiles64Folder">
|
||||||
<Directory Id="InstallFolder" Name="!(bind.Property.ProductName)">
|
<Directory Id="InstallFolder" Name="!(bind.Property.ProductName)" />
|
||||||
<Directory Id="InstallFolderResources" Name="resources">
|
|
||||||
<Directory Id="InstallFolderDocuments" Name="Documents" />
|
|
||||||
</Directory>
|
|
||||||
</Directory>
|
|
||||||
</StandardDirectory>
|
</StandardDirectory>
|
||||||
|
|
||||||
<!-- C:\ProgramData\Elwig -->
|
<!-- C:\ProgramData\Elwig -->
|
||||||
<StandardDirectory Id="CommonAppDataFolder">
|
<StandardDirectory Id="CommonAppDataFolder">
|
||||||
<Directory Id="ConfigFolder" Name="!(bind.Property.ProductName)" />
|
<Directory Id="ConfigFolder" Name="!(bind.Property.ProductName)">
|
||||||
|
<Directory Id="ConfigFolderResources" Name="resources" />
|
||||||
|
</Directory>
|
||||||
</StandardDirectory>
|
</StandardDirectory>
|
||||||
|
|
||||||
<!-- C:\ProgramData\Microsoft\Windows\Start Menu\Programs -->
|
<!-- C:\ProgramData\Microsoft\Windows\Start Menu\Programs -->
|
||||||
@ -20,7 +17,7 @@
|
|||||||
<Directory Id="StartMenuProgramsFolder" Name="!(bind.Property.ProductName)" />
|
<Directory Id="StartMenuProgramsFolder" Name="!(bind.Property.ProductName)" />
|
||||||
</StandardDirectory>
|
</StandardDirectory>
|
||||||
|
|
||||||
<!-- C:\Users\{USERNAME}\Desktop -->
|
<!-- C:\Users{USERNAME}\Desktop -->
|
||||||
<StandardDirectory Id="DesktopFolder" />
|
<StandardDirectory Id="DesktopFolder" />
|
||||||
</Fragment>
|
</Fragment>
|
||||||
</Wix>
|
</Wix>
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
<Exclude Files="..\Elwig\bin\Publish\**.exe" />
|
<Exclude Files="..\Elwig\bin\Publish\**.exe" />
|
||||||
<Exclude Files="..\Elwig\bin\Publish\**.pdb" />
|
<Exclude Files="..\Elwig\bin\Publish\**.pdb" />
|
||||||
</Files>
|
</Files>
|
||||||
<Files Directory="InstallFolderDocuments" Include="..\Elwig\Documents\**">
|
<Files Directory="ConfigFolderResources" Include="..\Elwig\Documents\**">
|
||||||
<Exclude Files="..\Elwig\Documents\**.cs" />
|
<Exclude Files="..\Elwig\Documents\**.cs" />
|
||||||
</Files>
|
</Files>
|
||||||
</ComponentGroup>
|
</ComponentGroup>
|
||||||
|
@ -12,7 +12,7 @@ namespace Tests.DocumentTests {
|
|||||||
using var ctx = new AppDbContext();
|
using var ctx = new AppDbContext();
|
||||||
var m = await ctx.Members.FindAsync(101);
|
var m = await ctx.Members.FindAsync(101);
|
||||||
var p = await ctx.MemberPayments.Where(p => p.Year == 2020 && p.AvNr == 1).SingleAsync();
|
var p = await ctx.MemberPayments.Where(p => p.Year == 2020 && p.AvNr == 1).SingleAsync();
|
||||||
var data = await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.PaymentVariants, 2020, 1);
|
var data = await CreditNoteDeliveryData.ForPaymentVariant(ctx.CreditNoteDeliveryRows, ctx.Seasons, 2020, 1);
|
||||||
using var doc = new CreditNote(ctx, p, data[m!.MgNr], false, false, false, false,
|
using var doc = new CreditNote(ctx, p, data[m!.MgNr], false, false, false, false,
|
||||||
ctx.GetMemberUnderDelivery(2020, m!.MgNr).GetAwaiter().GetResult());
|
ctx.GetMemberUnderDelivery(2020, m!.MgNr).GetAwaiter().GetResult());
|
||||||
var text = await Utils.GeneratePdfText(doc);
|
var text = await Utils.GeneratePdfText(doc);
|
||||||
|
@ -12,17 +12,16 @@ namespace Tests.DocumentTests {
|
|||||||
var v = (await ctx.PaymentVariants.FindAsync(2020, 1))!;
|
var v = (await ctx.PaymentVariants.FindAsync(2020, 1))!;
|
||||||
var data = await PaymentVariantSummaryData.ForPaymentVariant(v, ctx.PaymentVariantSummaryRows);
|
var data = await PaymentVariantSummaryData.ForPaymentVariant(v, ctx.PaymentVariantSummaryRows);
|
||||||
using var doc = new PaymentVariantSummary(v, data);
|
using var doc = new PaymentVariantSummary(v, data);
|
||||||
var text = await Utils.GeneratePdfText(doc, true);
|
var text = await Utils.GeneratePdfText(doc);
|
||||||
var table = Utils.ExtractTable(text);
|
|
||||||
Assert.Multiple(() => {
|
Assert.Multiple(() => {
|
||||||
Assert.That(text, Contains.Substring("Auszahlungsvariante"));
|
Assert.That(text, Contains.Substring("Auszahlungsvariante"));
|
||||||
Assert.That(text, Contains.Substring(v.Name));
|
Assert.That(text, Contains.Substring(v.Name));
|
||||||
Assert.That(table.Skip(17).ToArray(), Is.EqualTo(new string[][] {
|
Assert.That(text, Contains.Substring("""
|
||||||
[ "Gradation", "ungebunden", "attributlos gebunden", "gebunden", "Gesamt" ],
|
Gradation ungebunden gebunden Gesamt
|
||||||
[ "[°Oe]", "[kg]", "[€/kg]", "[kg]", "[€/kg]", "[kg]", "[€/kg]", "[€]" ],
|
[°Oe] [kg] [€/kg] [kg] [€/kg] [€]
|
||||||
["Grüner Veltliner", "3 219", "0", "0", "1 609,50"],
|
Grüner Veltliner 3 219 0 1 609,50
|
||||||
["Qualitätswein", "73", "3 219", "0,5000", "-", "-", "-", "-", "1 609,50"]
|
Qualitätswein 73 3 219 0,5000 - - 1 609,50
|
||||||
}));
|
"""));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user