Lieferscheine
This commit is contained in:
@ -20,6 +20,13 @@ namespace Elwig {
|
|||||||
public static readonly Config Config = new(DataPath + "config.ini");
|
public static readonly Config Config = new(DataPath + "config.ini");
|
||||||
|
|
||||||
public static string ZwstId { get; private set; }
|
public static string ZwstId { get; private set; }
|
||||||
|
public static string BranchName { get; private set; }
|
||||||
|
public static int? BranchPlz { get; private set; }
|
||||||
|
public static string? BranchOrt { get; private set; }
|
||||||
|
public static string? BranchAddress { get; private set; }
|
||||||
|
public static string? BranchPhoneNr { get; private set; }
|
||||||
|
public static string? BranchFaxNr { get; private set; }
|
||||||
|
public static string? BranchMobileNr { get; private set; }
|
||||||
public static IEnumerable<IScale> Scales { get; private set; }
|
public static IEnumerable<IScale> Scales { get; private set; }
|
||||||
public static ClientParameters Client { get; private set; }
|
public static ClientParameters Client { get; private set; }
|
||||||
|
|
||||||
@ -48,13 +55,13 @@ namespace Elwig {
|
|||||||
new FrameworkPropertyMetadata(XmlLanguage.GetLanguage(CultureInfo.CurrentCulture.IetfLanguageTag))
|
new FrameworkPropertyMetadata(XmlLanguage.GetLanguage(CultureInfo.CurrentCulture.IetfLanguageTag))
|
||||||
);
|
);
|
||||||
|
|
||||||
Dictionary<string, string> branches = new();
|
Dictionary<string, (string, string, int?, string?, string?, string?, string?, string?)> branches = new();
|
||||||
using (var ctx = new AppDbContext()) {
|
using (var ctx = new AppDbContext()) {
|
||||||
if (!ctx.Database.CanConnect()) {
|
if (!ctx.Database.CanConnect()) {
|
||||||
MessageBox.Show($"Invalid Database:\n\n{Config.DatabaseFile}", "Invalid Database", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show($"Invalid Database:\n\n{Config.DatabaseFile}", "Invalid Database", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
Shutdown();
|
Shutdown();
|
||||||
} else {
|
} else {
|
||||||
branches = ctx.Branches.ToDictionary(b => b.Name.ToLower(), b => b.ZwstId);
|
branches = ctx.Branches.ToDictionary(b => b.Name.ToLower(), b => (b.ZwstId, b.Name, b.PostalDest?.AtPlz?.Plz, b.PostalDest?.AtPlz?.Dest, b.Address, b.PhoneNr, b.FaxNr, b.MobileNr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Utils.RunBackground("HTML Initialization", () => Documents.Html.Init(PrintingReadyChanged));
|
Utils.RunBackground("HTML Initialization", () => Documents.Html.Init(PrintingReadyChanged));
|
||||||
@ -88,10 +95,26 @@ namespace Elwig {
|
|||||||
MessageBox.Show("Invalid branch name in config!", "Invalid Branch Config", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show("Invalid branch name in config!", "Invalid Branch Config", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
Shutdown();
|
Shutdown();
|
||||||
} else {
|
} else {
|
||||||
ZwstId = branches[Config.Branch.ToLower()];
|
var entry = branches[Config.Branch.ToLower()];
|
||||||
|
ZwstId = entry.Item1;
|
||||||
|
BranchName = entry.Item2;
|
||||||
|
BranchPlz = entry.Item3;
|
||||||
|
BranchOrt = entry.Item4;
|
||||||
|
BranchAddress = entry.Item5;
|
||||||
|
BranchPhoneNr = entry.Item6;
|
||||||
|
BranchFaxNr = entry.Item7;
|
||||||
|
BranchMobileNr = entry.Item8;
|
||||||
}
|
}
|
||||||
} else if (branches.Count == 1) {
|
} else if (branches.Count == 1) {
|
||||||
ZwstId = branches.First().Value;
|
var entry = branches.First().Value;
|
||||||
|
ZwstId = entry.Item1;
|
||||||
|
BranchName = entry.Item2;
|
||||||
|
BranchPlz = entry.Item3;
|
||||||
|
BranchOrt = entry.Item4;
|
||||||
|
BranchAddress = entry.Item5;
|
||||||
|
BranchPhoneNr = entry.Item6;
|
||||||
|
BranchFaxNr = entry.Item7;
|
||||||
|
BranchMobileNr = entry.Item8;
|
||||||
} else {
|
} else {
|
||||||
MessageBox.Show("Unable to determine local branch!", "Invalid Branch Config", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show("Unable to determine local branch!", "Invalid Branch Config", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
Shutdown();
|
Shutdown();
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<address>@Model.Address</address>
|
<address>@Model.Address</address>
|
||||||
</div>
|
</div>
|
||||||
<aside></aside>
|
<aside>@Raw(Model.Aside)</aside>
|
||||||
</div>
|
</div>
|
||||||
<main>
|
<main>
|
||||||
@RenderBody()
|
@RenderBody()
|
||||||
|
@ -5,10 +5,20 @@ namespace Elwig.Documents {
|
|||||||
|
|
||||||
public Member Member;
|
public Member Member;
|
||||||
public bool IncludeSender = false;
|
public bool IncludeSender = false;
|
||||||
|
public string Aside { get; set; }
|
||||||
|
public string? Location { get; set; }
|
||||||
|
|
||||||
public BusinessDocument(string title, Member m, bool includeSender = false) : base(title) {
|
public BusinessDocument(string title, Member m, bool includeSender = false) : base(title) {
|
||||||
Member = m;
|
Member = m;
|
||||||
|
Location = App.BranchName;
|
||||||
IncludeSender = includeSender;
|
IncludeSender = includeSender;
|
||||||
|
var uid = (m.UstId ?? "-") + (m.IsBuchführend ? "" : " <i>(pauschaliert)</i>");
|
||||||
|
Aside = $"<table><colgroup><col span='1' style='width: 2.25cm;'/><col span='1' style='width: 100%;'/></colgroup>" +
|
||||||
|
$"<thead><tr><th colspan='2'>Mitglied</th></tr></thead><tbody>" +
|
||||||
|
$"<tr><th>Mitglieds-Nr.</th><td>{m.MgNr}</td></tr>" +
|
||||||
|
$"<tr><th>Betriebs-Nr.</th><td>{m.LfbisNr}</td></tr>" +
|
||||||
|
$"<tr><th>UID</th><td>{uid}</td></tr>" +
|
||||||
|
$"</tbody></table>";
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Address {
|
public string Address {
|
||||||
@ -16,9 +26,9 @@ namespace Elwig.Documents {
|
|||||||
var b = Member.BillingAddress;
|
var b = Member.BillingAddress;
|
||||||
var plz = (b == null) ? Member.PostalDest.AtPlz : b.PostalDest.AtPlz;
|
var plz = (b == null) ? Member.PostalDest.AtPlz : b.PostalDest.AtPlz;
|
||||||
if (b != null) {
|
if (b != null) {
|
||||||
return $"{b.Name}\n{b.Address}\n{plz.Plz} {plz.Dest}";
|
return $"{b.Name}\n{Member.AdministrativeName}\n{b.Address}\n{plz.Plz} {plz.Dest}\nÖsterreich";
|
||||||
} else {
|
} else {
|
||||||
return $"{Member.AdministrativeName}\n{Member.Address}\n{plz.Plz} {plz.Dest}";
|
return $"{Member.AdministrativeName}\n{Member.Address}\n{plz.Plz} {plz.Dest}\nÖsterreich";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,6 @@ using Elwig.Models;
|
|||||||
|
|
||||||
namespace Elwig.Documents {
|
namespace Elwig.Documents {
|
||||||
public class BusinessLetter : BusinessDocument {
|
public class BusinessLetter : BusinessDocument {
|
||||||
public BusinessLetter(string title, Member m) : base(title, m) {
|
public BusinessLetter(string title, Member m) : base(title, m) { }
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,30 +3,67 @@
|
|||||||
@model Elwig.Documents.DeliveryNote
|
@model Elwig.Documents.DeliveryNote
|
||||||
@{ Layout = "BusinessDocument"; }
|
@{ Layout = "BusinessDocument"; }
|
||||||
|
|
||||||
<h1>Traubenübernahmeschein Nr. @Model.Delivery.LsNr</h1>
|
<div class="date">@Model.Location, am @($"{Model.Date:dd.MM.yyyy}")</div>
|
||||||
<table>
|
<h1>@Model.Title</h1>
|
||||||
|
<table class="delivery">
|
||||||
|
<colgroup>
|
||||||
|
<col span="1" style="width: 1cm;"/>
|
||||||
|
<col span="1" style="width: 50%;"/>
|
||||||
|
<col span="1" style="width: 50%;"/>
|
||||||
|
<col span="1" style="width: 3cm;"/>
|
||||||
|
<col span="1" style="width: 1.25cm;"/>
|
||||||
|
<col span="1" style="width: 1.25cm;"/>
|
||||||
|
<col span="1" style="width: 1.5cm;"/>
|
||||||
|
</colgroup>
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th rowspan="2">Sorte</th>
|
<th class="main" rowspan="2" style="text-align: center;">Pos.</th>
|
||||||
<th rowspan="2">Qualitätsstufe</th>
|
<th class="main" rowspan="2">Sorte</th>
|
||||||
|
<th class="main" rowspan="2">Attribut(e)</th>
|
||||||
|
<th class="main" rowspan="2">Qualitätsstufe</th>
|
||||||
<th colspan="2">Gradation</th>
|
<th colspan="2">Gradation</th>
|
||||||
<th>Gewicht</th>
|
<th>Gewicht</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th>°KMW</th>
|
<th style="font-size: 8pt">[°Oe]</th>
|
||||||
<th>°Oe</th>
|
<th style="font-size: 8pt">[°KMW]</th>
|
||||||
<th>kg</th>
|
<th style="font-size: 8pt">[kg]</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@foreach (var part in Model.Delivery.Parts.OrderBy(p => p.DPNr)) {
|
@foreach (var part in Model.Delivery.Parts.OrderBy(p => p.DPNr)) {
|
||||||
<tr>
|
<tr class="main">
|
||||||
|
<td style="text-align: center;">@part.DPNr</td>
|
||||||
<td>@part.Variant.Name</td>
|
<td>@part.Variant.Name</td>
|
||||||
|
<td>@string.Join(" / ", part.Attributes)</td>
|
||||||
<td>@part.Quality.Name</td>
|
<td>@part.Quality.Name</td>
|
||||||
<td>@part.Kmw</td>
|
<td class="narrow" style="text-align: center;">@($"{part.Oe:N0}")</td>
|
||||||
<td>@part.Oe</td>
|
<td class="narrow" style="text-align: center;">@($"{part.Kmw:N1}")</td>
|
||||||
<td>@part.Weight</td>
|
<td class="narrow" style="text-align: right;">@($"{part.Weight:N0}")</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr><td></td><td colspan="3" style="font-size: 8pt; white-space: pre">Herkunft: @part.OriginString</td></tr>
|
||||||
|
<tr><td></td><td colspan="3" style="font-size: 8pt;">
|
||||||
|
@(part.ManualWeighing ? "Handwiegung" : $"Waage: {part.ScaleId ?? "?"}, ID: {part.WeighingId ?? "?"}") (@(part.IsGerebelt ? "gerebelt gewogen" : "nicht gerebelt gewogen"))
|
||||||
|
</td></tr>
|
||||||
|
@if (part.Comment != null) {
|
||||||
|
<tr><td></td><td colspan="3" style="font-size: 8pt;">Anmerkung: @part.Comment</td></tr>
|
||||||
|
}
|
||||||
|
@if (part.Temperature != null || part.Acid != null) {
|
||||||
|
<tr><td></td><td colspan="3" style="font-size: 8pt;">@(part.Temperature != null ? $"Temperatur: {part.Temperature:N1} °C" : "")@(part.Temperature != null && part.Acid != null ? ", " : "")@(part.Acid != null ? $"Säure: {part.Acid:N1} g/l" : "")</td></tr>
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@if (Model.Delivery.Comment != null) {
|
||||||
|
<p class="comment">Amerkung zur Lieferung: @Model.Delivery.Comment</p>
|
||||||
|
}
|
||||||
|
<div class="bottom">
|
||||||
|
<!-- FIXME page breaking -->
|
||||||
|
@if (Model.Text != null) {
|
||||||
|
<p class="comment">@Model.Text</p>
|
||||||
|
}
|
||||||
|
<div class="signatures">
|
||||||
|
<div>Genossenschaft</div>
|
||||||
|
<div>Mitglied</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@ -4,9 +4,17 @@ namespace Elwig.Documents {
|
|||||||
public class DeliveryNote : BusinessDocument {
|
public class DeliveryNote : BusinessDocument {
|
||||||
|
|
||||||
public Delivery Delivery;
|
public Delivery Delivery;
|
||||||
|
public string? Text;
|
||||||
|
|
||||||
public DeliveryNote(Delivery d) : base($"Lieferschein {d.LsNr}", d.Member) {
|
public DeliveryNote(Delivery d) : base($"Traubenübernahmeschein Nr. {d.LsNr}", d.Member) {
|
||||||
Delivery = d;
|
Delivery = d;
|
||||||
|
Aside = Aside.Replace("</table>", "") +
|
||||||
|
$"<thead><tr><th colspan='2'>Lieferung</th></tr></thead><tbody>" +
|
||||||
|
$"<tr><th>LS-Nr.</th><td>{d.LsNr}</td></tr>" +
|
||||||
|
$"<tr><th>Datum/Zeit</th><td>{d.Date:dd.MM.yyyy} / {d.Time:HH:mm}</td></tr>" +
|
||||||
|
$"<tr><th>Zweigstelle</th><td>{d.Branch.Name}</td></tr>" +
|
||||||
|
$"</tbody></table>";
|
||||||
|
Text = App.Client.DeliveryNoteText;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
<header>@Raw(Model.Header)</header>
|
<header>@Raw(Model.Header)</header>
|
||||||
<div class="footer-wrapper">
|
<div class="footer-wrapper">
|
||||||
<div class="pre-footer">
|
<div class="pre-footer">
|
||||||
<span class="date">@Model.FullDateString</span>
|
<span class="date">@($"{Model.Date:dddd, d. MMMM yyyy}")</span>
|
||||||
<span class="page"></span>
|
<span class="page"></span>
|
||||||
</div>
|
</div>
|
||||||
<footer>@Raw(Model.Footer)</footer>
|
<footer>@Raw(Model.Footer)</footer>
|
||||||
|
@ -9,10 +9,15 @@ namespace Elwig.Documents {
|
|||||||
private TempFile? PdfFile = null;
|
private TempFile? PdfFile = null;
|
||||||
|
|
||||||
public Document(string title) {
|
public Document(string title) {
|
||||||
|
var c = App.Client;
|
||||||
DataPath = App.DataPath;
|
DataPath = App.DataPath;
|
||||||
Title = title;
|
Title = title;
|
||||||
Header = $"<h1>{App.Client.Name}</h1>";
|
Header = $"<h1>{c.Name}</h1>";
|
||||||
Footer = App.Client.NameFull;
|
Footer = $"{c.NameFull}<br/>" +
|
||||||
|
$"{c.Address} \u00b7 {c.Plz} {c.Ort} \u00b7 Österreich \u00b7 " +
|
||||||
|
$"Tel.: {c.PhoneNr} \u00b7 Fax: {c.FaxNr}<br/>{c.EmailAddress} \u00b7 {c.Website} \u00b7 " +
|
||||||
|
$"Betriebs-Nr.: {c.LfbisNr} \u00b7 UID: {c.UstId}<br/>" +
|
||||||
|
$"BIC: {c.Bic} \u00b7 IBAN: {c.Iban}";
|
||||||
Date = DateTime.Today;
|
Date = DateTime.Today;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -23,20 +28,13 @@ namespace Elwig.Documents {
|
|||||||
public void Dispose() {
|
public void Dispose() {
|
||||||
PdfFile?.Dispose();
|
PdfFile?.Dispose();
|
||||||
PdfFile = null;
|
PdfFile = null;
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public string DataPath { get; set; }
|
public string DataPath { get; set; }
|
||||||
|
|
||||||
public string Title { get; set; }
|
public string Title { get; set; }
|
||||||
|
|
||||||
public string Header { get; set; }
|
public string Header { get; set; }
|
||||||
|
|
||||||
public string Footer { get; set; }
|
public string Footer { get; set; }
|
||||||
|
|
||||||
public string FullDateString {
|
|
||||||
get => Date.ToString("dddd, d. MMMM yyyy");
|
|
||||||
}
|
|
||||||
|
|
||||||
public DateTime Date { get; set; }
|
public DateTime Date { get; set; }
|
||||||
|
|
||||||
private async Task<string> Render() {
|
private async Task<string> Render() {
|
||||||
@ -57,7 +55,7 @@ namespace Elwig.Documents {
|
|||||||
await File.WriteAllTextAsync(tmpHtml.FilePath, await Render());
|
await File.WriteAllTextAsync(tmpHtml.FilePath, await Render());
|
||||||
await Pdf.Convert(tmpHtml.FilePath, pdf.FilePath);
|
await Pdf.Convert(tmpHtml.FilePath, pdf.FilePath);
|
||||||
}
|
}
|
||||||
Pdf.UpdateMetadata(pdf.FilePath, Title, "Winzergenossenschaft für Matzen und Umgebung reg. Gen.m.b.H.");
|
Pdf.UpdateMetadata(pdf.FilePath, Title, App.Client.NameFull);
|
||||||
PdfFile = pdf;
|
PdfFile = pdf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
|
|
||||||
body {
|
body {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
|
break-inside: avoid;
|
||||||
}
|
}
|
||||||
|
|
||||||
.m1, .m2, .m3 {
|
.m1, .m2, .m3 {
|
||||||
@ -24,6 +25,10 @@ body {
|
|||||||
.m2 {top: 148.5mm;}
|
.m2 {top: 148.5mm;}
|
||||||
.m3 {top: 210mm;}
|
.m3 {top: 210mm;}
|
||||||
|
|
||||||
|
header, .address-wrapper, aside, main {
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
header {
|
header {
|
||||||
height: 45mm;
|
height: 45mm;
|
||||||
padding: 5mm;
|
padding: 5mm;
|
||||||
@ -33,7 +38,14 @@ header {
|
|||||||
right: 0;
|
right: 0;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
header h1{
|
||||||
|
font-size: 18pt;
|
||||||
|
margin-top: 1cm;
|
||||||
|
}
|
||||||
|
|
||||||
.spacing {height: 20mm;}
|
.spacing {height: 20mm;}
|
||||||
|
|
||||||
.info-wrapper {
|
.info-wrapper {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height:45mm;
|
height:45mm;
|
||||||
@ -79,6 +91,38 @@ aside {
|
|||||||
top: 5mm;
|
top: 5mm;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
aside table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
border: 1pt solid #808080;
|
||||||
|
width: calc(100% - 1cm);
|
||||||
|
margin-right: 1cm;
|
||||||
|
}
|
||||||
|
|
||||||
|
aside table thead:not(:first-child) tr {
|
||||||
|
border-top: 1pt solid #808080;
|
||||||
|
}
|
||||||
|
|
||||||
|
aside table thead th {
|
||||||
|
background-color: #E0E0E0;
|
||||||
|
font-size: 10pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
aside table tbody th,
|
||||||
|
aside table tbody td {
|
||||||
|
padding: 0.5mm 1mm;
|
||||||
|
text-align: left;
|
||||||
|
font-size: 10pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
aside table tbody th {
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.main-wrapper,
|
||||||
|
.main-wrapper * {
|
||||||
|
break-inside: auto;
|
||||||
|
}
|
||||||
|
|
||||||
main {
|
main {
|
||||||
margin: 8.46mm 20mm 4.23mm 25mm;
|
margin: 8.46mm 20mm 4.23mm 25mm;
|
||||||
}
|
}
|
||||||
@ -104,6 +148,11 @@ main h1 {
|
|||||||
margin-bottom: 2em;
|
margin-bottom: 2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
main p.comment {
|
||||||
|
font-size: 10pt;
|
||||||
|
hyphens: auto;
|
||||||
|
}
|
||||||
|
|
||||||
.footer-wrapper {
|
.footer-wrapper {
|
||||||
padding: 0 20mm 0 25mm;
|
padding: 0 20mm 0 25mm;
|
||||||
position: running(page-footer);
|
position: running(page-footer);
|
||||||
@ -139,6 +188,48 @@ footer {
|
|||||||
table {
|
table {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
border-collapse: collapse;
|
border-collapse: collapse;
|
||||||
|
table-layout: fixed;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.delivery {
|
||||||
|
margin-bottom: 1cm;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.delivery th {
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: italic;
|
||||||
|
font-size: 10pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.delivery th.main {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.delivery tr.main td {
|
||||||
|
font-weight: bold;
|
||||||
|
padding-top: 2mm;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
main .bottom {
|
||||||
|
bottom: 0;
|
||||||
|
position: absolute;
|
||||||
|
width: calc(100% - 25mm - 20mm);
|
||||||
|
}
|
||||||
|
|
||||||
|
main .signatures {
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-around;
|
||||||
|
margin: 20mm 0 5mm 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
main .signatures > * {
|
||||||
|
width: 5cm;
|
||||||
|
border-top: 1pt solid black;
|
||||||
|
padding-top: 1mm;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 10pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
@page {
|
@page {
|
||||||
@ -154,7 +245,7 @@ table {
|
|||||||
width: 210mm;
|
width: 210mm;
|
||||||
}
|
}
|
||||||
header, .address-wrapper, aside, main {
|
header, .address-wrapper, aside, main {
|
||||||
border: 1px solid lightgray;
|
border: 1pt solid lightgray;
|
||||||
}
|
}
|
||||||
.m1, .m2, .m3 {display: none;}
|
.m1, .m2, .m3 {display: none;}
|
||||||
header {top: 0;}
|
header {top: 0;}
|
||||||
|
@ -32,6 +32,8 @@ namespace Elwig.Helpers {
|
|||||||
public string? EmailAddress;
|
public string? EmailAddress;
|
||||||
public string? Website;
|
public string? Website;
|
||||||
|
|
||||||
|
public string? DeliveryNoteText;
|
||||||
|
|
||||||
public ClientParameters() {
|
public ClientParameters() {
|
||||||
NameToken = "WGM";
|
NameToken = "WGM";
|
||||||
NameShort = "WG Matzen";
|
NameShort = "WG Matzen";
|
||||||
@ -41,7 +43,21 @@ namespace Elwig.Helpers {
|
|||||||
Plz = 2243;
|
Plz = 2243;
|
||||||
Ort = "Matzen";
|
Ort = "Matzen";
|
||||||
Address = "Schloßstraße 6";
|
Address = "Schloßstraße 6";
|
||||||
|
PhoneNr = "+43 2289 2221";
|
||||||
|
FaxNr = "+43 2289 2221";
|
||||||
|
EmailAddress = "winzermatzen@aon.at";
|
||||||
|
Website = "winzermatzen.at";
|
||||||
|
LfbisNr = "0901768";
|
||||||
|
UstId = "ATU16328105";
|
||||||
|
Bic = "RLNWATWWGAE";
|
||||||
|
Iban = "AT92 3209 2000 0240 0075";
|
||||||
Sender2 = "E Österreichische Post AG Eco Brief";
|
Sender2 = "E Österreichische Post AG Eco Brief";
|
||||||
|
DeliveryNoteText = "Das Mitglied erklärt, dass die gelieferte Ware dem österreichischen Weingesetz entspricht und insbesondere die " +
|
||||||
|
"Bestimmungen über die Mengenbeschränkungen sowie für die Erzeugung von Wein besonderer Leseart eingehalten wird. " +
|
||||||
|
"Alle maßgeblichen Veränderungen obiger Angaben sind der Winzergenossenschaft unverzüglich zu melden. " +
|
||||||
|
"Das Mitglied bestätigt weiters mit seiner Unterschrift, dass die gelieferten Trauben entsprechend der guten Herstellungspraxis erzeugt wurden, " +
|
||||||
|
"insbesondere die Einhaltung der vom Hersteller vorgegebenen Wartefristen für Pflanzenschutzmittel. " +
|
||||||
|
"Weiters wird bestätigt, dass die Datenschutzerklärung der Winzergenossenschaft für Matzen und Umgebung in der Übernahmestelle zur freien Entnahme aufliegt.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,6 +11,30 @@ namespace Elwig.Models {
|
|||||||
[Column("name")]
|
[Column("name")]
|
||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
[Column("country")]
|
||||||
|
public int? CountryNum { get; set; }
|
||||||
|
|
||||||
|
[Column("postal_dest")]
|
||||||
|
public string? PostalDestId { get; set; }
|
||||||
|
|
||||||
|
[Column("address")]
|
||||||
|
public string? Address { get; set; }
|
||||||
|
|
||||||
|
[ForeignKey("CountryNum")]
|
||||||
|
public virtual Country? Country { get; private set; }
|
||||||
|
|
||||||
|
[ForeignKey("CountryNum, PostalDestId")]
|
||||||
|
public virtual PostalDest? PostalDest { get; private set; }
|
||||||
|
|
||||||
|
[Column("phone_nr")]
|
||||||
|
public string? PhoneNr { get; set; }
|
||||||
|
|
||||||
|
[Column("fax_nr")]
|
||||||
|
public string? FaxNr { get; set; }
|
||||||
|
|
||||||
|
[Column("mobile_nr")]
|
||||||
|
public string? MobileNr { get; set; }
|
||||||
|
|
||||||
[InverseProperty("Branch")]
|
[InverseProperty("Branch")]
|
||||||
public virtual ISet<Member> Members { get; private set; }
|
public virtual ISet<Member> Members { get; private set; }
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ namespace Elwig.Models {
|
|||||||
|
|
||||||
public int SearchScore(IEnumerable<string> keywords) {
|
public int SearchScore(IEnumerable<string> keywords) {
|
||||||
var list = new string?[] {
|
var list = new string?[] {
|
||||||
LsNr, Year.ToString(), Date.ToString("dd.MM.yyyy"), Time?.ToString("HH:ss"),
|
LsNr, Year.ToString(), Date.ToString("dd.MM.yyyy"), Time?.ToString("HH:mm"),
|
||||||
MgNr.ToString(), Member.FamilyName, Member.MiddleName, Member.GivenName, Member.BillingAddress?.Name,
|
MgNr.ToString(), Member.FamilyName, Member.MiddleName, Member.GivenName, Member.BillingAddress?.Name,
|
||||||
Comment
|
Comment
|
||||||
}.ToList();
|
}.ToList();
|
||||||
|
@ -106,5 +106,7 @@ namespace Elwig.Models {
|
|||||||
|
|
||||||
[NotMapped]
|
[NotMapped]
|
||||||
public IEnumerable<Modifier> Modifiers => PartModifiers.Select(m => m.Modifier);
|
public IEnumerable<Modifier> Modifiers => PartModifiers.Select(m => m.Modifier);
|
||||||
|
|
||||||
|
public string OriginString => Origin.OriginString + "\n" + (Kg?.Gl != null ? $" / {Kg.Gl.Name}" : "") + (Kg != null ? $" / {Kg.AtKg.Gem.Name} / KG {Kg.AtKg.Name}" : "") + (Rd != null ? $" / Ried {Rd.Name}" : "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,5 +40,7 @@ namespace Elwig.Models {
|
|||||||
public override string ToString() {
|
public override string ToString() {
|
||||||
return Name;
|
return Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string OriginString => (Parent != null ? $"{Parent.OriginString} / " : "") + Name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,10 @@
|
|||||||
<MenuItem Header="Lieferung">
|
<MenuItem Header="Lieferung">
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="Drucken">
|
<MenuItem Header="Drucken">
|
||||||
<MenuItem Header="Lieferschein drucken"/>
|
<MenuItem x:Name="Menu_Print_ShowDeliveryNote" Header="Lieferschein anzeigen" IsEnabled="False"
|
||||||
|
Click="Menu_Print_ShowDeliveryNote_Click"/>
|
||||||
|
<MenuItem x:Name="Menu_Print_PrintDeliveryNote" Header="Lieferschein drucken" IsEnabled="False"
|
||||||
|
Click="Menu_Print_PrintDeliveryNote_Click"/>
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="Werkzeuge">
|
<MenuItem Header="Werkzeuge">
|
||||||
<MenuItem Header="Alle Lieferscheine überprüfen"/>
|
<MenuItem Header="Alle Lieferscheine überprüfen"/>
|
||||||
|
@ -87,6 +87,20 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async void Menu_Print_ShowDeliveryNote_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (DeliveryList.SelectedItem is not Delivery d) return;
|
||||||
|
using var doc = new DeliveryNote(d);
|
||||||
|
await doc.Generate();
|
||||||
|
doc.Show();
|
||||||
|
}
|
||||||
|
|
||||||
|
private async void Menu_Print_PrintDeliveryNote_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (DeliveryList.SelectedItem is not Delivery d) return;
|
||||||
|
using var doc = new DeliveryNote(d);
|
||||||
|
await doc.Generate();
|
||||||
|
await doc.Print();
|
||||||
|
}
|
||||||
|
|
||||||
private void OnSecondPassed(object? sender, EventArgs? evt) {
|
private void OnSecondPassed(object? sender, EventArgs? evt) {
|
||||||
if (IsReceipt && IsCreating) {
|
if (IsReceipt && IsCreating) {
|
||||||
var now = DateTime.Now;
|
var now = DateTime.Now;
|
||||||
@ -407,8 +421,12 @@ namespace Elwig.Windows {
|
|||||||
RefreshDeliveryParts();
|
RefreshDeliveryParts();
|
||||||
if (DeliveryList.SelectedItem != null) {
|
if (DeliveryList.SelectedItem != null) {
|
||||||
DeleteDeliveryButton.IsEnabled = true;
|
DeleteDeliveryButton.IsEnabled = true;
|
||||||
|
Menu_Print_ShowDeliveryNote.IsEnabled = !IsEditing && !IsCreating;
|
||||||
|
Menu_Print_PrintDeliveryNote.IsEnabled = !IsEditing && !IsCreating;
|
||||||
} else {
|
} else {
|
||||||
DeleteDeliveryButton.IsEnabled = false;
|
DeleteDeliveryButton.IsEnabled = false;
|
||||||
|
Menu_Print_ShowDeliveryNote.IsEnabled = false;
|
||||||
|
Menu_Print_PrintDeliveryNote.IsEnabled = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -466,7 +484,7 @@ namespace Elwig.Windows {
|
|||||||
await RefreshDeliveryList();
|
await RefreshDeliveryList();
|
||||||
RefreshDeliveryParts();
|
RefreshDeliveryParts();
|
||||||
if (p != null) {
|
if (p != null) {
|
||||||
var doc = new DeliveryNote(p.Delivery);
|
using var doc = new DeliveryNote(p.Delivery);
|
||||||
await doc.Generate();
|
await doc.Generate();
|
||||||
doc.Show();
|
doc.Show();
|
||||||
//await doc.Print(2);
|
//await doc.Print(2);
|
||||||
|
Reference in New Issue
Block a user