Architecture
Add DI, Interfaces, Repositories
This commit is contained in:
17
Jugenddienst Stunden/Interfaces/IHoursRepository.cs
Normal file
17
Jugenddienst Stunden/Interfaces/IHoursRepository.cs
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
using Jugenddienst_Stunden.Types;
|
||||||
|
|
||||||
|
namespace Jugenddienst_Stunden.Interfaces;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Repository‑Schnittstelle für Datenzugriff (API/Storage) rund um Stunden.
|
||||||
|
/// </summary>
|
||||||
|
internal interface IHoursRepository {
|
||||||
|
Task<BaseResponse> LoadBase(string query);
|
||||||
|
Task<Settings> LoadSettings();
|
||||||
|
Task<Hours> LoadData();
|
||||||
|
Task<User> LoadUser(string apiKey);
|
||||||
|
Task<List<DayTime>> LoadDay(DateTime date);
|
||||||
|
Task<DayTime> LoadEntry(int id);
|
||||||
|
Task<DayTime> SaveEntry(DayTime stunde);
|
||||||
|
Task DeleteEntry(DayTime stunde);
|
||||||
|
}
|
||||||
16
Jugenddienst Stunden/Interfaces/IHoursService.cs
Normal file
16
Jugenddienst Stunden/Interfaces/IHoursService.cs
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
using Jugenddienst_Stunden.Types;
|
||||||
|
|
||||||
|
namespace Jugenddienst_Stunden.Interfaces;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Fachlicher Service für Stunden – konsumiert Repository und stellt VM‑freundliche Methoden bereit.
|
||||||
|
/// </summary>
|
||||||
|
internal interface IHoursService {
|
||||||
|
Task<(Hours hours, Settings settings)> GetMonthSummaryAsync(DateTime monthDate);
|
||||||
|
Task<(List<DayTime> dayTimes, Settings settings)> GetDayWithSettingsAsync(DateTime date);
|
||||||
|
Task<List<DayTime>> GetDayRangeAsync(DateTime from, DateTime to);
|
||||||
|
Task<Settings> GetSettingsAsync();
|
||||||
|
Task<DayTime> GetEntryAsync(int id);
|
||||||
|
Task<DayTime> SaveEntryAsync(DayTime stunde);
|
||||||
|
Task DeleteEntryAsync(DayTime stunde);
|
||||||
|
}
|
||||||
@@ -1,5 +1,8 @@
|
|||||||
using CommunityToolkit.Maui;
|
using CommunityToolkit.Maui;
|
||||||
using Jugenddienst_Stunden.Models;
|
using Jugenddienst_Stunden.Models;
|
||||||
|
using Jugenddienst_Stunden.Interfaces;
|
||||||
|
using Jugenddienst_Stunden.Repositories;
|
||||||
|
using Jugenddienst_Stunden.Services;
|
||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
using ZXing.Net.Maui.Controls;
|
using ZXing.Net.Maui.Controls;
|
||||||
|
|
||||||
@@ -36,6 +39,10 @@ public static class MauiProgram {
|
|||||||
builder.Logging.AddDebug();
|
builder.Logging.AddDebug();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// DI: Services & Repositories
|
||||||
|
builder.Services.AddSingleton<IHoursRepository, HoursRepository>();
|
||||||
|
builder.Services.AddSingleton<IHoursService, HoursService>();
|
||||||
|
|
||||||
return builder.Build();
|
return builder.Build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
19
Jugenddienst Stunden/Repositories/HoursRepository.cs
Normal file
19
Jugenddienst Stunden/Repositories/HoursRepository.cs
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
using Jugenddienst_Stunden.Interfaces;
|
||||||
|
using Jugenddienst_Stunden.Models;
|
||||||
|
using Jugenddienst_Stunden.Types;
|
||||||
|
|
||||||
|
namespace Jugenddienst_Stunden.Repositories;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Standard-Repository, das die bestehende API-/Model-Logik kapselt.
|
||||||
|
/// </summary>
|
||||||
|
internal class HoursRepository : IHoursRepository {
|
||||||
|
public async Task<BaseResponse> LoadBase(string query) => await HoursBase.LoadBase(query);
|
||||||
|
public async Task<Settings> LoadSettings() => await HoursBase.LoadSettings();
|
||||||
|
public async Task<Hours> LoadData() => await HoursBase.LoadData();
|
||||||
|
public async Task<User> LoadUser(string apiKey) => await HoursBase.LoadUser(apiKey);
|
||||||
|
public async Task<List<DayTime>> LoadDay(DateTime date) => await HoursBase.LoadDay(date);
|
||||||
|
public async Task<DayTime> LoadEntry(int id) => await HoursBase.LoadEntry(id);
|
||||||
|
public async Task<DayTime> SaveEntry(DayTime stunde) => await HoursBase.SaveEntry(stunde);
|
||||||
|
public async Task DeleteEntry(DayTime stunde) => await HoursBase.DeleteEntry(stunde);
|
||||||
|
}
|
||||||
38
Jugenddienst Stunden/Services/HoursService.cs
Normal file
38
Jugenddienst Stunden/Services/HoursService.cs
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
using Jugenddienst_Stunden.Interfaces;
|
||||||
|
using Jugenddienst_Stunden.Types;
|
||||||
|
|
||||||
|
namespace Jugenddienst_Stunden.Services;
|
||||||
|
|
||||||
|
internal class HoursService : IHoursService {
|
||||||
|
private readonly IHoursRepository _repo;
|
||||||
|
|
||||||
|
public HoursService(IHoursRepository repo) {
|
||||||
|
_repo = repo;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<(Hours hours, Settings settings)> GetMonthSummaryAsync(DateTime monthDate) {
|
||||||
|
string q = $"hours&year={monthDate:yyyy}&month={monthDate:MM}";
|
||||||
|
var baseRes = await _repo.LoadBase(q);
|
||||||
|
return (baseRes.hour, baseRes.settings);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<(List<DayTime> dayTimes, Settings settings)> GetDayWithSettingsAsync(DateTime date) {
|
||||||
|
string q = $"date={date:yyyy-MM-dd}";
|
||||||
|
var baseRes = await _repo.LoadBase(q);
|
||||||
|
return (baseRes.daytimes ?? new List<DayTime>(), baseRes.settings);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<List<DayTime>> GetDayRangeAsync(DateTime from, DateTime to) {
|
||||||
|
string q = $"date={from:yyyy-MM-dd}&tilldate={to:yyyy-MM-dd}";
|
||||||
|
var baseRes = await _repo.LoadBase(q);
|
||||||
|
return baseRes.daytimes ?? new List<DayTime>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<Settings> GetSettingsAsync() => await _repo.LoadSettings();
|
||||||
|
|
||||||
|
public async Task<DayTime> GetEntryAsync(int id) => await _repo.LoadEntry(id);
|
||||||
|
|
||||||
|
public async Task<DayTime> SaveEntryAsync(DayTime stunde) => await _repo.SaveEntry(stunde);
|
||||||
|
|
||||||
|
public async Task DeleteEntryAsync(DayTime stunde) => await _repo.DeleteEntry(stunde);
|
||||||
|
}
|
||||||
@@ -5,12 +5,16 @@ using Jugenddienst_Stunden.Types;
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
using static System.Runtime.InteropServices.JavaScript.JSType;
|
using static System.Runtime.InteropServices.JavaScript.JSType;
|
||||||
|
using Jugenddienst_Stunden.Interfaces;
|
||||||
|
using Jugenddienst_Stunden.Repositories;
|
||||||
|
using Jugenddienst_Stunden.Services;
|
||||||
|
|
||||||
namespace Jugenddienst_Stunden.ViewModels;
|
namespace Jugenddienst_Stunden.ViewModels;
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Viewmodel für die einzelnen Stundeneinträge / Bearbeitung
|
/// Viewmodel für die einzelnen Stundeneinträge / Bearbeitung
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
||||||
|
private readonly IHoursService _hoursService;
|
||||||
|
|
||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
public string Title { get; set; } = "Eintrag bearbeiten";
|
public string Title { get; set; } = "Eintrag bearbeiten";
|
||||||
@@ -76,20 +80,20 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
//public ICommand LoadDataCommand { get; private set; }
|
//public ICommand LoadDataCommand { get; private set; }
|
||||||
|
|
||||||
|
|
||||||
public StundeViewModel() {
|
public StundeViewModel() : this(GetServiceOrCreate()) { }
|
||||||
|
|
||||||
|
private static IHoursService GetServiceOrCreate() => new HoursService(new HoursRepository());
|
||||||
|
|
||||||
|
internal StundeViewModel(IHoursService hoursService) {
|
||||||
|
_hoursService = hoursService;
|
||||||
SaveCommand = new AsyncRelayCommand(Save);
|
SaveCommand = new AsyncRelayCommand(Save);
|
||||||
//DeleteCommand = new AsyncRelayCommand(Delete);
|
//DeleteCommand = new AsyncRelayCommand(Delete);
|
||||||
DeleteConfirmCommand = new Command(async () => await DeleteConfirm());
|
DeleteConfirmCommand = new Command(async () => await DeleteConfirm());
|
||||||
}
|
}
|
||||||
|
|
||||||
public StundeViewModel(DayTime stunde) {
|
|
||||||
SaveCommand = new AsyncRelayCommand(Save);
|
|
||||||
DeleteConfirmCommand = new AsyncRelayCommand(DeleteConfirm);
|
|
||||||
}
|
|
||||||
|
|
||||||
private async void LoadSettingsAsync() {
|
private async void LoadSettingsAsync() {
|
||||||
try {
|
try {
|
||||||
Settings = await HoursBase.LoadSettings();
|
Settings = await _hoursService.GetSettingsAsync();
|
||||||
GlobalVar.Settings = Settings;
|
GlobalVar.Settings = Settings;
|
||||||
|
|
||||||
OptionsGemeinde = Settings.Gemeinden;
|
OptionsGemeinde = Settings.Gemeinden;
|
||||||
@@ -114,7 +118,7 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
|
|
||||||
if (proceed) {
|
if (proceed) {
|
||||||
try {
|
try {
|
||||||
await HoursBase.SaveEntry(DayTime);
|
await _hoursService.SaveEntryAsync(DayTime);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
AlertEvent?.Invoke(this, e.Message);
|
AlertEvent?.Invoke(this, e.Message);
|
||||||
exceptionOccurred = true;
|
exceptionOccurred = true;
|
||||||
@@ -133,7 +137,7 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
/// Löschen ohne Bestätigung
|
/// Löschen ohne Bestätigung
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private async Task Delete() {
|
private async Task Delete() {
|
||||||
await HoursBase.DeleteEntry(DayTime);
|
await _hoursService.DeleteEntryAsync(DayTime);
|
||||||
await Shell.Current.GoToAsync($"..?date={DayTime.Day.ToString("yyyy-MM-dd")}");
|
await Shell.Current.GoToAsync($"..?date={DayTime.Day.ToString("yyyy-MM-dd")}");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -145,7 +149,7 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
bool answer = await ConfirmEvent.Invoke("Achtung", "Löschen kann nicht ungeschehen gemacht werden. Fortfahren?");
|
bool answer = await ConfirmEvent.Invoke("Achtung", "Löschen kann nicht ungeschehen gemacht werden. Fortfahren?");
|
||||||
if (answer) {
|
if (answer) {
|
||||||
//Löschen
|
//Löschen
|
||||||
await HoursBase.DeleteEntry(DayTime);
|
await _hoursService.DeleteEntryAsync(DayTime);
|
||||||
await Shell.Current.GoToAsync($"..?date={DayTime.Day.ToString("yyyy-MM-dd")}");
|
await Shell.Current.GoToAsync($"..?date={DayTime.Day.ToString("yyyy-MM-dd")}");
|
||||||
} else {
|
} else {
|
||||||
//nicht Löschen
|
//nicht Löschen
|
||||||
@@ -163,27 +167,27 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
|
|
||||||
//DateTime heute = DateTime.Now;
|
//DateTime heute = DateTime.Now;
|
||||||
try {
|
try {
|
||||||
//_dayTime = await HoursBase.LoadEntry(Convert.ToInt32(query["load"]));
|
var entry = await _hoursService.GetEntryAsync(Convert.ToInt32(query["load"]));
|
||||||
BaseResponse dat = await HoursBase.LoadBase("id=" + Convert.ToInt32(query["load"]));
|
var settings = await _hoursService.GetSettingsAsync();
|
||||||
GlobalVar.Settings = dat.settings;
|
GlobalVar.Settings = settings;
|
||||||
GemeindeAktivSet = dat.settings.GemeindeAktivSet;
|
GemeindeAktivSet = settings.GemeindeAktivSet;
|
||||||
ProjektAktivSet = dat.settings.ProjektAktivSet;
|
ProjektAktivSet = settings.ProjektAktivSet;
|
||||||
|
|
||||||
DayTime = dat.daytime;
|
DayTime = entry;
|
||||||
DayTime.TimeSpanVon = dat.daytime.Begin.ToTimeSpan();
|
DayTime.TimeSpanVon = entry.Begin.ToTimeSpan();
|
||||||
DayTime.TimeSpanBis = dat.daytime.End.ToTimeSpan();
|
DayTime.TimeSpanBis = entry.End.ToTimeSpan();
|
||||||
|
|
||||||
OptionsGemeinde = dat.settings.Gemeinden ?? new List<Gemeinde>();
|
OptionsGemeinde = settings.Gemeinden ?? new List<Gemeinde>();
|
||||||
OptionsProjekt = dat.settings.Projekte ?? new List<Projekt>();
|
OptionsProjekt = settings.Projekte ?? new List<Projekt>();
|
||||||
OptionsFreistellung = dat.settings.Freistellungen ?? new List<Freistellung>();
|
OptionsFreistellung = settings.Freistellungen ?? new List<Freistellung>();
|
||||||
|
|
||||||
DayTime.GemeindeAktiv = OptionsGemeinde.FirstOrDefault(Gemeinde => Gemeinde.Id == DayTime.Gemeinde) ?? new Gemeinde();
|
DayTime.GemeindeAktiv = OptionsGemeinde.FirstOrDefault(Gemeinde => Gemeinde.Id == DayTime.Gemeinde) ?? new Gemeinde();
|
||||||
DayTime.ProjektAktiv = OptionsProjekt.FirstOrDefault(Projekt => Projekt.Id == DayTime.Projekt) ?? new Projekt();
|
DayTime.ProjektAktiv = OptionsProjekt.FirstOrDefault(Projekt => Projekt.Id == DayTime.Projekt) ?? new Projekt();
|
||||||
DayTime.FreistellungAktiv = OptionsFreistellung.FirstOrDefault(Freistellung => Freistellung.Id == DayTime.Free) ?? new Freistellung();
|
DayTime.FreistellungAktiv = OptionsFreistellung.FirstOrDefault(Freistellung => Freistellung.Id == DayTime.Free) ?? new Freistellung();
|
||||||
|
|
||||||
//Evtl. noch die anderen Zeiten des gleichen Tages holen
|
//Evtl. noch die anderen Zeiten des gleichen Tages holen
|
||||||
BaseResponse dat1 = await HoursBase.LoadBase("date=" + DayTime.Day.ToString("yyyy-MM-dd"));
|
var day = await _hoursService.GetDayWithSettingsAsync(DayTime.Day);
|
||||||
DayTimes = dat1.daytimes;
|
DayTimes = day.dayTimes;
|
||||||
OnPropertyChanged(nameof(DayTime));
|
OnPropertyChanged(nameof(DayTime));
|
||||||
OnPropertyChanged(nameof(DayTimes));
|
OnPropertyChanged(nameof(DayTimes));
|
||||||
|
|
||||||
@@ -209,17 +213,16 @@ public partial class StundeViewModel : ObservableObject, IQueryAttributable {
|
|||||||
DateTime _date = DateTime.ParseExact((string)query["date"], "yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture);
|
DateTime _date = DateTime.ParseExact((string)query["date"], "yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture);
|
||||||
//Bei neuem Eintrag die vorhandenen des gleichen Tages anzeigen
|
//Bei neuem Eintrag die vorhandenen des gleichen Tages anzeigen
|
||||||
try {
|
try {
|
||||||
//DayTimes = await HoursBase.LoadDay(_date);
|
var (list, settings) = await _hoursService.GetDayWithSettingsAsync(_date);
|
||||||
BaseResponse dat = await HoursBase.LoadBase("date=" + _date.ToString("yyyy-MM-dd"));
|
GlobalVar.Settings = settings;
|
||||||
GlobalVar.Settings = dat.settings;
|
DayTimes = list;
|
||||||
DayTimes = dat.daytimes;
|
|
||||||
|
|
||||||
OptionsGemeinde = dat.settings.Gemeinden;
|
OptionsGemeinde = settings.Gemeinden;
|
||||||
OptionsProjekt = dat.settings.Projekte;
|
OptionsProjekt = settings.Projekte;
|
||||||
OptionsFreistellung = dat.settings.Freistellungen;
|
OptionsFreistellung = settings.Freistellungen;
|
||||||
|
|
||||||
GemeindeAktivSet = dat.settings.GemeindeAktivSet;
|
GemeindeAktivSet = settings.GemeindeAktivSet;
|
||||||
ProjektAktivSet = dat.settings.ProjektAktivSet;
|
ProjektAktivSet = settings.ProjektAktivSet;
|
||||||
|
|
||||||
} catch (Exception) {
|
} catch (Exception) {
|
||||||
//Ein Tag ohne Einträge gibt eine Fehlermeldung,
|
//Ein Tag ohne Einträge gibt eine Fehlermeldung,
|
||||||
|
|||||||
@@ -8,6 +8,9 @@ using System.Windows.Input;
|
|||||||
using CommunityToolkit.Maui.Alerts;
|
using CommunityToolkit.Maui.Alerts;
|
||||||
using CommunityToolkit.Maui.Core;
|
using CommunityToolkit.Maui.Core;
|
||||||
using static System.Runtime.InteropServices.JavaScript.JSType;
|
using static System.Runtime.InteropServices.JavaScript.JSType;
|
||||||
|
using Jugenddienst_Stunden.Interfaces;
|
||||||
|
using Jugenddienst_Stunden.Repositories;
|
||||||
|
using Jugenddienst_Stunden.Services;
|
||||||
|
|
||||||
|
|
||||||
namespace Jugenddienst_Stunden.ViewModels;
|
namespace Jugenddienst_Stunden.ViewModels;
|
||||||
@@ -15,6 +18,7 @@ namespace Jugenddienst_Stunden.ViewModels;
|
|||||||
/// ViewModel für die Stundenliste
|
/// ViewModel für die Stundenliste
|
||||||
/// </summary>
|
/// </summary>
|
||||||
internal partial class StundenViewModel : ObservableObject, IQueryAttributable, INotifyPropertyChanged {
|
internal partial class StundenViewModel : ObservableObject, IQueryAttributable, INotifyPropertyChanged {
|
||||||
|
private readonly IHoursService _hoursService;
|
||||||
|
|
||||||
public ICommand NewEntryCommand { get; }
|
public ICommand NewEntryCommand { get; }
|
||||||
public ICommand SelectEntryCommand { get; }
|
public ICommand SelectEntryCommand { get; }
|
||||||
@@ -156,7 +160,13 @@ internal partial class StundenViewModel : ObservableObject, IQueryAttributable,
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// CTOR
|
/// CTOR
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public StundenViewModel() {
|
public StundenViewModel() : this(GetServiceOrCreate()) {
|
||||||
|
}
|
||||||
|
|
||||||
|
private static IHoursService GetServiceOrCreate() => new HoursService(new HoursRepository());
|
||||||
|
|
||||||
|
internal StundenViewModel(IHoursService hoursService) {
|
||||||
|
_hoursService = hoursService;
|
||||||
Hours = new Hours();
|
Hours = new Hours();
|
||||||
|
|
||||||
LoadOverview = "Lade Summen für " + DateToday.ToString("MMMM");
|
LoadOverview = "Lade Summen für " + DateToday.ToString("MMMM");
|
||||||
@@ -200,9 +210,9 @@ internal partial class StundenViewModel : ObservableObject, IQueryAttributable,
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
private async Task LoadData() {
|
private async Task LoadData() {
|
||||||
try {
|
try {
|
||||||
BaseResponse dat = await HoursBase.LoadBase("hours&year=" + DateToday.ToString("yyyy") + "&month=" + DateToday.ToString("MM"));
|
var (hours, settings) = await _hoursService.GetMonthSummaryAsync(DateToday);
|
||||||
Hours = dat.hour;
|
Hours = hours;
|
||||||
Settings = dat.settings;
|
Settings = settings;
|
||||||
|
|
||||||
if (Settings.Version != AppInfo.Current.VersionString.Substring(0, 5)) {
|
if (Settings.Version != AppInfo.Current.VersionString.Substring(0, 5)) {
|
||||||
InfoEvent?.Invoke(this, "Version: " + Settings.Version + " verfügbar (" + AppInfo.Current.VersionString.Substring(0, 5) + " installiert)");
|
InfoEvent?.Invoke(this, "Version: " + Settings.Version + " verfügbar (" + AppInfo.Current.VersionString.Substring(0, 5) + " installiert)");
|
||||||
@@ -222,11 +232,10 @@ internal partial class StundenViewModel : ObservableObject, IQueryAttributable,
|
|||||||
DayTotal = new TimeOnly(0);
|
DayTotal = new TimeOnly(0);
|
||||||
Sollstunden = new TimeOnly(0);
|
Sollstunden = new TimeOnly(0);
|
||||||
try {
|
try {
|
||||||
//_dayTimes = await HoursBase.LoadDay(date);
|
var (dayTimes, settings) = await _hoursService.GetDayWithSettingsAsync(date);
|
||||||
BaseResponse dat = await HoursBase.LoadBase("date=" + date.ToString("yyyy-MM-dd"));
|
|
||||||
|
|
||||||
DayTimes = dat.daytimes;
|
DayTimes = dayTimes;
|
||||||
Settings = dat.settings;
|
Settings = settings;
|
||||||
GemeindeAktivSet = Settings.GemeindeAktivSet;
|
GemeindeAktivSet = Settings.GemeindeAktivSet;
|
||||||
ProjektAktivSet = Settings.ProjektAktivSet;
|
ProjektAktivSet = Settings.ProjektAktivSet;
|
||||||
|
|
||||||
@@ -251,9 +260,9 @@ internal partial class StundenViewModel : ObservableObject, IQueryAttributable,
|
|||||||
|
|
||||||
//Nach der Tagessumme die anderen Tage anhängen
|
//Nach der Tagessumme die anderen Tage anhängen
|
||||||
if (DayTimes != null) {
|
if (DayTimes != null) {
|
||||||
BaseResponse dat1 = await HoursBase.LoadBase("date=" + date.ToString("yyyy-MM-dd") + "&tilldate=" + date.AddDays(3).ToString("yyyy-MM-dd"));
|
var more = await _hoursService.GetDayRangeAsync(date, date.AddDays(3));
|
||||||
if (dat1.daytimes != null)
|
if (more != null && more.Count > 0)
|
||||||
DayTimes = dat.daytimes.Concat(dat1.daytimes).ToList();
|
DayTimes = DayTimes.Concat(more).ToList();
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|||||||
Reference in New Issue
Block a user