Auftraggeber können nun geändert werden

This commit is contained in:
2023-07-03 08:01:20 +02:00
parent 40a0882631
commit 287c7aaa0a
6 changed files with 96 additions and 8 deletions

View File

@@ -29,7 +29,14 @@ namespace SewerStammGen.DAL.Services.PostgresqlData
IAuftraggeberDataService auftraggeberDataService = new AuftraggeberDataService(connString);
var s = await auftraggeberDataService.GetAll();
// TODO : Auftraggeber verwaltung
entity.Auftraggeber = s.ToList().Last();
if (s.Count() < 1)
{
entity.Auftraggeber = await auftraggeberDataService.Create(new Auftraggeber() { Name = "Anonym" });
}
else
{
entity.Auftraggeber = s.ToList().Last();
}
}
await using (var cmd = new NpgsqlCommand(command, conn))
@@ -45,6 +52,7 @@ namespace SewerStammGen.DAL.Services.PostgresqlData
reader.Read();
entity.Id = reader.GetInt32(0);
}
entity.AuftraggeberTemporar = true;
return entity;
}
@@ -100,7 +108,7 @@ namespace SewerStammGen.DAL.Services.PostgresqlData
public async Task<Projekt> Update(Projekt entity)
{
string command = "UPDATE "+tableName+" SET projektname=@1, erstelldatum=@2, strasse=@3, ort=@4, exporttype=@5, kodierungssystem=@6 WHERE projekt_id = @8";
string command = "UPDATE "+tableName+ " SET projektname=@1, erstelldatum=@2, strasse=@3, ort=@4, exporttype=@5, kodierungssystem=@6,ref_auftraggeber_id=@7 WHERE projekt_id = @8";
using (var cmd = new NpgsqlCommand(command, conn))
{
cmd.Parameters.AddWithValue("1", entity.Projektname);
@@ -109,6 +117,7 @@ namespace SewerStammGen.DAL.Services.PostgresqlData
cmd.Parameters.AddWithValue("4", entity.Ort);
cmd.Parameters.AddWithValue("5", (int)entity.ExportType);
cmd.Parameters.AddWithValue("6", (int)entity.Kodierungssystem);
cmd.Parameters.AddWithValue("7", entity.Auftraggeber.Id);
cmd.Parameters.AddWithValue("8", entity.Id);
int res = await cmd.ExecuteNonQueryAsync();
Trace.WriteLine(res);

View File

@@ -16,5 +16,10 @@ namespace SewerStammGen.Shared.Domain
public string Telefonnummer { get; set; } = String.Empty;
public bool DataChanged { get; set; } = false;
public override string ToString()
{
return string.Format("{0} [{1}]", Name, Ansprechpartner);
}
}
}

View File

@@ -19,5 +19,9 @@ namespace SewerStammGen.Shared.Domain
public EKodierungssystem Kodierungssystem { get; set; }
public IList<Kanal> Kanaele { get; set; } = new List<Kanal>();
public IList<Schacht> Schaechte { get; set;} = new List<Schacht>();
public bool AuftraggeberTemporar { get; set; } = false;
}
}

View File

@@ -1,10 +1,13 @@
using SewerStammGen.Shared.Domain;
using SewerStammGen.Shared.Contracts;
using SewerStammGen.Shared.Domain;
using Shared.Contracts;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.CompilerServices;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Input;
namespace StammGenerator.ViewModel
{
@@ -84,15 +87,58 @@ namespace StammGenerator.ViewModel
}
}
public Auftraggeber? SelectedAuftraggber { get; set; } = null;
public ICommand ApplyCommand { get; set; }
private readonly IAuftraggeberDataService _auftraggeberDataService;
private IList<Auftraggeber> verfuegbareAuftraggeber = new List<Auftraggeber>();
public IList<Auftraggeber> VerfuegbareAuftraggeber
{
get => verfuegbareAuftraggeber;
set
{
verfuegbareAuftraggeber = value;
OnPropertyChanged();
}
}
protected override void OnPropertyChanged([CallerMemberName] string? propertyName = null)
{
_model.DataChanged = true;
base.OnPropertyChanged(propertyName);
}
public AuftraggeberEditViewModel(Auftraggeber model)
public AuftraggeberEditViewModel(Auftraggeber model, IAuftraggeberDataService auftraggeberDataService)
{
_model = model;
_auftraggeberDataService = auftraggeberDataService;
ApplyCommand = new RelayCommand((x) => this.Apply());
LoadAuftraggebers();
}
private void Apply()
{
if (SelectedAuftraggber == null) return;
_model = SelectedAuftraggber;
OnPropertyChanged(nameof(Name));
OnPropertyChanged(nameof(Strasse));
OnPropertyChanged(nameof(Ort));
OnPropertyChanged(nameof(Postleitzahl));
OnPropertyChanged(nameof(Telefonnummer));
OnPropertyChanged(nameof(Ansprechpartner));
}
private async void LoadAuftraggebers()
{
VerfuegbareAuftraggeber.Clear();
IEnumerable<Auftraggeber> s = await _auftraggeberDataService.GetAll();
VerfuegbareAuftraggeber = s.ToList();
OnPropertyChanged(nameof(VerfuegbareAuftraggeber));
}
}

