Compare commits
21 Commits
6b6373238a
...
v0.5.0
| Author | SHA1 | Date | |
|---|---|---|---|
| 2f98df87a0 | |||
| f6ff2869c1 | |||
| 65ae2090ac | |||
| 73b3ddbcff | |||
| 78d83691df | |||
| c1b5631e24 | |||
| f9a3d31a49 | |||
| 3c8501cbe2 | |||
| 00eec47e13 | |||
| ff053e56cf | |||
| 493cfa3156 | |||
| 4fff89029d | |||
| 7e6aaf514b | |||
| 053fbdbf30 | |||
| a1ae44e135 | |||
| 7fe2ea76c3 | |||
| 6435a649b4 | |||
| 12226c3d0f | |||
| 1413f480cd | |||
| f7a044ba79 | |||
| d9dbfe68c1 |
@@ -2,11 +2,12 @@
|
|||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:local="clr-namespace:Elwig"
|
xmlns:local="clr-namespace:Elwig"
|
||||||
xmlns:controls="clr-namespace:Elwig.Controls"
|
xmlns:ctrl="clr-namespace:Elwig.Controls"
|
||||||
StartupUri="Windows\MainWindow.xaml"
|
StartupUri="Windows\MainWindow.xaml"
|
||||||
xmlns:ui="http://schemas.modernwpf.com/2019">
|
xmlns:ui="http://schemas.modernwpf.com/2019">
|
||||||
<Application.Resources>
|
<Application.Resources>
|
||||||
<controls:BoolToStringConverter x:Key="BoolToStarConverter" FalseValue="" TrueValue="*"/>
|
<ctrl:BoolToStringConverter x:Key="BoolToStarConverter" FalseValue="" TrueValue="*"/>
|
||||||
|
<ctrl:WidthToPaddingConverter x:Key="WidthToPaddingConverter"/>
|
||||||
|
|
||||||
<DataTemplate x:Key="PostalDestTemplate">
|
<DataTemplate x:Key="PostalDestTemplate">
|
||||||
<StackPanel Orientation="Horizontal">
|
<StackPanel Orientation="Horizontal">
|
||||||
|
|||||||
@@ -128,7 +128,7 @@ namespace Elwig {
|
|||||||
ZwstId = entry.Item1;
|
ZwstId = entry.Item1;
|
||||||
BranchName = entry.Item2;
|
BranchName = entry.Item2;
|
||||||
BranchPlz = entry.Item3;
|
BranchPlz = entry.Item3;
|
||||||
BranchLocation = entry.Item4?.Split(" im ")[0]; // FIXME
|
BranchLocation = entry.Item4?.Split(" im ")[0].Split(" an ")[0].Split(" bei ")[0]; // FIXME
|
||||||
BranchAddress = entry.Item5;
|
BranchAddress = entry.Item5;
|
||||||
BranchPhoneNr = entry.Item6;
|
BranchPhoneNr = entry.Item6;
|
||||||
BranchFaxNr = entry.Item7;
|
BranchFaxNr = entry.Item7;
|
||||||
@@ -139,7 +139,7 @@ namespace Elwig {
|
|||||||
ZwstId = entry.Item1;
|
ZwstId = entry.Item1;
|
||||||
BranchName = entry.Item2;
|
BranchName = entry.Item2;
|
||||||
BranchPlz = entry.Item3;
|
BranchPlz = entry.Item3;
|
||||||
BranchLocation = entry.Item4?.Split(" im ")[0]; // FIXME
|
BranchLocation = entry.Item4?.Split(" im ")[0].Split(" an ")[0].Split(" bei ")[0]; // FIXME
|
||||||
BranchAddress = entry.Item5;
|
BranchAddress = entry.Item5;
|
||||||
BranchPhoneNr = entry.Item6;
|
BranchPhoneNr = entry.Item6;
|
||||||
BranchFaxNr = entry.Item7;
|
BranchFaxNr = entry.Item7;
|
||||||
|
|||||||
@@ -1,16 +1,17 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Windows.Data;
|
using System.Windows.Data;
|
||||||
|
using System.Globalization;
|
||||||
|
|
||||||
namespace Elwig.Controls {
|
namespace Elwig.Controls {
|
||||||
public class BoolToValueConverter<T> : IValueConverter {
|
public class BoolToValueConverter<T> : IValueConverter {
|
||||||
public T FalseValue { get; set; }
|
public T FalseValue { get; set; }
|
||||||
public T TrueValue { get; set; }
|
public T TrueValue { get; set; }
|
||||||
|
|
||||||
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) {
|
public object Convert(object value, Type targetType, object parameter, CultureInfo culture) {
|
||||||
return (bool)value ? TrueValue : FalseValue;
|
return (bool)value ? TrueValue : FalseValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) {
|
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) {
|
||||||
return value?.Equals(TrueValue) ?? false;
|
return value?.Equals(TrueValue) ?? false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
11
Elwig/Controls/UnitTextBox.xaml
Normal file
11
Elwig/Controls/UnitTextBox.xaml
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
<UserControl x:Class="Elwig.Controls.UnitTextBox"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
|
||||||
|
<Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch" Height="25">
|
||||||
|
<TextBox x:Name="TextBox" TextAlignment="Right" FontSize="14" VerticalAlignment="Stretch"
|
||||||
|
Padding="{Binding ElementName=UnitBlock, Path=ActualWidth, Converter={StaticResource WidthToPaddingConverter}}"
|
||||||
|
Text="{Binding Path=Text}" TextChanged="TextBox_TextChanged"/>
|
||||||
|
<TextBlock x:Name="UnitBlock" Text="{Binding Path=Unit}" Margin="0,0,4,4" FontSize="10"
|
||||||
|
HorizontalAlignment="Right" VerticalAlignment="Bottom"/>
|
||||||
|
</Grid>
|
||||||
|
</UserControl>
|
||||||
37
Elwig/Controls/UnitTextBox.xaml.cs
Normal file
37
Elwig/Controls/UnitTextBox.xaml.cs
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
|
||||||
|
namespace Elwig.Controls {
|
||||||
|
public partial class UnitTextBox : UserControl {
|
||||||
|
|
||||||
|
public event TextChangedEventHandler? TextChanged;
|
||||||
|
|
||||||
|
public static readonly DependencyProperty TextProperty = DependencyProperty.Register("Text", typeof(string), typeof(UnitTextBox));
|
||||||
|
public string Text {
|
||||||
|
get => (string)GetValue(TextProperty);
|
||||||
|
set => SetValue(TextProperty, value ?? "");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static readonly DependencyProperty UnitProperty = DependencyProperty.Register("Unit", typeof(string), typeof(UnitTextBox));
|
||||||
|
public string Unit {
|
||||||
|
get => (string)GetValue(UnitProperty);
|
||||||
|
set => SetValue(UnitProperty, value ?? "");
|
||||||
|
}
|
||||||
|
|
||||||
|
public UnitTextBox() {
|
||||||
|
Text = "";
|
||||||
|
Unit = "";
|
||||||
|
InitializeComponent();
|
||||||
|
DataContext = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void TextBox_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
Text = TextBox.Text;
|
||||||
|
TextChanged?.Invoke(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
public new void Focus() {
|
||||||
|
TextBox.Focus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
16
Elwig/Controls/WidthToPaddingConverter.cs
Normal file
16
Elwig/Controls/WidthToPaddingConverter.cs
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
using System;
|
||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Data;
|
||||||
|
using System.Globalization;
|
||||||
|
|
||||||
|
namespace Elwig.Controls {
|
||||||
|
public class WidthToPaddingConverter : IValueConverter {
|
||||||
|
public object Convert(object value, Type targetType, object parameter, CultureInfo culture) {
|
||||||
|
return new Thickness(2, 2, 4 + (double)value, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) {
|
||||||
|
return ((Thickness)value).Right - 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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.4.3</Version>
|
<Version>0.5.0</Version>
|
||||||
<SatelliteResourceLanguages>de-AT</SatelliteResourceLanguages>
|
<SatelliteResourceLanguages>de-AT</SatelliteResourceLanguages>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
|
|||||||
@@ -4,11 +4,12 @@ using System;
|
|||||||
namespace Elwig.Helpers {
|
namespace Elwig.Helpers {
|
||||||
public static class AppDbUpdater {
|
public static class AppDbUpdater {
|
||||||
|
|
||||||
public static readonly int RequiredSchemaVersion = 6;
|
public static readonly int RequiredSchemaVersion = 7;
|
||||||
|
|
||||||
private static int _versionOffset = 0;
|
private static int _versionOffset = 0;
|
||||||
private static readonly Action<SqliteConnection>[] _updaters = new[] {
|
private static readonly Action<SqliteConnection>[] _updaters = new[] {
|
||||||
UpdateDbSchema_1_To_2, UpdateDbSchema_2_To_3, UpdateDbSchema_3_To_4, UpdateDbSchema_4_To_5, UpdateDbSchema_5_To_6
|
UpdateDbSchema_1_To_2, UpdateDbSchema_2_To_3, UpdateDbSchema_3_To_4, UpdateDbSchema_4_To_5,
|
||||||
|
UpdateDbSchema_5_To_6, UpdateDBSchema_6_To_7
|
||||||
};
|
};
|
||||||
|
|
||||||
private static void ExecuteNonQuery(SqliteConnection cnx, string sql) {
|
private static void ExecuteNonQuery(SqliteConnection cnx, string sql) {
|
||||||
@@ -492,5 +493,52 @@ namespace Elwig.Helpers {
|
|||||||
ORDER BY year, mgnr, bucket;
|
ORDER BY year, mgnr, bucket;
|
||||||
""");
|
""");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void UpdateDBSchema_6_To_7(SqliteConnection cnx) {
|
||||||
|
ExecuteNonQuery(cnx, "DROP VIEW v_area_commitment_bucket_strict");
|
||||||
|
ExecuteNonQuery(cnx, """
|
||||||
|
CREATE VIEW v_area_commitment_bucket_strict AS
|
||||||
|
SELECT s.year, c.mgnr,
|
||||||
|
t.sortid || COALESCE(a.attrid, '') AS bucket,
|
||||||
|
t.sortid, a.attrid,
|
||||||
|
SUM(area) AS area,
|
||||||
|
CAST(ROUND(SUM(area) * COALESCE(t.min_kg_per_ha, 0) / 10000.0, 0) AS INTEGER) AS min_kg,
|
||||||
|
CAST(ROUND(SUM(area) * MIN(COALESCE(a.max_kg_per_ha, s.max_kg_per_ha), s.max_kg_per_ha) / 10000.0, 0) AS INTEGER) AS max_kg,
|
||||||
|
CAST(ROUND(SUM(area) * s.max_kg_per_ha / 10000.0, 0) AS INTEGER) AS upper_max_kg
|
||||||
|
FROM season s, area_commitment c
|
||||||
|
JOIN area_commitment_type t ON t.vtrgid = c.vtrgid
|
||||||
|
LEFT JOIN wine_attribute a ON a.attrid = t.attrid
|
||||||
|
WHERE (year_from IS NULL OR year_from <= s.year) AND
|
||||||
|
(year_to IS NULL OR year_to >= s.year)
|
||||||
|
GROUP BY s.year, c.mgnr, bucket
|
||||||
|
ORDER BY s.year, c.mgnr, bucket;
|
||||||
|
""");
|
||||||
|
|
||||||
|
ExecuteNonQuery(cnx, """
|
||||||
|
CREATE VIEW v_under_delivery_bucket_strict AS
|
||||||
|
SELECT c.year, c.mgnr, c.bucket, c.min_kg, COALESCE(p.weight, 0) AS weight
|
||||||
|
FROM v_area_commitment_bucket_strict c
|
||||||
|
LEFT JOIN v_payment_bucket_strict p ON (p.year, p.mgnr, p.bucket) = (c.year, c.mgnr, c.bucket)
|
||||||
|
ORDER BY c.year, c.mgnr, c.bucket;
|
||||||
|
""");
|
||||||
|
ExecuteNonQuery(cnx, """
|
||||||
|
CREATE VIEW v_under_delivery_bucket AS
|
||||||
|
SELECT u.year, u.mgnr, u.bucket, u.min_kg,
|
||||||
|
u.weight + SUM(MAX(COALESCE(p.weight - s.min_kg, 0), 0)) AS weight
|
||||||
|
FROM v_under_delivery_bucket_strict u
|
||||||
|
LEFT JOIN v_payment_bucket_strict p ON (p.year, p.mgnr, p.sortid) = (u.year, u.mgnr, u.bucket) AND p.attrid IS NOT NULL
|
||||||
|
LEFT JOIN wine_attribute a ON a.attrid = p.attrid
|
||||||
|
LEFT JOIN v_area_commitment_bucket_strict s ON (s.year, s.mgnr, s.bucket) = (p.year, p.mgnr, p.bucket)
|
||||||
|
WHERE (p.gebunden IS NULL OR p.gebunden) AND (a.strict IS NULL OR a.strict = FALSE)
|
||||||
|
GROUP BY u.year, u.mgnr, u.bucket
|
||||||
|
ORDER BY u.year, u.mgnr, u.bucket;
|
||||||
|
""");
|
||||||
|
ExecuteNonQuery(cnx, """
|
||||||
|
CREATE VIEW v_under_delivery AS
|
||||||
|
SELECT year, mgnr, bucket, min_kg, weight, weight - min_kg AS diff
|
||||||
|
FROM v_under_delivery_bucket
|
||||||
|
WHERE diff < 0;
|
||||||
|
""");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -63,13 +63,15 @@ namespace Elwig.Helpers {
|
|||||||
return CheckDecimal(input, required, -1, -1);
|
return CheckDecimal(input, required, -1, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ValidationResult CheckDecimal(TextBox input, bool required, int maxLen, int maxDecimal) {
|
public static ValidationResult CheckDecimal(TextBox input, bool required, int maxLen, int maxDecimal, bool allowMinus = false) {
|
||||||
string text = "";
|
string text = "";
|
||||||
int pos = input.CaretIndex;
|
int pos = input.CaretIndex;
|
||||||
int v1 = 0, v2 = -1;
|
int v1 = 0, v2 = -1;
|
||||||
for (int i = 0; i < input.Text.Length; i++) {
|
for (int i = 0; i < input.Text.Length; i++) {
|
||||||
char ch = input.Text[i];
|
char ch = input.Text[i];
|
||||||
if (char.IsAsciiDigit(ch)) {
|
if (ch == '-' && i == 0 && allowMinus) {
|
||||||
|
text += ch;
|
||||||
|
} else if (char.IsAsciiDigit(ch)) {
|
||||||
if (v2 == -1 && (maxLen == -1 || v1 < maxLen)) {
|
if (v2 == -1 && (maxLen == -1 || v1 < maxLen)) {
|
||||||
text += ch; v1++;
|
text += ch; v1++;
|
||||||
} else if (v2 != -1 && (maxDecimal == -1 || v2 < maxDecimal)) {
|
} else if (v2 != -1 && (maxDecimal == -1 || v2 < maxDecimal)) {
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.ComponentModel.DataAnnotations.Schema;
|
using System.ComponentModel.DataAnnotations.Schema;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace Elwig.Models {
|
namespace Elwig.Models {
|
||||||
[Table("area_commitment"), PrimaryKey("FbNr")]
|
[Table("area_commitment"), PrimaryKey("FbNr")]
|
||||||
@@ -51,5 +55,12 @@ namespace Elwig.Models {
|
|||||||
|
|
||||||
[ForeignKey("KgNr, RdNr")]
|
[ForeignKey("KgNr, RdNr")]
|
||||||
public virtual WbRd? Rd { get; private set; }
|
public virtual WbRd? Rd { get; private set; }
|
||||||
|
|
||||||
|
public int SearchScore(IEnumerable<string> keywords) {
|
||||||
|
var list = new string?[] {
|
||||||
|
WineCult.Name, Kg.AtKg.Name, Rd.Name, GstNr, Comment,
|
||||||
|
}.ToList();
|
||||||
|
return Utils.GetSearchScore(list, keywords);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,6 +12,6 @@ namespace Elwig.Models {
|
|||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
|
|
||||||
[Column("description")]
|
[Column("description")]
|
||||||
public string Description { get; set; }
|
public string? Description { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
using Elwig.Controls;
|
||||||
using Elwig.Helpers;
|
using Elwig.Helpers;
|
||||||
using Elwig.Models;
|
using Elwig.Models;
|
||||||
using System;
|
using System;
|
||||||
@@ -62,16 +63,18 @@ namespace Elwig.Windows {
|
|||||||
OriginalValues = new();
|
OriginalValues = new();
|
||||||
DefaultValues = new();
|
DefaultValues = new();
|
||||||
Closing += OnClosing;
|
Closing += OnClosing;
|
||||||
|
Loaded -= base.OnLoaded;
|
||||||
Loaded += OnLoaded;
|
Loaded += OnLoaded;
|
||||||
|
Loaded += base.OnLoaded;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnLoaded(object sender, RoutedEventArgs evt) {
|
private new void OnLoaded(object sender, RoutedEventArgs evt) {
|
||||||
TextBoxInputs = ControlUtils.FindAllChildren<TextBox>(this, ExemptInputs).ToArray();
|
TextBoxInputs = ControlUtils.FindAllChildren<TextBox>(this, ExemptInputs).ToArray();
|
||||||
ComboBoxInputs = ControlUtils.FindAllChildren<ComboBox>(this, ExemptInputs).ToArray();
|
ComboBoxInputs = ControlUtils.FindAllChildren<ComboBox>(this, ExemptInputs).ToArray();
|
||||||
CheckBoxInputs = ControlUtils.FindAllChildren<CheckBox>(this, ExemptInputs).ToArray();
|
CheckBoxInputs = ControlUtils.FindAllChildren<CheckBox>(this, ExemptInputs).ToArray();
|
||||||
CheckComboBoxInputs = ControlUtils.FindAllChildren<CheckComboBox>(this, ExemptInputs).ToArray();
|
CheckComboBoxInputs = ControlUtils.FindAllChildren<CheckComboBox>(this, ExemptInputs).ToArray();
|
||||||
RadioButtonInputs = ControlUtils.FindAllChildren<RadioButton>(this, ExemptInputs).ToArray();
|
RadioButtonInputs = ControlUtils.FindAllChildren<RadioButton>(this, ExemptInputs).ToArray();
|
||||||
PlzInputs = TextBoxInputs.Where(tb => "PLZ".Equals(tb.Tag)).ToArray();
|
PlzInputs = ControlUtils.FindAllChildren<TextBox>(this).Where(tb => "PLZ".Equals(tb.Tag)).ToArray();
|
||||||
PlzOrtInputs = PlzInputs.Select(tb => ControlUtils.FindNextSibling<ComboBox>(tb) ?? throw new MissingMemberException()).ToArray();
|
PlzOrtInputs = PlzInputs.Select(tb => ControlUtils.FindNextSibling<ComboBox>(tb) ?? throw new MissingMemberException()).ToArray();
|
||||||
foreach (var tb in TextBoxInputs)
|
foreach (var tb in TextBoxInputs)
|
||||||
Valid[tb] = true;
|
Valid[tb] = true;
|
||||||
@@ -105,6 +108,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void ValidateInput(Control input, bool valid) {
|
protected void ValidateInput(Control input, bool valid) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
Valid[input] = valid;
|
Valid[input] = valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -205,6 +209,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void SetOriginalValue(Control input, object? value) {
|
protected void SetOriginalValue(Control input, object? value) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
OriginalValues[input] = value is bool b ? b.ToString() : value;
|
OriginalValues[input] = value is bool b ? b.ToString() : value;
|
||||||
if (InputHasChanged(input)) {
|
if (InputHasChanged(input)) {
|
||||||
ControlUtils.SetInputChanged(input);
|
ControlUtils.SetInputChanged(input);
|
||||||
@@ -214,15 +219,18 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void SetOriginalValue(Control input) {
|
protected void SetOriginalValue(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
SetOriginalValue(input, ControlUtils.GetInputValue(input));
|
SetOriginalValue(input, ControlUtils.GetInputValue(input));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void UnsetOriginalValue(Control input) {
|
protected void UnsetOriginalValue(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
OriginalValues.Remove(input);
|
OriginalValues.Remove(input);
|
||||||
ControlUtils.ClearInputState(input);
|
ControlUtils.ClearInputState(input);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void SetDefaultValue(Control input, object? value) {
|
protected void SetDefaultValue(Control input, object? value) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
DefaultValues[input] = value is bool b ? b.ToString() : value;
|
DefaultValues[input] = value is bool b ? b.ToString() : value;
|
||||||
if (!InputHasChanged(input)) {
|
if (!InputHasChanged(input)) {
|
||||||
if (InputIsNotDefault(input)) {
|
if (InputIsNotDefault(input)) {
|
||||||
@@ -234,10 +242,12 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void SetDefaultValue(Control input) {
|
protected void SetDefaultValue(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
SetDefaultValue(input, ControlUtils.GetInputValue(input));
|
SetDefaultValue(input, ControlUtils.GetInputValue(input));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void UnsetDefaultValue(Control input) {
|
protected void UnsetDefaultValue(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
DefaultValues.Remove(input);
|
DefaultValues.Remove(input);
|
||||||
if (!InputHasChanged(input)) {
|
if (!InputHasChanged(input)) {
|
||||||
ControlUtils.ClearInputState(input);
|
ControlUtils.ClearInputState(input);
|
||||||
@@ -261,10 +271,12 @@ namespace Elwig.Windows {
|
|||||||
protected bool IsValid => Valid.All(kv => kv.Value);
|
protected bool IsValid => Valid.All(kv => kv.Value);
|
||||||
|
|
||||||
protected bool GetInputValid(Control input) {
|
protected bool GetInputValid(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
return Valid[input];
|
return Valid[input];
|
||||||
}
|
}
|
||||||
|
|
||||||
protected bool InputHasChanged(Control input) {
|
protected bool InputHasChanged(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
if (!OriginalValues.ContainsKey(input)) {
|
if (!OriginalValues.ContainsKey(input)) {
|
||||||
return false;
|
return false;
|
||||||
} else if (input is TextBox tb) {
|
} else if (input is TextBox tb) {
|
||||||
@@ -283,6 +295,7 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected bool InputIsNotDefault(Control input) {
|
protected bool InputIsNotDefault(Control input) {
|
||||||
|
if (input is UnitTextBox utbx) input = utbx.TextBox;
|
||||||
if (!DefaultValues.ContainsKey(input)) {
|
if (!DefaultValues.ContainsKey(input)) {
|
||||||
return false;
|
return false;
|
||||||
} else if (input is TextBox tb) {
|
} else if (input is TextBox tb) {
|
||||||
@@ -317,7 +330,7 @@ namespace Elwig.Windows {
|
|||||||
);
|
);
|
||||||
|
|
||||||
protected void UpdatePlz(TextBox plzInput, ComboBox ortInput) {
|
protected void UpdatePlz(TextBox plzInput, ComboBox ortInput) {
|
||||||
var plzInputValid = GetInputValid(plzInput);
|
var plzInputValid = Validator.CheckPlz(plzInput, RequiredInputs.Contains(plzInput), Context).IsValid;
|
||||||
var item = ortInput.SelectedItem;
|
var item = ortInput.SelectedItem;
|
||||||
var list = plzInputValid && plzInput.Text.Length == 4 ? Context.Postleitzahlen.Find(int.Parse(plzInput.Text))?.Orte.ToList() : null;
|
var list = plzInputValid && plzInput.Text.Length == 4 ? Context.Postleitzahlen.Find(int.Parse(plzInput.Text))?.Orte.ToList() : null;
|
||||||
ControlUtils.RenewItemsSource(ortInput, list, i => (i as AT_PlzDest)?.Id);
|
ControlUtils.RenewItemsSource(ortInput, list, i => (i as AT_PlzDest)?.Id);
|
||||||
@@ -458,15 +471,15 @@ namespace Elwig.Windows {
|
|||||||
UpdateComboBox((Control)sender);
|
UpdateComboBox((Control)sender);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void IntegerInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void IntegerInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckInteger);
|
InputTextChanged((TextBox)sender, Validator.CheckInteger);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void DecimalInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void DecimalInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckDecimal);
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void PartialDateInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void PartialDateInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckPartialDate);
|
InputTextChanged((TextBox)sender, Validator.CheckPartialDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -474,7 +487,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckPartialDate);
|
InputLostFocus((TextBox)sender, Validator.CheckPartialDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void DateInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void DateInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckDate);
|
InputTextChanged((TextBox)sender, Validator.CheckDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -482,7 +495,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckDate);
|
InputLostFocus((TextBox)sender, Validator.CheckDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void TimeInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void TimeInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckTime);
|
InputTextChanged((TextBox)sender, Validator.CheckTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -490,7 +503,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckTime);
|
InputLostFocus((TextBox)sender, Validator.CheckTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void PlzInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void PlzInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
var plz = (TextBox)sender;
|
var plz = (TextBox)sender;
|
||||||
InputTextChanged(plz, Validator.CheckPlz);
|
InputTextChanged(plz, Validator.CheckPlz);
|
||||||
if ("PLZ".Equals(plz.Tag))
|
if ("PLZ".Equals(plz.Tag))
|
||||||
@@ -504,7 +517,7 @@ namespace Elwig.Windows {
|
|||||||
UpdatePlz(plz, GetPlzOrtInput(plz));
|
UpdatePlz(plz, GetPlzOrtInput(plz));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void EmailAddressInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void EmailAddressInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckEmailAddress);
|
InputTextChanged((TextBox)sender, Validator.CheckEmailAddress);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -512,7 +525,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckEmailAddress);
|
InputLostFocus((TextBox)sender, Validator.CheckEmailAddress);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void PhoneNrInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void PhoneNrInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckPhoneNumber);
|
InputTextChanged((TextBox)sender, Validator.CheckPhoneNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -520,7 +533,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckPhoneNumber);
|
InputLostFocus((TextBox)sender, Validator.CheckPhoneNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void IbanInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void IbanInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckIban);
|
InputTextChanged((TextBox)sender, Validator.CheckIban);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -528,7 +541,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckIban);
|
InputLostFocus((TextBox)sender, Validator.CheckIban);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void BicInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void BicInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckBic);
|
InputTextChanged((TextBox)sender, Validator.CheckBic);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -536,7 +549,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckBic);
|
InputLostFocus((TextBox)sender, Validator.CheckBic);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void UstIdNrInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void UstIdNrInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckUstIdNr);
|
InputTextChanged((TextBox)sender, Validator.CheckUstIdNr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -544,12 +557,20 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckUstIdNr);
|
InputLostFocus((TextBox)sender, Validator.CheckUstIdNr);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void LfbisNrInput_TextChanged(object sender, RoutedEventArgs evt) {
|
protected void LfbisNrInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
InputTextChanged((TextBox)sender, Validator.CheckLfbisNr);
|
InputTextChanged((TextBox)sender, Validator.CheckLfbisNr);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void LfbisNrInput_LostFocus(object sender, RoutedEventArgs evt) {
|
protected void LfbisNrInput_LostFocus(object sender, RoutedEventArgs evt) {
|
||||||
InputLostFocus((TextBox)sender, Validator.CheckLfbisNr);
|
InputLostFocus((TextBox)sender, Validator.CheckLfbisNr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void UpperCaseInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckUpperCase);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void UpperCaseInput_LostFocus(object sender, RoutedEventArgs evt) {
|
||||||
|
InputLostFocus((TextBox)sender, Validator.CheckUpperCase);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,9 +4,10 @@
|
|||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
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"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
|
xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
|
||||||
Title="Flächenbindungen - Elwig" Height="480" Width="1100"
|
Title="Flächenbindungen - Elwig" Height="500" Width="920" MinWidth="860"
|
||||||
Loaded="Window_Loaded">
|
Loaded="Window_Loaded">
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
<Style TargetType="Label">
|
<Style TargetType="Label">
|
||||||
@@ -46,124 +47,168 @@
|
|||||||
</Window.Resources>
|
</Window.Resources>
|
||||||
<Grid>
|
<Grid>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="19"/>
|
|
||||||
<RowDefinition Height="*"/>
|
|
||||||
<RowDefinition Height="*"/>
|
<RowDefinition Height="*"/>
|
||||||
|
<RowDefinition Height="24"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="*"/>
|
<ColumnDefinition Width="2*" MinWidth="555"/>
|
||||||
<ColumnDefinition Width="340"/>
|
<ColumnDefinition Width="5"/>
|
||||||
|
<ColumnDefinition Width="*" MinWidth="280"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<Menu Grid.ColumnSpan="2" BorderThickness="0,0,0,1" BorderBrush="LightGray" Background="White">
|
<Grid Grid.Row="0" Grid.Column="0">
|
||||||
<MenuItem Header="Flächenbindugen"/>
|
<Grid.RowDefinitions>
|
||||||
</Menu>
|
<RowDefinition Height="37"/>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
<Grid Grid.RowSpan="2" Grid.Row="1" Grid.Column="0">
|
<RowDefinition Height="42"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<TextBox x:Name="SearchInput" Grid.ColumnSpan="3" Margin="5,7,145,0" IsReadOnly="False"
|
||||||
|
TextChanged="SearchInput_TextChanged"/>
|
||||||
|
<CheckBox x:Name="ActiveAreaCommitmentInput" Content="Nur aktive anzeigen"
|
||||||
|
Checked="ActiveAreaCommitmentInput_Changed" Unchecked="ActiveAreaCommitmentInput_Changed"
|
||||||
|
HorizontalAlignment="Right" Margin="0,12,10,0" VerticalAlignment="Top" Grid.Column="1" Grid.ColumnSpan="2"/>
|
||||||
|
|
||||||
<DataGrid x:Name="AreaCommitmentList" AutoGenerateColumns="False" HeadersVisibility="Column" IsReadOnly="True" GridLinesVisibility="None" SelectionMode="Single"
|
<DataGrid x:Name="AreaCommitmentList" AutoGenerateColumns="False" HeadersVisibility="Column" IsReadOnly="True" GridLinesVisibility="None" SelectionMode="Single"
|
||||||
CanUserDeleteRows="False" CanUserResizeRows="False" CanUserAddRows="False" SelectionChanged="AreaCommitmentList_SelectionChanged" Grid.Column="0" Grid.Row="1"
|
CanUserDeleteRows="False" CanUserResizeRows="False" CanUserAddRows="False" SelectionChanged="AreaCommitmentList_SelectionChanged" Grid.Column="0" Grid.Row="1"
|
||||||
Margin="5,10,5,42" FontSize="14" Grid.ColumnSpan="3" Background="#e2e2e2">
|
Margin="5,0,5,0" FontSize="14" Grid.ColumnSpan="3" Background="#e2e2e2">
|
||||||
<DataGrid.Columns>
|
<DataGrid.Columns>
|
||||||
<DataGridTextColumn Header="FbNr." Binding="{Binding FbNr}" Width="2*"/>
|
<DataGridTextColumn Header="FbNr." Binding="{Binding FbNr}" Width="50"/>
|
||||||
<DataGridTextColumn Header="Katastralgemeinde" Binding="{Binding Kg.AtKg.Name}" Width="6*"/>
|
<DataGridTextColumn Header="Katastralgemeinde" Binding="{Binding Kg.AtKg.Name}" Width="150"/>
|
||||||
<DataGridTextColumn Header="Ried" Binding="{Binding Rd.Name}" Width="4*"/>
|
<DataGridTextColumn Header="Ried" Binding="{Binding Rd.Name}" Width="130"/>
|
||||||
<DataGridTextColumn Header="Parzelle" Binding="{Binding GstNr}" Width="4*"/>
|
<DataGridTextColumn Header="Parzelle" Binding="{Binding GstNr}" Width="120"/>
|
||||||
<DataGridTextColumn Header="Fläche" Binding="{Binding Area, StringFormat='{}{0:N0} m²'}" Width="3*">
|
<DataGridTextColumn Header="Fläche" Binding="{Binding Area, StringFormat='{}{0:N0} m²'}" Width="80">
|
||||||
<DataGridTextColumn.CellStyle>
|
<DataGridTextColumn.CellStyle>
|
||||||
<Style>
|
<Style>
|
||||||
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
<Setter Property="TextBlock.TextAlignment" Value="Right"/>
|
||||||
</Style>
|
</Style>
|
||||||
</DataGridTextColumn.CellStyle>
|
</DataGridTextColumn.CellStyle>
|
||||||
</DataGridTextColumn>
|
</DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="Sorte" Binding="{Binding AreaComType.WineVar.Name}" Width="4*"/>
|
<DataGridTextColumn Header="Sorte" Binding="{Binding AreaComType.WineVar.SortId}" Width="70"/>
|
||||||
<DataGridTextColumn Header="Attribut" Binding="{Binding AreaComType.WineAttr1.Name}" Width="3*"/>
|
<DataGridTextColumn Header="Attribut" Binding="{Binding AreaComType.WineAttr.Name}" Width="120"/>
|
||||||
</DataGrid.Columns>
|
</DataGrid.Columns>
|
||||||
</DataGrid>
|
</DataGrid>
|
||||||
|
|
||||||
<Button x:Name="NewAreaCommitmentButton" Content="Neu" Click="NewAreaCommitmentButton_Click"
|
<Button x:Name="NewAreaCommitmentButton" Content="Neu" Click="NewAreaCommitmentButton_Click"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="5,5,2.5,10" Grid.Column="0"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="5,5,2.5,10" Grid.Column="0" Grid.Row="2"/>
|
||||||
<Button x:Name="EditAreaCommitmentButton" Content="Bearbeiten" Click="EditAreaCommitmentButton_Click" IsEnabled="False"
|
<Button x:Name="EditAreaCommitmentButton" Content="Bearbeiten" Click="EditAreaCommitmentButton_Click" IsEnabled="False"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,2.5,10" Grid.Column="1"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,2.5,10" Grid.Column="1" Grid.Row="2"/>
|
||||||
<Button x:Name="DeleteAreaCommitmentButton" Content="Löschen" Click="DeleteAreaCommitmentButton_Click" IsEnabled="False"
|
<Button x:Name="DeleteAreaCommitmentButton" Content="Löschen" Click="DeleteAreaCommitmentButton_Click" IsEnabled="False"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,5,10" Grid.Column="2"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,5,10" Grid.Column="2" Grid.Row="2"/>
|
||||||
|
|
||||||
<Button x:Name="AreaCommitmentSaveButton" Content="Speichern" Click="AreaCommitmentSaveButton_Click" IsEnabled="False" Visibility="Hidden"
|
<Button x:Name="AreaCommitmentSaveButton" Content="Speichern" Click="AreaCommitmentSaveButton_Click" IsEnabled="False" Visibility="Hidden"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="5,5,2.5,10" Grid.Column="0"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="5,5,2.5,10" Grid.Column="0" Grid.Row="2"/>
|
||||||
<Button x:Name="AreaCommitmentResetButton" Content="Zurücksetzen" Click="AreaCommitmentResetButton_Click" IsEnabled="False" Visibility="Hidden"
|
<Button x:Name="AreaCommitmentResetButton" Content="Zurücksetzen" Click="AreaCommitmentResetButton_Click" IsEnabled="False" Visibility="Hidden"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,2.5,10" Grid.Column="1"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,2.5,10" Grid.Column="1" Grid.Row="2"/>
|
||||||
<Button x:Name="AreaCommitmentCancelButton" Content="Abbrechen" Click="AreaCommitmentCancelButton_Click" IsEnabled="False" Visibility="Hidden" IsCancel="True"
|
<Button x:Name="AreaCommitmentCancelButton" Content="Abbrechen" Click="AreaCommitmentCancelButton_Click" IsEnabled="False" Visibility="Hidden" IsCancel="True"
|
||||||
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,5,10" Grid.Column="2"/>
|
HorizontalAlignment="Stretch" VerticalAlignment="Bottom" Margin="2.5,5,5,10" Grid.Column="2" Grid.Row="2"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<GroupBox Header="Vertrag" Grid.Column="2" Grid.Row="1" Grid.RowSpan="1" Margin="5,5,5,5">
|
<GridSplitter Grid.Column="1" Grid.Row="0" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
|
||||||
<Grid>
|
|
||||||
<Grid.ColumnDefinitions>
|
|
||||||
<ColumnDefinition Width="80"/>
|
|
||||||
<ColumnDefinition Width="*"/>
|
|
||||||
<ColumnDefinition Width="50"/>
|
|
||||||
<ColumnDefinition Width="*"/>
|
|
||||||
</Grid.ColumnDefinitions>
|
|
||||||
|
|
||||||
<Label Content="FbNr.:" Margin="10,10,0,0" Grid.Column="0"/>
|
<Grid Grid.Column="2" Grid.Row="0">
|
||||||
<TextBox x:Name="FbNrInput" Margin="0,10,0,0" Width="48" Grid.Column="1" TextAlignment="Right" HorizontalAlignment="Left"
|
<Grid.RowDefinitions>
|
||||||
TextChanged="FbNrInput_TextChanged" LostFocus="FbNrInput_LostFocus"/>
|
<RowDefinition Height="*"/>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<Label Content="MgNr.:" Margin="10,40,0,0" Grid.Column="0"/>
|
<GroupBox Header="Vertrag" Grid.Column="2" Grid.Row="0" Grid.RowSpan="1" Margin="5,5,5,5">
|
||||||
<TextBox x:Name="MgNrInput" IsEnabled="False"
|
<Grid>
|
||||||
Margin="0,40,0,0" Width="48" Grid.Column="1" TextAlignment="Right" HorizontalAlignment="Left"/>
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
<ColumnDefinition Width="50"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<Label Content="Von:" Margin="10,10,0,0" Grid.Column="2"/>
|
<Label Content="FbNr.:" Margin="10,10,0,0" Grid.Column="0"/>
|
||||||
<TextBox x:Name="YearFromInput" Margin="0,10,0,0" Width="41" Grid.Column="3" TextAlignment="Right" HorizontalAlignment="Left"
|
<TextBox x:Name="FbNrInput" Margin="0,10,10,0" Grid.Column="1" TextAlignment="Right"
|
||||||
TextChanged="IntegerInput_TextChanged"/>
|
TextChanged="FbNrInput_TextChanged" LostFocus="FbNrInput_LostFocus"/>
|
||||||
|
|
||||||
<Label Content="Bis:" Margin="10,40,0,0" Grid.Column="2"/>
|
<Label Content="MgNr.:" Margin="10,40,0,0" Grid.Column="0"/>
|
||||||
<TextBox x:Name="YearToInput" Margin="0,40,0,0" Width="41" Grid.Column="3" TextAlignment="Right" HorizontalAlignment="Left"
|
<TextBox x:Name="MgNrInput" IsEnabled="False"
|
||||||
TextChanged="IntegerInput_TextChanged"/>
|
Margin="0,40,10,0" Grid.Column="1" TextAlignment="Right"/>
|
||||||
|
|
||||||
<Label Content="Vertragsart:" Margin="10,70,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
<Label Content="Von:" Margin="10,10,0,0" Grid.Column="2"/>
|
||||||
<ComboBox x:Name="AreaComTypeInput" DisplayMemberPath="DisplayName" TextSearch.TextPath="DisplayName"
|
<TextBox x:Name="YearFromInput" Margin="0,10,10,0" Grid.Column="3" TextAlignment="Right"
|
||||||
HorizontalAlignment="Stretch" Margin="0,70,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
TextChanged="IntegerInput_TextChanged"/>
|
||||||
|
|
||||||
<Label Content="Bewirt.-Art:" Margin="10,100,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
<Label Content="Bis:" Margin="10,40,0,0" Grid.Column="2"/>
|
||||||
<ComboBox x:Name="WineCultivationInput" DisplayMemberPath="Name" TextSearch.TextPath="Name"
|
<TextBox x:Name="YearToInput" Margin="0,40,10,0" Grid.Column="3" TextAlignment="Right"
|
||||||
HorizontalAlignment="Stretch" Margin="0,100,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
TextChanged="IntegerInput_TextChanged"/>
|
||||||
|
|
||||||
<Label Content="Anmerkung:" Margin="10,130,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
<Label Content="Vertragsart:" Margin="10,70,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
||||||
<TextBox x:Name="CommentInput" TextChanged="TextBox_TextChanged"
|
<ComboBox x:Name="AreaComTypeInput" DisplayMemberPath="DisplayName" TextSearch.TextPath="DisplayName"
|
||||||
HorizontalAlignment="Stretch" Margin="0,130,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
HorizontalAlignment="Stretch" Margin="0,70,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
||||||
</Grid>
|
|
||||||
</GroupBox>
|
|
||||||
|
|
||||||
<GroupBox Header="Lage" Grid.Column="2" Grid.Row="2" Grid.RowSpan="1" Margin="5,5,5,10">
|
<Label Content="Bewirt.-Art:" Margin="10,100,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
||||||
<Grid>
|
<ComboBox x:Name="WineCultivationInput" DisplayMemberPath="Name" TextSearch.TextPath="Name"
|
||||||
<Grid.ColumnDefinitions>
|
HorizontalAlignment="Stretch" Margin="0,100,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
||||||
<ColumnDefinition Width="80"/>
|
|
||||||
<ColumnDefinition Width="*"/>
|
|
||||||
</Grid.ColumnDefinitions>
|
|
||||||
|
|
||||||
<Label Content="KG:" Margin="10,10,0,0" Grid.Column="0"/>
|
<Label Content="Anmerkung:" Margin="10,130,0,0" Grid.Column="0" Grid.ColumnSpan="2"/>
|
||||||
<ComboBox x:Name="KgInput" ItemTemplate="{StaticResource KgNrTemplate}" TextSearch.TextPath="Name"
|
<TextBox x:Name="CommentInput" TextChanged="TextBox_TextChanged"
|
||||||
HorizontalAlignment="Stretch" Margin="0,10,10,0" Grid.Column="1"
|
HorizontalAlignment="Stretch" Margin="0,130,10,0" Grid.Column="1" Grid.ColumnSpan="3"/>
|
||||||
SelectionChanged="KgInput_SelectionChanged"/>
|
</Grid>
|
||||||
|
</GroupBox>
|
||||||
|
|
||||||
<Label Content="Ried:" Margin="10,40,0,0" Grid.Column="0"/>
|
<GroupBox Header="Lage" Grid.Column="2" Grid.Row="1" Grid.RowSpan="1" Margin="5,5,5,10">
|
||||||
<ComboBox x:Name="RdInput" DisplayMemberPath="Name" TextSearch.TextPath="Name"
|
<Grid>
|
||||||
HorizontalAlignment="Stretch" Margin="0,40,10,0" Grid.Column="1"/>
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<Label Content="Parzelle(n):" Margin="10,70,0,0" Grid.Column="0"/>
|
<Label Content="KG:" Margin="10,10,0,0" Grid.Column="0"/>
|
||||||
<TextBox x:Name="GstNrInput" Margin="0,70,10,0" Grid.Column="1" HorizontalAlignment="Stretch"
|
<ComboBox x:Name="KgInput" ItemTemplate="{StaticResource KgNrTemplate}" TextSearch.TextPath="Name"
|
||||||
TextChanged="GstNrInput_TextChanged" LostFocus="GstNrInput_LostFocus"/>
|
HorizontalAlignment="Stretch" Margin="0,10,10,0" Grid.Column="1"
|
||||||
|
SelectionChanged="KgInput_SelectionChanged"/>
|
||||||
|
|
||||||
<Label Content="Fläche:" Margin="10,100,0,0" Grid.Column="0"/>
|
<Label Content="Ried:" Margin="10,40,0,0" Grid.Column="0"/>
|
||||||
<TextBox x:Name="AreaInput" Margin="0,100,0,0" Width="100" Grid.Column="1" TextAlignment="Right" HorizontalAlignment="Left"
|
<ComboBox x:Name="RdInput" DisplayMemberPath="Name" TextSearch.TextPath="Name"
|
||||||
TextChanged="IntegerInput_TextChanged"/>
|
HorizontalAlignment="Stretch" Margin="0,40,10,0" Grid.Column="1"/>
|
||||||
</Grid>
|
|
||||||
</GroupBox>
|
|
||||||
|
<Label Content="Parzelle(n):" Margin="10,70,0,0" Grid.Column="0"/>
|
||||||
|
<TextBox x:Name="GstNrInput" Margin="0,70,10,0" Grid.Column="1" HorizontalAlignment="Stretch"
|
||||||
|
TextChanged="GstNrInput_TextChanged" LostFocus="GstNrInput_LostFocus"/>
|
||||||
|
|
||||||
|
<Label Content="Fläche:" Margin="10,100,0,0" Grid.Column="0"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="AreaInput" Unit="m²" TextChanged="IntegerInput_TextChanged"
|
||||||
|
Grid.Column="1" Width="70" Margin="0,100,10,10" VerticalAlignment="Top" HorizontalAlignment="Left"/>
|
||||||
|
</Grid>
|
||||||
|
</GroupBox>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<StatusBar Grid.Row="5" Grid.ColumnSpan="3" BorderThickness="0,1,0,0" BorderBrush="Gray">
|
||||||
|
<StatusBar.ItemsPanel>
|
||||||
|
<ItemsPanelTemplate>
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="160"/>
|
||||||
|
<ColumnDefinition Width="Auto"/>
|
||||||
|
<ColumnDefinition Width="150"/>
|
||||||
|
<ColumnDefinition Width="Auto"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
</Grid>
|
||||||
|
</ItemsPanelTemplate>
|
||||||
|
</StatusBar.ItemsPanel>
|
||||||
|
<StatusBarItem>
|
||||||
|
<TextBlock Name="StatusAreaCommitments" Text="Flächenbindungen: -"/>
|
||||||
|
</StatusBarItem>
|
||||||
|
<Separator Grid.Column="1"/>
|
||||||
|
<StatusBarItem Grid.Column="2">
|
||||||
|
<TextBlock Name="StatusArea" Text="Fläche: -"/>
|
||||||
|
</StatusBarItem>
|
||||||
|
<Separator Grid.Column="3"/>
|
||||||
|
<StatusBarItem Grid.Column="4">
|
||||||
|
<TextBlock Name="StatusContracts" Text="Vertragsarten: -"/>
|
||||||
|
</StatusBarItem>
|
||||||
|
</StatusBar>
|
||||||
</Grid>
|
</Grid>
|
||||||
</local:AdministrationWindow>
|
</local:AdministrationWindow>
|
||||||
|
|||||||
@@ -9,10 +9,12 @@ using System.Threading.Tasks;
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Microsoft.EntityFrameworkCore.ChangeTracking;
|
using Microsoft.EntityFrameworkCore.ChangeTracking;
|
||||||
using Xceed.Wpf.Toolkit.Primitives;
|
using Xceed.Wpf.Toolkit.Primitives;
|
||||||
|
using System.Runtime.Intrinsics.Arm;
|
||||||
|
|
||||||
namespace Elwig.Windows {
|
namespace Elwig.Windows {
|
||||||
public partial class AreaComAdminWindow : AdministrationWindow {
|
public partial class AreaComAdminWindow : AdministrationWindow {
|
||||||
private readonly Member Member;
|
private readonly Member Member;
|
||||||
|
private List<string> TextFilter = new();
|
||||||
|
|
||||||
public AreaComAdminWindow(int mgnr) {
|
public AreaComAdminWindow(int mgnr) {
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
@@ -21,15 +23,16 @@ namespace Elwig.Windows {
|
|||||||
ExemptInputs = new Control[] {
|
ExemptInputs = new Control[] {
|
||||||
MgNrInput, AreaCommitmentList, NewAreaCommitmentButton,
|
MgNrInput, AreaCommitmentList, NewAreaCommitmentButton,
|
||||||
EditAreaCommitmentButton, DeleteAreaCommitmentButton, AreaCommitmentSaveButton,
|
EditAreaCommitmentButton, DeleteAreaCommitmentButton, AreaCommitmentSaveButton,
|
||||||
AreaCommitmentResetButton, AreaCommitmentCancelButton
|
AreaCommitmentResetButton, AreaCommitmentCancelButton, SearchInput, ActiveAreaCommitmentInput
|
||||||
};
|
};
|
||||||
RequiredInputs = new Control[] {
|
RequiredInputs = new Control[] {
|
||||||
FbNrInput, YearFromInput, KgInput, RdInput,
|
FbNrInput, YearFromInput, KgInput, RdInput,
|
||||||
GstNrInput, AreaInput, AreaComTypeInput, WineCultivationInput
|
GstNrInput, AreaInput.TextBox, AreaComTypeInput, WineCultivationInput
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Window_Loaded(object sender, RoutedEventArgs e) {
|
private void Window_Loaded(object sender, RoutedEventArgs e) {
|
||||||
|
ActiveAreaCommitmentInput.IsChecked = true;
|
||||||
LockInputs();
|
LockInputs();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -38,11 +41,84 @@ namespace Elwig.Windows {
|
|||||||
await RefreshAreaCommitmentListQuery();
|
await RefreshAreaCommitmentListQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task RefreshAreaCommitmentListQuery() {
|
private async Task RefreshAreaCommitmentListQuery(bool updateSort = false) {
|
||||||
List<AreaCom> areaComs = await Context.AreaCommitments.Where(a => a.MgNr == Member.MgNr).OrderBy(a => a.FbNr).ToListAsync();
|
var (_, areaComQuery, filter) = await GetFilters();
|
||||||
|
var areaComs = await areaComQuery.ToListAsync();
|
||||||
|
|
||||||
|
if (filter.Count > 0 && areaComs.Count > 0) {
|
||||||
|
var dict = areaComs.AsParallel()
|
||||||
|
.ToDictionary(d => d, d => d.SearchScore(TextFilter))
|
||||||
|
.OrderByDescending(c => c.Value);
|
||||||
|
var threshold = dict.Select(a => a.Value).Max() * 3 / 4;
|
||||||
|
areaComs = dict
|
||||||
|
.Where(a => a.Value > threshold)
|
||||||
|
.Select(a => a.Key)
|
||||||
|
.ToList();
|
||||||
|
}
|
||||||
|
|
||||||
ControlUtils.RenewItemsSource(AreaCommitmentList, areaComs, i => (i as AreaCom)?.FbNr,
|
ControlUtils.RenewItemsSource(AreaCommitmentList, areaComs, i => (i as AreaCom)?.FbNr,
|
||||||
AreaCommitmentList_SelectionChanged, ControlUtils.RenewSourceDefault.None);
|
AreaCommitmentList_SelectionChanged, filter.Count > 0 ? ControlUtils.RenewSourceDefault.IfOnly : ControlUtils.RenewSourceDefault.None, !updateSort);
|
||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
|
|
||||||
|
if(filter.Count == 0) {
|
||||||
|
StatusAreaCommitments.Text = $"Flächenbindungen: {await areaComQuery.CountAsync()}";
|
||||||
|
StatusArea.Text = $"Fläche: {await areaComQuery.Select(a => a.Area).SumAsync():N0} m²";
|
||||||
|
} else {
|
||||||
|
StatusAreaCommitments.Text = $"Flächenbindungen: {areaComs.Count}";
|
||||||
|
StatusArea.Text = $"Fläche: {areaComs.Select(a => a.Area).Sum():N0} m²";
|
||||||
|
}
|
||||||
|
var groups = areaComs.GroupBy(a => a.AreaComType.DisplayName).Select(a => (a.Key, a.Sum(b => b.Area))).OrderByDescending(a => a.Item2).ToList();
|
||||||
|
StatusContracts.Text = $"Vertragsarten: {groups.Count} (" + string.Join(", ", groups.Select(g => $"{g.Key}: {g.Item2:N0} m²")) + ")";
|
||||||
|
StatusContracts.ToolTip = $"Vertragsarten: {groups.Count}\n" + string.Join($"\n", groups.Select(g => $"{g.Key}: {g.Item2:N0} m²"));
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task<(List<string>, IQueryable<AreaCom>, List<string>)> GetFilters() {
|
||||||
|
List<string> filterNames = new();
|
||||||
|
IQueryable<AreaCom> areaComQuery = Context.AreaCommitments.Where(a => a.MgNr == Member.MgNr).OrderBy(a => a.FbNr);
|
||||||
|
if (ActiveAreaCommitmentInput.IsChecked == true) {
|
||||||
|
areaComQuery = areaComQuery.Where(a => a.YearTo == null);
|
||||||
|
filterNames.Add("ohne Enddatum");
|
||||||
|
}
|
||||||
|
|
||||||
|
var filterVar = new List<string>();
|
||||||
|
var filterNotVar = new List<string>();
|
||||||
|
var filterAttr = new List<string>();
|
||||||
|
var filterNotAttr = new List<string>();
|
||||||
|
|
||||||
|
var filter = TextFilter.ToList();
|
||||||
|
if (filter.Count > 0) {
|
||||||
|
var var = await Context.WineVarieties.ToDictionaryAsync(v => v.SortId, v => v);
|
||||||
|
var attr = await Context.WineAttributes.ToDictionaryAsync(a => a.Name.ToLower().Split(" ")[0], a => a);
|
||||||
|
|
||||||
|
for (int i = 0; i < filter.Count; i++) {
|
||||||
|
var e = filter[i];
|
||||||
|
if (e.Length == 2 && var.ContainsKey(e.ToUpper())) {
|
||||||
|
filterVar.Add(e.ToUpper());
|
||||||
|
filter.RemoveAt(i--);
|
||||||
|
filterNames.Add(var[e.ToUpper()].Name);
|
||||||
|
} else if (e.Length == 3 && e[0] == '!' && var.ContainsKey(e[1..].ToUpper())) {
|
||||||
|
filterNotVar.Add(e[1..].ToUpper());
|
||||||
|
filter.RemoveAt(i--);
|
||||||
|
} else if (attr.ContainsKey(e.ToLower())) {
|
||||||
|
var a = attr[e.ToLower()];
|
||||||
|
filterAttr.Add(a.AttrId);
|
||||||
|
filter.RemoveAt(i--);
|
||||||
|
filterNames.Add($"Attribut {a.Name}");
|
||||||
|
} else if (e[0] == '!' && attr.ContainsKey(e[1..].ToLower())) {
|
||||||
|
var a = attr[e[1..].ToLower()];
|
||||||
|
filterNotAttr.Add(a.AttrId);
|
||||||
|
filter.RemoveAt(i--);
|
||||||
|
filterNames.Add($"ohne Attribut {a.Name}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (filterVar.Count > 0) areaComQuery = areaComQuery.Where(a => filterVar.Contains(a.AreaComType.WineVar.SortId));
|
||||||
|
if (filterNotVar.Count > 0) areaComQuery = areaComQuery.Where(a => !filterNotVar.Contains(a.AreaComType.WineVar.SortId));
|
||||||
|
if (filterAttr.Count > 0) areaComQuery = areaComQuery.Where(a => a.AreaComType.WineAttr != null && a.AreaComType.WineAttr.AttrId != null && filterAttr.Contains(a.AreaComType.WineAttr.AttrId));
|
||||||
|
if (filterNotAttr.Count > 0) areaComQuery = areaComQuery.Where(a => a.AreaComType.WineAttr == null || a.AreaComType.WineAttr.AttrId == null || !filterAttr.Contains(a.AreaComType.WineAttr.AttrId));
|
||||||
|
}
|
||||||
|
|
||||||
|
return (filterNames, areaComQuery, filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RefreshInputs(bool validate = false) {
|
private void RefreshInputs(bool validate = false) {
|
||||||
@@ -111,6 +187,7 @@ namespace Elwig.Windows {
|
|||||||
ShowAreaCommitmentSaveResetCancelButtons();
|
ShowAreaCommitmentSaveResetCancelButtons();
|
||||||
UnlockInputs();
|
UnlockInputs();
|
||||||
InitInputs();
|
InitInputs();
|
||||||
|
LockSearchInputs();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void EditAreaCommitmentButton_Click(object sender, RoutedEventArgs evt) {
|
private void EditAreaCommitmentButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
@@ -123,6 +200,7 @@ namespace Elwig.Windows {
|
|||||||
HideAreaCommitmentNewEditDeleteButtons();
|
HideAreaCommitmentNewEditDeleteButtons();
|
||||||
ShowAreaCommitmentSaveResetCancelButtons();
|
ShowAreaCommitmentSaveResetCancelButtons();
|
||||||
UnlockInputs();
|
UnlockInputs();
|
||||||
|
LockSearchInputs();
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void DeleteAreaCommitmentButton_Click(object sender, RoutedEventArgs evt) {
|
private async void DeleteAreaCommitmentButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
@@ -194,6 +272,7 @@ namespace Elwig.Windows {
|
|||||||
HideAreaCommitmentSaveResetCancelButtons();
|
HideAreaCommitmentSaveResetCancelButtons();
|
||||||
ShowAreaCommitmentNewEditDeleteButtons();
|
ShowAreaCommitmentNewEditDeleteButtons();
|
||||||
LockInputs();
|
LockInputs();
|
||||||
|
UnlockSearchInputs();
|
||||||
await RefreshAreaCommitmentList();
|
await RefreshAreaCommitmentList();
|
||||||
AreaCommitmentList.SelectedItem = a;
|
AreaCommitmentList.SelectedItem = a;
|
||||||
}
|
}
|
||||||
@@ -216,6 +295,7 @@ namespace Elwig.Windows {
|
|||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
ClearInputStates();
|
ClearInputStates();
|
||||||
LockInputs();
|
LockInputs();
|
||||||
|
UnlockSearchInputs();
|
||||||
}
|
}
|
||||||
|
|
||||||
override protected void UpdateButtons() {
|
override protected void UpdateButtons() {
|
||||||
@@ -269,6 +349,16 @@ namespace Elwig.Windows {
|
|||||||
DeleteAreaCommitmentButton.Visibility = Visibility.Hidden;
|
DeleteAreaCommitmentButton.Visibility = Visibility.Hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void LockSearchInputs() {
|
||||||
|
SearchInput.IsEnabled = false;
|
||||||
|
ActiveAreaCommitmentInput.IsEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void UnlockSearchInputs() {
|
||||||
|
SearchInput.IsEnabled = true;
|
||||||
|
ActiveAreaCommitmentInput.IsEnabled = true;
|
||||||
|
}
|
||||||
|
|
||||||
private void AreaCommitmentList_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
private void AreaCommitmentList_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
||||||
RefreshInputs();
|
RefreshInputs();
|
||||||
}
|
}
|
||||||
@@ -277,6 +367,15 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async void ActiveAreaCommitmentInput_Changed(object sender, RoutedEventArgs evt) {
|
||||||
|
await RefreshAreaCommitmentListQuery();
|
||||||
|
}
|
||||||
|
|
||||||
|
private async void SearchInput_TextChanged(object sender, RoutedEventArgs evt) {
|
||||||
|
TextFilter = SearchInput.Text.ToLower().Split(" ").ToList().FindAll(e => e.Length > 0);
|
||||||
|
await RefreshAreaCommitmentListQuery(true);
|
||||||
|
}
|
||||||
|
|
||||||
private async void KgInput_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
private async void KgInput_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
||||||
if (KgInput.SelectedItem is AT_Kg curr_kg) {
|
if (KgInput.SelectedItem is AT_Kg curr_kg) {
|
||||||
var rdList = await Context.WbRde.Where(r => r.KgNr == curr_kg.KgNr).OrderBy(r => r.Name).Cast<object>().ToListAsync();
|
var rdList = await Context.WbRde.Where(r => r.KgNr == curr_kg.KgNr).OrderBy(r => r.Name).Cast<object>().ToListAsync();
|
||||||
|
|||||||
@@ -1,11 +1,13 @@
|
|||||||
<local:AdministrationWindow x:Class="Elwig.Windows.BaseDataWindow"
|
<local:AdministrationWindow
|
||||||
|
x:Class="Elwig.Windows.BaseDataWindow"
|
||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
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"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
Title="Stammdaten - Elwig" Height="500" MinHeight="400" Width="800" MinWidth="800"
|
Title="Stammdaten - Elwig" Height="500" MinHeight="400" Width="850" MinWidth="810"
|
||||||
Loaded="Window_Loaded">
|
Loaded="Window_Loaded">
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
<Style TargetType="Label">
|
<Style TargetType="Label">
|
||||||
@@ -133,21 +135,258 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
<TabItem Header="Zweigstellen">
|
<TabItem Header="Zweigstellen">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="260"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<ListBox x:Name="BranchList" Margin="10,10,35,10"
|
||||||
|
SelectionChanged="BranchList_SelectionChanged" Grid.Column="0">
|
||||||
|
<ListBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<StackPanel Orientation="Horizontal">
|
||||||
|
<TextBlock Text="{Binding ZwstId}" Width="20"/>
|
||||||
|
<TextBlock Text="{Binding Name}"/>
|
||||||
|
</StackPanel>
|
||||||
|
</DataTemplate>
|
||||||
|
</ListBox.ItemTemplate>
|
||||||
|
</ListBox>
|
||||||
|
<Button x:Name="BranchAddButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="BranchAddButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,0,5,30" Grid.Column="0"/>
|
||||||
|
<Button x:Name="BranchDeleteButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="BranchDeleteButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,30,5,0" Grid.Column="0"/>
|
||||||
|
|
||||||
|
<Grid Grid.Column="1" Margin="0,10,0,10">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="110"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Label Content="Identifikator:" Margin="10,10,0,10"/>
|
||||||
|
<TextBox x:Name="BranchIdInput" Grid.Column="1" Margin="0,10,10,10" Width="50" HorizontalAlignment="Left"
|
||||||
|
TextChanged="Branch_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Name:" Margin="10,40,0,10"/>
|
||||||
|
<TextBox x:Name="BranchNameInput" Grid.Column="1" Margin="0,40,10,10" Width="150" HorizontalAlignment="Left"
|
||||||
|
TextChanged="Branch_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="PLZ/Ort:" Margin="10,70,0,10"/>
|
||||||
|
<TextBox x:Name="BranchPlzInput" Margin="0,70,0,0" Width="42" Grid.Column="1" HorizontalAlignment="Left"
|
||||||
|
TextChanged="BranchPlzInput_TextChanged" LostFocus="PlzInput_LostFocus" Tag="PLZ"/>
|
||||||
|
<ComboBox x:Name="BranchOrtInput" ItemTemplate="{StaticResource PostalDestTemplate}" TextSearch.TextPath="Ort.Name"
|
||||||
|
Margin="47,70,10,0" Grid.Column="1" Grid.ColumnSpan="3" Width="253" HorizontalAlignment="Left"
|
||||||
|
SelectionChanged="Branch_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Adresse:" Margin="10,100,0,10"/>
|
||||||
|
<TextBox x:Name="BranchAddressInput" Grid.Column="1" Margin="0,100,10,10" Width="300" HorizontalAlignment="Left"
|
||||||
|
TextChanged="Branch_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Tel.-Nr. (Festnetz):" Margin="10,130,0,10"/>
|
||||||
|
<TextBox x:Name="BranchPhoneNrInput" Grid.Column="1" Margin="0,130,10,10" Width="200" HorizontalAlignment="Left"
|
||||||
|
TextChanged="BranchPhoneNr_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Fax-Nr.:" Margin="10,160,0,10"/>
|
||||||
|
<TextBox x:Name="BranchFaxNrInput" Grid.Column="1" Margin="0,160,10,10" Width="200" HorizontalAlignment="Left"
|
||||||
|
TextChanged="BranchPhoneNr_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Tel.-Nr. (mobil):" Margin="10,190,0,10"/>
|
||||||
|
<TextBox x:Name="BranchMobileNrInput" Grid.Column="1" Margin="0,190,10,10" Width="200" HorizontalAlignment="Left"
|
||||||
|
TextChanged="BranchPhoneNr_TextChanged"/>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
<TabItem Header="Sortenattribute">
|
<TabItem Header="Sortenattribute">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="280"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<ListBox x:Name="WineAttributeList" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="10,10,35,10"
|
||||||
|
SelectionChanged="WineAttributeList_SelectionChanged">
|
||||||
|
<ListBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<StackPanel Orientation="Horizontal">
|
||||||
|
<TextBlock Text="{Binding AttrId}" Width="30"/>
|
||||||
|
<TextBlock Text="{Binding Name}" Width="80"/>
|
||||||
|
<TextBlock Text="{Binding MaxKgPerHa, StringFormat='{}{0:N0} kg'}" Width="60" TextAlignment="Right" Margin="0,0,5,0"/>
|
||||||
|
<CheckBox IsChecked="{Binding IsActive}" IsEnabled="False" Margin="10,0,10,0"/>
|
||||||
|
</StackPanel>
|
||||||
|
</DataTemplate>
|
||||||
|
</ListBox.ItemTemplate>
|
||||||
|
</ListBox>
|
||||||
|
<Button x:Name="WineAttributeAddButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="WineAttributeAddButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,0,5,30"/>
|
||||||
|
<Button x:Name="WineAttributeDeleteButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="WineAttributeDeleteButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,30,5,0"/>
|
||||||
|
|
||||||
|
<Grid Grid.Column="1" Margin="0,10,0,10">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="100"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Label Content="Identifikator:" Margin="10,10,0,10"/>
|
||||||
|
<TextBox x:Name="WineAttributeIdInput" Grid.Column="1" Margin="0,10,10,10" Width="50" HorizontalAlignment="Left"
|
||||||
|
TextChanged="WineAttributeIdInput_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Name:" Margin="10,40,0,10"/>
|
||||||
|
<TextBox x:Name="WineAttributeNameInput" Grid.Column="1" Margin="0,40,10,10" Width="150" HorizontalAlignment="Left"
|
||||||
|
TextChanged="WineAttribute_Changed"/>
|
||||||
|
|
||||||
|
<CheckBox x:Name="WineAttributeActiveInput" Content="In Übernahme-Fenster anzeigen"
|
||||||
|
Grid.Column="1" Margin="0,74,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
Checked="WineAttribute_Changed" Unchecked="WineAttribute_Changed"/>
|
||||||
|
|
||||||
|
<GroupBox Header="Auszahlung" Grid.ColumnSpan="2" Margin="10,100,10,10">
|
||||||
|
<Grid>
|
||||||
|
<Label Content="Max. Ertrag:" Margin="10,10,0,10"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="WineAttributeMaxKgPerHaInput" Unit="kg/ha" TextChanged="WineAttributeMaxKgPerHaInput_TextChanged"
|
||||||
|
Grid.Column="1" Width="80" Margin="84,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<CheckBox x:Name="WineAttributeStrictInput" Content="Strikte Trennung zu Flächenbindung ohne Attribut"
|
||||||
|
Margin="10,50,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
Checked="WineAttributeStrictInput_Changed" Unchecked="WineAttributeStrictInput_Changed"/>
|
||||||
|
|
||||||
|
<Label x:Name="WineAttributeFillLowerLabel" Content="Wenn möglich, Flächenbindung ohne Attribut..." Margin="10,75,10,10"/>
|
||||||
|
<ComboBox x:Name="WineAttributeFillLowerInput" Width="300"
|
||||||
|
Margin="10,100,10,10" HorizontalAlignment="Left"
|
||||||
|
SelectionChanged="WineAttribute_Changed">
|
||||||
|
<ComboBoxItem>...nicht auffüllen</ComboBoxItem>
|
||||||
|
<ComboBoxItem>...bis Lieferpflicht auffüllen</ComboBoxItem>
|
||||||
|
<ComboBoxItem>...bis Lieferrecht auffüllen</ComboBoxItem>
|
||||||
|
</ComboBox>
|
||||||
|
</Grid>
|
||||||
|
</GroupBox>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
<TabItem Header="Bewirtschaftungsarten">
|
<TabItem Header="Bewirtschaftungsarten">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="260"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<ListBox x:Name="WineCultivationList" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="10,10,35,10"
|
||||||
|
SelectionChanged="WineCultivationList_SelectionChanged">
|
||||||
|
<ListBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<StackPanel Orientation="Horizontal">
|
||||||
|
<TextBlock Text="{Binding CultId}" Width="30"/>
|
||||||
|
<TextBlock Text="{Binding Name}"/>
|
||||||
|
</StackPanel>
|
||||||
|
</DataTemplate>
|
||||||
|
</ListBox.ItemTemplate>
|
||||||
|
</ListBox>
|
||||||
|
<Button x:Name="WineCultivationAddButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="WineCultivationAddButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,0,5,30"/>
|
||||||
|
<Button x:Name="WineCultivationDeleteButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="WineCultivationDeleteButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,30,5,0"/>
|
||||||
|
|
||||||
|
<Grid Grid.Column="1" Margin="0,10,0,10">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="100"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Label Content="Identifikator:" Margin="10,10,0,10"/>
|
||||||
|
<TextBox x:Name="WineCultivationIdInput" Grid.Column="1" Margin="0,10,10,10" Width="50" HorizontalAlignment="Left"
|
||||||
|
TextChanged="WineCultivationIdInput_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Name:" Margin="10,40,0,10"/>
|
||||||
|
<TextBox x:Name="WineCultivationNameInput" Grid.Column="1" Margin="0,40,10,10" Width="150" HorizontalAlignment="Left"
|
||||||
|
TextChanged="WineCultivation_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Beschreibung:" Margin="10,70,0,10"/>
|
||||||
|
<TextBox x:Name="WineCultivationDescriptionInput" Grid.Column="1" Margin="0,70,10,10"
|
||||||
|
TextChanged="WineCultivation_Changed"/>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
<TabItem Header="Flächenbindungsverträge">
|
|
||||||
|
|
||||||
|
<TabItem Header="Flächenbindungsverträge">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="260"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<ListBox x:Name="AreaCommitmentTypeList" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="10,10,35,10"
|
||||||
|
SelectionChanged="AreaCommitmentTypeList_SelectionChanged">
|
||||||
|
<ListBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<StackPanel Orientation="Horizontal">
|
||||||
|
<TextBlock Text="{Binding SortId}" Width="30"/>
|
||||||
|
<TextBlock Text="{Binding WineAttr.Name}" Width="70"/>
|
||||||
|
<TextBlock Text="{Binding Discriminator}"/>
|
||||||
|
</StackPanel>
|
||||||
|
</DataTemplate>
|
||||||
|
</ListBox.ItemTemplate>
|
||||||
|
</ListBox>
|
||||||
|
<Button x:Name="AreaCommitmentTypeAddButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="AreaCommitmentTypeAddButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,0,5,30"/>
|
||||||
|
<Button x:Name="AreaCommitmentTypeDeleteButton" Content="" FontFamily="Segoe MDL2 Assets" FontSize="11" Padding="0,1.5,0,0" IsEnabled="False"
|
||||||
|
Click="AreaCommitmentTypeDeleteButton_Click"
|
||||||
|
VerticalAlignment="Center" HorizontalAlignment="Right" Width="25" Height="25" Margin="5,30,5,0"/>
|
||||||
|
|
||||||
|
<Grid Grid.Column="1" Margin="0,10,0,10">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="100"/>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Label Content="Identifikator:" Margin="10,10,0,10"/>
|
||||||
|
<TextBox x:Name="AreaCommitmentTypeIdInput" Grid.Column="1" Grid.ColumnSpan="2" Margin="0,10,10,10" Width="50" HorizontalAlignment="Left" IsEnabled="False"/>
|
||||||
|
|
||||||
|
<Label Content="Sorte:" Margin="10,40,0,10"/>
|
||||||
|
<ComboBox x:Name="AreaCommitmentTypeWineVariantInput" Grid.Column="1" Grid.ColumnSpan="2" Margin="0,40,10,10" Width="250" HorizontalAlignment="Left"
|
||||||
|
ItemTemplate="{StaticResource WineVarietyTemplate}" TextSearch.TextPath="Name"
|
||||||
|
SelectionChanged="AreaCommitmentType_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Attribut:" Margin="10,70,0,10"/>
|
||||||
|
<ComboBox x:Name="AreaCommitmentTypeWineAttributeInput" Grid.Column="1" Grid.ColumnSpan="2" Margin="0,70,10,10" Width="250" HorizontalAlignment="Left"
|
||||||
|
SelectionChanged="AreaCommitmentType_Changed"/>
|
||||||
|
|
||||||
|
<Label Content="Lieferpflicht:" Margin="10,100,0,10" Grid.ColumnSpan="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="AreaCommitmentTypeMinKgPerHaInput" Unit="kg/ha" Grid.Column="2" Margin="0,100,10,10" Width="80" HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
TextChanged="AreaCommitmentTypeMinKgPerHa_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (pro unterl. kg):" Margin="10,130,0,10" Grid.ColumnSpan="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="AreaCommitmentTypePenaltyPerKgInput" Unit="€/kg" Grid.Column="2" Margin="0,130,10,10" Width="80"
|
||||||
|
HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
TextChanged="AreaCommitmentTypePenaltyPerKgInput_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (bei Unterlieferung):" Margin="10,160,0,10" Grid.ColumnSpan="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="AreaCommitmentTypePenaltyInput" Unit="€" Grid.Column="2" Margin="0,160,10,10" Width="68"
|
||||||
|
HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
TextChanged="AreaCommitmentTypePenaltyInput_TextChanged"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (bei Nicht-Lieferung):" Margin="10,190,0,10" Grid.ColumnSpan="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="AreaCommitmentTypePenaltyNoneInput" Unit="€" Grid.Column="2" Margin="0,190,10,10" Width="68"
|
||||||
|
HorizontalAlignment="Left" VerticalAlignment="Top"
|
||||||
|
TextChanged="AreaCommitmentTypePenaltyInput_TextChanged"/>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
||||||
<TabItem Header="Saisons">
|
<TabItem Header="Saisons">
|
||||||
<Grid>
|
<Grid>
|
||||||
<ListBox x:Name="SeasonList" HorizontalAlignment="Left" VerticalAlignment="Stretch" Width="150" Margin="10,10,10,10"
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="180"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="180"/>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<ListBox x:Name="SeasonList" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="10,10,10,10" Grid.RowSpan="2"
|
||||||
SelectionChanged="SeasonList_SelectionChanged">
|
SelectionChanged="SeasonList_SelectionChanged">
|
||||||
<ListBox.ItemTemplate>
|
<ListBox.ItemTemplate>
|
||||||
<DataTemplate>
|
<DataTemplate>
|
||||||
@@ -160,7 +399,56 @@
|
|||||||
</ListBox.ItemTemplate>
|
</ListBox.ItemTemplate>
|
||||||
</ListBox>
|
</ListBox>
|
||||||
|
|
||||||
<GroupBox Header="Zu-/Abschläge" Margin="170,150,10,10" VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
|
<Grid Grid.Column="1" Margin="0,10,0,0">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="130"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
<ColumnDefinition Width="150"/>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Label Content="Maximaler Ertrag:" Margin="10,10,0,10"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonMaxKgPerHaInput" Unit="kg/ha" TextChanged="SeasonMinMaxKgInput_TextChanged"
|
||||||
|
Grid.Column="1" Width="80" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="MwSt. (buchführend):" Margin="10,40,0,10"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonVatNormalInput" Unit="%" TextChanged="SeasonVatInput_TextChanged"
|
||||||
|
Grid.Column="1" Width="48" Margin="0,40,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="MwSt. (pauschaliert):" Margin="10,70,0,10"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonVatFlatrateInput" Unit="%" TextChanged="SeasonVatInput_TextChanged"
|
||||||
|
Grid.Column="1" Width="48" Margin="0,70,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="Übernahme-Beginn:" Margin="10,100,0,10"/>
|
||||||
|
<TextBox x:Name="SeasonStartInput" Grid.Column="1" Margin="0,100,10,10" Width="78" IsEnabled="False"
|
||||||
|
HorizontalAlignment="Left"/>
|
||||||
|
|
||||||
|
<Label Content="Übernahme-Ende:" Margin="10,130,0,10"/>
|
||||||
|
<TextBox x:Name="SeasonEndInput" Grid.Column="1" Margin="0,130,10,10" Width="78" IsEnabled="False"
|
||||||
|
HorizontalAlignment="Left"/>
|
||||||
|
|
||||||
|
<Label Content="Lieferpflicht:" Margin="10,10,0,10" Grid.Column="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonMinKgPerBsInput" Unit="kg/GA" TextChanged="SeasonMinMaxKgInput_TextChanged"
|
||||||
|
Grid.Column="3" Width="80" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="Lieferrecht:" Margin="10,40,0,10" Grid.Column="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonMaxKgPerBsInput" Unit="kg/GA" TextChanged="SeasonMinMaxKgInput_TextChanged"
|
||||||
|
Grid.Column="3" Width="80" Margin="0,40,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (pro unterl. kg):" Margin="10,70,0,10" Grid.Column="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonPenaltyPerKgInput" Unit="€/kg" TextChanged="SeasonPenaltyPerKgInput_TextChanged"
|
||||||
|
Grid.Column="3" Width="80" Margin="0,70,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (Unterlieferung):" Margin="10,100,0,10" Grid.Column="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonPenaltyInput" Unit="€" TextChanged="SeasonPenaltyInput_TextChanged"
|
||||||
|
Grid.Column="3" Width="68" Margin="0,100,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
|
<Label Content="Strafe (Nicht-Lieferung):" Margin="10,130,0,10" Grid.Column="2"/>
|
||||||
|
<ctrl:UnitTextBox x:Name="SeasonPenaltyNoneInput" Unit="€" TextChanged="SeasonPenaltyInput_TextChanged"
|
||||||
|
Grid.Column="3" Width="68" Margin="0,130,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<GroupBox Grid.Column="1" Grid.Row="1" Header="Zu-/Abschläge" Margin="0,0,10,10" VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
|
||||||
<Grid>
|
<Grid>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="400"/>
|
<ColumnDefinition Width="400"/>
|
||||||
@@ -198,15 +486,15 @@
|
|||||||
|
|
||||||
<Label Content="Name:" Grid.Column="1" Margin="10,40,10,10"/>
|
<Label Content="Name:" Grid.Column="1" Margin="10,40,10,10"/>
|
||||||
<TextBox x:Name="SeasonModifierNameInput" Grid.Column="2" Margin="0,40,10,10"
|
<TextBox x:Name="SeasonModifierNameInput" Grid.Column="2" Margin="0,40,10,10"
|
||||||
TextChanged="SeasonModifierNameInput_TextChanged"/>
|
TextChanged="SeasonModifier_Changed"/>
|
||||||
|
|
||||||
<Label Content="Relativ:" Grid.Column="1" Margin="10,70,10,10"/>
|
<Label Content="Relativ:" Grid.Column="1" Margin="10,70,10,10"/>
|
||||||
<TextBox x:Name="SeasonModifierRelInput" Grid.Column="2" Margin="0,70,10,10"
|
<ctrl:UnitTextBox x:Name="SeasonModifierRelInput" Unit="%" TextChanged="SeasonModifierRelInput_TextChanged"
|
||||||
TextChanged="SeasonModifierRelInput_TextChanged"/>
|
Grid.Column="2" Width="68" Margin="0,70,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
|
|
||||||
<Label Content="Absolut:" Grid.Column="1" Margin="10,100,10,10"/>
|
<Label Content="Absolut:" Grid.Column="1" Margin="10,100,10,10"/>
|
||||||
<TextBox x:Name="SeasonModifierAbsInput" Grid.Column="2" Margin="0,100,10,10"
|
<ctrl:UnitTextBox x:Name="SeasonModifierAbsInput" Unit="€/kg" TextChanged="SeasonModifierAbsInput_TextChanged"
|
||||||
TextChanged="SeasonModifierAbsInput_TextChanged"/>
|
Grid.Column="2" Width="86" Margin="0,100,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
154
Elwig/Windows/BaseDataWindow.xaml.AreaCom.cs
Normal file
154
Elwig/Windows/BaseDataWindow.xaml.AreaCom.cs
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
|
using Elwig.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Data;
|
||||||
|
using System.Windows;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private Dictionary<string, string?>? _acts = null;
|
||||||
|
private Dictionary<AreaComType, string>? _actIds = null;
|
||||||
|
private ObservableCollection<AreaComType>? _actList = null;
|
||||||
|
private bool _actChanged = false;
|
||||||
|
private bool _actUpdate = false;
|
||||||
|
|
||||||
|
private void AreaCommitmentTypesInitEditing() {
|
||||||
|
_actList = new(Context.AreaCommitmentTypes.OrderBy(v => v.VtrgId).ToList());
|
||||||
|
_acts = _actList.ToDictionary(v => v.VtrgId, v => (string?)v.VtrgId);
|
||||||
|
_actIds = _actList.ToDictionary(v => v, v => v.VtrgId);
|
||||||
|
ControlUtils.RenewItemsSource(AreaCommitmentTypeList, _actList, a => (a as AreaComType)?.VtrgId);
|
||||||
|
AreaCommitmentTypeList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypesFinishEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(AreaCommitmentTypeList, Context.AreaCommitmentTypes.OrderBy(v => v.SortId).ToList(), v => (v as AreaComType)?.VtrgId);
|
||||||
|
_actList = null;
|
||||||
|
_acts = null;
|
||||||
|
_actIds = null;
|
||||||
|
_actChanged = false;
|
||||||
|
|
||||||
|
AreaCommitmentTypeAddButton.IsEnabled = false;
|
||||||
|
AreaCommitmentTypeDeleteButton.IsEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task AreaCommitmentTypesSave() {
|
||||||
|
if (!_actChanged || _actList == null || _acts == null || _actIds == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
foreach (var (vtrgid, _) in _acts.Where(a => a.Value == null)) {
|
||||||
|
Context.Remove(Context.AreaCommitmentTypes.Find(vtrgid));
|
||||||
|
}
|
||||||
|
foreach (var (attr, old) in _actIds) {
|
||||||
|
attr.VtrgId = old;
|
||||||
|
}
|
||||||
|
foreach (var (old, vtrgid) in _acts.Where(a => a.Value != null)) {
|
||||||
|
Context.Update(Context.AreaCommitmentTypes.Find(old));
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var (old, vtrgid) in _acts.Where(a => a.Value != null)) {
|
||||||
|
await Context.Database.ExecuteSqlAsync($"UPDATE area_commitment_type SET vtrgid = {vtrgid} WHERE vtrgid = {old}");
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var type in _actList.Where(a => !_actIds.ContainsKey(a))) {
|
||||||
|
if (type.VtrgId == null) continue;
|
||||||
|
await Context.AddAsync(type);
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypeList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
UpdateButtons();
|
||||||
|
_actUpdate = true;
|
||||||
|
if (AreaCommitmentTypeList.SelectedItem is AreaComType type) {
|
||||||
|
AreaCommitmentTypeIdInput.Text = $"{type.SortId}{type.AttrId}";
|
||||||
|
ControlUtils.SelectComboBoxItem(AreaCommitmentTypeWineVariantInput, s => (s as WineVar)?.SortId, type.SortId);
|
||||||
|
ControlUtils.SelectComboBoxItem(AreaCommitmentTypeWineAttributeInput, a => (a as WineAttr)?.AttrId, type.AttrId);
|
||||||
|
AreaCommitmentTypeMinKgPerHaInput.Text = $"{type.MinKgPerHa}";
|
||||||
|
AreaCommitmentTypePenaltyPerKgInput.Text = $"{type.PenaltyPerKg}";
|
||||||
|
AreaCommitmentTypePenaltyInput.Text = $"{type.PenaltyAmount}";
|
||||||
|
AreaCommitmentTypePenaltyNoneInput.Text = $"{type.PenaltyNone}";
|
||||||
|
} else {
|
||||||
|
AreaCommitmentTypeIdInput.Text = "";
|
||||||
|
AreaCommitmentTypeWineVariantInput.SelectedItem = null;
|
||||||
|
AreaCommitmentTypeWineAttributeInput.SelectedItem = null;
|
||||||
|
AreaCommitmentTypeMinKgPerHaInput.Text = "";
|
||||||
|
AreaCommitmentTypePenaltyPerKgInput.Text = "";
|
||||||
|
AreaCommitmentTypePenaltyInput.Text = "";
|
||||||
|
AreaCommitmentTypePenaltyNoneInput.Text = "";
|
||||||
|
}
|
||||||
|
_actUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypeAddButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_actList == null) return;
|
||||||
|
_actChanged = true;
|
||||||
|
var item = Context.CreateProxy<AreaComType>();
|
||||||
|
_actList.Add(item);
|
||||||
|
AreaCommitmentTypeList.SelectedItem = item;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypeDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_actList == null || _acts == null) return;
|
||||||
|
_actChanged = true;
|
||||||
|
var idx = AreaCommitmentTypeList.SelectedIndex;
|
||||||
|
var item = _actList[idx];
|
||||||
|
_acts[item.VtrgId] = null;
|
||||||
|
_actList.RemoveAt(idx);
|
||||||
|
AreaCommitmentTypeList.SelectedIndex = idx < _actList.Count ? idx : idx - 1;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentType_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_actUpdate || (!IsEditing && !IsCreating) || AreaCommitmentTypeList.SelectedItem is not AreaComType attr || _acts == null || _actIds == null) return;
|
||||||
|
_actChanged = true;
|
||||||
|
|
||||||
|
var v = AreaCommitmentTypeWineVariantInput.SelectedItem as WineVar;
|
||||||
|
var a = AreaCommitmentTypeWineAttributeInput.SelectedItem as WineAttr;
|
||||||
|
AreaCommitmentTypeIdInput.Text = $"{v?.SortId}{a?.AttrId}";
|
||||||
|
|
||||||
|
var old = _actIds.GetValueOrDefault(attr);
|
||||||
|
var id = AreaCommitmentTypeIdInput.Text;
|
||||||
|
if (old != null) _acts[old] = id;
|
||||||
|
attr.VtrgId = id;
|
||||||
|
attr.SortId = v?.SortId;
|
||||||
|
attr.AttrId = a?.AttrId;
|
||||||
|
attr.MinKgPerHa = AreaCommitmentTypeMinKgPerHaInput.Text.Length > 0 ? int.Parse(AreaCommitmentTypeMinKgPerHaInput.Text) : null;
|
||||||
|
attr.PenaltyPerKg = AreaCommitmentTypePenaltyPerKgInput.Text.Length > 0 ? decimal.Parse(AreaCommitmentTypePenaltyPerKgInput.Text) : null;
|
||||||
|
attr.PenaltyAmount = AreaCommitmentTypePenaltyInput.Text.Length > 0 ? decimal.Parse(AreaCommitmentTypePenaltyInput.Text) : null;
|
||||||
|
attr.PenaltyNone = AreaCommitmentTypePenaltyNoneInput.Text.Length > 0 ? decimal.Parse(AreaCommitmentTypePenaltyNoneInput.Text) : null;
|
||||||
|
|
||||||
|
CollectionViewSource.GetDefaultView(_actList).Refresh();
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypeIdInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
UpperCaseInput_TextChanged(sender, evt);
|
||||||
|
AreaCommitmentType_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypeMinKgPerHa_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckInteger((TextBox)sender, false, 5));
|
||||||
|
AreaCommitmentType_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypePenaltyPerKgInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
if (SeasonList.SelectedItem is not Season s) return;
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 2, s.Precision));
|
||||||
|
AreaCommitmentType_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AreaCommitmentTypePenaltyInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 4, 2));
|
||||||
|
AreaCommitmentType_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
151
Elwig/Windows/BaseDataWindow.xaml.Branch.cs
Normal file
151
Elwig/Windows/BaseDataWindow.xaml.Branch.cs
Normal file
@@ -0,0 +1,151 @@
|
|||||||
|
using Elwig.Models;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows;
|
||||||
|
using Elwig.Helpers;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Data;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private Dictionary<string, string?>? _branches = null;
|
||||||
|
private Dictionary<Branch, string>? _branchIds = null;
|
||||||
|
private ObservableCollection<Branch>? _branchList = null;
|
||||||
|
private bool _branchChanged = false;
|
||||||
|
private bool _branchUpdate = false;
|
||||||
|
|
||||||
|
private void BranchesInitEditing() {
|
||||||
|
_branchList = new(Context.Branches.OrderBy(b => b.Name).ToList());
|
||||||
|
_branches = _branchList.ToDictionary(b => b.ZwstId, b => (string?)b.ZwstId);
|
||||||
|
_branchIds = _branchList.ToDictionary(b => b, b => b.ZwstId);
|
||||||
|
ControlUtils.RenewItemsSource(BranchList, _branchList, b => (b as Branch)?.ZwstId);
|
||||||
|
BranchList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchesFinishEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(BranchList, Context.Branches.OrderBy(b => b.Name).ToList(), b => (b as Branch)?.ZwstId);
|
||||||
|
_branchList = null;
|
||||||
|
_branches = null;
|
||||||
|
_branchIds = null;
|
||||||
|
_branchChanged = false;
|
||||||
|
|
||||||
|
BranchAddButton.IsEnabled = false;
|
||||||
|
BranchDeleteButton.IsEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task BranchesSave() {
|
||||||
|
if (!_branchChanged || _branchList == null || _branches == null || _branchIds == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
foreach (var (zwstid, _) in _branches.Where(b => b.Value == null)) {
|
||||||
|
Context.Remove(Context.Branches.Find(zwstid));
|
||||||
|
}
|
||||||
|
foreach (var (branch, old) in _branchIds) {
|
||||||
|
branch.ZwstId = old;
|
||||||
|
}
|
||||||
|
foreach (var (old, zwstid) in _branches.Where(b => b.Value != null)) {
|
||||||
|
Context.Update(Context.Branches.Find(old));
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var (old, zwstid) in _branches.Where(b => b.Value != null)) {
|
||||||
|
await Context.Database.ExecuteSqlAsync($"UPDATE branch SET zwstid = {zwstid} WHERE zwstid = {old}");
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var branch in _branchList.Where(b => !_branchIds.ContainsKey(b))) {
|
||||||
|
if (branch.ZwstId == null) continue;
|
||||||
|
await Context.AddAsync(branch);
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
UpdateButtons();
|
||||||
|
_branchUpdate = true;
|
||||||
|
if (BranchList.SelectedItem is not Branch branch) {
|
||||||
|
BranchIdInput.Text = "";
|
||||||
|
BranchNameInput.Text = "";
|
||||||
|
BranchPlzInput.Text = "";
|
||||||
|
BranchAddressInput.Text = "";
|
||||||
|
BranchPhoneNrInput.Text = "";
|
||||||
|
BranchFaxNrInput.Text = "";
|
||||||
|
BranchMobileNrInput.Text = "";
|
||||||
|
} else {
|
||||||
|
BranchIdInput.Text = branch.ZwstId;
|
||||||
|
BranchNameInput.Text = branch.Name;
|
||||||
|
BranchPlzInput.Text = branch.PostalDest?.AtPlz?.Plz.ToString() ?? "";
|
||||||
|
ControlUtils.SelectComboBoxItem(BranchOrtInput, o => (o as AT_PlzDest)?.Okz, branch.PostalDest?.AtPlz?.Okz);
|
||||||
|
BranchAddressInput.Text = branch.Address;
|
||||||
|
BranchPhoneNrInput.Text = branch.PhoneNr;
|
||||||
|
BranchFaxNrInput.Text = branch.FaxNr;
|
||||||
|
BranchMobileNrInput.Text = branch.MobileNr;
|
||||||
|
}
|
||||||
|
_branchUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchAddButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_branchList == null) return;
|
||||||
|
_branchChanged = true;
|
||||||
|
var item = Context.CreateProxy<Branch>();
|
||||||
|
_branchList.Add(item);
|
||||||
|
BranchList.SelectedItem = item;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_branchList == null || _branches == null) return;
|
||||||
|
_branchChanged = true;
|
||||||
|
var idx = BranchList.SelectedIndex;
|
||||||
|
var item = _branchList[idx];
|
||||||
|
_branches[item.ZwstId] = null;
|
||||||
|
_branchList.RemoveAt(idx);
|
||||||
|
BranchList.SelectedIndex = idx < _branchList.Count ? idx : idx - 1;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Branch_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_branchUpdate || (!IsEditing && !IsCreating) || BranchList.SelectedItem is not Branch branch || _branches == null || _branchIds == null) return;
|
||||||
|
_branchChanged = _branchChanged ||
|
||||||
|
BranchIdInput.Text != branch.ZwstId ||
|
||||||
|
BranchNameInput.Text != branch.Name ||
|
||||||
|
BranchPlzInput.Text != (branch.PostalDest?.AtPlz?.Plz.ToString() ?? "") ||
|
||||||
|
(BranchOrtInput.SelectedItem as AT_PlzDest)?.Okz != branch.PostalDest?.AtPlz?.Okz ||
|
||||||
|
BranchAddressInput.Text != branch.Address ||
|
||||||
|
BranchPhoneNrInput.Text != (branch.PhoneNr ?? "") ||
|
||||||
|
BranchFaxNrInput.Text != (branch.FaxNr ?? "") ||
|
||||||
|
BranchMobileNrInput.Text != (branch.MobileNr ?? "");
|
||||||
|
|
||||||
|
var old = _branchIds.GetValueOrDefault(branch);
|
||||||
|
var id = BranchIdInput.Text;
|
||||||
|
if (old != null) _branches[old] = id;
|
||||||
|
branch.ZwstId = id;
|
||||||
|
branch.Name = BranchNameInput.Text;
|
||||||
|
branch.PostalDestId = (BranchOrtInput.SelectedItem as AT_PlzDest)?.Id;
|
||||||
|
branch.Address = BranchAddressInput.Text;
|
||||||
|
branch.PhoneNr = BranchPhoneNrInput.Text;
|
||||||
|
branch.FaxNr = BranchFaxNrInput.Text;
|
||||||
|
branch.MobileNr = BranchMobileNrInput.Text;
|
||||||
|
if (branch.PhoneNr.Length == 0) branch.PhoneNr = null;
|
||||||
|
if (branch.FaxNr.Length == 0) branch.FaxNr = null;
|
||||||
|
if (branch.MobileNr.Length == 0) branch.MobileNr = null;
|
||||||
|
|
||||||
|
CollectionViewSource.GetDefaultView(_branchList).Refresh();
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchPlzInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
PlzInput_TextChanged(sender, evt);
|
||||||
|
Branch_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void BranchPhoneNr_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
PhoneNrInput_TextChanged(sender, evt);
|
||||||
|
Branch_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
176
Elwig/Windows/BaseDataWindow.xaml.Mod.cs
Normal file
176
Elwig/Windows/BaseDataWindow.xaml.Mod.cs
Normal file
@@ -0,0 +1,176 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
|
using Elwig.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Data;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private Dictionary<string, string?>? _mods = null;
|
||||||
|
private Dictionary<Modifier, string>? _modIds = null;
|
||||||
|
private ObservableCollection<Modifier>? _modList = null;
|
||||||
|
private bool _modChanged = false;
|
||||||
|
private bool _modUpdate = false;
|
||||||
|
|
||||||
|
private void ModifiersInitEditing() {
|
||||||
|
SeasonList.IsEnabled = false;
|
||||||
|
var year = (SeasonList.SelectedItem as Season)?.Year;
|
||||||
|
_modList = new(Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToList());
|
||||||
|
_mods = _modList.ToDictionary(m => m.ModId, m => (string?)m.ModId);
|
||||||
|
_modIds = _modList.ToDictionary(m => m, m => m.ModId);
|
||||||
|
ControlUtils.RenewItemsSource(SeasonModifierList, _modList, m => (m as Modifier)?.ModId);
|
||||||
|
SeasonModifierList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ModifiersFinishEditing() {
|
||||||
|
var year = (SeasonList.SelectedItem as Season)?.Year;
|
||||||
|
ControlUtils.RenewItemsSource(SeasonModifierList, Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToList(), m => (m as Modifier)?.ModId);
|
||||||
|
_modList = null;
|
||||||
|
_mods = null;
|
||||||
|
_modIds = null;
|
||||||
|
_modChanged = false;
|
||||||
|
|
||||||
|
SeasonModifierUpButton.IsEnabled = false;
|
||||||
|
SeasonModifierDownButton.IsEnabled = false;
|
||||||
|
SeasonModifierAddButton.IsEnabled = false;
|
||||||
|
SeasonModifierDeleteButton.IsEnabled = false;
|
||||||
|
SeasonList.IsEnabled = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task ModifiersSave() {
|
||||||
|
if (!_modChanged || _modList == null || _mods == null || _modIds == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
foreach (var mod in _modList) mod.Ordering = ++i;
|
||||||
|
|
||||||
|
var year = (SeasonList.SelectedItem as Season)?.Year;
|
||||||
|
foreach (var (modid, _) in _mods.Where(m => m.Value == null)) {
|
||||||
|
Context.Remove(Context.Modifiers.Find(new object?[] { year, modid }));
|
||||||
|
}
|
||||||
|
foreach (var (mod, old) in _modIds) {
|
||||||
|
mod.ModId = old;
|
||||||
|
}
|
||||||
|
foreach (var (old, modid) in _mods.Where(m => m.Value != null)) {
|
||||||
|
Context.Update(Context.Modifiers.Find(new object?[] { year, old }));
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var (old, modid) in _mods.Where(m => m.Value != null)) {
|
||||||
|
await Context.Database.ExecuteSqlAsync($"UPDATE modifier SET modid = {modid} WHERE (year, modid) = ({year}, {old})");
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var mod in _modList.Where(m => !_modIds.ContainsKey(m))) {
|
||||||
|
if (mod.ModId == null) continue;
|
||||||
|
await Context.AddAsync(mod);
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierUpButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_modList == null) return;
|
||||||
|
_modChanged = true;
|
||||||
|
var idx = SeasonModifierList.SelectedIndex;
|
||||||
|
var item = _modList[idx];
|
||||||
|
_modList.RemoveAt(idx);
|
||||||
|
idx--;
|
||||||
|
_modList.Insert(idx, item);
|
||||||
|
SeasonModifierList.SelectedIndex = idx;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierDownButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_modList == null) return;
|
||||||
|
_modChanged = true;
|
||||||
|
var idx = SeasonModifierList.SelectedIndex;
|
||||||
|
var item = _modList[idx];
|
||||||
|
_modList.RemoveAt(idx);
|
||||||
|
idx++;
|
||||||
|
_modList.Insert(idx, item);
|
||||||
|
SeasonModifierList.SelectedIndex = idx;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierAddButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_modList == null || SeasonList.SelectedItem is not Season s) return;
|
||||||
|
_modChanged = true;
|
||||||
|
var idx = (SeasonModifierList.SelectedIndex != -1) ? SeasonModifierList.SelectedIndex + 1 : _modList.Count;
|
||||||
|
var item = Context.CreateProxy<Modifier>();
|
||||||
|
item.Year = s.Year;
|
||||||
|
_modList.Insert(idx, item);
|
||||||
|
SeasonModifierList.SelectedIndex = idx;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_modList == null || _mods == null) return;
|
||||||
|
_modChanged = true;
|
||||||
|
var idx = SeasonModifierList.SelectedIndex;
|
||||||
|
var item = _modList[idx];
|
||||||
|
_mods[item.ModId] = null;
|
||||||
|
_modList.RemoveAt(idx);
|
||||||
|
SeasonModifierList.SelectedIndex = idx < _modList.Count ? idx : idx - 1;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
UpdateButtons();
|
||||||
|
_modUpdate = true;
|
||||||
|
if (SeasonModifierList.SelectedItem is not Modifier mod) {
|
||||||
|
SeasonModifierIdInput.Text = "";
|
||||||
|
SeasonModifierNameInput.Text = "";
|
||||||
|
SeasonModifierRelInput.Text = "";
|
||||||
|
SeasonModifierAbsInput.Text = "";
|
||||||
|
} else {
|
||||||
|
SeasonModifierIdInput.Text = mod.ModId;
|
||||||
|
SeasonModifierNameInput.Text = mod.Name;
|
||||||
|
SeasonModifierRelInput.Text = (mod.Rel * 100)?.ToString() ?? "";
|
||||||
|
SeasonModifierAbsInput.Text = mod.Abs?.ToString() ?? "";
|
||||||
|
}
|
||||||
|
_modUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifier_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_modUpdate || (!IsEditing && !IsCreating) || SeasonModifierList.SelectedItem is not Modifier mod || SeasonList.SelectedItem is not Season s || _mods == null || _modIds == null) return;
|
||||||
|
_modChanged = true;
|
||||||
|
|
||||||
|
var old = _modIds.GetValueOrDefault(mod);
|
||||||
|
var id = SeasonModifierIdInput.Text ?? "";
|
||||||
|
if (old != null) _mods[old] = id;
|
||||||
|
mod.ModId = id;
|
||||||
|
mod.Name = SeasonModifierNameInput.Text;
|
||||||
|
mod.Rel = decimal.TryParse(SeasonModifierRelInput.Text, out var vRel) ? vRel / 100 : null;
|
||||||
|
mod.AbsValue = decimal.TryParse(SeasonModifierAbsInput.Text, out var vAbs) ? Utils.DecToDb(vAbs, s.Precision) : null;
|
||||||
|
|
||||||
|
CollectionViewSource.GetDefaultView(_modList).Refresh();
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierIdInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
UpperCaseInput_TextChanged(sender, evt);
|
||||||
|
SeasonModifier_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierRelInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 3, 2, true));
|
||||||
|
if (SeasonModifierRelInput.Text.Length > 0 && SeasonModifierAbsInput.Text.Length > 0)
|
||||||
|
SeasonModifierAbsInput.Text = "";
|
||||||
|
SeasonModifier_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonModifierAbsInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
if (SeasonList.SelectedItem is not Season s) return;
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 2, s.Precision, true));
|
||||||
|
if (SeasonModifierAbsInput.Text.Length > 0 && SeasonModifierRelInput.Text.Length > 0)
|
||||||
|
SeasonModifierRelInput.Text = "";
|
||||||
|
SeasonModifier_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
113
Elwig/Windows/BaseDataWindow.xaml.Season.cs
Normal file
113
Elwig/Windows/BaseDataWindow.xaml.Season.cs
Normal file
@@ -0,0 +1,113 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
|
using Elwig.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private bool _seasonChanged = false;
|
||||||
|
private bool _seasonUpdate = false;
|
||||||
|
|
||||||
|
private void SeasonsInitEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(SeasonList, Context.Seasons.OrderByDescending(s => s.Year).ToList(), s => (s as Season)?.Year);
|
||||||
|
SeasonList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonsFinishEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(SeasonList, Context.Seasons.OrderByDescending(s => s.Year).ToList(), s => (s as Season)?.Year);
|
||||||
|
_seasonChanged = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task SeasonsSave() {
|
||||||
|
if (!_seasonChanged || SeasonList.SelectedItem is not Season s)
|
||||||
|
return;
|
||||||
|
Context.Update(s);
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private async void SeasonList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
_seasonUpdate = true;
|
||||||
|
if (SeasonList.SelectedItem is Season s) {
|
||||||
|
SeasonModifierList.ItemsSource = await Context.Modifiers.Where(m => m.Year == s.Year).OrderBy(m => m.Ordering).ToListAsync();
|
||||||
|
SeasonMaxKgPerHaInput.Text = s.MaxKgPerHa.ToString();
|
||||||
|
SeasonVatNormalInput.Text = (s.VatNormal * 100).ToString();
|
||||||
|
SeasonVatFlatrateInput.Text = (s.VatFlatrate * 100).ToString();
|
||||||
|
SeasonStartInput.Text = $"{s.StartDate:dd.MM.yyyy}";
|
||||||
|
SeasonEndInput.Text = $"{s.EndDate:dd.MM.yyyy}";
|
||||||
|
SeasonMinKgPerBsInput.Text = s.MinKgPerBusinessShare.ToString();
|
||||||
|
SeasonMaxKgPerBsInput.Text = s.MaxKgPerBusinessShare.ToString();
|
||||||
|
SeasonPenaltyPerKgInput.Text = s.PenaltyPerKg?.ToString() ?? "";
|
||||||
|
SeasonPenaltyInput.Text = s.PenaltyAmount?.ToString() ?? "";
|
||||||
|
SeasonPenaltyNoneInput.Text = s.PenaltyNone?.ToString() ?? "";
|
||||||
|
|
||||||
|
var sym = s.Currency.Symbol ?? "";
|
||||||
|
SeasonModifierAbsInput.Unit = $"{sym}/kg";
|
||||||
|
SeasonPenaltyPerKgInput.Unit = $"{sym}/kg";
|
||||||
|
SeasonPenaltyInput.Unit = sym;
|
||||||
|
SeasonPenaltyNoneInput.Unit = sym;
|
||||||
|
AreaCommitmentTypePenaltyPerKgInput.Unit = $"{sym}/kg";
|
||||||
|
AreaCommitmentTypePenaltyInput.Unit = sym;
|
||||||
|
AreaCommitmentTypePenaltyNoneInput.Unit = sym;
|
||||||
|
} else {
|
||||||
|
SeasonModifierList.ItemsSource = null;
|
||||||
|
SeasonMaxKgPerHaInput.Text = "";
|
||||||
|
SeasonVatNormalInput.Text = "";
|
||||||
|
SeasonVatFlatrateInput.Text = "";
|
||||||
|
SeasonStartInput.Text = "";
|
||||||
|
SeasonEndInput.Text = "";
|
||||||
|
SeasonMinKgPerBsInput.Text = "";
|
||||||
|
SeasonMaxKgPerBsInput.Text = "";
|
||||||
|
SeasonPenaltyPerKgInput.Text = "";
|
||||||
|
SeasonPenaltyInput.Text = "";
|
||||||
|
SeasonPenaltyNoneInput.Text = "";
|
||||||
|
}
|
||||||
|
_seasonUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Season_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_seasonUpdate || (!IsEditing && !IsCreating) || SeasonList.SelectedItem is not Season s) return;
|
||||||
|
_seasonChanged = true;
|
||||||
|
|
||||||
|
if (SeasonMaxKgPerHaInput.Text.Length > 0)
|
||||||
|
s.MaxKgPerHa = int.Parse(SeasonMaxKgPerHaInput.Text);
|
||||||
|
if (SeasonVatNormalInput.Text.Length > 0)
|
||||||
|
s.VatNormal = double.Parse(SeasonVatNormalInput.Text) / 100;
|
||||||
|
if (SeasonVatFlatrateInput.Text.Length > 0)
|
||||||
|
s.VatFlatrate = double.Parse(SeasonVatFlatrateInput.Text) / 100;
|
||||||
|
if (SeasonMinKgPerBsInput.Text.Length > 0)
|
||||||
|
s.MinKgPerBusinessShare = int.Parse(SeasonMinKgPerBsInput.Text);
|
||||||
|
if (SeasonMaxKgPerBsInput.Text.Length > 0)
|
||||||
|
s.MaxKgPerBusinessShare = int.Parse(SeasonMaxKgPerBsInput.Text);
|
||||||
|
s.PenaltyPerKg = (SeasonPenaltyPerKgInput.Text.Length > 0) ? decimal.Parse(SeasonPenaltyPerKgInput.Text) : null;
|
||||||
|
s.PenaltyAmount = (SeasonPenaltyInput.Text.Length > 0) ? decimal.Parse(SeasonPenaltyInput.Text) : null;
|
||||||
|
s.PenaltyNone = (SeasonPenaltyNoneInput.Text.Length > 0) ? decimal.Parse(SeasonPenaltyNoneInput.Text) : null;
|
||||||
|
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonMinMaxKgInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckInteger((TextBox)sender, true, 5));
|
||||||
|
Season_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonVatInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, true, 2, 1));
|
||||||
|
Season_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonPenaltyPerKgInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
if (SeasonList.SelectedItem is not Season s) return;
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 2, s.Precision));
|
||||||
|
Season_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SeasonPenaltyInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckDecimal((TextBox)sender, false, 4, 2));
|
||||||
|
Season_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
149
Elwig/Windows/BaseDataWindow.xaml.WineAttr.cs
Normal file
149
Elwig/Windows/BaseDataWindow.xaml.WineAttr.cs
Normal file
@@ -0,0 +1,149 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
|
using Elwig.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Data;
|
||||||
|
using System.Windows;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private Dictionary<string, string?>? _attrs = null;
|
||||||
|
private Dictionary<WineAttr, string>? _attrIds = null;
|
||||||
|
private ObservableCollection<WineAttr>? _attrList = null;
|
||||||
|
private bool _attrChanged = false;
|
||||||
|
private bool _attrUpdate = false;
|
||||||
|
|
||||||
|
private void WineAttributesInitEditing() {
|
||||||
|
_attrList = new(Context.WineAttributes.OrderBy(a => a.Name).ToList());
|
||||||
|
_attrs = _attrList.ToDictionary(a => a.AttrId, a => (string?)a.AttrId);
|
||||||
|
_attrIds = _attrList.ToDictionary(a => a, a => a.AttrId);
|
||||||
|
ControlUtils.RenewItemsSource(WineAttributeList, _attrList, a => (a as WineAttr)?.AttrId);
|
||||||
|
WineAttributeList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributesFinishEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(WineAttributeList, Context.WineAttributes.OrderBy(a => a.Name).ToList(), a => (a as WineAttr)?.AttrId);
|
||||||
|
_attrList = null;
|
||||||
|
_attrs = null;
|
||||||
|
_attrIds = null;
|
||||||
|
_attrChanged = false;
|
||||||
|
|
||||||
|
WineAttributeAddButton.IsEnabled = false;
|
||||||
|
WineAttributeDeleteButton.IsEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task WineAttributesSave() {
|
||||||
|
if (!_attrChanged || _attrList == null || _attrs == null || _attrIds == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
foreach (var (attrid, _) in _attrs.Where(a => a.Value == null)) {
|
||||||
|
Context.Remove(Context.WineAttributes.Find(attrid));
|
||||||
|
}
|
||||||
|
foreach (var (attr, old) in _attrIds) {
|
||||||
|
attr.AttrId = old;
|
||||||
|
}
|
||||||
|
foreach (var (old, attrid) in _attrs.Where(a => a.Value != null)) {
|
||||||
|
Context.Update(Context.WineAttributes.Find(old));
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var (old, attrid) in _attrs.Where(a => a.Value != null)) {
|
||||||
|
await Context.Database.ExecuteSqlAsync($"UPDATE wine_attribute SET attrid = {attrid} WHERE attrid = {old}");
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var attr in _attrList.Where(a => !_attrIds.ContainsKey(a))) {
|
||||||
|
if (attr.AttrId == null) continue;
|
||||||
|
await Context.AddAsync(attr);
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
UpdateButtons();
|
||||||
|
_attrUpdate = true;
|
||||||
|
if (WineAttributeList.SelectedItem is not WineAttr attr) {
|
||||||
|
WineAttributeIdInput.Text = "";
|
||||||
|
WineAttributeNameInput.Text = "";
|
||||||
|
WineAttributeActiveInput.IsChecked = false;
|
||||||
|
WineAttributeMaxKgPerHaInput.Text = "";
|
||||||
|
WineAttributeStrictInput.IsChecked = false;
|
||||||
|
WineAttributeFillLowerInput.SelectedItem = null;
|
||||||
|
} else {
|
||||||
|
WineAttributeIdInput.Text = attr.AttrId;
|
||||||
|
WineAttributeNameInput.Text = attr.Name;
|
||||||
|
WineAttributeActiveInput.IsChecked = attr.IsActive;
|
||||||
|
WineAttributeMaxKgPerHaInput.Text = attr.MaxKgPerHa?.ToString() ?? "";
|
||||||
|
WineAttributeStrictInput.IsChecked = attr.IsStrict;
|
||||||
|
WineAttributeFillLowerInput.SelectedIndex = attr.FillLower;
|
||||||
|
}
|
||||||
|
_attrUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeAddButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_attrList == null) return;
|
||||||
|
_attrChanged = true;
|
||||||
|
var item = Context.CreateProxy<WineAttr>();
|
||||||
|
_attrList.Add(item);
|
||||||
|
WineAttributeList.SelectedItem = item;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_attrList == null || _attrs == null) return;
|
||||||
|
_attrChanged = true;
|
||||||
|
var idx = WineAttributeList.SelectedIndex;
|
||||||
|
var item = _attrList[idx];
|
||||||
|
_attrs[item.AttrId] = null;
|
||||||
|
_attrList.RemoveAt(idx);
|
||||||
|
WineAttributeList.SelectedIndex = idx < _attrList.Count ? idx : idx - 1;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttribute_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_attrUpdate || (!IsEditing && !IsCreating) || WineAttributeList.SelectedItem is not WineAttr attr || _attrs == null || _attrIds == null) return;
|
||||||
|
_attrChanged = _attrChanged ||
|
||||||
|
WineAttributeIdInput.Text != attr.AttrId ||
|
||||||
|
WineAttributeNameInput.Text != attr.Name ||
|
||||||
|
WineAttributeActiveInput.IsChecked != attr.IsActive ||
|
||||||
|
WineAttributeMaxKgPerHaInput.Text != attr.MaxKgPerHa?.ToString() ||
|
||||||
|
WineAttributeStrictInput.IsChecked != attr.IsStrict ||
|
||||||
|
WineAttributeFillLowerInput.SelectedIndex != attr.FillLower;
|
||||||
|
|
||||||
|
var old = _attrIds.GetValueOrDefault(attr);
|
||||||
|
var id = WineAttributeIdInput.Text;
|
||||||
|
if (old != null) _attrs[old] = id;
|
||||||
|
attr.AttrId = id;
|
||||||
|
attr.Name = WineAttributeNameInput.Text ?? "";
|
||||||
|
attr.IsActive = WineAttributeActiveInput.IsChecked ?? false;
|
||||||
|
attr.MaxKgPerHa = WineAttributeMaxKgPerHaInput.Text.Length > 0 ? int.Parse(WineAttributeMaxKgPerHaInput.Text) : null;
|
||||||
|
attr.IsStrict = WineAttributeStrictInput.IsChecked ?? false;
|
||||||
|
attr.FillLower = WineAttributeFillLowerInput.SelectedIndex;
|
||||||
|
|
||||||
|
CollectionViewSource.GetDefaultView(_attrList).Refresh();
|
||||||
|
CollectionViewSource.GetDefaultView(_attrList).Refresh();
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeIdInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
UpperCaseInput_TextChanged(sender, evt);
|
||||||
|
WineAttribute_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeMaxKgPerHaInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
InputTextChanged((TextBox)sender, Validator.CheckInteger((TextBox)sender, false, 5));
|
||||||
|
WineAttribute_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineAttributeStrictInput_Changed(object sender, RoutedEventArgs evt) {
|
||||||
|
WineAttributeFillLowerInput.Visibility = WineAttributeStrictInput.IsChecked == true ? Visibility.Visible : Visibility.Hidden;
|
||||||
|
WineAttributeFillLowerLabel.Visibility = WineAttributeFillLowerInput.Visibility;
|
||||||
|
WineAttribute_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
126
Elwig/Windows/BaseDataWindow.xaml.WineCult.cs
Normal file
126
Elwig/Windows/BaseDataWindow.xaml.WineCult.cs
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
using Elwig.Helpers;
|
||||||
|
using Elwig.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Data;
|
||||||
|
using System.Windows;
|
||||||
|
|
||||||
|
namespace Elwig.Windows {
|
||||||
|
public partial class BaseDataWindow {
|
||||||
|
|
||||||
|
private Dictionary<string, string?>? _cults = null;
|
||||||
|
private Dictionary<WineCult, string>? _cultIds = null;
|
||||||
|
private ObservableCollection<WineCult>? _cultList = null;
|
||||||
|
private bool _cultChanged = false;
|
||||||
|
private bool _cultUpdate = false;
|
||||||
|
|
||||||
|
private void WineCultivationsInitEditing() {
|
||||||
|
_cultList = new(Context.WineCultivations.OrderBy(c => c.Name).ToList());
|
||||||
|
_cults = _cultList.ToDictionary(c => c.CultId, c => (string?)c.CultId);
|
||||||
|
_cultIds = _cultList.ToDictionary(c => c, c => c.CultId);
|
||||||
|
ControlUtils.RenewItemsSource(WineCultivationList, _cultList, c => (c as WineCult)?.CultId);
|
||||||
|
WineCultivationList_SelectionChanged(null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivationsFinishEditing() {
|
||||||
|
ControlUtils.RenewItemsSource(WineCultivationList, Context.WineCultivations.OrderBy(c => c.Name).ToList(), c => (c as WineCult)?.CultId);
|
||||||
|
_cultList = null;
|
||||||
|
_cults = null;
|
||||||
|
_cultIds = null;
|
||||||
|
_cultChanged = false;
|
||||||
|
|
||||||
|
WineCultivationAddButton.IsEnabled = false;
|
||||||
|
WineCultivationDeleteButton.IsEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task WineCultivationsSave() {
|
||||||
|
if (!_cultChanged || _cultList == null || _cults == null || _cultIds == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
foreach (var (cultid, _) in _cults.Where(c => c.Value == null)) {
|
||||||
|
Context.Remove(Context.WineCultivations.Find(cultid));
|
||||||
|
}
|
||||||
|
foreach (var (cult, old) in _cultIds) {
|
||||||
|
cult.CultId = old;
|
||||||
|
}
|
||||||
|
foreach (var (old, cultid) in _cults.Where(c => c.Value != null)) {
|
||||||
|
Context.Update(Context.WineCultivations.Find(old));
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var (old, cultid) in _cults.Where(c => c.Value != null)) {
|
||||||
|
await Context.Database.ExecuteSqlAsync($"UPDATE wine_cultivation SET cultid = {cultid} WHERE cultid = {old}");
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
|
||||||
|
foreach (var cult in _cultList.Where(c => !_cultIds.ContainsKey(c))) {
|
||||||
|
if (cult.CultId == null) continue;
|
||||||
|
await Context.AddAsync(cult);
|
||||||
|
}
|
||||||
|
await Context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivationList_SelectionChanged(object? sender, SelectionChangedEventArgs? evt) {
|
||||||
|
UpdateButtons();
|
||||||
|
_cultUpdate = true;
|
||||||
|
if (WineCultivationList.SelectedItem is not WineCult cult) {
|
||||||
|
WineCultivationIdInput.Text = "";
|
||||||
|
WineCultivationNameInput.Text = "";
|
||||||
|
WineCultivationDescriptionInput.Text = "";
|
||||||
|
} else {
|
||||||
|
WineCultivationIdInput.Text = cult.CultId;
|
||||||
|
WineCultivationNameInput.Text = cult.Name;
|
||||||
|
WineCultivationDescriptionInput.Text = cult.Description;
|
||||||
|
}
|
||||||
|
_cultUpdate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivationAddButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_cultList == null) return;
|
||||||
|
_cultChanged = true;
|
||||||
|
var item = Context.CreateProxy<WineCult>();
|
||||||
|
_cultList.Add(item);
|
||||||
|
WineCultivationList.SelectedItem = item;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivationDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
|
if (_cultList == null || _cults == null) return;
|
||||||
|
_cultChanged = true;
|
||||||
|
var idx = WineCultivationList.SelectedIndex;
|
||||||
|
var item = _cultList[idx];
|
||||||
|
_cults[item.CultId] = null;
|
||||||
|
_cultList.RemoveAt(idx);
|
||||||
|
WineCultivationList.SelectedIndex = idx < _cultList.Count ? idx : idx - 1;
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivation_Changed(object? sender, RoutedEventArgs? evt) {
|
||||||
|
if (_cultUpdate || (!IsEditing && !IsCreating) || WineCultivationList.SelectedItem is not WineCult cult || _cults == null || _cultIds == null) return;
|
||||||
|
_cultChanged = _cultChanged ||
|
||||||
|
WineCultivationIdInput.Text != cult.CultId ||
|
||||||
|
WineCultivationNameInput.Text != cult.Name ||
|
||||||
|
WineCultivationDescriptionInput.Text != (cult.Description ?? "");
|
||||||
|
|
||||||
|
var old = _cultIds.GetValueOrDefault(cult);
|
||||||
|
var id = WineCultivationIdInput.Text ?? "";
|
||||||
|
if (old != null) _cults[old] = id;
|
||||||
|
cult.CultId = id;
|
||||||
|
cult.Name = WineCultivationNameInput.Text ?? "";
|
||||||
|
cult.Description = WineCultivationDescriptionInput.Text ?? "";
|
||||||
|
if (cult.Description.Length == 0) cult.Description = null;
|
||||||
|
|
||||||
|
CollectionViewSource.GetDefaultView(_cultList).Refresh();
|
||||||
|
UpdateButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void WineCultivationIdInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
|
UpperCaseInput_TextChanged(sender, evt);
|
||||||
|
WineCultivation_Changed(sender, evt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -2,23 +2,14 @@ using Elwig.Helpers;
|
|||||||
using Elwig.Models;
|
using Elwig.Models;
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Collections.ObjectModel;
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using System.Windows.Data;
|
|
||||||
|
|
||||||
namespace Elwig.Windows {
|
namespace Elwig.Windows {
|
||||||
public partial class BaseDataWindow : AdministrationWindow {
|
public partial class BaseDataWindow : AdministrationWindow {
|
||||||
|
|
||||||
private Dictionary<string, string?>? Modifiers = null;
|
|
||||||
private Dictionary<Modifier, string>? ModifierIds = null;
|
|
||||||
private ObservableCollection<Modifier>? ModifierList = null;
|
|
||||||
private bool ModifiersChanged = false;
|
|
||||||
private bool ModifierUpdate = false;
|
|
||||||
|
|
||||||
public BaseDataWindow() {
|
public BaseDataWindow() {
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
RequiredInputs = new Control[] {
|
RequiredInputs = new Control[] {
|
||||||
@@ -27,108 +18,167 @@ namespace Elwig.Windows {
|
|||||||
};
|
};
|
||||||
ExemptInputs = new Control[] {
|
ExemptInputs = new Control[] {
|
||||||
ClientNameFull,
|
ClientNameFull,
|
||||||
SeasonModifierIdInput, SeasonModifierNameInput, SeasonModifierRelInput, SeasonModifierAbsInput,
|
BranchIdInput, BranchNameInput, BranchPlzInput, BranchOrtInput,
|
||||||
|
BranchAddressInput, BranchPhoneNrInput, BranchFaxNrInput, BranchMobileNrInput,
|
||||||
|
WineAttributeIdInput, WineAttributeNameInput, WineAttributeActiveInput,
|
||||||
|
WineAttributeMaxKgPerHaInput.TextBox, WineAttributeStrictInput, WineAttributeFillLowerInput,
|
||||||
|
WineCultivationIdInput, WineCultivationNameInput, WineCultivationDescriptionInput,
|
||||||
|
AreaCommitmentTypeIdInput, AreaCommitmentTypeWineVariantInput, AreaCommitmentTypeWineAttributeInput,
|
||||||
|
AreaCommitmentTypeMinKgPerHaInput.TextBox, AreaCommitmentTypePenaltyPerKgInput.TextBox,
|
||||||
|
AreaCommitmentTypePenaltyInput.TextBox, AreaCommitmentTypePenaltyNoneInput.TextBox,
|
||||||
|
SeasonMaxKgPerHaInput.TextBox, SeasonVatNormalInput.TextBox, SeasonVatFlatrateInput.TextBox, SeasonStartInput, SeasonEndInput,
|
||||||
|
SeasonMinKgPerBsInput.TextBox, SeasonMaxKgPerBsInput.TextBox, SeasonPenaltyPerKgInput.TextBox, SeasonPenaltyInput.TextBox, SeasonPenaltyNoneInput.TextBox,
|
||||||
|
SeasonModifierIdInput, SeasonModifierNameInput, SeasonModifierRelInput.TextBox, SeasonModifierAbsInput.TextBox,
|
||||||
};
|
};
|
||||||
|
WineAttributeFillLowerInput.Visibility = Visibility.Hidden;
|
||||||
|
WineAttributeFillLowerLabel.Visibility = Visibility.Hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
new protected void LockInputs() {
|
new protected void LockInputs() {
|
||||||
base.LockInputs();
|
base.LockInputs();
|
||||||
|
|
||||||
|
BranchIdInput.IsReadOnly = true;
|
||||||
|
BranchNameInput.IsReadOnly = true;
|
||||||
|
BranchPlzInput.IsReadOnly = true;
|
||||||
|
BranchOrtInput.IsEnabled = false;
|
||||||
|
BranchAddressInput.IsReadOnly = true;
|
||||||
|
BranchPhoneNrInput.IsReadOnly = true;
|
||||||
|
BranchFaxNrInput.IsReadOnly = true;
|
||||||
|
BranchMobileNrInput.IsReadOnly = true;
|
||||||
|
|
||||||
|
WineAttributeIdInput.IsReadOnly = true;
|
||||||
|
WineAttributeNameInput.IsReadOnly = true;
|
||||||
|
WineAttributeActiveInput.IsEnabled = false;
|
||||||
|
WineAttributeMaxKgPerHaInput.TextBox.IsReadOnly = true;
|
||||||
|
WineAttributeStrictInput.IsEnabled = false;
|
||||||
|
WineAttributeFillLowerInput.IsEnabled = false;
|
||||||
|
|
||||||
|
WineCultivationIdInput.IsReadOnly = true;
|
||||||
|
WineCultivationNameInput.IsReadOnly = true;
|
||||||
|
WineCultivationDescriptionInput.IsReadOnly = true;
|
||||||
|
|
||||||
|
AreaCommitmentTypeWineVariantInput.IsEnabled = false;
|
||||||
|
AreaCommitmentTypeWineAttributeInput.IsEnabled = false;
|
||||||
|
AreaCommitmentTypeMinKgPerHaInput.TextBox.IsReadOnly = true;
|
||||||
|
AreaCommitmentTypePenaltyPerKgInput.TextBox.IsReadOnly = true;
|
||||||
|
AreaCommitmentTypePenaltyInput.TextBox.IsReadOnly = true;
|
||||||
|
AreaCommitmentTypePenaltyNoneInput.TextBox.IsReadOnly = true;
|
||||||
|
|
||||||
|
SeasonMaxKgPerHaInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonVatNormalInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonVatFlatrateInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonMinKgPerBsInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonMaxKgPerBsInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonPenaltyPerKgInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonPenaltyInput.TextBox.IsReadOnly = true;
|
||||||
|
SeasonPenaltyNoneInput.TextBox.IsReadOnly = true;
|
||||||
|
|
||||||
SeasonModifierIdInput.IsReadOnly = true;
|
SeasonModifierIdInput.IsReadOnly = true;
|
||||||
SeasonModifierNameInput.IsReadOnly = true;
|
SeasonModifierNameInput.IsReadOnly = true;
|
||||||
SeasonModifierRelInput.IsReadOnly = true;
|
SeasonModifierRelInput.TextBox.IsReadOnly = true;
|
||||||
SeasonModifierAbsInput.IsReadOnly = true;
|
SeasonModifierAbsInput.TextBox.IsReadOnly = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
new protected void UnlockInputs() {
|
new protected void UnlockInputs() {
|
||||||
base.UnlockInputs();
|
base.UnlockInputs();
|
||||||
|
|
||||||
|
BranchIdInput.IsReadOnly = false;
|
||||||
|
BranchNameInput.IsReadOnly = false;
|
||||||
|
BranchPlzInput.IsReadOnly = false;
|
||||||
|
BranchOrtInput.IsEnabled = true;
|
||||||
|
BranchAddressInput.IsReadOnly = false;
|
||||||
|
BranchPhoneNrInput.IsReadOnly = false;
|
||||||
|
BranchFaxNrInput.IsReadOnly = false;
|
||||||
|
BranchMobileNrInput.IsReadOnly = false;
|
||||||
|
|
||||||
|
WineAttributeIdInput.IsReadOnly = false;
|
||||||
|
WineAttributeNameInput.IsReadOnly = false;
|
||||||
|
WineAttributeActiveInput.IsEnabled = true;
|
||||||
|
WineAttributeMaxKgPerHaInput.TextBox.IsReadOnly = false;
|
||||||
|
WineAttributeStrictInput.IsEnabled = true;
|
||||||
|
WineAttributeFillLowerInput.IsEnabled = true;
|
||||||
|
|
||||||
|
WineCultivationIdInput.IsReadOnly = false;
|
||||||
|
WineCultivationNameInput.IsReadOnly = false;
|
||||||
|
WineCultivationDescriptionInput.IsReadOnly = false;
|
||||||
|
|
||||||
|
AreaCommitmentTypeWineVariantInput.IsEnabled = true;
|
||||||
|
AreaCommitmentTypeWineAttributeInput.IsEnabled = true;
|
||||||
|
AreaCommitmentTypeMinKgPerHaInput.TextBox.IsReadOnly = false;
|
||||||
|
AreaCommitmentTypePenaltyPerKgInput.TextBox.IsReadOnly = false;
|
||||||
|
AreaCommitmentTypePenaltyInput.TextBox.IsReadOnly = false;
|
||||||
|
AreaCommitmentTypePenaltyNoneInput.TextBox.IsReadOnly = false;
|
||||||
|
|
||||||
|
SeasonMaxKgPerHaInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonVatNormalInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonVatFlatrateInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonMinKgPerBsInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonMaxKgPerBsInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonPenaltyPerKgInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonPenaltyInput.TextBox.IsReadOnly = false;
|
||||||
|
SeasonPenaltyNoneInput.TextBox.IsReadOnly = false;
|
||||||
|
|
||||||
SeasonModifierIdInput.IsReadOnly = false;
|
SeasonModifierIdInput.IsReadOnly = false;
|
||||||
SeasonModifierNameInput.IsReadOnly = false;
|
SeasonModifierNameInput.IsReadOnly = false;
|
||||||
SeasonModifierRelInput.IsReadOnly = false;
|
SeasonModifierRelInput.TextBox.IsReadOnly = false;
|
||||||
SeasonModifierAbsInput.IsReadOnly = false;
|
SeasonModifierAbsInput.TextBox.IsReadOnly = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Window_Loaded(object sender, RoutedEventArgs evt) {
|
private void Window_Loaded(object sender, RoutedEventArgs evt) {
|
||||||
LockInputs();
|
LockInputs();
|
||||||
FillInputs(App.Client);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override async Task OnRenewContext() {
|
protected override async Task OnRenewContext() {
|
||||||
await base.OnRenewContext();
|
await base.OnRenewContext();
|
||||||
|
FillInputs(App.Client);
|
||||||
ControlUtils.RenewItemsSource(SeasonList, await Context.Seasons.OrderByDescending(s => s.Year).ToListAsync(), s => (s as Season)?.Year, null, ControlUtils.RenewSourceDefault.First);
|
ControlUtils.RenewItemsSource(SeasonList, await Context.Seasons.OrderByDescending(s => s.Year).ToListAsync(), s => (s as Season)?.Year, null, ControlUtils.RenewSourceDefault.First);
|
||||||
var year = (SeasonList.SelectedItem as Season)?.Year;
|
var year = (SeasonList.SelectedItem as Season)?.Year;
|
||||||
ControlUtils.RenewItemsSource(SeasonModifierList, await Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToListAsync(), m => (m as Modifier)?.ModId);
|
ControlUtils.RenewItemsSource(BranchList, await Context.Branches.OrderBy(b => b.Name).ToListAsync(), b => (b as Branch)?.ZwstId, null, ControlUtils.RenewSourceDefault.First);
|
||||||
|
ControlUtils.RenewItemsSource(WineAttributeList, await Context.WineAttributes.OrderBy(a => a.Name).ToListAsync(), a => (a as WineAttr)?.AttrId, null, ControlUtils.RenewSourceDefault.First);
|
||||||
|
ControlUtils.RenewItemsSource(AreaCommitmentTypeWineVariantInput, await Context.WineVarieties.OrderBy(s => s.Name).ToListAsync(), s => (s as WineVar)?.SortId);
|
||||||
|
var attrList = await Context.WineAttributes.OrderBy(a => a.Name).Cast<object>().ToListAsync();
|
||||||
|
attrList.Insert(0, new NullItem(""));
|
||||||
|
ControlUtils.RenewItemsSource(AreaCommitmentTypeWineAttributeInput, attrList, a => (a as WineAttr)?.AttrId);
|
||||||
|
ControlUtils.RenewItemsSource(AreaCommitmentTypeList, await Context.AreaCommitmentTypes.OrderBy(v => v.VtrgId).ToListAsync(), v => (v as AreaComType)?.VtrgId, null, ControlUtils.RenewSourceDefault.First);
|
||||||
|
ControlUtils.RenewItemsSource(WineCultivationList, await Context.WineCultivations.OrderBy(c => c.Name).ToListAsync(), c=> (c as WineCult)?.CultId, null, ControlUtils.RenewSourceDefault.First);
|
||||||
|
ControlUtils.RenewItemsSource(SeasonModifierList, await Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToListAsync(), m => (m as Modifier)?.ModId, null, ControlUtils.RenewSourceDefault.First);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void UpdateButtons() {
|
protected override void UpdateButtons() {
|
||||||
if (!IsEditing && !IsCreating) return;
|
if (!IsEditing && !IsCreating) return;
|
||||||
bool ch = ModifiersChanged || HasChanged, v = IsValid;
|
bool ch = _branchChanged || _attrChanged || _cultChanged || _actChanged ||
|
||||||
|
_seasonChanged || _modChanged || HasChanged,
|
||||||
|
v = IsValid;
|
||||||
CancelButton.IsEnabled = true;
|
CancelButton.IsEnabled = true;
|
||||||
ResetButton.IsEnabled = ch;
|
ResetButton.IsEnabled = ch;
|
||||||
SaveButton.IsEnabled = ch && v;
|
SaveButton.IsEnabled = ch && v;
|
||||||
|
|
||||||
|
BranchAddButton.IsEnabled = true;
|
||||||
|
BranchDeleteButton.IsEnabled = BranchList.SelectedIndex != -1;
|
||||||
|
WineAttributeAddButton.IsEnabled = true;
|
||||||
|
WineAttributeDeleteButton.IsEnabled = WineAttributeList.SelectedIndex != -1;
|
||||||
|
WineCultivationAddButton.IsEnabled = true;
|
||||||
|
WineCultivationDeleteButton.IsEnabled = WineCultivationList.SelectedIndex != -1;
|
||||||
|
AreaCommitmentTypeAddButton.IsEnabled = true;
|
||||||
|
AreaCommitmentTypeDeleteButton.IsEnabled = AreaCommitmentTypeList.SelectedIndex != -1;
|
||||||
SeasonModifierUpButton.IsEnabled = SeasonModifierList.SelectedIndex >= 1;
|
SeasonModifierUpButton.IsEnabled = SeasonModifierList.SelectedIndex >= 1;
|
||||||
SeasonModifierDownButton.IsEnabled = SeasonModifierList.SelectedIndex != -1 && SeasonModifierList.SelectedIndex < (ModifierList?.Count - 1 ?? 0);
|
SeasonModifierDownButton.IsEnabled = SeasonModifierList.SelectedIndex != -1 && SeasonModifierList.SelectedIndex < (_modList?.Count - 1 ?? 0);
|
||||||
SeasonModifierAddButton.IsEnabled = true;
|
SeasonModifierAddButton.IsEnabled = true;
|
||||||
SeasonModifierDeleteButton.IsEnabled = SeasonModifierList.SelectedIndex != -1;
|
SeasonModifierDeleteButton.IsEnabled = SeasonModifierList.SelectedIndex != -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ModifiersInitEditing() {
|
|
||||||
var year = (SeasonList.SelectedItem as Season)?.Year;
|
|
||||||
Context.ChangeTracker.Clear();
|
|
||||||
ModifierList = new(Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToList());
|
|
||||||
Modifiers = ModifierList.ToDictionary(m => m.ModId, m => m.ModId);
|
|
||||||
ModifierIds = ModifierList.ToDictionary(m => m, m => m.ModId);
|
|
||||||
ControlUtils.RenewItemsSource(SeasonModifierList, ModifierList, m => (m as Modifier)?.ModId);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ModifiersFinishEditing() {
|
|
||||||
var year = (SeasonList.SelectedItem as Season)?.Year;
|
|
||||||
ControlUtils.RenewItemsSource(SeasonModifierList, Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToList(), m => (m as Modifier)?.ModId);
|
|
||||||
ModifierList = null;
|
|
||||||
Modifiers = null;
|
|
||||||
ModifierIds = null;
|
|
||||||
ModifiersChanged = false;
|
|
||||||
|
|
||||||
SeasonModifierUpButton.IsEnabled = false;
|
|
||||||
SeasonModifierDownButton.IsEnabled = false;
|
|
||||||
SeasonModifierAddButton.IsEnabled = false;
|
|
||||||
SeasonModifierDeleteButton.IsEnabled = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private async Task ModifiersSave() {
|
|
||||||
if (!ModifiersChanged || ModifierList == null || Modifiers == null || ModifierIds == null) return;
|
|
||||||
int i = 0;
|
|
||||||
foreach (var mod in ModifierList) mod.Ordering = ++i;
|
|
||||||
|
|
||||||
var year = (SeasonList.SelectedItem as Season)?.Year;
|
|
||||||
foreach (var (modid, _) in Modifiers.Where(m => m.Value == null)) {
|
|
||||||
Context.Remove(Context.Modifiers.Find(new object?[] { year, modid }));
|
|
||||||
}
|
|
||||||
foreach (var (mod, old) in ModifierIds) {
|
|
||||||
mod.ModId = old;
|
|
||||||
}
|
|
||||||
foreach (var (old, modid) in Modifiers.Where(m => m.Value != null)) {
|
|
||||||
Context.Update(Context.Modifiers.Find(new object?[] { year, old }));
|
|
||||||
}
|
|
||||||
await Context.SaveChangesAsync();
|
|
||||||
|
|
||||||
foreach (var (old, modid) in Modifiers.Where(m => m.Value != null)) {
|
|
||||||
await Context.Database.ExecuteSqlAsync($"UPDATE modifier SET modid = {modid} WHERE (year, modid) = ({year}, {old})");
|
|
||||||
}
|
|
||||||
await Context.SaveChangesAsync();
|
|
||||||
|
|
||||||
foreach (var mod in ModifierList.Where(m => !ModifierIds.ContainsKey(m))) {
|
|
||||||
if (mod.ModId == null) continue;
|
|
||||||
await Context.AddAsync(mod);
|
|
||||||
}
|
|
||||||
await Context.SaveChangesAsync();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void EditButton_Click(object sender, RoutedEventArgs evt) {
|
private void EditButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
IsEditing = true;
|
IsEditing = true;
|
||||||
EditButton.Visibility = Visibility.Hidden;
|
EditButton.Visibility = Visibility.Hidden;
|
||||||
ResetButton.Visibility = Visibility.Visible;
|
ResetButton.Visibility = Visibility.Visible;
|
||||||
|
|
||||||
|
BranchesInitEditing();
|
||||||
|
WineAttributesInitEditing();
|
||||||
|
WineCultivationsInitEditing();
|
||||||
|
AreaCommitmentTypesInitEditing();
|
||||||
|
SeasonsInitEditing();
|
||||||
ModifiersInitEditing();
|
ModifiersInitEditing();
|
||||||
|
|
||||||
UnlockInputs();
|
UnlockInputs();
|
||||||
UpdateButtons();
|
UpdateButtons();
|
||||||
}
|
}
|
||||||
@@ -141,6 +191,13 @@ namespace Elwig.Windows {
|
|||||||
CancelButton.IsEnabled = false;
|
CancelButton.IsEnabled = false;
|
||||||
SaveButton.IsEnabled = false;
|
SaveButton.IsEnabled = false;
|
||||||
ResetButton.IsEnabled = false;
|
ResetButton.IsEnabled = false;
|
||||||
|
|
||||||
|
Context.ChangeTracker.Clear();
|
||||||
|
BranchesFinishEditing();
|
||||||
|
WineCultivationsFinishEditing();
|
||||||
|
WineAttributesFinishEditing();
|
||||||
|
AreaCommitmentTypesFinishEditing();
|
||||||
|
SeasonsFinishEditing();
|
||||||
ModifiersFinishEditing();
|
ModifiersFinishEditing();
|
||||||
|
|
||||||
ClearInputStates();
|
ClearInputStates();
|
||||||
@@ -149,8 +206,19 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void ResetButton_Click(object sender, RoutedEventArgs evt) {
|
private void ResetButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
ModifiersChanged = false;
|
_branchChanged = false;
|
||||||
|
_attrChanged = false;
|
||||||
|
_cultChanged = false;
|
||||||
|
_modChanged = false;
|
||||||
|
Context.ChangeTracker.Clear();
|
||||||
|
|
||||||
|
BranchesInitEditing();
|
||||||
|
WineAttributesInitEditing();
|
||||||
|
WineCultivationsInitEditing();
|
||||||
|
AreaCommitmentTypesInitEditing();
|
||||||
|
SeasonsInitEditing();
|
||||||
ModifiersInitEditing();
|
ModifiersInitEditing();
|
||||||
|
|
||||||
ClearInputStates();
|
ClearInputStates();
|
||||||
FillInputs(App.Client);
|
FillInputs(App.Client);
|
||||||
UpdateButtons();
|
UpdateButtons();
|
||||||
@@ -159,6 +227,11 @@ namespace Elwig.Windows {
|
|||||||
private async void SaveButton_Click(object sender, RoutedEventArgs evt) {
|
private async void SaveButton_Click(object sender, RoutedEventArgs evt) {
|
||||||
try {
|
try {
|
||||||
await UpdateClientParameters(App.Client);
|
await UpdateClientParameters(App.Client);
|
||||||
|
await BranchesSave();
|
||||||
|
await WineAttributesSave();
|
||||||
|
await WineCultivationsSave();
|
||||||
|
await AreaCommitmentTypesSave();
|
||||||
|
await SeasonsSave();
|
||||||
await ModifiersSave();
|
await ModifiersSave();
|
||||||
} 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;
|
||||||
@@ -173,6 +246,12 @@ namespace Elwig.Windows {
|
|||||||
CancelButton.IsEnabled = false;
|
CancelButton.IsEnabled = false;
|
||||||
SaveButton.IsEnabled = false;
|
SaveButton.IsEnabled = false;
|
||||||
ResetButton.IsEnabled = false;
|
ResetButton.IsEnabled = false;
|
||||||
|
|
||||||
|
BranchesFinishEditing();
|
||||||
|
WineAttributesFinishEditing();
|
||||||
|
WineCultivationsFinishEditing();
|
||||||
|
AreaCommitmentTypesFinishEditing();
|
||||||
|
SeasonsFinishEditing();
|
||||||
ModifiersFinishEditing();
|
ModifiersFinishEditing();
|
||||||
|
|
||||||
ClearInputStates();
|
ClearInputStates();
|
||||||
@@ -238,123 +317,10 @@ namespace Elwig.Windows {
|
|||||||
await p.UpdateValues();
|
await p.UpdateValues();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SeasonModifierUpButton_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (ModifierList == null) return;
|
|
||||||
ModifiersChanged = true;
|
|
||||||
var idx = SeasonModifierList.SelectedIndex;
|
|
||||||
var item = ModifierList[idx];
|
|
||||||
ModifierList.RemoveAt(idx);
|
|
||||||
idx--;
|
|
||||||
ModifierList.Insert(idx, item);
|
|
||||||
SeasonModifierList.SelectedIndex = idx;
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierDownButton_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (ModifierList == null) return;
|
|
||||||
ModifiersChanged = true;
|
|
||||||
var idx = SeasonModifierList.SelectedIndex;
|
|
||||||
var item = ModifierList[idx];
|
|
||||||
ModifierList.RemoveAt(idx);
|
|
||||||
idx++;
|
|
||||||
ModifierList.Insert(idx, item);
|
|
||||||
SeasonModifierList.SelectedIndex = idx;
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierAddButton_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (ModifierList == null || SeasonList.SelectedItem is not Season s) return;
|
|
||||||
ModifiersChanged = true;
|
|
||||||
var idx = (SeasonModifierList.SelectedIndex != -1) ? SeasonModifierList.SelectedIndex + 1 : ModifierList.Count;
|
|
||||||
var item = Context.CreateProxy<Modifier>();
|
|
||||||
item.Year = s.Year;
|
|
||||||
ModifierList.Insert(idx, item);
|
|
||||||
SeasonModifierList.SelectedIndex = idx;
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierDeleteButton_Click(object sender, RoutedEventArgs evt) {
|
|
||||||
if (ModifierList == null || Modifiers == null) return;
|
|
||||||
ModifiersChanged = true;
|
|
||||||
var idx = SeasonModifierList.SelectedIndex;
|
|
||||||
var item = ModifierList[idx];
|
|
||||||
Modifiers[item.ModId] = null;
|
|
||||||
ModifierList.RemoveAt(idx);
|
|
||||||
SeasonModifierList.SelectedIndex = idx < ModifierList.Count ? idx : idx - 1;
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private void ClientNames_TextChanged(object sender, TextChangedEventArgs evt) {
|
private void ClientNames_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
var suffix = ClientNameSuffixInput.Text.Length > 0 ? ClientNameSuffixInput.Text : null;
|
var suffix = ClientNameSuffixInput.Text.Length > 0 ? ClientNameSuffixInput.Text : null;
|
||||||
ClientNameFull.Text = $"{ClientNameInput.Text}{(suffix != null ? $", {suffix}," : "")} {ClientNameTypeInput.Text}";
|
ClientNameFull.Text = $"{ClientNameInput.Text}{(suffix != null ? $", {suffix}," : "")} {ClientNameTypeInput.Text}";
|
||||||
TextBox_TextChanged(sender, evt);
|
TextBox_TextChanged(sender, evt);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void SeasonList_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
|
||||||
var year = (SeasonList.SelectedItem as Season)?.Year;
|
|
||||||
SeasonModifierList.ItemsSource = await Context.Modifiers.Where(m => m.Year == year).OrderBy(m => m.Ordering).ToListAsync();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierList_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
|
||||||
UpdateButtons();
|
|
||||||
ModifierUpdate = true;
|
|
||||||
if (SeasonModifierList.SelectedItem is not Modifier mod) {
|
|
||||||
SeasonModifierIdInput.Text = "";
|
|
||||||
SeasonModifierNameInput.Text = "";
|
|
||||||
SeasonModifierRelInput.Text = "";
|
|
||||||
SeasonModifierAbsInput.Text = "";
|
|
||||||
} else {
|
|
||||||
SeasonModifierIdInput.Text = mod.ModId;
|
|
||||||
SeasonModifierNameInput.Text = mod.Name;
|
|
||||||
SeasonModifierRelInput.Text = (mod.Rel * 100)?.ToString();
|
|
||||||
SeasonModifierAbsInput.Text = mod.Abs?.ToString();
|
|
||||||
}
|
|
||||||
ModifierUpdate = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierIdInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
|
||||||
if ((!IsEditing && !IsCreating) || SeasonModifierList.SelectedItem is not Modifier mod || Modifiers == null || ModifierIds == null) return;
|
|
||||||
ModifiersChanged = ModifiersChanged || (SeasonModifierIdInput.Text ?? "") != ((SeasonModifierList.SelectedItem as Modifier)?.ModId ?? "");
|
|
||||||
if (ModifierUpdate) return;
|
|
||||||
var old = ModifierIds.GetValueOrDefault(mod);
|
|
||||||
var id = SeasonModifierIdInput.Text ?? "";
|
|
||||||
if (old != null) Modifiers[old] = id;
|
|
||||||
mod.ModId = id;
|
|
||||||
CollectionViewSource.GetDefaultView(ModifierList).Refresh();
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierNameInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
|
||||||
if ((!IsEditing && !IsCreating) || SeasonModifierList.SelectedItem is not Modifier mod) return;
|
|
||||||
ModifiersChanged = ModifiersChanged || (SeasonModifierNameInput.Text ?? "") != ((SeasonModifierList.SelectedItem as Modifier)?.Name ?? "");
|
|
||||||
if (ModifierUpdate) return;
|
|
||||||
mod.Name = SeasonModifierNameInput.Text ?? "";
|
|
||||||
CollectionViewSource.GetDefaultView(ModifierList).Refresh();
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierRelInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
|
||||||
// DecimalInput_TextChanged(sender, evt); FIXME '-' is ignored
|
|
||||||
if ((!IsEditing && !IsCreating) || SeasonModifierList.SelectedItem is not Modifier mod) return;
|
|
||||||
ModifiersChanged = ModifiersChanged || (SeasonModifierRelInput.Text ?? "") != ((SeasonModifierList.SelectedItem as Modifier)?.Rel?.ToString() ?? "");
|
|
||||||
if (ModifierUpdate) return;
|
|
||||||
mod.Rel = decimal.TryParse(SeasonModifierRelInput.Text, out var v) ? v / 100 : null;
|
|
||||||
if (mod.Rel != null) SeasonModifierAbsInput.Text = "";
|
|
||||||
CollectionViewSource.GetDefaultView(ModifierList).Refresh();
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SeasonModifierAbsInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
|
||||||
// DecimalInput_TextChanged(sender, evt); FIXME '-' is ignored
|
|
||||||
if ((!IsEditing && !IsCreating) || SeasonModifierList.SelectedItem is not Modifier mod || SeasonList.SelectedItem is not Season s) return;
|
|
||||||
ModifiersChanged = ModifiersChanged || (SeasonModifierAbsInput.Text ?? "") != ((SeasonModifierList.SelectedItem as Modifier)?.Abs?.ToString() ?? "");
|
|
||||||
if (ModifierUpdate) return;
|
|
||||||
// FIXME ValueStr does not work in ModifierList when modifier is newly created
|
|
||||||
mod.AbsValue = decimal.TryParse(SeasonModifierAbsInput.Text, out var v) ? Utils.DecToDb(v, s.Precision) : null;
|
|
||||||
if (mod.AbsValue != null) SeasonModifierRelInput.Text = "";
|
|
||||||
CollectionViewSource.GetDefaultView(ModifierList).Refresh();
|
|
||||||
UpdateButtons();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -375,7 +375,7 @@ namespace Elwig.Windows {
|
|||||||
OechslePricePlot.Plot.Legend(false, Alignment.UpperRight);
|
OechslePricePlot.Plot.Legend(false, Alignment.UpperRight);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OechsleInput_TextChanged(object sender, RoutedEventArgs evt) {
|
private void OechsleInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
IntegerInput_TextChanged(sender, evt);
|
IntegerInput_TextChanged(sender, evt);
|
||||||
|
|
||||||
bool success = int.TryParse(OechsleInput.Text, out int oechsle);
|
bool success = int.TryParse(OechsleInput.Text, out int oechsle);
|
||||||
|
|||||||
@@ -31,8 +31,8 @@ namespace Elwig.Windows {
|
|||||||
await RenewContext();
|
await RenewContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnLoaded(object sender, RoutedEventArgs evt) {
|
protected async void OnLoaded(object sender, RoutedEventArgs evt) {
|
||||||
OnRenewContext().GetAwaiter().GetResult();
|
await OnRenewContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnClosed(EventArgs evt) {
|
protected override void OnClosed(EventArgs evt) {
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
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:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
|
xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
|
||||||
Title="Lieferungen - Elwig" Height="720" Width="1100" MinHeight="720" MinWidth="1000"
|
Title="Lieferungen - Elwig" Height="720" Width="1100" MinHeight="720" MinWidth="1000"
|
||||||
Loaded="Window_Loaded">
|
Loaded="Window_Loaded">
|
||||||
@@ -93,7 +94,7 @@
|
|||||||
<TextBox x:Name="SearchInput" Grid.ColumnSpan="3" Margin="5,10,161,0" IsReadOnly="False"
|
<TextBox x:Name="SearchInput" Grid.ColumnSpan="3" Margin="5,10,161,0" IsReadOnly="False"
|
||||||
TextChanged="SearchInput_TextChanged"
|
TextChanged="SearchInput_TextChanged"
|
||||||
ToolTip="Lieferungen filtern und durchsuchen. Die Filter sind beliebig kombinierbar.

Filtern nach:
Sorte: z.B. GV, ZW, rr, sa, !gv (ausgenommen GV), ...
Qualitätsstufe: z.B. QUW, kab, ldw, ...
Gradation: z.B. >73, <15, 17-18, 15-, >17,5, 62-75, ...
Mitglied: z.B. 1234, 987, ...
Saison: z.B. 2020, >2015, 2017-2019, <2005, 2019-, ...
Zweigstelle: z.B. musterort, ...
Attribute: z.B. kabinett, !kabinett (alle außer kabinett), ...
Datum: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...
Uhrzeit: z.B. 06:00-08:00, 18:00-, ...
Freitext: z.B. Lieferscheinnummern, "quw" (sucht nach dem Text "quw")"/>
|
ToolTip="Lieferungen filtern und durchsuchen. Die Filter sind beliebig kombinierbar.

Filtern nach:
Sorte: z.B. GV, ZW, rr, sa, !gv (ausgenommen GV), ...
Qualitätsstufe: z.B. QUW, kab, ldw, ...
Gradation: z.B. >73, <15, 17-18, 15-, >17,5, 62-75, ...
Mitglied: z.B. 1234, 987, ...
Saison: z.B. 2020, >2015, 2017-2019, <2005, 2019-, ...
Zweigstelle: z.B. musterort, ...
Attribute: z.B. kabinett, !kabinett (alle außer kabinett), ...
Datum: z.B. 1.9., 15.9.-10.10., -15.10.2020, ...
Uhrzeit: z.B. 06:00-08:00, 18:00-, ...
Freitext: z.B. Lieferscheinnummern, "quw" (sucht nach dem Text "quw")"/>
|
||||||
<xctk:IntegerUpDown Name="SeasonInput" Grid.ColumnSpan="3" Height="25" Width="56" FontSize="14" Minimum="1000" Maximum="9999"
|
<xctk:IntegerUpDown x:Name="SeasonInput" Grid.ColumnSpan="3" Height="25" Width="56" FontSize="14" Minimum="1000" Maximum="9999"
|
||||||
Margin="0,10,100,0" VerticalAlignment="Top" HorizontalAlignment="Right"
|
Margin="0,10,100,0" VerticalAlignment="Top" HorizontalAlignment="Right"
|
||||||
ValueChanged="SeasonInput_ValueChanged"/>
|
ValueChanged="SeasonInput_ValueChanged"/>
|
||||||
<CheckBox x:Name="TodayOnlyInput" Content="Nur heute"
|
<CheckBox x:Name="TodayOnlyInput" Content="Nur heute"
|
||||||
@@ -285,17 +286,12 @@
|
|||||||
<ColumnDefinition/>
|
<ColumnDefinition/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Label Content="Gradation:" Margin="10,10,10,10"/>
|
<Label Content="Gradation:" Margin="10,10,10,10"/>
|
||||||
<Grid Grid.Column="1" Width="54" Height="25" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top">
|
<ctrl:UnitTextBox x:Name="GradationOeInput" Unit="°Oe" TextChanged="GradationOeInput_TextChanged" KeyUp="Input_KeyUp"
|
||||||
<TextBox x:Name="GradationOeInput" TextAlignment="Right" Padding="2,2,23,2"
|
Grid.Column="1" Width="54" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
TextChanged="GradationOeInput_TextChanged" LostFocus="GradationOeInput_LostFocus" KeyUp="Input_KeyUp"/>
|
|
||||||
<Label Content="°Oe" Margin="0,4,3,0" HorizontalAlignment="Right" FontSize="10"/>
|
|
||||||
</Grid>
|
|
||||||
<Label Content="=" Margin="60,10,10,10" Grid.Column="1"/>
|
<Label Content="=" Margin="60,10,10,10" Grid.Column="1"/>
|
||||||
<Grid Grid.Column="1" Width="68" Height="25" Margin="78,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top">
|
<ctrl:UnitTextBox x:Name="GradationKmwInput" Unit="°KMW" TextChanged="GradationKmwInput_TextChanged" KeyUp="Input_KeyUp"
|
||||||
<TextBox x:Name="GradationKmwInput" TextAlignment="Right" Padding="2,2,34,2" SnapsToDevicePixels="True"
|
Grid.Column="1" Width="68" Margin="78,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
TextChanged="GradationKmwInput_TextChanged" LostFocus="GradationKmwInput_LostFocus" KeyUp="Input_KeyUp"/>
|
|
||||||
<Label Content="°KMW" Margin="0,4,3,0" HorizontalAlignment="Right" FontSize="10"/>
|
|
||||||
</Grid>
|
|
||||||
|
|
||||||
<Label Content="Qualitätsstufe:" Margin="10,40,10,10"/>
|
<Label Content="Qualitätsstufe:" Margin="10,40,10,10"/>
|
||||||
<ComboBox x:Name="WineQualityLevelInput" Width="146" Margin="0,40,10,10" Grid.Column="1" HorizontalAlignment="Left"
|
<ComboBox x:Name="WineQualityLevelInput" Width="146" Margin="0,40,10,10" Grid.Column="1" HorizontalAlignment="Left"
|
||||||
@@ -315,11 +311,8 @@
|
|||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<Label Content="Gewicht:" Margin="10,10,10,10"/>
|
<Label Content="Gewicht:" Margin="10,10,10,10"/>
|
||||||
<Grid Grid.Column="1" Width="70" Height="25" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top">
|
<ctrl:UnitTextBox x:Name="WeightInput" Unit="kg" TextChanged="WeightInput_TextChanged"
|
||||||
<TextBox x:Name="WeightInput" TextAlignment="Right" Padding="2,2,17,2" IsReadOnly="True"
|
Grid.Column="1" Width="70" Margin="0,10,10,10" HorizontalAlignment="Left" VerticalAlignment="Top"/>
|
||||||
TextChanged="WeightInput_TextChanged"/>
|
|
||||||
<Label Content="kg" Margin="0,4,3,0" HorizontalAlignment="Right" FontSize="10"/>
|
|
||||||
</Grid>
|
|
||||||
|
|
||||||
<CheckBox x:Name="ManualWeighingInput" Content="Handwiegung" IsEnabled="False"
|
<CheckBox x:Name="ManualWeighingInput" Content="Handwiegung" IsEnabled="False"
|
||||||
VerticalAlignment="Top" HorizontalAlignment="Left" Margin="10,45,10,10" Grid.Column="0" Grid.ColumnSpan="2"
|
VerticalAlignment="Top" HorizontalAlignment="Left" Margin="10,45,10,10" Grid.Column="0" Grid.ColumnSpan="2"
|
||||||
@@ -365,18 +358,14 @@
|
|||||||
TextChanged="TextBox_TextChanged"/>
|
TextChanged="TextBox_TextChanged"/>
|
||||||
|
|
||||||
<Label Content="Temperatur:" Margin="10,70,0,10"/>
|
<Label Content="Temperatur:" Margin="10,70,0,10"/>
|
||||||
<Grid Grid.Column="1" Height="25" Margin="0,70,10,10" VerticalAlignment="Top">
|
<ctrl:UnitTextBox x:Name="TemperatureInput" Unit="°C"
|
||||||
<TextBox x:Name="TemperatureInput" TextAlignment="Right" Padding="2,2,16,2"
|
TextChanged="TemperatureAcidInput_TextChanged" LostFocus="TemperatureAcidInput_LostFocus"
|
||||||
TextChanged="TemperatureAcidInput_TextChanged" LostFocus="TemperatureAcidInput_LostFocus"/>
|
Grid.Column="1" Margin="0,70,10,10" VerticalAlignment="Top"/>
|
||||||
<Label Content="°C" Margin="0,4,3,0" HorizontalAlignment="Right" FontSize="10"/>
|
|
||||||
</Grid>
|
|
||||||
|
|
||||||
<Label Content="Säure:" Margin="10,100,0,10"/>
|
<Label Content="Säure:" Margin="10,100,0,10"/>
|
||||||
<Grid Grid.Column="1" Height="25" Margin="0,100,10,10" VerticalAlignment="Top">
|
<ctrl:UnitTextBox x:Name="AcidInput" Unit="g/l"
|
||||||
<TextBox x:Name="AcidInput" TextAlignment="Right" Padding="2,2,19,2"
|
TextChanged="TemperatureAcidInput_TextChanged" LostFocus="TemperatureAcidInput_LostFocus"
|
||||||
TextChanged="TemperatureAcidInput_TextChanged" LostFocus="TemperatureAcidInput_LostFocus"/>
|
Grid.Column="1" Margin="0,100,10,10" VerticalAlignment="Top"/>
|
||||||
<Label Content="g/l" Margin="0,4,3,0" HorizontalAlignment="Right" FontSize="10"/>
|
|
||||||
</Grid>
|
|
||||||
|
|
||||||
<CheckBox x:Name="LesewagenInput" Content="Lesewagen" Margin="10,75,0,0" Grid.Column="2"
|
<CheckBox x:Name="LesewagenInput" Content="Lesewagen" Margin="10,75,0,0" Grid.Column="2"
|
||||||
VerticalAlignment="Top" HorizontalAlignment="Left"
|
VerticalAlignment="Top" HorizontalAlignment="Left"
|
||||||
@@ -465,23 +454,47 @@
|
|||||||
</ItemsPanelTemplate>
|
</ItemsPanelTemplate>
|
||||||
</StatusBar.ItemsPanel>
|
</StatusBar.ItemsPanel>
|
||||||
<StatusBarItem>
|
<StatusBarItem>
|
||||||
<TextBlock Name="StatusMembers" Text="Mitglieder: -"/>
|
<TextBlock x:Name="StatusMembers" Text="Mitglieder: -"/>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="1"/>
|
<Separator Grid.Column="1"/>
|
||||||
<StatusBarItem Grid.Column="2">
|
<StatusBarItem Grid.Column="2">
|
||||||
<TextBlock Name="StatusDeliveries" Text="Lieferungen: -"/>
|
<TextBlock x:Name="StatusDeliveries" Text="Lieferungen: -"/>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="3"/>
|
<Separator Grid.Column="3"/>
|
||||||
<StatusBarItem Grid.Column="4">
|
<StatusBarItem Grid.Column="4">
|
||||||
<TextBlock Name="StatusVarieties" Text="Sorten: -"/>
|
<TextBlock x:Name="StatusVarieties" Text="Sorten: -"/>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="5"/>
|
<Separator Grid.Column="5"/>
|
||||||
<StatusBarItem Grid.Column="6">
|
<StatusBarItem Grid.Column="6">
|
||||||
<TextBlock Name="StatusWeight" Text="Gewicht: -"/>
|
<TextBlock x:Name="StatusWeight" Text="Gewicht: -">
|
||||||
|
<TextBlock.ToolTip>
|
||||||
|
<Grid x:Name="StatusWeightToolTip">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="10"/>
|
||||||
|
<ColumnDefinition Width="60"/>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="50"/>
|
||||||
|
<ColumnDefinition Width="50"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
</Grid>
|
||||||
|
</TextBlock.ToolTip>
|
||||||
|
</TextBlock>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
<Separator Grid.Column="7"/>
|
<Separator Grid.Column="7"/>
|
||||||
<StatusBarItem Grid.Column="8">
|
<StatusBarItem Grid.Column="8">
|
||||||
<TextBlock Name="StatusGradation" Text="Gradation: -"/>
|
<TextBlock x:Name="StatusGradation" Text="Gradation: -">
|
||||||
|
<TextBlock.ToolTip>
|
||||||
|
<Grid x:Name="StatusGradationToolTip">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="10"/>
|
||||||
|
<ColumnDefinition Width="60"/>
|
||||||
|
<ColumnDefinition Width="35"/>
|
||||||
|
<ColumnDefinition Width="35"/>
|
||||||
|
<ColumnDefinition Width="35"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
</Grid>
|
||||||
|
</TextBlock.ToolTip>
|
||||||
|
</TextBlock>
|
||||||
</StatusBarItem>
|
</StatusBarItem>
|
||||||
</StatusBar>
|
</StatusBar>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -40,9 +40,9 @@ namespace Elwig.Windows {
|
|||||||
MgNrInput, MemberInput,
|
MgNrInput, MemberInput,
|
||||||
LsNrInput, DateInput, BranchInput,
|
LsNrInput, DateInput, BranchInput,
|
||||||
SortIdInput, WineVarietyInput,
|
SortIdInput, WineVarietyInput,
|
||||||
GradationOeInput, GradationKmwInput, WineQualityLevelInput,
|
GradationOeInput.TextBox, GradationKmwInput.TextBox, WineQualityLevelInput,
|
||||||
WineOriginInput, WineKgInput,
|
WineOriginInput, WineKgInput,
|
||||||
WeightInput
|
WeightInput.TextBox
|
||||||
};
|
};
|
||||||
ExemptInputs = new Control[] {
|
ExemptInputs = new Control[] {
|
||||||
SearchInput, SeasonInput, TodayOnlyInput, AllSeasonsInput,
|
SearchInput, SeasonInput, TodayOnlyInput, AllSeasonsInput,
|
||||||
@@ -282,7 +282,7 @@ namespace Elwig.Windows {
|
|||||||
SortIdInput.SelectAll();
|
SortIdInput.SelectAll();
|
||||||
} else if (ctrl == SortIdInput || ctrl == WineVarietyInput || ctrl == AttributeInput) {
|
} else if (ctrl == SortIdInput || ctrl == WineVarietyInput || ctrl == AttributeInput) {
|
||||||
GradationOeInput.Focus();
|
GradationOeInput.Focus();
|
||||||
GradationOeInput.SelectAll();
|
GradationOeInput.TextBox.SelectAll();
|
||||||
} else if (ctrl == GradationKmwInput || ctrl == GradationOeInput || ctrl == WineQualityLevelInput) {
|
} else if (ctrl == GradationKmwInput || ctrl == GradationOeInput || ctrl == WineQualityLevelInput) {
|
||||||
if (WeighingAButton.IsVisible) WeighingAButton.Focus();
|
if (WeighingAButton.IsVisible) WeighingAButton.Focus();
|
||||||
else WeighingManualButton.Focus();
|
else WeighingManualButton.Focus();
|
||||||
@@ -519,6 +519,38 @@ namespace Elwig.Windows {
|
|||||||
return (filterNames, dpq.Select(p => p.Delivery).Distinct().OrderBy(d => d.DateString).ThenBy(d => d.TimeString), dpq, filter);
|
return (filterNames, dpq.Select(p => p.Delivery).Distinct().OrderBy(d => d.DateString).ThenBy(d => d.TimeString), dpq, filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void AddToolTipCell(Grid grid, string text, int row, int col, int colSpan = 1, bool bold = false, bool alignRight = false, bool alignCenter = false) {
|
||||||
|
var tb = new TextBlock() {
|
||||||
|
Text = text,
|
||||||
|
TextAlignment = alignRight ? TextAlignment.Right : alignCenter ? TextAlignment.Center : TextAlignment.Left,
|
||||||
|
Margin = new(0, 12 * row, 0, 0),
|
||||||
|
FontWeight = bold ? FontWeights.Bold : FontWeights.Normal,
|
||||||
|
};
|
||||||
|
tb.SetValue(Grid.ColumnProperty, col);
|
||||||
|
tb.SetValue(Grid.ColumnSpanProperty, colSpan);
|
||||||
|
grid.Children.Add(tb);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AddWeightToolTipRow(int row, string? h1, string? h2, int weight, int? total1, int total2) {
|
||||||
|
var bold = h2 == null;
|
||||||
|
if (h1 != null) AddToolTipCell(StatusWeightToolTip, h1 + ":", row, 0, (h2 == null) ? 2 : 1, bold);
|
||||||
|
if (h2 != null) AddToolTipCell(StatusWeightToolTip, h2 + ":", row, 1, 1, bold);
|
||||||
|
AddToolTipCell(StatusWeightToolTip, $"{weight:N0} kg", row, 2, 1, bold, true);
|
||||||
|
if (total1 != null && total1 != 0)
|
||||||
|
AddToolTipCell(StatusWeightToolTip, $"{weight * 100.0 / total1:N1} %", row, 3, 1, bold, true);
|
||||||
|
if (total2 != 0)
|
||||||
|
AddToolTipCell(StatusWeightToolTip, $"{weight * 100.0 / total2:N1} %", row, 4, 1, bold, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AddGradationToolTipRow(int row, string? h1, string? h2, double min, double avg, double max) {
|
||||||
|
var bold = h2 == null;
|
||||||
|
if (h1 != null) AddToolTipCell(StatusGradationToolTip, h1 + ":", row, 0, (h2 == null) ? 2 : 1, bold);
|
||||||
|
if (h2 != null) AddToolTipCell(StatusGradationToolTip, h2 + ":", row, 1, 1, bold);
|
||||||
|
AddToolTipCell(StatusGradationToolTip, $"{min:N1}°", row, 2, 1, bold, true);
|
||||||
|
AddToolTipCell(StatusGradationToolTip, $"{avg:N1}°", row, 3, 1, bold, true);
|
||||||
|
AddToolTipCell(StatusGradationToolTip, $"{max:N1}°", row, 4, 1, bold, true);
|
||||||
|
}
|
||||||
|
|
||||||
private async Task RefreshDeliveryListQuery(bool updateSort = false) {
|
private async Task RefreshDeliveryListQuery(bool updateSort = false) {
|
||||||
var (_, deliveryQuery, deliveryPartsQuery, filter) = await GetFilters();
|
var (_, deliveryQuery, deliveryPartsQuery, filter) = await GetFilters();
|
||||||
var deliveries = await deliveryQuery.ToListAsync();
|
var deliveries = await deliveryQuery.ToListAsync();
|
||||||
@@ -551,47 +583,99 @@ namespace Elwig.Windows {
|
|||||||
var varieties = await deliveryParts.Select(d => d.SortId).Distinct().ToListAsync();
|
var varieties = await deliveryParts.Select(d => d.SortId).Distinct().ToListAsync();
|
||||||
StatusVarieties.Text = $"Sorten: {varieties.Count}" + (varieties.Count > 0 && varieties.Count <= 10 ? $" ({string.Join(", ", varieties)})" : "");
|
StatusVarieties.Text = $"Sorten: {varieties.Count}" + (varieties.Count > 0 && varieties.Count <= 10 ? $" ({string.Join(", ", varieties)})" : "");
|
||||||
|
|
||||||
|
StatusWeightToolTip.Children.Clear();
|
||||||
|
StatusGradationToolTip.Children.Clear();
|
||||||
|
|
||||||
var weight = await deliveryParts.SumAsync(p => p.Weight);
|
var weight = await deliveryParts.SumAsync(p => p.Weight);
|
||||||
StatusWeight.Text = $"Gewicht: {weight:N0} kg";
|
StatusWeight.Text = $"Gewicht: {weight:N0} kg";
|
||||||
|
AddWeightToolTipRow(0, "Gewicht", null, weight, null, weight);
|
||||||
|
|
||||||
if (n > 0) {
|
if (n > 0) {
|
||||||
var kmwMin = await deliveryParts.MinAsync(p => p.Kmw);
|
var kmwMin = await deliveryParts.MinAsync(p => p.Kmw);
|
||||||
var kmwAvg = Utils.AggregateDeliveryPartsKmw(deliveryParts);
|
var kmwAvg = Utils.AggregateDeliveryPartsKmw(deliveryParts);
|
||||||
var kmwMax = await deliveryParts.MaxAsync(p => p.Kmw);
|
var kmwMax = await deliveryParts.MaxAsync(p => p.Kmw);
|
||||||
StatusGradation.Text = $"Gradation: {kmwMin:N1}° / {kmwAvg:N1}° / {kmwMax:N1}°";
|
StatusGradation.Text = $"Gradation: {kmwMin:N1}° / {kmwAvg:N1}° / {kmwMax:N1}°";
|
||||||
} else {
|
AddToolTipCell(StatusGradationToolTip, "Min.", 0, 2, 1, false, false, true);
|
||||||
StatusGradation.Text = "Gradation: -";
|
AddToolTipCell(StatusGradationToolTip, "⌀", 0, 3, 1, false, false, true);
|
||||||
}
|
AddToolTipCell(StatusGradationToolTip, "Max.", 0, 4, 1, false, false, true);
|
||||||
|
AddGradationToolTipRow(1, "Gradation", null, kmwMin, kmwAvg, kmwMax);
|
||||||
|
|
||||||
if (n > 0 && (n <= 200 || TodayOnlyInput.IsChecked == true)) {
|
var attrGroups = await deliveryParts
|
||||||
var parts = await deliveryParts.ToListAsync();
|
.GroupBy(p => p.Attribute.Name)
|
||||||
var groups = parts
|
.Select(g => new {
|
||||||
.GroupBy(p => p.Attribute?.Name)
|
Attr = g.Key,
|
||||||
.Select(g => (g.Key, g.Sum(p => p.Weight), g.Min(p => p.Kmw), Utils.AggregateDeliveryPartsKmw(g), g.Max(p => p.Kmw)))
|
Weight = g.Sum(p => p.Weight),
|
||||||
.OrderByDescending(g => g.Item2)
|
Min = g.Min(p => p.Kmw),
|
||||||
.ToList();
|
Avg = g.Sum(p => p.Kmw * p.Weight) / g.Sum(p => p.Weight),
|
||||||
|
Max = g.Max(p => p.Kmw),
|
||||||
|
})
|
||||||
|
.OrderByDescending(g => g.Weight)
|
||||||
|
.ThenBy(g => g.Attr)
|
||||||
|
.ToListAsync();
|
||||||
|
var sortGroups = await deliveryParts
|
||||||
|
.GroupBy(p => p.SortId)
|
||||||
|
.Select(g => new {
|
||||||
|
SortId = g.Key,
|
||||||
|
Weight = g.Sum(p => p.Weight),
|
||||||
|
Min = g.Min(p => p.Kmw),
|
||||||
|
Avg = g.Sum(p => p.Kmw * p.Weight) / g.Sum(p => p.Weight),
|
||||||
|
Max = g.Max(p => p.Kmw),
|
||||||
|
})
|
||||||
|
.OrderByDescending(g => g.Weight)
|
||||||
|
.ThenBy(g => g.SortId)
|
||||||
|
.ToListAsync();
|
||||||
|
var groups = await deliveryParts
|
||||||
|
.GroupBy(p => new {
|
||||||
|
p.Attribute.Name,
|
||||||
|
p.SortId,
|
||||||
|
})
|
||||||
|
.Select(g => new {
|
||||||
|
Attr = g.Key.Name,
|
||||||
|
g.Key.SortId,
|
||||||
|
Weight = g.Sum(p => p.Weight),
|
||||||
|
Min = g.Min(p => p.Kmw),
|
||||||
|
Avg = g.Sum(p => p.Kmw * p.Weight) / g.Sum(p => p.Weight),
|
||||||
|
Max = g.Max(p => p.Kmw)
|
||||||
|
})
|
||||||
|
.OrderByDescending(g => g.SortId)
|
||||||
|
.ThenBy(g => g.Attr)
|
||||||
|
.ThenBy(g => g.SortId)
|
||||||
|
.ToListAsync();
|
||||||
|
|
||||||
if (groups.Count == 1) {
|
int rowNum = 1;
|
||||||
var g = groups.First().Key;
|
foreach (var attrG in attrGroups) {
|
||||||
if (g != "") {
|
rowNum++;
|
||||||
|
AddWeightToolTipRow(rowNum++, attrG.Attr, null, attrG.Weight, attrG.Weight, weight);
|
||||||
|
foreach (var g in groups.Where(g => g.Attr == attrG.Attr).OrderByDescending(g => g.Weight).ThenBy(g => g.SortId)) {
|
||||||
|
AddWeightToolTipRow(rowNum++, null, g.SortId, g.Weight, attrG.Weight, weight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rowNum = 2;
|
||||||
|
foreach (var attrG in attrGroups) {
|
||||||
|
rowNum++;
|
||||||
|
AddGradationToolTipRow(rowNum++, attrG.Attr, null, attrG.Min, attrG.Avg, attrG.Max);
|
||||||
|
foreach (var g in groups.Where(g => g.Attr == attrG.Attr).OrderByDescending(g => g.Avg).ThenBy(g => g.SortId)) {
|
||||||
|
AddGradationToolTipRow(rowNum++, null, g.SortId, g.Min, g.Avg, g.Max);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (attrGroups.Count == 1) {
|
||||||
|
var g = attrGroups.First().Attr;
|
||||||
|
if (g != null) {
|
||||||
StatusWeight.Text += $" [{g}]";
|
StatusWeight.Text += $" [{g}]";
|
||||||
StatusGradation.Text += $" [{g}]";
|
StatusGradation.Text += $" [{g}]";
|
||||||
}
|
}
|
||||||
|
|
||||||
var sortGroups = parts
|
|
||||||
.GroupBy(p => p.SortId)
|
|
||||||
.Select(g => (g.Key, g.Sum(p => p.Weight), g.Min(p => p.Kmw), Utils.AggregateDeliveryPartsKmw(g), g.Max(p => p.Kmw)))
|
|
||||||
.OrderByDescending(g => g.Item2)
|
|
||||||
.ToList();
|
|
||||||
|
|
||||||
if (sortGroups.Count > 1 && sortGroups.Count <= 4) {
|
if (sortGroups.Count > 1 && sortGroups.Count <= 4) {
|
||||||
StatusWeight.Text += $" = {string.Join(" + ", sortGroups.Select(g => $"{g.Item2:N0} kg ({(double)g.Item2 / weight:0%})" + (g.Key == "" ? "" : $" [{g.Key}]")))}";
|
StatusWeight.Text += $" = {string.Join(" + ", sortGroups.Select(g => $"{g.Weight:N0} kg ({(double)g.Weight / weight:0%})" + (g.SortId == null ? "" : $" [{g.SortId}]")))}";
|
||||||
StatusGradation.Text += $" = {string.Join(" + ", sortGroups.Select(g => $"{g.Item3:N1}/{g.Item4:N1}/{g.Item5:N1}" + (g.Key == "" ? "" : $" [{g.Key}]")))}";
|
StatusGradation.Text += $" = {string.Join(" + ", sortGroups.Select(g => $"{g.Min:N1}/{g.Avg:N1}/{g.Max:N1}" + (g.SortId == null ? "" : $" [{g.SortId}]")))}";
|
||||||
|
|
||||||
}
|
}
|
||||||
} else if (groups.Count <= 4) {
|
} else if (attrGroups.Count <= 4) {
|
||||||
StatusWeight.Text += $" = {string.Join(" + ", groups.Select(g => $"{g.Item2:N0} kg ({(double)g.Item2 / weight:0%})" + (g.Key == "" ? "" : $" [{g.Key}]")))}";
|
StatusWeight.Text += $" = {string.Join(" + ", attrGroups.Select(g => $"{g.Weight:N0} kg ({(double)g.Weight / weight:0%})" + (g.Attr == null ? "" : $" [{g.Attr}]")))}";
|
||||||
StatusGradation.Text += $" = {string.Join(" + ", groups.Select(g => $"{g.Item3:N1}/{g.Item4:N1}/{g.Item5:N1}" + (g.Key == "" ? "" : $" [{g.Key}]")))}";
|
StatusGradation.Text += $" = {string.Join(" + ", attrGroups.Select(g => $"{g.Min:N1}/{g.Avg:N1}/{g.Max:N1}" + (g.Attr == null ? "" : $" [{g.Attr}]")))}";
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
StatusGradation.Text = "Gradation: -";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
StatusVarieties.Text = "Sorten: -";
|
StatusVarieties.Text = "Sorten: -";
|
||||||
@@ -600,9 +684,6 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
|
|
||||||
StatusVarieties.ToolTip = StatusVarieties.Text;
|
StatusVarieties.ToolTip = StatusVarieties.Text;
|
||||||
// TODO display Weight/Gradation with newlines in ToolTip and grouped by sortid AND attributes
|
|
||||||
StatusWeight.ToolTip = StatusWeight.Text;
|
|
||||||
StatusGradation.ToolTip = StatusGradation.Text;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override async Task OnRenewContext() {
|
protected override async Task OnRenewContext() {
|
||||||
@@ -1367,7 +1448,7 @@ namespace Elwig.Windows {
|
|||||||
WineOriginInput.IsEnabled = false;
|
WineOriginInput.IsEnabled = false;
|
||||||
if (WineKgInput.SelectedItem == null)
|
if (WineKgInput.SelectedItem == null)
|
||||||
WineRdInput.IsEnabled = false;
|
WineRdInput.IsEnabled = false;
|
||||||
WeightInput.IsReadOnly = true;
|
WeightInput.TextBox.IsReadOnly = true;
|
||||||
AbgewertetInput.IsEnabled = false;
|
AbgewertetInput.IsEnabled = false;
|
||||||
ManualWeighingInput.IsEnabled = false;
|
ManualWeighingInput.IsEnabled = false;
|
||||||
LsNrInput.IsReadOnly = true;
|
LsNrInput.IsReadOnly = true;
|
||||||
@@ -1408,12 +1489,12 @@ namespace Elwig.Windows {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void DateInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
private new async void DateInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
base.DateInput_TextChanged(sender, evt);
|
base.DateInput_TextChanged(sender, evt);
|
||||||
if (IsEditing || IsCreating) await UpdateLsNr();
|
if (IsEditing || IsCreating) await UpdateLsNr();
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void BranchInput_SelectionChanged(object sender, RoutedEventArgs evt) {
|
private async void BranchInput_SelectionChanged(object sender, SelectionChangedEventArgs evt) {
|
||||||
base.ComboBox_SelectionChanged(sender, evt);
|
base.ComboBox_SelectionChanged(sender, evt);
|
||||||
if (IsEditing || IsCreating) {
|
if (IsEditing || IsCreating) {
|
||||||
await UpdateLsNr();
|
await UpdateLsNr();
|
||||||
@@ -1465,17 +1546,17 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
private void UpdateGradationKmw() {
|
private void UpdateGradationKmw() {
|
||||||
IsUpdatingGradation = true;
|
IsUpdatingGradation = true;
|
||||||
var caret = GradationKmwInput.CaretIndex;
|
var caret = GradationKmwInput.TextBox.CaretIndex;
|
||||||
GradationKmwInput.Text = $"{Utils.OeToKmw(double.Parse(GradationOeInput.Text)):#.0}";
|
GradationKmwInput.Text = $"{Utils.OeToKmw(double.Parse(GradationOeInput.Text)):#.0}";
|
||||||
GradationKmwInput.CaretIndex = caret;
|
GradationKmwInput.TextBox.CaretIndex = caret;
|
||||||
IsUpdatingGradation = false;
|
IsUpdatingGradation = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UpdateGradationOe() {
|
private void UpdateGradationOe() {
|
||||||
IsUpdatingGradation = true;
|
IsUpdatingGradation = true;
|
||||||
var caret = GradationOeInput.CaretIndex;
|
var caret = GradationOeInput.TextBox.CaretIndex;
|
||||||
GradationOeInput.Text = $"{Utils.KmwToOe(double.Parse(GradationKmwInput.Text)):#}";
|
GradationOeInput.Text = $"{Utils.KmwToOe(double.Parse(GradationKmwInput.Text)):#}";
|
||||||
GradationOeInput.CaretIndex = caret;
|
GradationOeInput.TextBox.CaretIndex = caret;
|
||||||
IsUpdatingGradation = false;
|
IsUpdatingGradation = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -311,6 +311,10 @@
|
|||||||
<CheckBox x:Name="BuchführendInput" Content="Buchführend" IsEnabled="False"
|
<CheckBox x:Name="BuchführendInput" Content="Buchführend" IsEnabled="False"
|
||||||
Checked="CheckBox_Changed" Unchecked="CheckBox_Changed"
|
Checked="CheckBox_Changed" Unchecked="CheckBox_Changed"
|
||||||
Grid.Column="2" HorizontalAlignment="Left" Margin="10,15,0,0" VerticalAlignment="Top" IsChecked="False"/>
|
Grid.Column="2" HorizontalAlignment="Left" Margin="10,15,0,0" VerticalAlignment="Top" IsChecked="False"/>
|
||||||
|
|
||||||
|
<CheckBox x:Name="OrganicInput" Content="Bio" IsEnabled="False"
|
||||||
|
Checked="CheckBox_Changed" Unchecked="CheckBox_Changed"
|
||||||
|
Grid.Column="2" HorizontalAlignment="Left" Margin="10,45,0,0" VerticalAlignment="Top" IsChecked="False"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
<GroupBox Header="Rechnungsadresse (optional)" Grid.Column="1" Grid.Row="1" Grid.RowSpan="2" Margin="5,5,5,5">
|
<GroupBox Header="Rechnungsadresse (optional)" Grid.Column="1" Grid.Row="1" Grid.RowSpan="2" Margin="5,5,5,5">
|
||||||
|
|||||||
@@ -425,6 +425,7 @@ namespace Elwig.Windows {
|
|||||||
m.UstIdNr = (UstIdNrInput.Text == "") ? null : UstIdNrInput.Text;
|
m.UstIdNr = (UstIdNrInput.Text == "") ? null : UstIdNrInput.Text;
|
||||||
m.LfbisNr = (LfbisNrInput.Text == "") ? null : LfbisNrInput.Text;
|
m.LfbisNr = (LfbisNrInput.Text == "") ? null : LfbisNrInput.Text;
|
||||||
m.IsBuchführend = BuchführendInput.IsChecked ?? false;
|
m.IsBuchführend = BuchführendInput.IsChecked ?? false;
|
||||||
|
m.IsOrganic = OrganicInput.IsChecked ?? false;
|
||||||
|
|
||||||
m.EntryDateString = (EntryDateInput.Text == "") ? null : string.Join("-", EntryDateInput.Text.Split(".").Reverse());
|
m.EntryDateString = (EntryDateInput.Text == "") ? null : string.Join("-", EntryDateInput.Text.Split(".").Reverse());
|
||||||
m.ExitDateString = (ExitDateInput.Text == "") ? null : string.Join("-", ExitDateInput.Text.Split(".").Reverse());
|
m.ExitDateString = (ExitDateInput.Text == "") ? null : string.Join("-", ExitDateInput.Text.Split(".").Reverse());
|
||||||
@@ -585,6 +586,7 @@ namespace Elwig.Windows {
|
|||||||
UstIdNrInput.Text = m.UstIdNr;
|
UstIdNrInput.Text = m.UstIdNr;
|
||||||
LfbisNrInput.Text = m.LfbisNr;
|
LfbisNrInput.Text = m.LfbisNr;
|
||||||
BuchführendInput.IsChecked = m.IsBuchführend;
|
BuchführendInput.IsChecked = m.IsBuchführend;
|
||||||
|
OrganicInput.IsChecked = m.IsOrganic;
|
||||||
|
|
||||||
var billingAddr = m.BillingAddress;
|
var billingAddr = m.BillingAddress;
|
||||||
if (billingAddr != null) {
|
if (billingAddr != null) {
|
||||||
@@ -668,7 +670,7 @@ namespace Elwig.Windows {
|
|||||||
InputLostFocus((TextBox)sender, Validator.CheckPredecessorMgNr);
|
InputLostFocus((TextBox)sender, Validator.CheckPredecessorMgNr);
|
||||||
}
|
}
|
||||||
|
|
||||||
private new void PhoneNrInput_TextChanged(object sender, RoutedEventArgs evt) {
|
private new void PhoneNrInput_TextChanged(object sender, TextChangedEventArgs evt) {
|
||||||
base.PhoneNrInput_TextChanged(sender, evt);
|
base.PhoneNrInput_TextChanged(sender, evt);
|
||||||
UpdatePhoneNrInputVisibility(IsEditing || IsCreating);
|
UpdatePhoneNrInputVisibility(IsEditing || IsCreating);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,13 +80,14 @@ namespace Elwig.Windows {
|
|||||||
using (var cmd = cnx.CreateCommand()) {
|
using (var cmd = cnx.CreateCommand()) {
|
||||||
cmd.CommandText = $"""
|
cmd.CommandText = $"""
|
||||||
SELECT m.mgnr, m.family_name, m.given_name, p.plz, o.name, m.address, m.business_shares,
|
SELECT m.mgnr, m.family_name, m.given_name, p.plz, o.name, m.address, m.business_shares,
|
||||||
m.business_shares * (SELECT value FROM client_parameter WHERE param = 'DELIVERY_OBLIGATION') AS min_kg,
|
m.business_shares * s.min_kg_per_bs AS min_kg,
|
||||||
m.business_shares * (SELECT value FROM client_parameter WHERE param = 'DELIVERY_RIGHT') AS max_kg,
|
m.business_shares * s.max_kg_per_bs AS max_kg,
|
||||||
COALESCE(SUM(d.weight), 0) AS sum
|
COALESCE(SUM(d.weight), 0) AS sum
|
||||||
FROM member m
|
FROM member m
|
||||||
LEFT JOIN AT_plz_dest p ON p.id = m.postal_dest
|
LEFT JOIN AT_plz_dest p ON p.id = m.postal_dest
|
||||||
LEFT JOIN AT_ort o ON o.okz = p.okz
|
LEFT JOIN AT_ort o ON o.okz = p.okz
|
||||||
LEFT JOIN v_delivery d ON d.mgnr = m.mgnr AND d.year = {year}
|
LEFT JOIN season s ON s.year = {year}
|
||||||
|
LEFT JOIN v_delivery d ON d.mgnr = m.mgnr AND d.year = s.year
|
||||||
WHERE m.active = 1
|
WHERE m.active = 1
|
||||||
GROUP BY d.year, m.mgnr
|
GROUP BY d.year, m.mgnr
|
||||||
ORDER BY sum = 0 DESC, 100.0 * sum / max_kg, m.mgnr;
|
ORDER BY sum = 0 DESC, 100.0 * sum / max_kg, m.mgnr;
|
||||||
@@ -97,7 +98,7 @@ namespace Elwig.Windows {
|
|||||||
var familyName = reader.GetString(1);
|
var familyName = reader.GetString(1);
|
||||||
var givenName = reader.GetString(2);
|
var givenName = reader.GetString(2);
|
||||||
var plz = reader.GetInt32(3);
|
var plz = reader.GetInt32(3);
|
||||||
var ort = reader.GetString(4);
|
var ort = reader.GetString(4).Split(',')[0];
|
||||||
var addr = reader.GetString(5);
|
var addr = reader.GetString(5);
|
||||||
var ga = reader.GetInt32(6);
|
var ga = reader.GetInt32(6);
|
||||||
var minKg = reader.GetInt32(7);
|
var minKg = reader.GetInt32(7);
|
||||||
@@ -111,17 +112,17 @@ namespace Elwig.Windows {
|
|||||||
|
|
||||||
await file.WriteLineAsync($";;;;;;;;;;;");
|
await file.WriteLineAsync($";;;;;;;;;;;");
|
||||||
await file.WriteLineAsync($"Unterlieferungen lt. Flächenbindungen;;;;;;;;;;;");
|
await file.WriteLineAsync($"Unterlieferungen lt. Flächenbindungen;;;;;;;;;;;");
|
||||||
await file.WriteLineAsync($"MgNr;Name;Vorname;Adresse;PLZ;Ort;Vertrag;Lieferpflicht;Lieferrecht;Geliefert;Unterliefert;Prozent");
|
await file.WriteLineAsync($"MgNr;Name;Vorname;Adresse;PLZ;Ort;Vertrag;Fläche;Lieferpflicht;Geliefert;Unterliefert;Prozent");
|
||||||
using (var cmd = cnx.CreateCommand()) {
|
using (var cmd = cnx.CreateCommand()) {
|
||||||
cmd.CommandText = $"""
|
cmd.CommandText = $"""
|
||||||
SELECT m.mgnr, m.family_name, m.given_name, p.plz, o.name, m.address,
|
SELECT m.mgnr, m.family_name, m.given_name, p.plz, o.name, m.address,
|
||||||
c.bucket, c.min_kg, c.max_kg, b.weight
|
c.bucket, c.area, u.min_kg, u.weight
|
||||||
FROM member m
|
FROM member m
|
||||||
LEFT JOIN AT_plz_dest p ON p.id = m.postal_dest
|
LEFT JOIN AT_plz_dest p ON p.id = m.postal_dest
|
||||||
LEFT JOIN AT_ort o ON o.okz = p.okz
|
LEFT JOIN AT_ort o ON o.okz = p.okz
|
||||||
JOIN v_area_commitment_bucket c ON c.mgnr = m.mgnr AND c.year = {year}
|
LEFT JOIN v_area_commitment_bucket_strict c ON c.mgnr = m.mgnr AND c.year = {year}
|
||||||
LEFT JOIN v_payment_bucket b ON (b.mgnr, b.bucket) = (m.mgnr, c.bucket) AND b.year = {year}
|
JOIN v_under_delivery u ON (u.mgnr, u.bucket, u.year) = (m.mgnr, c.bucket, c.year)
|
||||||
WHERE m.active = 1 AND b.weight < c.min_kg
|
WHERE m.active = 1
|
||||||
ORDER BY m.mgnr, c.bucket
|
ORDER BY m.mgnr, c.bucket
|
||||||
""";
|
""";
|
||||||
using var reader = await cmd.ExecuteReaderAsync();
|
using var reader = await cmd.ExecuteReaderAsync();
|
||||||
@@ -130,16 +131,61 @@ namespace Elwig.Windows {
|
|||||||
var familyName = reader.GetString(1);
|
var familyName = reader.GetString(1);
|
||||||
var givenName = reader.GetString(2);
|
var givenName = reader.GetString(2);
|
||||||
var plz = reader.GetInt32(3);
|
var plz = reader.GetInt32(3);
|
||||||
var ort = reader.GetString(4);
|
var ort = reader.GetString(4).Split(',')[0];
|
||||||
var addr = reader.GetString(5);
|
var addr = reader.GetString(5);
|
||||||
var id = reader.GetString(6);
|
var id = reader.GetString(6);
|
||||||
var minKg = reader.GetInt32(7);
|
var area = reader.GetInt32(7);
|
||||||
var maxKg = reader.GetInt32(8);
|
var minKg = reader.GetInt32(8);
|
||||||
var sum = reader.GetInt32(9);
|
var sum = reader.GetInt32(9);
|
||||||
await file.WriteLineAsync($"{mgnr};{familyName};{givenName};{addr};{plz};{ort};{id};{minKg};{maxKg};{sum};{sum - minKg};{sum * 100.0 / minKg - 100.0:0.0}");
|
await file.WriteLineAsync($"{mgnr};{familyName};{givenName};{addr};{plz};{ort};{id};{area};{minKg};{sum};{sum - minKg};{sum * 100.0 / minKg - 100.0:0.0}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
await file.WriteLineAsync($";;;;;;;;;;;");
|
||||||
|
await file.WriteLineAsync($"Lieferungen pro Mitglied und Sorte;;;;;;;;;;;");
|
||||||
|
await file.WriteLineAsync($"MgNr;Name;Vorname;Adresse;PLZ;Ort;Sorte;Attribut;Geliefert;Fläche;Ertrag");
|
||||||
|
using (var cmd = cnx.CreateCommand()) {
|
||||||
|
cmd.CommandText = $"""
|
||||||
|
SELECT m.mgnr, m.family_name, m.given_name, p.plz, o.name, m.address,
|
||||||
|
v.bucket, v.weight, v.area
|
||||||
|
FROM (
|
||||||
|
SELECT c.year AS year,
|
||||||
|
c.mgnr AS mgnr,
|
||||||
|
c.bucket AS bucket,
|
||||||
|
COALESCE(d.weight, 0) AS weight,
|
||||||
|
COALESCE(c.area, 0) AS area
|
||||||
|
FROM v_area_commitment_bucket_strict c
|
||||||
|
LEFT JOIN v_delivery_bucket_strict d ON (d.year, d.mgnr, d.bucket) = (c.year, c.mgnr, c.bucket)
|
||||||
|
WHERE c.year = {year}
|
||||||
|
UNION
|
||||||
|
SELECT d.year,
|
||||||
|
d.mgnr,
|
||||||
|
d.bucket,
|
||||||
|
COALESCE(d.weight, 0),
|
||||||
|
COALESCE(c.area, 0)
|
||||||
|
FROM v_delivery_bucket_strict d
|
||||||
|
LEFT JOIN v_area_commitment_bucket_strict c ON (c.year, c.mgnr, c.bucket) = (d.year, d.mgnr, d.bucket)
|
||||||
|
WHERE d.year = {year}
|
||||||
|
) v
|
||||||
|
LEFT JOIN member m ON m.mgnr = v.mgnr
|
||||||
|
LEFT JOIN AT_plz_dest p ON p.id = m.postal_dest
|
||||||
|
LEFT JOIN AT_ort o ON o.okz = p.okz
|
||||||
|
ORDER BY m.mgnr, v.bucket
|
||||||
|
""";
|
||||||
|
using var reader = await cmd.ExecuteReaderAsync();
|
||||||
|
while (await reader.ReadAsync()) {
|
||||||
|
var mgnr = reader.GetInt32(0);
|
||||||
|
var familyName = reader.GetString(1);
|
||||||
|
var givenName = reader.GetString(2);
|
||||||
|
var plz = reader.GetInt32(3);
|
||||||
|
var ort = reader.GetString(4).Split(',')[0];
|
||||||
|
var addr = reader.GetString(5);
|
||||||
|
var id = reader.GetString(6);
|
||||||
|
var sum = reader.GetInt32(7);
|
||||||
|
var area = reader.GetInt32(8);
|
||||||
|
await file.WriteLineAsync($"{mgnr};{familyName};{givenName};{addr};{plz};{ort};{id[..2]};{id[2..]};{sum};{area};{(area > 0 ? sum * 10000 / area : "")}");
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
MessageBox.Show(exc.Message, "Fehler", MessageBoxButton.OK, MessageBoxImage.Error);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<MajorUpgrade DowngradeErrorMessage="!(loc.DowngradeError)" AllowSameVersionUpgrades="no" />
|
<MajorUpgrade DowngradeErrorMessage="!(loc.DowngradeError)" AllowSameVersionUpgrades="no" />
|
||||||
<MediaTemplate EmbedCab="true" MaximumUncompressedMediaSize="10"/>
|
<MediaTemplate EmbedCab="true" MaximumUncompressedMediaSize="10"/>
|
||||||
|
|
||||||
<Icon Id="icon.ico" SourceFile="$(var.ElwigProjectDir)\Resourcs\Images\Elwig.ico"/>
|
<Icon Id="icon.ico" SourceFile="$(var.ElwigProjectDir)\Resources\Images\Elwig.ico"/>
|
||||||
<Property Id="ARPPRODUCTICON" Value="icon.ico"/>
|
<Property Id="ARPPRODUCTICON" Value="icon.ico"/>
|
||||||
|
|
||||||
<Feature Id="Main">
|
<Feature Id="Main">
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util">
|
<Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util">
|
||||||
<Bundle Name="Elwig" Manufacturer="Elwig" Version="!(bind.packageVersion.ElwigMsi)" UpgradeCode="f3c8fcab-c37c-43aa-9ab8-e42f4bb518b7" IconSourceFile="$(var.ElwigProjectDir)\Resources\Images\Elwig.ico" >
|
<Bundle Name="Elwig" Manufacturer="Elwig" Version="!(bind.packageVersion.ElwigMsi)" UpgradeCode="f3c8fcab-c37c-43aa-9ab8-e42f4bb518b7" IconSourceFile="$(var.ElwigProjectDir)\Resources\Images\Elwig.ico" >
|
||||||
<BootstrapperApplication>
|
<BootstrapperApplication>
|
||||||
<bal:WixStandardBootstrapperApplication LicenseUrl="" Theme="hyperlinkLicense" LogoFile="$(var.ElwigProjectDir)\elwig.png" SuppressOptionsUI="yes" ShowVersion="yes" />
|
<bal:WixStandardBootstrapperApplication LicenseUrl="" Theme="hyperlinkLicense" LogoFile="$(var.ElwigProjectDir)\Resources\Images\Elwig.png" SuppressOptionsUI="yes" ShowVersion="yes" />
|
||||||
</BootstrapperApplication>
|
</BootstrapperApplication>
|
||||||
|
|
||||||
<util:RegistrySearch Id="VCredistx86" Variable="VCredistx86" Result="exists" Root="HKLM" Key="SOFTWARE\Classes\Installer\Dependencies\VC,redist.x86,x86,14.36,bundle" />
|
<util:RegistrySearch Id="VCredistx86" Variable="VCredistx86" Result="exists" Root="HKLM" Key="SOFTWARE\Classes\Installer\Dependencies\VC,redist.x86,x86,14.36,bundle" />
|
||||||
|
|||||||
Reference in New Issue
Block a user