Save / Update / Delete Entrys
This commit is contained in:
@@ -64,6 +64,7 @@
|
|||||||
|
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(TargetFramework)|$(Platform)'=='Debug|net8.0-windows10.0.26100.0|AnyCPU'">
|
<PropertyGroup Condition="'$(Configuration)|$(TargetFramework)|$(Platform)'=='Debug|net8.0-windows10.0.26100.0|AnyCPU'">
|
||||||
<ApplicationId>com.danielpichler.jugenddienststunden</ApplicationId>
|
<ApplicationId>com.danielpichler.jugenddienststunden</ApplicationId>
|
||||||
|
<Optimize>True</Optimize>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(TargetFramework)|$(Platform)'=='Release|net8.0-android34.0|AnyCPU'">
|
<PropertyGroup Condition="'$(Configuration)|$(TargetFramework)|$(Platform)'=='Release|net8.0-android34.0|AnyCPU'">
|
||||||
@@ -80,6 +81,10 @@
|
|||||||
<TargetFrameworks Condition="$([MSBuild]::IsOSPlatform('windows'))">$(TargetFrameworks);net8.0-windows10.0.26100.0</TargetFrameworks>
|
<TargetFrameworks Condition="$([MSBuild]::IsOSPlatform('windows'))">$(TargetFrameworks);net8.0-windows10.0.26100.0</TargetFrameworks>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(TargetFramework)|$(Platform)'=='Debug|net8.0-android|AnyCPU'">
|
||||||
|
<Optimize>True</Optimize>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<!-- App Icon -->
|
<!-- App Icon -->
|
||||||
<MauiIcon Include="Resources\AppIcon\appicon.svg" ForegroundFile="Resources\AppIcon\appiconfg.svg" Color="#512BD4" />
|
<MauiIcon Include="Resources\AppIcon\appicon.svg" ForegroundFile="Resources\AppIcon\appiconfg.svg" Color="#512BD4" />
|
||||||
|
|||||||
@@ -70,6 +70,24 @@ namespace Jugenddienst_Stunden.Models {
|
|||||||
//}
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static async Task DeleteItemAsync(string url, string token) {
|
||||||
|
//using (HttpClient client = new HttpClient() { Timeout = TimeSpan.FromSeconds(15) }) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
HttpClient client = new HttpClient();
|
||||||
|
client.DefaultRequestHeaders.Add("Accept", "application/json");
|
||||||
|
client.DefaultRequestHeaders.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", token);
|
||||||
|
|
||||||
|
HttpResponseMessage response = await client.DeleteAsync(url);
|
||||||
|
|
||||||
|
if (response.IsSuccessStatusCode)
|
||||||
|
Debug.WriteLine(@"\tTodoItem successfully deleted.");
|
||||||
|
} catch (Exception ex) {
|
||||||
|
Debug.WriteLine(@"\tERROR {0}", ex.Message);
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,8 +24,9 @@ namespace Jugenddienst_Stunden.Models {
|
|||||||
|
|
||||||
//Christine Feichter
|
//Christine Feichter
|
||||||
public static string apiKey = Preferences.Default.Get("apiKey", "MTQzfEFlMVRjQXdZMnI4RmpxZ0FSY3A0VEN2bVZYVXxodHRwOi8vaG91cnMuZGF1bmkubWluZS5udTo4MS9hcHBhcGk=");
|
public static string apiKey = Preferences.Default.Get("apiKey", "MTQzfEFlMVRjQXdZMnI4RmpxZ0FSY3A0VEN2bVZYVXxodHRwOi8vaG91cnMuZGF1bmkubWluZS5udTo4MS9hcHBhcGk=");
|
||||||
public static string name = Preferences.Default.Get("name", "Christine");
|
public static int EmployeeId = Preferences.Default.Get("employeeId", 0);
|
||||||
public static string surname = Preferences.Default.Get("surname", "Feichter");
|
public static string name = Preferences.Default.Get("name", "Vorname");
|
||||||
|
public static string surname = Preferences.Default.Get("surname", "Nachname");
|
||||||
public static string apiUrl = Preferences.Default.Get("apiUrl", "https://");
|
public static string apiUrl = Preferences.Default.Get("apiUrl", "https://");
|
||||||
|
|
||||||
//Damian
|
//Damian
|
||||||
@@ -71,6 +72,32 @@ namespace Jugenddienst_Stunden.Models {
|
|||||||
return hours;
|
return hours;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static async Task<Hours> LoadBasicData() {
|
||||||
|
|
||||||
|
|
||||||
|
Hours hours = new Hours();
|
||||||
|
|
||||||
|
if (Connectivity.Current.NetworkAccess == NetworkAccess.None) {
|
||||||
|
await App.Current.MainPage.DisplayAlert("Keine Internetverbindung",
|
||||||
|
"Bitte überprüfen Sie Ihre Internetverbindung und versuchen Sie es erneut.",
|
||||||
|
"OK");
|
||||||
|
} else {
|
||||||
|
var tokendata = new TokenData(apiKey);
|
||||||
|
|
||||||
|
string data = await Auth.GetApiDataWithAuthAsync(tokendata.url + "?basic", tokendata.apiKey);
|
||||||
|
|
||||||
|
if (data == "null") {
|
||||||
|
throw new Exception("Keine Daten erhalten");
|
||||||
|
}
|
||||||
|
if (data == "\"Lalala\"") {
|
||||||
|
throw new Exception("Problem mit Token");
|
||||||
|
}
|
||||||
|
|
||||||
|
hours = JsonConvert.DeserializeObject<Hours>(data);
|
||||||
|
|
||||||
|
}
|
||||||
|
return hours;
|
||||||
|
}
|
||||||
|
|
||||||
public static async Task<List<DayTime>> LoadDay(DateTime date) {
|
public static async Task<List<DayTime>> LoadDay(DateTime date) {
|
||||||
|
|
||||||
@@ -134,7 +161,18 @@ namespace Jugenddienst_Stunden.Models {
|
|||||||
public static async Task<DayTime> SaveEntry(DayTime stunde) { //, string begin, string end, string freistellung, string bemerkung) {
|
public static async Task<DayTime> SaveEntry(DayTime stunde) { //, string begin, string end, string freistellung, string bemerkung) {
|
||||||
|
|
||||||
var tokendata = new TokenData(apiKey);
|
var tokendata = new TokenData(apiKey);
|
||||||
await Auth.SaveItemAsync(tokendata.url, tokendata.apiKey, stunde,false);
|
bool isNew = false;
|
||||||
|
if (stunde.id == null)
|
||||||
|
isNew = true;
|
||||||
|
await Auth.SaveItemAsync(tokendata.url, tokendata.apiKey, stunde, isNew);
|
||||||
|
|
||||||
|
return stunde;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static async Task<DayTime> DeleteEntry(DayTime stunde) { //, string begin, string end, string freistellung, string bemerkung) {
|
||||||
|
|
||||||
|
var tokendata = new TokenData(apiKey);
|
||||||
|
await Auth.DeleteItemAsync(tokendata.url + "/entry/" + stunde.id, tokendata.apiKey);
|
||||||
|
|
||||||
return stunde;
|
return stunde;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
using CommunityToolkit.Mvvm.ComponentModel;
|
using CommunityToolkit.Mvvm.ComponentModel;
|
||||||
using Jugenddienst_Stunden.Models;
|
using Jugenddienst_Stunden.Models;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
|
||||||
namespace Jugenddienst_Stunden.Types
|
namespace Jugenddienst_Stunden.Types
|
||||||
{
|
{
|
||||||
@@ -17,9 +18,9 @@ namespace Jugenddienst_Stunden.Types
|
|||||||
public string zeit_total;
|
public string zeit_total;
|
||||||
|
|
||||||
//https://stackoverflow.com/questions/29449641/deserialize-json-when-a-value-can-be-an-object-or-an-empty-array/29450279#29450279
|
//https://stackoverflow.com/questions/29449641/deserialize-json-when-a-value-can-be-an-object-or-an-empty-array/29450279#29450279
|
||||||
|
|
||||||
//[JsonConverter(typeof(JsonSingleOrEmptyArrayConverter<Hours>))]
|
//[JsonConverter(typeof(JsonSingleOrEmptyArrayConverter<Hours>))]
|
||||||
//public Dictionary<int,decimal> zeit_total_daily;
|
//public Dictionary<int,decimal> zeit_total_daily;
|
||||||
|
|
||||||
public List<TimeDay> zeit_total_daily_api;
|
public List<TimeDay> zeit_total_daily_api;
|
||||||
public List<DayTime> daytime;
|
public List<DayTime> daytime;
|
||||||
//public List<string> wochensumme;
|
//public List<string> wochensumme;
|
||||||
@@ -38,6 +39,9 @@ namespace Jugenddienst_Stunden.Types
|
|||||||
public DateTime Date;
|
public DateTime Date;
|
||||||
public DateTime MinDate;
|
public DateTime MinDate;
|
||||||
public DateTime MaxDate;
|
public DateTime MaxDate;
|
||||||
|
public Collection<Projekt> Projekte { get; set; }
|
||||||
|
public Collection<Gemeinde> Gemeinden { get; set; }
|
||||||
|
public int EmployeeId { get; set; }
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
|
|
||||||
public string Message => "Scanne den QR-Code von deinem Benutzerprofil auf der Stundenseite.";
|
public string Message => "Scanne den QR-Code von deinem Benutzerprofil auf der Stundenseite.";
|
||||||
|
|
||||||
public string Server { get; set; } = "Server: " + Preferences.Default.Get("apiUrl", "https://");
|
public string Server { get; set; } = "Server: " + Preferences.Default.Get("apiUrl", "https://").Replace("/appapi","");
|
||||||
|
|
||||||
public string Title { get; set; } = Preferences.Default.Get("name", "") + " " + Preferences.Default.Get("surname", "");
|
public string Title { get; set; } = Preferences.Default.Get("name", "") + " " + Preferences.Default.Get("surname", "");
|
||||||
|
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
public DayTime Stunde { get => _stunde; }
|
public DayTime Stunde { get => _stunde; }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public event EventHandler<string> AlertEvent;
|
public event EventHandler<string> AlertEvent;
|
||||||
|
|
||||||
public ObservableCollection<Gemeinde> OptionsGemeinde { get; private set; }
|
public ObservableCollection<Gemeinde> OptionsGemeinde { get; private set; }
|
||||||
@@ -64,37 +65,24 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public Collection<Projekt> Projekte { get; set; }
|
||||||
//public TimeSpan Von {
|
public Collection<Gemeinde> Gemeinden { get; set; }
|
||||||
// get => _stunde.begin.ToTimeSpan();
|
|
||||||
// set {
|
|
||||||
// if (_stunde.begin.ToTimeSpan() != value) {
|
|
||||||
// _stunde.begin = TimeOnly.FromTimeSpan(value);
|
|
||||||
// OnPropertyChanged(nameof(Von));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
//public TimeSpan Bis {
|
|
||||||
// get => _stunde.end.ToTimeSpan();
|
|
||||||
// set {
|
|
||||||
// if (_stunde.end.ToTimeSpan() != value) {
|
|
||||||
// _stunde.end = TimeOnly.FromTimeSpan(value);
|
|
||||||
// OnPropertyChanged(nameof(Bis));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public ICommand SaveCommand { get; private set; }
|
public ICommand SaveCommand { get; private set; }
|
||||||
public ICommand DeleteCommand { get; private set; }
|
public ICommand DeleteCommand { get; private set; }
|
||||||
|
//public ICommand LoadDataCommand { get; private set; }
|
||||||
|
|
||||||
|
|
||||||
public StundeViewModel() {
|
public StundeViewModel() {
|
||||||
_stunde = new DayTime();
|
_stunde = new DayTime();
|
||||||
|
//_stunde.EmployeeId = Preferences.Default.Get("employeeId", 0);
|
||||||
|
|
||||||
|
//LoadDataCommand = new AsyncRelayCommand(LoadData);
|
||||||
|
|
||||||
|
|
||||||
SaveCommand = new AsyncRelayCommand(Save);
|
SaveCommand = new AsyncRelayCommand(Save);
|
||||||
//DeleteCommand = new AsyncRelayCommand(Delete);
|
DeleteCommand = new AsyncRelayCommand(Delete);
|
||||||
|
|
||||||
OptionsFreistellung = new ObservableCollection<string> {
|
OptionsFreistellung = new ObservableCollection<string> {
|
||||||
"Keine",
|
"Keine",
|
||||||
@@ -102,30 +90,50 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
"Krankheit",
|
"Krankheit",
|
||||||
"Elternzeit"
|
"Elternzeit"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
_ = LoadData();
|
||||||
}
|
}
|
||||||
|
|
||||||
public StundeViewModel(DayTime stunde) {
|
public StundeViewModel(DayTime stunde) {
|
||||||
_stunde = stunde;
|
_stunde = stunde;
|
||||||
|
|
||||||
SaveCommand = new AsyncRelayCommand(Save);
|
SaveCommand = new AsyncRelayCommand(Save);
|
||||||
//DeleteCommand = new AsyncRelayCommand(Delete);
|
DeleteCommand = new AsyncRelayCommand(Delete);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task LoadData() {
|
||||||
|
try {
|
||||||
|
Hours _hours = await Models.Stunde.LoadBasicData();
|
||||||
|
OptionsProjekt = new ObservableCollection<Projekt>(_hours.Projekte);
|
||||||
|
OptionsGemeinde = new ObservableCollection<Gemeinde>(_hours.Gemeinden);
|
||||||
|
OnPropertyChanged(nameof(OptionsGemeinde));
|
||||||
|
OnPropertyChanged(nameof(OptionsProjekt));
|
||||||
|
_stunde.EmployeeId = _hours.EmployeeId;
|
||||||
|
} catch (Exception e) {
|
||||||
|
AlertEvent?.Invoke(this, e.Message);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async Task Save() {
|
async Task Save() {
|
||||||
await Models.Stunde.SaveEntry(_stunde);
|
await Models.Stunde.SaveEntry(_stunde);
|
||||||
await Shell.Current.GoToAsync($"..?saved={_stunde.id}");
|
if (_stunde.id != null) {
|
||||||
|
await Shell.Current.GoToAsync($"..?saved={_stunde.id}");
|
||||||
|
} else {
|
||||||
|
await Shell.Current.GoToAsync($"..?date={_stunde.day.ToString("yyyy-MM-dd")}");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//private async Task Delete() {
|
private async Task Delete() {
|
||||||
// _stunde.Delete();
|
await Models.Stunde.DeleteEntry(_stunde);
|
||||||
// await Shell.Current.GoToAsync($"..?deleted={_stunde.Filename}");
|
await Shell.Current.GoToAsync($"..?date={_stunde.day.ToString("yyyy-MM-dd")}");
|
||||||
//}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
async void IQueryAttributable.ApplyQueryAttributes(IDictionary<string, object> query) {
|
async void IQueryAttributable.ApplyQueryAttributes(IDictionary<string, object> query) {
|
||||||
if (query.ContainsKey("load")) {
|
if (query.ContainsKey("load")) {
|
||||||
|
|
||||||
//DateTime heute = DateTime.Now;
|
//DateTime heute = DateTime.Now;
|
||||||
_stunde = await Models.Stunde.LoadEntry(Convert.ToInt32(query["load"]));
|
_stunde = await Models.Stunde.LoadEntry(Convert.ToInt32(query["load"]));
|
||||||
if (String.IsNullOrEmpty(_stunde.description)) {
|
if (String.IsNullOrEmpty(_stunde.description)) {
|
||||||
@@ -151,6 +159,12 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
OnPropertyChanged(nameof(SubTitle));
|
OnPropertyChanged(nameof(SubTitle));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
if (query.ContainsKey("date")) {
|
||||||
|
SubTitle = DateTime.ParseExact((string)query["date"], "yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture).ToString("dddd, d. MMM. yyyy");
|
||||||
|
_stunde.day = DateTime.ParseExact((string)query["date"], "yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture);
|
||||||
|
OnPropertyChanged(nameof(SubTitle));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -7,15 +7,16 @@ using ZXing.Net.Maui;
|
|||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using Jugenddienst_Stunden.Types;
|
using Jugenddienst_Stunden.Types;
|
||||||
|
using System.Globalization;
|
||||||
|
|
||||||
|
|
||||||
namespace Jugenddienst_Stunden.ViewModels {
|
namespace Jugenddienst_Stunden.ViewModels {
|
||||||
internal class StundenViewModel : ObservableObject {
|
internal class StundenViewModel : ObservableObject, IQueryAttributable {
|
||||||
public string Name => AppInfo.Name;
|
public string Name => AppInfo.Name;
|
||||||
public string Surname => AppInfo.VersionString;
|
public string Surname => AppInfo.VersionString;
|
||||||
public string MoreInfoUrl => "https://aka.ms/maui";
|
public string MoreInfoUrl => "https://aka.ms/maui";
|
||||||
public string Message => "Hier werden deine geleisteten Arbeitsstunden aufgelistet";
|
public string Message => "Hier werden deine geleisteten Arbeitsstunden aufgelistet";
|
||||||
public string LoadOverview => "Zeige Summen für " + DateTime.Today.ToString("MMMM");
|
public string LoadOverview => "Lade Summen für " + DateTime.Today.ToString("MMMM");
|
||||||
public static DateTime GetDay = DateTime.Today;
|
public static DateTime GetDay = DateTime.Today;
|
||||||
public string ShowDay => "Zeit an Tag " + GetDay.ToString("ddd d. MMM") + ": ";
|
public string ShowDay => "Zeit an Tag " + GetDay.ToString("ddd d. MMM") + ": ";
|
||||||
|
|
||||||
@@ -125,7 +126,8 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
|
|
||||||
private async Task NewEntryAsync() {
|
private async Task NewEntryAsync() {
|
||||||
//Hier muss das Datum übergeben werden
|
//Hier muss das Datum übergeben werden
|
||||||
await Shell.Current.GoToAsync(nameof(Views.StundePage));
|
//await Shell.Current.GoToAsync(nameof(Views.StundePage));
|
||||||
|
await Shell.Current.GoToAsync($"{nameof(Views.StundePage)}?date={dateToday.ToString("yyyy-MM-dd")}");
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task SelectEntryAsync(DayTime entry) {
|
private async Task SelectEntryAsync(DayTime entry) {
|
||||||
@@ -174,6 +176,12 @@ namespace Jugenddienst_Stunden.ViewModels {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async void IQueryAttributable.ApplyQueryAttributes(IDictionary<string, object> query) {
|
||||||
|
if (query.ContainsKey("date")) {
|
||||||
|
await LoadDay(Convert.ToDateTime(query["date"]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void RefreshProperties() {
|
private void RefreshProperties() {
|
||||||
OnPropertyChanged(nameof(Nominal));
|
OnPropertyChanged(nameof(Nominal));
|
||||||
OnPropertyChanged(nameof(Overtime));
|
OnPropertyChanged(nameof(Overtime));
|
||||||
|
|||||||
@@ -39,11 +39,13 @@ public partial class LoginPage : ContentPage {
|
|||||||
Models.Stunde.apiKey = barcode.Value;
|
Models.Stunde.apiKey = barcode.Value;
|
||||||
Models.Stunde.name = op.name;
|
Models.Stunde.name = op.name;
|
||||||
Models.Stunde.surname = op.surname;
|
Models.Stunde.surname = op.surname;
|
||||||
|
Models.Stunde.EmployeeId = int.Parse(op.id);
|
||||||
Title = op.name + " " + op.surname;
|
Title = op.name + " " + op.surname;
|
||||||
|
|
||||||
Preferences.Default.Set("apiKey", barcode.Value);
|
Preferences.Default.Set("apiKey", barcode.Value);
|
||||||
Preferences.Default.Set("name", op.name);
|
Preferences.Default.Set("name", op.name);
|
||||||
Preferences.Default.Set("surname", op.surname);
|
Preferences.Default.Set("surname", op.surname);
|
||||||
|
Preferences.Default.Set("EmployeeId", int.Parse(op.id));
|
||||||
//Preferences.Default.Set("apiUrl", Pre);
|
//Preferences.Default.Set("apiUrl", Pre);
|
||||||
_loginViewModel.Server = Preferences.Default.Get("apiUrl", "");
|
_loginViewModel.Server = Preferences.Default.Get("apiUrl", "");
|
||||||
|
|
||||||
|
|||||||
@@ -16,14 +16,14 @@
|
|||||||
<FlexLayout Direction="Row" AlignItems="Start" Wrap="Wrap" JustifyContent="SpaceBetween">
|
<FlexLayout Direction="Row" AlignItems="Start" Wrap="Wrap" JustifyContent="SpaceBetween">
|
||||||
<Border>
|
<Border>
|
||||||
<HorizontalStackLayout>
|
<HorizontalStackLayout>
|
||||||
<Label Text="Beginn" TextColor="Gray" VerticalTextAlignment="Center" HorizontalTextAlignment="End" Padding="0,0,10,0" Margin="5,0,0,0" MinimumWidthRequest="60"></Label>
|
<Label Text="Beginn" VerticalTextAlignment="Center" HorizontalTextAlignment="End" Padding="0,0,10,0" Margin="5,0,0,0" MinimumWidthRequest="60"></Label>
|
||||||
<TimePicker x:Name="TimeBegin" HorizontalOptions="Center" TextColor="Gray" Format="HH:mm" MinimumWidthRequest="80" Time="{Binding Stunde.TimeSpanVon}" Margin="0,0,0,-5" />
|
<TimePicker x:Name="TimeBegin" HorizontalOptions="Center" Format="HH:mm" MinimumWidthRequest="80" Time="{Binding Stunde.TimeSpanVon}" Margin="0,0,0,-5" />
|
||||||
</HorizontalStackLayout>
|
</HorizontalStackLayout>
|
||||||
</Border>
|
</Border>
|
||||||
<Border>
|
<Border>
|
||||||
<HorizontalStackLayout>
|
<HorizontalStackLayout>
|
||||||
<Label Text="Ende" TextColor="White" VerticalTextAlignment="Center" HorizontalTextAlignment="End" Padding="0,0,10,0" Margin="5,0,0,0" MinimumWidthRequest="60"></Label>
|
<Label Text="Ende" VerticalTextAlignment="Center" HorizontalTextAlignment="End" Padding="0,0,10,0" Margin="5,0,0,0" MinimumWidthRequest="60"></Label>
|
||||||
<TimePicker x:Name="TimeEnd" TextColor="White" Format="HH:mm" MinimumWidthRequest="80" Time="{Binding Stunde.TimeSpanBis}" Margin="0,0,0,-5" />
|
<TimePicker x:Name="TimeEnd" Format="HH:mm" MinimumWidthRequest="80" Time="{Binding Stunde.TimeSpanBis}" Margin="0,0,0,-5" />
|
||||||
</HorizontalStackLayout>
|
</HorizontalStackLayout>
|
||||||
</Border>
|
</Border>
|
||||||
</FlexLayout>
|
</FlexLayout>
|
||||||
@@ -43,7 +43,7 @@
|
|||||||
|
|
||||||
<Grid ColumnDefinitions="*,*" ColumnSpacing="4">
|
<Grid ColumnDefinitions="*,*" ColumnSpacing="4">
|
||||||
<Button Text="Speichern" Command="{Binding SaveCommand}" />
|
<Button Text="Speichern" Command="{Binding SaveCommand}" />
|
||||||
<Button Grid.Column="1" Text="Löschen" />
|
<Button Grid.Column="1" Text="Löschen" Command="{Binding DeleteCommand}" />
|
||||||
</Grid>
|
</Grid>
|
||||||
</VerticalStackLayout>
|
</VerticalStackLayout>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
Reference in New Issue
Block a user