View File

@@ -1,4 +1,5 @@
using SewerStammGen.Shared.Contracts;
using SewerStammGen.DAL.Services.PostgresqlData;
using SewerStammGen.Shared.Contracts;
using SewerStammGen.Shared.Domain;
using Shared.Contracts;
@@ -6,6 +7,7 @@ using StammGenerator.Interface;
using StammGenerator.Views;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Windows;
using System.Windows.Input;
@@ -16,9 +18,10 @@ namespace StammGenerator.ViewModel
private Projekt _model;
private int ProjektID;
private readonly IDataService<Projekt> _projectDataService;
private readonly IDataService<Auftraggeber> _auftraggeberDataService;
private readonly IAuftraggeberDataService _auftraggeberDataService;
private Auftraggeber auftraggeber = new Auftraggeber();
private readonly IRenavigator _renavigator;
private bool AuftraggeberChanged = false;
public ProjektSettingsViewModel ProjektSettingsViewModel { get; set; }
@@ -109,7 +112,7 @@ namespace StammGenerator.ViewModel
private void ChangeAuftraggeber()
{
var win = new AuftraggeberShow();
win.DataContext = new AuftraggeberEditViewModel(_model.Auftraggeber);
win.DataContext = new AuftraggeberEditViewModel(_model.Auftraggeber, _auftraggeberDataService);
win.Closed += AuftraggeberWin_Closed;
win.ShowDialog();
@@ -117,6 +120,17 @@ namespace StammGenerator.ViewModel
private void AuftraggeberWin_Closed(object? sender, EventArgs e)
{
AuftraggeberShow? shw = sender as AuftraggeberShow;
if (shw == null) return;
AuftraggeberEditViewModel? mdl = shw.DataContext as AuftraggeberEditViewModel;
if (mdl == null) return;
if (mdl.SelectedAuftraggber == null) return;
if (!_model.Auftraggeber.Id.Equals(mdl.SelectedAuftraggber.Id))
{
_model.Auftraggeber = mdl.SelectedAuftraggber;
AuftraggeberChanged = true;
}
OnPropertyChanged(nameof(Auftraggeber));
}
@@ -144,7 +158,10 @@ namespace StammGenerator.ViewModel
private void SaveProject()
{
if (_model.Auftraggeber.DataChanged)
// Zur Zeit ohne Funktion da die Klasse so nicht bearbeitet wird. State geht verloren
//if (_model.AuftraggeberTemporar && !_model.Auftraggeber.DataChanged)
// ChangeAuftraggeber();
if (_model.Auftraggeber.DataChanged && !AuftraggeberChanged)
_auftraggeberDataService.Update(_model.Auftraggeber);
_projectDataService.Update(_model);

View File

@@ -10,6 +10,7 @@
<Grid.ColumnDefinitions>
<ColumnDefinition Width="auto" />
<ColumnDefinition Width="300" />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="auto" />
@@ -33,5 +34,11 @@
<TextBox Grid.Column="1" Grid.Row="3" Margin="10" Text="{Binding Postleitzahl}" />
<TextBox Grid.Column="1" Grid.Row="4" Margin="10" Text="{Binding Ort}" />
<TextBox Grid.Column="1" Grid.Row="5" Margin="10" Text="{Binding Telefonnummer}" />
<StackPanel Grid.Column="3" Grid.RowSpan="6">
<Label Content="Oder wähle aus der Liste aus" />
<ComboBox ItemsSource="{Binding VerfuegbareAuftraggeber}" SelectedItem="{Binding SelectedAuftraggber}" />
<Button Margin="10" Content="Übernehmen" Command="{Binding ApplyCommand}" />
</StackPanel>
</Grid>
</Window>