mirror of
https://dev.azure.com/TeilRad/sharee.bike%20App/_git/Code
synced 2025-04-03 21:06:26 +02:00
Version 3.0.342
This commit is contained in:
parent
d852ccef4c
commit
2cde196f16
54 changed files with 998 additions and 498 deletions
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.TeilRad.LastenradBayern" android:versionName="3.0.341" android:versionCode="341">
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.TeilRad.LastenradBayern" android:versionName="3.0.342" android:versionCode="342">
|
||||||
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
||||||
<!-- Google Maps related permissions -->
|
<!-- Google Maps related permissions -->
|
||||||
<!-- Permission to receive remote notifications from Google Play Services -->
|
<!-- Permission to receive remote notifications from Google Play Services -->
|
||||||
|
|
|
@ -55,8 +55,8 @@
|
||||||
<key>CFBundleDisplayName</key>
|
<key>CFBundleDisplayName</key>
|
||||||
<string>LastenradBayern</string>
|
<string>LastenradBayern</string>
|
||||||
<key>CFBundleVersion</key>
|
<key>CFBundleVersion</key>
|
||||||
<string>341</string>
|
<string>342</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
<key>CFBundleShortVersionString</key>
|
||||||
<string>3.0.341</string>
|
<string>3.0.342</string>
|
||||||
</dict>
|
</dict>
|
||||||
</plist>
|
</plist>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<ViewCell xmlns="http://xamarin.com/schemas/2014/forms"
|
<ViewCell xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:conv="clr-namespace:TINK.View"
|
xmlns:conv="clr-namespace:TINK.View"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
|
@ -27,15 +27,11 @@
|
||||||
IsVisible="{Binding DisplayId, Converter={StaticResource Label_Converter}}"
|
IsVisible="{Binding DisplayId, Converter={StaticResource Label_Converter}}"
|
||||||
Text="{Binding DisplayId}"/>
|
Text="{Binding DisplayId}"/>
|
||||||
<!-- Battery level -->
|
<!-- Battery level -->
|
||||||
<!--<sharedGui:BarLevelView
|
<sharedGui:BarLevelView
|
||||||
Current="{Binding CurrentChargeBars}"
|
Current="{Binding CurrentChargeBars}"
|
||||||
Maximum="{Binding MaxChargeBars}"
|
Maximum="{Binding MaxChargeBars}"
|
||||||
IsVisible="{Binding IsBatteryChargeVisible}"/>-->
|
IsVisible="{Binding IsBatteryChargeVisible}"/>
|
||||||
<sharedGui:BarLevelView
|
<!-- Rental state -->
|
||||||
Current="{Binding CurrentChargeBars}"
|
|
||||||
Maximum="{Binding MaxChargeBars}"
|
|
||||||
IsVisible="False"/>
|
|
||||||
<!-- Rental state -->
|
|
||||||
<Label
|
<Label
|
||||||
Text="{Binding StateText}"
|
Text="{Binding StateText}"
|
||||||
TextColor="{Binding StateColor}"/>
|
TextColor="{Binding StateColor}"/>
|
||||||
|
@ -89,8 +85,6 @@
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<!-- Operator AGB -->
|
|
||||||
<RowDefinition Height="Auto" />
|
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
|
@ -216,17 +210,6 @@
|
||||||
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
||||||
Grid.Row="14"
|
Grid.Row="14"
|
||||||
Grid.ColumnSpan="2"/>
|
Grid.ColumnSpan="2"/>
|
||||||
<!-- AGB entry -->
|
|
||||||
<Label
|
|
||||||
TextType="Html"
|
|
||||||
Text="{Binding TariffDescription.OperatorAgb}"
|
|
||||||
IsVisible="{Binding TariffDescription.OperatorAgb, Converter={StaticResource Label_Converter}}"
|
|
||||||
Grid.ColumnSpan="2"
|
|
||||||
Grid.Row="15">
|
|
||||||
<Label.GestureRecognizers>
|
|
||||||
<TapGestureRecognizer Command="{Binding ShowAgbTappedCommand}"/>
|
|
||||||
</Label.GestureRecognizers>
|
|
||||||
</Label>
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
</ContentView>
|
</ContentView>
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
Source="{Binding Uri}" />
|
Source="{Binding Uri}" />
|
||||||
|
|
||||||
<ActivityIndicator Grid.Row="0"
|
<ActivityIndicator Grid.Row="0"
|
||||||
x:Name="ActivityIndicatorLoading"
|
|
||||||
Scale="2"
|
Scale="2"
|
||||||
VerticalOptions="CenterAndExpand"
|
VerticalOptions="CenterAndExpand"
|
||||||
HorizontalOptions="CenterAndExpand"
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using Serilog;
|
using Serilog;
|
||||||
using TINK.Model.Device;
|
using TINK.Model.Device;
|
||||||
using TINK.ViewModel.Login;
|
using TINK.ViewModel.Login;
|
||||||
|
@ -14,40 +14,12 @@ namespace TINK.View.CopriWebView
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
ManageAccount.Navigating += (sender, ev) =>
|
ManageAccount.Navigating += WebViewHelper.SetBusyAndDisplayOrDownload;
|
||||||
{
|
|
||||||
if (!ev.Url.ToUpper().EndsWith(".PDF"))
|
|
||||||
{
|
|
||||||
// Stay inside web view except for downloading pdf- files.
|
|
||||||
this.IsEnabled = false;
|
|
||||||
ActivityIndicatorLoading.IsVisible = true;
|
|
||||||
ActivityIndicatorLoading.IsRunning = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
DependencyService.Get<IExternalBrowserService>().OpenUrl(ev.Url);
|
ManageAccount.Navigated += (sender, eventArgs) => WebViewHelper.SetIdleAndHandleError(
|
||||||
};
|
sender,
|
||||||
|
eventArgs,
|
||||||
ManageAccount.Navigated += (sender, ev) =>
|
"<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
{
|
|
||||||
if (ev.Result == WebNavigationResult.Success)
|
|
||||||
{
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Log.ForContext<ManageAccountPage>().Error("Navigation did not succeed.{@Event}{@Sender}", ev, sender);
|
|
||||||
ManageAccount.Source = new HtmlWebViewSource
|
|
||||||
{
|
|
||||||
Html = "<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>"
|
|
||||||
};
|
|
||||||
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
ManageAccount.BindingContext = new ManageAccountViewModel(
|
ManageAccount.BindingContext = new ManageAccountViewModel(
|
||||||
App.ModelRoot.ActiveUser.SessionCookie,
|
App.ModelRoot.ActiveUser.SessionCookie,
|
||||||
|
|
|
@ -10,26 +10,51 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabFees}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabFees}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
x:Name="InfoRentBikeWebView"
|
<RowDefinition Height="*"/>
|
||||||
HeightRequest="1000"
|
</Grid.RowDefinitions>
|
||||||
WidthRequest="1000"
|
<WebView
|
||||||
Source="{Binding RentBikeText}"/>
|
x:Name="InfoRentBikeWebView"
|
||||||
</StackLayout>
|
HeightRequest="1000"
|
||||||
|
WidthRequest="1000"
|
||||||
|
Source="{Binding RentBikeText}"/>
|
||||||
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
x:Name="InfoTypesOfBikesWebView"
|
<RowDefinition Height="*"/>
|
||||||
HeightRequest="1000"
|
</Grid.RowDefinitions>
|
||||||
WidthRequest="1000"
|
<WebView
|
||||||
Source="{Binding TypesOfBikesText}"/>
|
x:Name="InfoTypesOfBikesWebView"
|
||||||
</StackLayout>
|
HeightRequest="1000"
|
||||||
|
WidthRequest="1000"
|
||||||
|
Source="{Binding TypesOfBikesText}"/>
|
||||||
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
|
@ -1,4 +1,5 @@
|
||||||
using TINK.ViewModel;
|
using Serilog;
|
||||||
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Contact;
|
using TINK.ViewModel.Contact;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
using Xamarin.Forms.Xaml;
|
using Xamarin.Forms.Xaml;
|
||||||
|
@ -14,19 +15,31 @@ namespace TINK.View.Contact
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
|
/// Info about renting.
|
||||||
|
InfoRentBikeWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoRentBikeWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Mietinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
/// Info about types of bikes.
|
||||||
|
InfoTypesOfBikesWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoTypesOfBikesWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Radinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
ViewModel = new FeesAndBikesPageViewModel(
|
ViewModel = new FeesAndBikesPageViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn);
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
|
|
||||||
BindingContext = ViewModel;
|
BindingContext = ViewModel;
|
||||||
|
|
||||||
/// Info about renting.
|
|
||||||
InfoRentBikeWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
|
|
||||||
/// Info about types of bikes.
|
|
||||||
InfoTypesOfBikesWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="utf-8" ?>
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
xmlns:resources="clr-namespace:TINK.MultilingualResources;assembly=TINKLib"
|
xmlns:resources="clr-namespace:TINK.MultilingualResources;assembly=TINKLib"
|
||||||
|
@ -11,49 +11,96 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="App">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabApp}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoLicenses"
|
x:Name="InfoLicenses"
|
||||||
Source="{Binding InfoLicenses}"
|
Source="{Binding InfoLicenses}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Datenschutz">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabPrivacy}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoDatenschutz"
|
x:Name="InfoDatenschutz"
|
||||||
Source="{Binding InfoPrivacy}"
|
Source="{Binding InfoPrivacy}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="AGB">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabGtc}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoABG"
|
x:Name="InfoABG"
|
||||||
Source ="{Binding InfoAgb}"
|
Source ="{Binding InfoAgb}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Impressum">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabImpress}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoImpressum"
|
x:Name="InfoImpressum"
|
||||||
Source="{Binding InfoImpressum}"
|
Source="{Binding InfoImpressum}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using TINK.ViewModel;
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Info;
|
using TINK.ViewModel.Info;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
|
@ -21,15 +21,34 @@ namespace TINK.View.Info
|
||||||
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
resourceName => ViewModelResourceHelper.GetSource(resourceName),
|
||||||
resourceName => ViewModelResourceHelper.GetSource(resourceName));
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
TabbedInfoPage.BindingContext = ViewModel;
|
TabbedInfoPage.BindingContext = ViewModel;
|
||||||
|
|
||||||
InfoLicenses.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
InfoDatenschutz.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
InfoABG.Navigating += ViewModelHelper.OnNavigating;
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Lizenzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
InfoImpressum.Navigating += ViewModelHelper.OnNavigating;
|
InfoDatenschutz.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoDatenschutz.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Datenschutzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoABG.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoABG.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann allgemeine Geschäftsbedingungen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoImpressum.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoImpressum.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Impressum nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
||||||
|
@ -19,7 +19,6 @@ namespace TINK.View.WhatsNew.Agb
|
||||||
agbViewModel = new AgbViewModel(
|
agbViewModel = new AgbViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
|
||||||
(resourceName) => ViewModelResourceHelper.GetSource(resourceName),
|
(resourceName) => ViewModelResourceHelper.GetSource(resourceName),
|
||||||
this);
|
this);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.TeilRad.Meinkonrad" android:versionName="3.0.341" android:versionCode="341">
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.TeilRad.Meinkonrad" android:versionName="3.0.342" android:versionCode="342">
|
||||||
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
||||||
<!-- Google Maps related permissions -->
|
<!-- Google Maps related permissions -->
|
||||||
<!-- Permission to receive remote notifications from Google Play Services -->
|
<!-- Permission to receive remote notifications from Google Play Services -->
|
||||||
|
|
|
@ -55,8 +55,8 @@
|
||||||
<key>CFBundleDisplayName</key>
|
<key>CFBundleDisplayName</key>
|
||||||
<string>Mein konrad</string>
|
<string>Mein konrad</string>
|
||||||
<key>CFBundleVersion</key>
|
<key>CFBundleVersion</key>
|
||||||
<string>341</string>
|
<string>342</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
<key>CFBundleShortVersionString</key>
|
||||||
<string>3.0.341</string>
|
<string>3.0.342</string>
|
||||||
</dict>
|
</dict>
|
||||||
</plist>
|
</plist>
|
||||||
|
|
|
@ -97,8 +97,6 @@
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<!-- Operator AGB -->
|
|
||||||
<RowDefinition Height="Auto" />
|
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
|
@ -224,17 +222,6 @@
|
||||||
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
||||||
Grid.Row="14"
|
Grid.Row="14"
|
||||||
Grid.ColumnSpan="2"/>
|
Grid.ColumnSpan="2"/>
|
||||||
<!-- AGB entry -->
|
|
||||||
<Label
|
|
||||||
TextType="Html"
|
|
||||||
Text="{Binding TariffDescription.OperatorAgb}"
|
|
||||||
IsVisible="{Binding TariffDescription.OperatorAgb, Converter={StaticResource Label_Converter}}"
|
|
||||||
Grid.ColumnSpan="2"
|
|
||||||
Grid.Row="15">
|
|
||||||
<Label.GestureRecognizers>
|
|
||||||
<TapGestureRecognizer Command="{Binding ShowAgbTappedCommand}"/>
|
|
||||||
</Label.GestureRecognizers>
|
|
||||||
</Label>
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
</ContentView>
|
</ContentView>
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
Source="{Binding Uri}" />
|
Source="{Binding Uri}" />
|
||||||
|
|
||||||
<ActivityIndicator Grid.Row="0"
|
<ActivityIndicator Grid.Row="0"
|
||||||
x:Name="ActivityIndicatorLoading"
|
|
||||||
Scale="2"
|
Scale="2"
|
||||||
VerticalOptions="CenterAndExpand"
|
VerticalOptions="CenterAndExpand"
|
||||||
HorizontalOptions="CenterAndExpand"
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using Serilog;
|
using Serilog;
|
||||||
using TINK.Model.Device;
|
using TINK.Model.Device;
|
||||||
using TINK.ViewModel.Login;
|
using TINK.ViewModel.Login;
|
||||||
|
@ -14,40 +14,12 @@ namespace TINK.View.CopriWebView
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
ManageAccount.Navigating += (sender, ev) =>
|
ManageAccount.Navigating += WebViewHelper.SetBusyAndDisplayOrDownload;
|
||||||
{
|
|
||||||
if (!ev.Url.ToUpper().EndsWith(".PDF"))
|
|
||||||
{
|
|
||||||
// Stay inside web view except for downloading pdf- files.
|
|
||||||
this.IsEnabled = false;
|
|
||||||
ActivityIndicatorLoading.IsVisible = true;
|
|
||||||
ActivityIndicatorLoading.IsRunning = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
DependencyService.Get<IExternalBrowserService>().OpenUrl(ev.Url);
|
ManageAccount.Navigated += (sender, eventArgs) => WebViewHelper.SetIdleAndHandleError(
|
||||||
};
|
sender,
|
||||||
|
eventArgs,
|
||||||
ManageAccount.Navigated += (sender, ev) =>
|
"<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
{
|
|
||||||
if (ev.Result == WebNavigationResult.Success)
|
|
||||||
{
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Log.ForContext<ManageAccountPage>().Error("Navigation did not succeed.{@Event}{@Sender}", ev, sender);
|
|
||||||
ManageAccount.Source = new HtmlWebViewSource
|
|
||||||
{
|
|
||||||
Html = "<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>"
|
|
||||||
};
|
|
||||||
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
ManageAccount.BindingContext = new ManageAccountViewModel(
|
ManageAccount.BindingContext = new ManageAccountViewModel(
|
||||||
App.ModelRoot.ActiveUser.SessionCookie,
|
App.ModelRoot.ActiveUser.SessionCookie,
|
||||||
|
|
|
@ -11,26 +11,44 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabFees}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabFees}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<WebView
|
||||||
x:Name="InfoRentBikeWebView"
|
x:Name="InfoRentBikeWebView"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000"
|
WidthRequest="1000"
|
||||||
Source="{Binding RentBikeText}"/>
|
Source="{Binding RentBikeText}"/>
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<WebView
|
||||||
x:Name="InfoTypesOfBikesWebView"
|
x:Name="InfoTypesOfBikesWebView"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000"
|
WidthRequest="1000"
|
||||||
Source="{Binding TypesOfBikesText}"/>
|
Source="{Binding TypesOfBikesText}"/>
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
|
@ -1,4 +1,5 @@
|
||||||
using TINK.ViewModel;
|
using Serilog;
|
||||||
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Contact;
|
using TINK.ViewModel.Contact;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
using Xamarin.Forms.Xaml;
|
using Xamarin.Forms.Xaml;
|
||||||
|
@ -14,19 +15,31 @@ namespace TINK.View.Contact
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
|
/// Info about renting.
|
||||||
|
InfoRentBikeWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoRentBikeWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Mietinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
/// Info about types of bikes.
|
||||||
|
InfoTypesOfBikesWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoTypesOfBikesWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Radinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
ViewModel = new FeesAndBikesPageViewModel(
|
ViewModel = new FeesAndBikesPageViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn);
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
|
|
||||||
BindingContext = ViewModel;
|
BindingContext = ViewModel;
|
||||||
|
|
||||||
/// Info about renting.
|
|
||||||
InfoRentBikeWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
|
|
||||||
/// Info about types of bikes.
|
|
||||||
InfoTypesOfBikesWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="utf-8" ?>
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
xmlns:resources="clr-namespace:TINK.MultilingualResources;assembly=TINKLib"
|
xmlns:resources="clr-namespace:TINK.MultilingualResources;assembly=TINKLib"
|
||||||
|
@ -12,49 +12,96 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="App">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabApp}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoLicenses"
|
x:Name="InfoLicenses"
|
||||||
Source="{Binding InfoLicenses}"
|
Source="{Binding InfoLicenses}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Datenschutz">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabPrivacy}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoDatenschutz"
|
x:Name="InfoDatenschutz"
|
||||||
Source="{Binding InfoPrivacy}"
|
Source="{Binding InfoPrivacy}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="AGB">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabGtc}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoABG"
|
x:Name="InfoABG"
|
||||||
Source ="{Binding InfoAgb}"
|
Source ="{Binding InfoAgb}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Impressum">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabImpress}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoImpressum"
|
x:Name="InfoImpressum"
|
||||||
Source="{Binding InfoImpressum}"
|
Source="{Binding InfoImpressum}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
|
using AndroidX.Navigation;
|
||||||
using TINK.ViewModel;
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Info;
|
using TINK.ViewModel.Info;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
|
@ -21,15 +22,34 @@ namespace TINK.View.Info
|
||||||
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
resourceName => ViewModelResourceHelper.GetEmbeddedResource(resourceName),
|
||||||
resourceName => ViewModelResourceHelper.GetSource(resourceName));
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
TabbedInfoPage.BindingContext = ViewModel;
|
TabbedInfoPage.BindingContext = ViewModel;
|
||||||
|
|
||||||
InfoLicenses.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
InfoDatenschutz.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
InfoABG.Navigating += ViewModelHelper.OnNavigating;
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Lizenzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
InfoImpressum.Navigating += ViewModelHelper.OnNavigating;
|
InfoDatenschutz.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoDatenschutz.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Datenschutzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoABG.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoABG.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann allgemeine Geschäftsbedingungen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoImpressum.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoImpressum.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Impressum nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
||||||
|
@ -19,8 +19,7 @@ namespace TINK.View.WhatsNew.Agb
|
||||||
agbViewModel = new AgbViewModel(
|
agbViewModel = new AgbViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
(resourceName) => ViewModelResourceHelper.GetEmbeddedResource(resourceName),
|
||||||
(resourceName) => ViewModelResourceHelper.GetSource(resourceName),
|
|
||||||
this);
|
this);
|
||||||
|
|
||||||
BindingContext = agbViewModel;
|
BindingContext = agbViewModel;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using Serilog;
|
using Serilog;
|
||||||
|
@ -27,16 +27,16 @@ namespace TINK.ViewModel
|
||||||
/// <summary> Gets an an embedded html ressource.</summary>
|
/// <summary> Gets an an embedded html ressource.</summary>
|
||||||
/// <param name="resrouceName">Name of resource to get.</param>
|
/// <param name="resrouceName">Name of resource to get.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public static string GetSource(string resrouceName)
|
public static string GetEmbeddedResource(string resrouceName)
|
||||||
{
|
{
|
||||||
var l_oRessourceName = RessourcePrefix + resrouceName;
|
var ressourceName = RessourcePrefix + resrouceName;
|
||||||
Log.Verbose($"Using this resource prefix {RessourcePrefix}.");
|
Log.Verbose($"Using this resource prefix {RessourcePrefix}.");
|
||||||
// note that the prefix includes the trailing period '.' that is required
|
// note that the prefix includes the trailing period '.' that is required
|
||||||
var assembly = typeof(ViewModelResourceHelper).GetTypeInfo().Assembly;
|
var assembly = typeof(ViewModelResourceHelper).GetTypeInfo().Assembly;
|
||||||
var stream = assembly.GetManifestResourceStream(l_oRessourceName);
|
var stream = assembly.GetManifestResourceStream(ressourceName);
|
||||||
return stream != null
|
return stream != null
|
||||||
? (new StreamReader(stream, Encoding.UTF8)).ReadToEnd()
|
? (new StreamReader(stream, Encoding.UTF8)).ReadToEnd()
|
||||||
: string.Format("<!DOCTYPE html><html lang=\"de\"><body>An error occurred loading html- ressource {0}.</body>", l_oRessourceName);
|
: string.Format("<!DOCTYPE html><html lang=\"de\"><body>An error occurred loading html- ressource {0}.</body>", ressourceName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.hauffware.sharee" android:versionName="3.0.341" android:versionCode="341">
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:installLocation="internalOnly" package="com.hauffware.sharee" android:versionName="3.0.342" android:versionCode="342">
|
||||||
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
<uses-sdk android:minSdkVersion="19" android:targetSdkVersion="30" />
|
||||||
<!-- Google Maps related permissions -->
|
<!-- Google Maps related permissions -->
|
||||||
<!-- Permission to receive remote notifications from Google Play Services -->
|
<!-- Permission to receive remote notifications from Google Play Services -->
|
||||||
|
|
|
@ -55,8 +55,8 @@
|
||||||
<key>CFBundleDisplayName</key>
|
<key>CFBundleDisplayName</key>
|
||||||
<string>sharee.bike</string>
|
<string>sharee.bike</string>
|
||||||
<key>CFBundleVersion</key>
|
<key>CFBundleVersion</key>
|
||||||
<string>341</string>
|
<string>342</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
<key>CFBundleShortVersionString</key>
|
||||||
<string>3.0.341</string>
|
<string>3.0.342</string>
|
||||||
</dict>
|
</dict>
|
||||||
</plist>
|
</plist>
|
||||||
|
|
|
@ -1,13 +1,15 @@
|
||||||
<?xml version="1.0" encoding="utf-8" ?>
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
<Application xmlns="http://xamarin.com/schemas/2014/forms"
|
<Application xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
xmlns:themes="clr-namespace:TINK.Themes;assembly=TINKLib"
|
xmlns:themes="clr-namespace:TINK.Themes;assembly=TINKLib"
|
||||||
|
xmlns:xct="http://xamarin.com/schemas/2020/toolkit"
|
||||||
x:Class="TINK.App"
|
x:Class="TINK.App"
|
||||||
xmlns:ios="clr-namespace:Xamarin.Forms.PlatformConfiguration.iOSSpecific;assembly=Xamarin.Forms.Core"
|
xmlns:ios="clr-namespace:Xamarin.Forms.PlatformConfiguration.iOSSpecific;assembly=Xamarin.Forms.Core"
|
||||||
ios:Application.EnableAccessibilityScalingForNamedFontSizes="false">
|
ios:Application.EnableAccessibilityScalingForNamedFontSizes="false">
|
||||||
<Application.Resources>
|
<Application.Resources>
|
||||||
<ResourceDictionary>
|
<ResourceDictionary>
|
||||||
<x:String x:Key="IconMap"></x:String>
|
<xct:InvertedBoolConverter x:Key="InvertedBoolConverter" />
|
||||||
|
<x:String x:Key="IconMap"></x:String>
|
||||||
<x:String x:Key="IconFindBike"></x:String>
|
<x:String x:Key="IconFindBike"></x:String>
|
||||||
<x:String x:Key="IconMyBikes"></x:String>
|
<x:String x:Key="IconMyBikes"></x:String>
|
||||||
<x:String x:Key="IconAccount"></x:String>
|
<x:String x:Key="IconAccount"></x:String>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<ViewCell xmlns="http://xamarin.com/schemas/2014/forms"
|
<ViewCell xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:conv="clr-namespace:TINK.View"
|
xmlns:conv="clr-namespace:TINK.View"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
|
@ -91,8 +91,6 @@
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<RowDefinition Height="Auto" />
|
<RowDefinition Height="Auto" />
|
||||||
<!-- Operator AGB -->
|
|
||||||
<RowDefinition Height="Auto" />
|
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
|
@ -218,17 +216,6 @@
|
||||||
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
IsVisible="{Binding TariffDescription.InfoEntry5, Converter={StaticResource Label_Converter}}"
|
||||||
Grid.Row="14"
|
Grid.Row="14"
|
||||||
Grid.ColumnSpan="2"/>
|
Grid.ColumnSpan="2"/>
|
||||||
<!-- AGB entry -->
|
|
||||||
<Label
|
|
||||||
TextType="Html"
|
|
||||||
Text="{Binding TariffDescription.OperatorAgb}"
|
|
||||||
IsVisible="{Binding TariffDescription.OperatorAgb, Converter={StaticResource Label_Converter}}"
|
|
||||||
Grid.ColumnSpan="2"
|
|
||||||
Grid.Row="15">
|
|
||||||
<Label.GestureRecognizers>
|
|
||||||
<TapGestureRecognizer Command="{Binding ShowAgbTappedCommand}"/>
|
|
||||||
</Label.GestureRecognizers>
|
|
||||||
</Label>
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
</ContentView>
|
</ContentView>
|
||||||
|
|
|
@ -31,7 +31,6 @@
|
||||||
Source="{Binding Uri}" />
|
Source="{Binding Uri}" />
|
||||||
|
|
||||||
<ActivityIndicator Grid.Row="0"
|
<ActivityIndicator Grid.Row="0"
|
||||||
x:Name="ActivityIndicatorLoading"
|
|
||||||
Scale="2"
|
Scale="2"
|
||||||
VerticalOptions="CenterAndExpand"
|
VerticalOptions="CenterAndExpand"
|
||||||
HorizontalOptions="CenterAndExpand"
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using Serilog;
|
using Serilog;
|
||||||
using TINK.Model.Device;
|
using TINK.Model.Device;
|
||||||
using TINK.ViewModel.Login;
|
using TINK.ViewModel.Login;
|
||||||
|
@ -14,40 +14,12 @@ namespace TINK.View.CopriWebView
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
ManageAccount.Navigating += (sender, ev) =>
|
ManageAccount.Navigating += WebViewHelper.SetBusyAndDisplayOrDownload;
|
||||||
{
|
|
||||||
if (!ev.Url.ToUpper().EndsWith(".PDF"))
|
|
||||||
{
|
|
||||||
// Stay inside web view except for downloading pdf- files.
|
|
||||||
this.IsEnabled = false;
|
|
||||||
ActivityIndicatorLoading.IsVisible = true;
|
|
||||||
ActivityIndicatorLoading.IsRunning = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
DependencyService.Get<IExternalBrowserService>().OpenUrl(ev.Url);
|
ManageAccount.Navigated += (sender, eventArgs) => WebViewHelper.SetIdleAndHandleError(
|
||||||
};
|
sender,
|
||||||
|
eventArgs,
|
||||||
ManageAccount.Navigated += (sender, ev) =>
|
"<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
{
|
|
||||||
if (ev.Result == WebNavigationResult.Success)
|
|
||||||
{
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Log.ForContext<ManageAccountPage>().Error("Navigation did not succeed.{@Event}{@Sender}", ev, sender);
|
|
||||||
ManageAccount.Source = new HtmlWebViewSource
|
|
||||||
{
|
|
||||||
Html = "<html><b>Kann persönliche Daten nicht anzeigen/ verwalten!</b><br>Verbindung mit Internet ok?</html>"
|
|
||||||
};
|
|
||||||
|
|
||||||
this.IsEnabled = true;
|
|
||||||
ActivityIndicatorLoading.IsVisible = false;
|
|
||||||
ActivityIndicatorLoading.IsRunning = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
ManageAccount.BindingContext = new ManageAccountViewModel(
|
ManageAccount.BindingContext = new ManageAccountViewModel(
|
||||||
App.ModelRoot.ActiveUser.SessionCookie,
|
App.ModelRoot.ActiveUser.SessionCookie,
|
||||||
|
|
|
@ -10,26 +10,50 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabFees}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabFees}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
x:Name="InfoRentBikeWebView"
|
<RowDefinition Height="*"/>
|
||||||
HeightRequest="1000"
|
</Grid.RowDefinitions>
|
||||||
WidthRequest="1000"
|
<WebView
|
||||||
Source="{Binding RentBikeText}"/>
|
x:Name="InfoRentBikeWebView"
|
||||||
</StackLayout>
|
HeightRequest="1000"
|
||||||
|
WidthRequest="1000"
|
||||||
|
Source="{Binding RentBikeText}"/>
|
||||||
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabBikes}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
x:Name="InfoTypesOfBikesWebView"
|
<RowDefinition Height="*"/>
|
||||||
HeightRequest="1000"
|
</Grid.RowDefinitions>
|
||||||
WidthRequest="1000"
|
<WebView
|
||||||
Source="{Binding TypesOfBikesText}"/>
|
x:Name="InfoTypesOfBikesWebView"
|
||||||
</StackLayout>
|
HeightRequest="1000"
|
||||||
|
WidthRequest="1000"
|
||||||
|
Source="{Binding TypesOfBikesText}"/>
|
||||||
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
|
@ -1,4 +1,5 @@
|
||||||
using TINK.ViewModel;
|
using Serilog;
|
||||||
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Contact;
|
using TINK.ViewModel.Contact;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
using Xamarin.Forms.Xaml;
|
using Xamarin.Forms.Xaml;
|
||||||
|
@ -14,19 +15,31 @@ namespace TINK.View.Contact
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
|
/// Info about renting.
|
||||||
|
InfoRentBikeWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoRentBikeWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Mietinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
/// Info about types of bikes.
|
||||||
|
InfoTypesOfBikesWebView.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
|
||||||
|
InfoTypesOfBikesWebView.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Radinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
ViewModel = new FeesAndBikesPageViewModel(
|
ViewModel = new FeesAndBikesPageViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
App.ModelRoot.ResourceUrls.FeesResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
App.ModelRoot.ResourceUrls.BikesResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn);
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
|
|
||||||
BindingContext = ViewModel;
|
BindingContext = ViewModel;
|
||||||
|
|
||||||
/// Info about renting.
|
|
||||||
InfoRentBikeWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
|
|
||||||
/// Info about types of bikes.
|
|
||||||
InfoTypesOfBikesWebView.Navigating += ViewModelHelper.OnNavigating;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="utf-8" ?>
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
|
||||||
x:Class="TINK.View.Info.InfoPage"
|
x:Class="TINK.View.Info.InfoPage"
|
||||||
|
@ -11,49 +11,96 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
</Shell.TitleView>
|
</Shell.TitleView>
|
||||||
<!--Pages can be added as references or inline-->
|
<!--Pages can be added as references or inline-->
|
||||||
<ContentPage Title="App">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabApp}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoLicenses"
|
x:Name="InfoLicenses"
|
||||||
Source="{Binding InfoLicenses}"
|
Source="{Binding InfoLicenses}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Datenschutz">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabPrivacy}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoDatenschutz"
|
x:Name="InfoDatenschutz"
|
||||||
Source="{Binding InfoPrivacy}"
|
Source="{Binding InfoPrivacy}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="AGB">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabGtc}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoABG"
|
x:Name="InfoABG"
|
||||||
Source ="{Binding InfoAgb}"
|
Source ="{Binding InfoAgb}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
<ContentPage Title="Impressum">
|
<ContentPage
|
||||||
|
IsEnabled="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Title="{x:Static resources:AppResources.MarkingTabImpress}">
|
||||||
<ContentPage.Content>
|
<ContentPage.Content>
|
||||||
<StackLayout>
|
<Grid>
|
||||||
<WebView
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<WebView
|
||||||
x:Name="InfoImpressum"
|
x:Name="InfoImpressum"
|
||||||
Source="{Binding InfoImpressum}"
|
Source="{Binding InfoImpressum}"
|
||||||
HeightRequest="1000"
|
HeightRequest="1000"
|
||||||
WidthRequest="1000" />
|
WidthRequest="1000" />
|
||||||
</StackLayout>
|
<ActivityIndicator Grid.Row="0"
|
||||||
|
IsRunning="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
IsVisible="{Binding IsIdle, Converter={StaticResource InvertedBoolConverter}}"
|
||||||
|
Scale="2"
|
||||||
|
VerticalOptions="CenterAndExpand"
|
||||||
|
HorizontalOptions="CenterAndExpand"
|
||||||
|
Color="{x:DynamicResource primary-back-title-color}"/>
|
||||||
|
</Grid>
|
||||||
</ContentPage.Content>
|
</ContentPage.Content>
|
||||||
</ContentPage>
|
</ContentPage>
|
||||||
</TabbedPage>
|
</TabbedPage>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using TINK.ViewModel;
|
using TINK.ViewModel;
|
||||||
using TINK.ViewModel.Info;
|
using TINK.ViewModel.Info;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
|
@ -21,15 +21,34 @@ namespace TINK.View.Info
|
||||||
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
App.ModelRoot.ResourceUrls.PrivacyResourcePath,
|
||||||
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
App.ModelRoot.ResourceUrls.ImpressResourcePath,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
resourceName => ViewModelResourceHelper.GetSource(resourceName),
|
||||||
resourceName => ViewModelResourceHelper.GetSource(resourceName));
|
() => App.ModelRoot.GetConnector(App.ModelRoot.GetIsConnected()).Query,
|
||||||
|
resourceUrls => App.ModelRoot.ResourceUrls = resourceUrls);
|
||||||
TabbedInfoPage.BindingContext = ViewModel;
|
TabbedInfoPage.BindingContext = ViewModel;
|
||||||
|
|
||||||
InfoLicenses.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
InfoDatenschutz.Navigating += ViewModelHelper.OnNavigating;
|
InfoLicenses.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
InfoABG.Navigating += ViewModelHelper.OnNavigating;
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Lizenzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
InfoImpressum.Navigating += ViewModelHelper.OnNavigating;
|
InfoDatenschutz.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoDatenschutz.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Datenschutzinformationen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoABG.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoABG.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann allgemeine Geschäftsbedingungen nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
|
|
||||||
|
InfoImpressum.Navigating += WebViewHelper.SelectDisplayTarget;
|
||||||
|
InfoImpressum.Navigated += (sender, ev) => WebViewHelper.HandleError(
|
||||||
|
sender,
|
||||||
|
ev,
|
||||||
|
"<html><b>Kann Impressum nicht anzeigen!</b><br>Verbindung mit Internet ok?</html>");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
using TINK.Model.Bikes.BikeInfoNS.DriveNS.BatteryNS;
|
||||||
|
@ -19,7 +19,6 @@ namespace TINK.View.WhatsNew.Agb
|
||||||
agbViewModel = new AgbViewModel(
|
agbViewModel = new AgbViewModel(
|
||||||
App.ModelRoot.NextActiveUri.Host,
|
App.ModelRoot.NextActiveUri.Host,
|
||||||
App.ModelRoot.IsSiteCachingOn,
|
App.ModelRoot.IsSiteCachingOn,
|
||||||
CultureInfo.CurrentUICulture.TwoLetterISOLanguageName,
|
|
||||||
(resourceName) => ViewModelResourceHelper.GetSource(resourceName),
|
(resourceName) => ViewModelResourceHelper.GetSource(resourceName),
|
||||||
this);
|
this);
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using TINK.MultilingualResources;
|
using TINK.MultilingualResources;
|
||||||
using TINK.Repository.Response;
|
using TINK.Repository.Response;
|
||||||
|
|
||||||
|
@ -67,12 +67,6 @@ namespace TINK.Model.Connector.Updater
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(tariffDesciption?.operator_agb ?? string.Empty))
|
|
||||||
{
|
|
||||||
bike.InfoEntries.Add("1", new Bikes.BikeInfoNS.RentalDescription.InfoElement { Key = "AGB", Value = tariffDesciption.operator_agb });
|
|
||||||
}
|
|
||||||
|
|
||||||
return bike;
|
return bike;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
namespace TINK.Model
|
namespace TINK.Model
|
||||||
{
|
{
|
||||||
public class ResourceUrls : IResourceUrls
|
public class ResourceUrls : IResourceUrls
|
||||||
{
|
{
|
||||||
|
@ -9,11 +9,11 @@
|
||||||
string privacyResourcePath = null,
|
string privacyResourcePath = null,
|
||||||
string impressResourcePath = null)
|
string impressResourcePath = null)
|
||||||
{
|
{
|
||||||
FeesResourcePath = !string.IsNullOrEmpty(feesResourcePath) ? feesResourcePath : "site/tariff_info_1.html";
|
FeesResourcePath = !string.IsNullOrEmpty(feesResourcePath) ? feesResourcePath : "";
|
||||||
BikesResourcePath = !string.IsNullOrEmpty(bikesResourcePath) ? bikesResourcePath : "site/bike_info.html";
|
BikesResourcePath = !string.IsNullOrEmpty(bikesResourcePath) ? bikesResourcePath : "";
|
||||||
AgbResourcePath = !string.IsNullOrEmpty(agbResourcePath) ? agbResourcePath : "site/agb.html";
|
AgbResourcePath = !string.IsNullOrEmpty(agbResourcePath) ? agbResourcePath : "";
|
||||||
PrivacyResourcePath = !string.IsNullOrEmpty(privacyResourcePath) ? privacyResourcePath : "site/privacy.html";
|
PrivacyResourcePath = !string.IsNullOrEmpty(privacyResourcePath) ? privacyResourcePath : "";
|
||||||
ImpressResourcePath = !string.IsNullOrEmpty(impressResourcePath) ? impressResourcePath : "site/impress.html";
|
ImpressResourcePath = !string.IsNullOrEmpty(impressResourcePath) ? impressResourcePath : "";
|
||||||
}
|
}
|
||||||
|
|
||||||
public string FeesResourcePath { get; }
|
public string FeesResourcePath { get; }
|
||||||
|
|
|
@ -596,12 +596,12 @@ namespace TINK.Model
|
||||||
new List<AppFlavor> { AppFlavor.MeinKonrad }
|
new List<AppFlavor> { AppFlavor.MeinKonrad }
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
new Version(3, 0, 341),
|
new Version(3, 0, 342),
|
||||||
AppResources.ChangeLog_MinorDesignImprovements,
|
AppResources.ChangeLog_MinorDesignImprovements,
|
||||||
new List<AppFlavor> { AppFlavor.LastenradBayern, AppFlavor.MeinKonrad }
|
new List<AppFlavor> { AppFlavor.LastenradBayern, AppFlavor.MeinKonrad }
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
new Version(3, 0, 341),
|
new Version(3, 0, 342),
|
||||||
AppResources.ChangeLog_MinorBugFixes,
|
AppResources.ChangeLog_MinorBugFixes,
|
||||||
new List<AppFlavor> { AppFlavor.ShareeBike }
|
new List<AppFlavor> { AppFlavor.ShareeBike }
|
||||||
}
|
}
|
||||||
|
|
|
@ -2081,6 +2081,15 @@ namespace TINK.MultilingualResources {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to App.
|
||||||
|
/// </summary>
|
||||||
|
public static string MarkingTabApp {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MarkingTabApp", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Instructions.
|
/// Looks up a localized string similar to Instructions.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -2099,6 +2108,33 @@ namespace TINK.MultilingualResources {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to GTC.
|
||||||
|
/// </summary>
|
||||||
|
public static string MarkingTabGtc {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MarkingTabGtc", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Impress.
|
||||||
|
/// </summary>
|
||||||
|
public static string MarkingTabImpress {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MarkingTabImpress", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Privacy.
|
||||||
|
/// </summary>
|
||||||
|
public static string MarkingTabPrivacy {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MarkingTabPrivacy", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Verbose error messages.
|
/// Looks up a localized string similar to Verbose error messages.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -1037,4 +1037,16 @@ Sie können nun auf einen Blick sehen, welche App-Version Sie installiert haben:
|
||||||
<data name="MarkingContactSupportBusy" xml:space="preserve">
|
<data name="MarkingContactSupportBusy" xml:space="preserve">
|
||||||
<value>{0} <font color="gray"><u>kontaktieren</u></font>.</value>
|
<value>{0} <font color="gray"><u>kontaktieren</u></font>.</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MarkingTabApp" xml:space="preserve">
|
||||||
|
<value>App</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabGtc" xml:space="preserve">
|
||||||
|
<value>AGB</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabImpress" xml:space="preserve">
|
||||||
|
<value>Impressum</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabPrivacy" xml:space="preserve">
|
||||||
|
<value>Datenschutz</value>
|
||||||
|
</data>
|
||||||
</root>
|
</root>
|
|
@ -1129,4 +1129,16 @@ You can now see at a glance which app version you have installed: in the menu at
|
||||||
<data name="MarkingContactSupportBusy" xml:space="preserve">
|
<data name="MarkingContactSupportBusy" xml:space="preserve">
|
||||||
<value><font color="gray"><u>Contact</u></font> {0}.</value>
|
<value><font color="gray"><u>Contact</u></font> {0}.</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MarkingTabApp" xml:space="preserve">
|
||||||
|
<value>App</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabGtc" xml:space="preserve">
|
||||||
|
<value>GTC</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabImpress" xml:space="preserve">
|
||||||
|
<value>Impress</value>
|
||||||
|
</data>
|
||||||
|
<data name="MarkingTabPrivacy" xml:space="preserve">
|
||||||
|
<value>Privacy</value>
|
||||||
|
</data>
|
||||||
</root>
|
</root>
|
|
@ -1408,6 +1408,22 @@ Sie können nun auf einen Blick sehen, welche App-Version Sie installiert haben:
|
||||||
<source><bpt id="1"><font color="gray"></bpt><bpt id="2"><u></bpt>Contact<ept id="2"></u></ept><ept id="1"></font></ept> {0}.</source>
|
<source><bpt id="1"><font color="gray"></bpt><bpt id="2"><u></bpt>Contact<ept id="2"></u></ept><ept id="1"></font></ept> {0}.</source>
|
||||||
<target state="translated">{0} <bpt id="1"><font color="gray"></bpt><bpt id="2"><u></bpt>kontaktieren<ept id="2"></u></ept><ept id="1"></font></ept>.</target>
|
<target state="translated">{0} <bpt id="1"><font color="gray"></bpt><bpt id="2"><u></bpt>kontaktieren<ept id="2"></u></ept><ept id="1"></font></ept>.</target>
|
||||||
</trans-unit>
|
</trans-unit>
|
||||||
|
<trans-unit id="MarkingTabApp" translate="yes" xml:space="preserve">
|
||||||
|
<source>App</source>
|
||||||
|
<target state="translated">App</target>
|
||||||
|
</trans-unit>
|
||||||
|
<trans-unit id="MarkingTabGtc" translate="yes" xml:space="preserve">
|
||||||
|
<source>GTC</source>
|
||||||
|
<target state="translated">AGB</target>
|
||||||
|
</trans-unit>
|
||||||
|
<trans-unit id="MarkingTabImpress" translate="yes" xml:space="preserve">
|
||||||
|
<source>Impress</source>
|
||||||
|
<target state="translated">Impressum</target>
|
||||||
|
</trans-unit>
|
||||||
|
<trans-unit id="MarkingTabPrivacy" translate="yes" xml:space="preserve">
|
||||||
|
<source>Privacy</source>
|
||||||
|
<target state="translated">Datenschutz</target>
|
||||||
|
</trans-unit>
|
||||||
</group>
|
</group>
|
||||||
</body>
|
</body>
|
||||||
</file>
|
</file>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Runtime.Serialization;
|
using System.Runtime.Serialization;
|
||||||
|
|
||||||
namespace TINK.Repository.Response
|
namespace TINK.Repository.Response
|
||||||
{
|
{
|
||||||
|
@ -48,10 +48,6 @@ namespace TINK.Repository.Response
|
||||||
[DataMember]
|
[DataMember]
|
||||||
public string max_eur_per_day { get; private set; }
|
public string max_eur_per_day { get; private set; }
|
||||||
|
|
||||||
/// <summary> Info about operator agb as HTML (i.g. text and hyperlink). </summary>
|
|
||||||
[DataMember]
|
|
||||||
public string operator_agb { get; private set; }
|
|
||||||
|
|
||||||
/// <summary> Text which informs users about GPS tracking if tracking is on. </summary>
|
/// <summary> Text which informs users about GPS tracking if tracking is on. </summary>
|
||||||
[DataMember]
|
[DataMember]
|
||||||
public string track_info { get; private set; }
|
public string track_info { get; private set; }
|
||||||
|
|
175
TINKLib/View/WebViewHelper.cs
Normal file
175
TINKLib/View/WebViewHelper.cs
Normal file
|
@ -0,0 +1,175 @@
|
||||||
|
using System.Linq;
|
||||||
|
using Serilog;
|
||||||
|
using TINK.Model.Device;
|
||||||
|
using Xamarin.Forms;
|
||||||
|
|
||||||
|
namespace TINK.View
|
||||||
|
{
|
||||||
|
public static class WebViewHelper
|
||||||
|
{
|
||||||
|
/// <summary> Rountes request to browser if internal URI was detected or displays link in app otherwise. </summary>
|
||||||
|
/// <param name="sender">Sender of the event.</param>
|
||||||
|
/// <param name="eventArgs">Event arguments</param>
|
||||||
|
public static void SelectDisplayTarget(object sender, WebNavigatingEventArgs eventArgs)
|
||||||
|
{
|
||||||
|
if (!eventArgs.Url.ToUpper().StartsWith("HTTP"))
|
||||||
|
{
|
||||||
|
// An internal link was detected.
|
||||||
|
// Stay inside WebView
|
||||||
|
eventArgs.Cancel = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Do not navigate outside the document on web view.
|
||||||
|
eventArgs.Cancel = true;
|
||||||
|
// Open external link in browser.
|
||||||
|
DependencyService.Get<IExternalBrowserService>().OpenUrl(eventArgs.Url);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary> Routes request to broswer to download pdf- documents or displays link in app otherwise. </summary>
|
||||||
|
/// <param name="sender">Sender of the event.</param>
|
||||||
|
/// <param name="eventArgs">Event arguments</param>
|
||||||
|
public static void SetBusyAndDisplayOrDownload(object sender, WebNavigatingEventArgs eventArgs)
|
||||||
|
{
|
||||||
|
if (!eventArgs.Url.ToUpper().EndsWith(".PDF"))
|
||||||
|
{
|
||||||
|
// Stay inside web view except for downloading pdf- files.
|
||||||
|
SetBusy(sender);
|
||||||
|
eventArgs.Cancel = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Do not navigate outside the document on web view.
|
||||||
|
eventArgs.Cancel = true;
|
||||||
|
// Open external link in browser.
|
||||||
|
DependencyService.Get<IExternalBrowserService>().OpenUrl(eventArgs.Url);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Disables WebView and shows ActivityIndicator.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// Prerequisites: Both WebView and ActivityInicator must be located on the same Grid object.
|
||||||
|
/// </remarks>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
private static void SetBusy(object sender)
|
||||||
|
{
|
||||||
|
if (!(sender is WebView webView))
|
||||||
|
{
|
||||||
|
// Nothing to do if sender is not a web view.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetBusy)} detected. Argument must not be of type {sender.GetType()}.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(webView.Parent is Grid grid))
|
||||||
|
{
|
||||||
|
// Nothing to do if web view is not located on grid.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetBusy)} detected. Parent of argument must not be of type {webView.Parent.GetType()}.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
grid.IsEnabled = false;
|
||||||
|
|
||||||
|
var indicator = grid.Children.OfType<ActivityIndicator>().FirstOrDefault();
|
||||||
|
if (indicator == null)
|
||||||
|
{
|
||||||
|
// Nothing to do if there is not activity indicator.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetBusy)} detected. No activity indicator found.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
indicator.IsVisible = true;
|
||||||
|
indicator.IsRunning = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables WebView and hides ActivityIndicator and sets error text to WebView in case an error occurred.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// Prerequisites: Both WebView and ActivityInicator must be located on the same Grid object.
|
||||||
|
/// </remarks>
|
||||||
|
/// <param name="htmlErrorMessage">HTML showing an error message.</param>
|
||||||
|
public static void SetIdleAndHandleError(
|
||||||
|
object sender,
|
||||||
|
WebNavigatedEventArgs eventArgs,
|
||||||
|
string htmlErrorMessage)
|
||||||
|
{
|
||||||
|
if (!(sender is WebView webView))
|
||||||
|
{
|
||||||
|
// Nothing to do if sender is not a web view.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetIdleAndHandleError)} detected. Argument must not be of type {sender.GetType()}.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(webView.Parent is Grid grid))
|
||||||
|
{
|
||||||
|
// Nothing to do if web view is not located on grid.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetIdleAndHandleError)} detected. Parent of argument must not be of type {webView.Parent.GetType()}.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var indicator = grid.Children.OfType<ActivityIndicator>().FirstOrDefault();
|
||||||
|
if (indicator == null)
|
||||||
|
{
|
||||||
|
// Nothing to do if there is not activity indicator.
|
||||||
|
Log.Error($"Unexpected call of {nameof(SetIdleAndHandleError)} detected. No activity indicator found.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (eventArgs.Result == WebNavigationResult.Success)
|
||||||
|
{
|
||||||
|
// Uri could be loaded successfully.
|
||||||
|
grid.IsEnabled = true;
|
||||||
|
if (indicator != null)
|
||||||
|
{
|
||||||
|
indicator.IsVisible = false;
|
||||||
|
indicator.IsRunning = false;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Navigation failed.
|
||||||
|
Log.Error("Navigation did not succeed.{@Event}{@Sender}", eventArgs, sender);
|
||||||
|
webView.Source = new HtmlWebViewSource
|
||||||
|
{
|
||||||
|
Html = !string.IsNullOrEmpty(htmlErrorMessage) ? htmlErrorMessage : $"Navigation to {eventArgs.Url} failed."
|
||||||
|
};
|
||||||
|
|
||||||
|
grid.IsEnabled = true;
|
||||||
|
if (indicator != null)
|
||||||
|
{
|
||||||
|
indicator.IsVisible = false;
|
||||||
|
indicator.IsRunning = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sets error text to WebView in case an error occurred.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="htmlErrorMessage">HTML showing an error message.</param>
|
||||||
|
public static void HandleError(
|
||||||
|
object sender,
|
||||||
|
WebNavigatedEventArgs eventArgs,
|
||||||
|
string htmlErrorMessage)
|
||||||
|
{
|
||||||
|
if (eventArgs.Result == WebNavigationResult.Success)
|
||||||
|
{
|
||||||
|
// Uri could be loaded successfully.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(sender is WebView webView))
|
||||||
|
{
|
||||||
|
// Nothing to do if sender is not a web view.
|
||||||
|
Log.Error($"Unexpected call of {nameof(HandleError)} detected. Argument must not be of type {sender.GetType()}.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Navigation failed.
|
||||||
|
Log.Error("Navigation did not succeed.{@Event}{@Sender}", eventArgs, sender);
|
||||||
|
webView.Source = new HtmlWebViewSource
|
||||||
|
{
|
||||||
|
Html = !string.IsNullOrEmpty(htmlErrorMessage) ? htmlErrorMessage : $"Navigation to {eventArgs.Url} failed."
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
using Serilog;
|
using Serilog;
|
||||||
using System;
|
using System;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
|
@ -355,32 +355,6 @@ namespace TINK.ViewModel.Bikes.Bike
|
||||||
/// <summary> Gets the value of property <see cref="StateColor"/> when PropertyChanged was fired. </summary>
|
/// <summary> Gets the value of property <see cref="StateColor"/> when PropertyChanged was fired. </summary>
|
||||||
public Color LastStateColor { get; set; }
|
public Color LastStateColor { get; set; }
|
||||||
|
|
||||||
/// <summary> Command object to bind login page redirect link to view model.</summary>
|
|
||||||
public System.Windows.Input.ICommand ShowAgbTappedCommand
|
|
||||||
=> new Xamarin.Forms.Command(() => ShowAgbPageAsync());
|
|
||||||
|
|
||||||
/// <summary> Opens login page. </summary>
|
|
||||||
public void ShowAgbPageAsync()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
var url = GetUrlFirstOrDefault(TariffDescription.OperatorAgb);
|
|
||||||
if (string.IsNullOrEmpty(url))
|
|
||||||
{
|
|
||||||
// No url contained in string.
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
OpenUrlInBrowser(url);
|
|
||||||
|
|
||||||
}
|
|
||||||
catch (Exception p_oException)
|
|
||||||
{
|
|
||||||
Log.Error("An unexpected error occurred opening broser. {@Exception}", p_oException);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary> Gets first url from text.</summary>
|
/// <summary> Gets first url from text.</summary>
|
||||||
/// <param name="htmlSource">url to extract text from.</param>
|
/// <param name="htmlSource">url to extract text from.</param>
|
||||||
/// <returns>Gets first url or an empty string if on url is contained in text.</returns>
|
/// <returns>Gets first url or an empty string if on url is contained in text.</returns>
|
||||||
|
|
|
@ -36,7 +36,7 @@ namespace TINK.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
IUser activeUser) : base(
|
IUser activeUser) : base(
|
||||||
selectedBike,
|
selectedBike,
|
||||||
AppResources.ActionReturn, // Copri button text "Miete beenden"
|
AppResources.ActionReturn, // Copri button text "Miete beenden"
|
||||||
false, // Do no more allow to return bike.
|
true, // Show button to enabled returning of bike.
|
||||||
isConnectedDelegate,
|
isConnectedDelegate,
|
||||||
connectorFactory,
|
connectorFactory,
|
||||||
geolocation,
|
geolocation,
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using TINK.Model.Bikes.BikeInfoNS;
|
using TINK.Model.Bikes.BikeInfoNS;
|
||||||
|
|
||||||
|
@ -9,8 +9,6 @@ namespace TINK.ViewModel.Bikes.Bike
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class TariffDescriptionViewModel
|
public class TariffDescriptionViewModel
|
||||||
{
|
{
|
||||||
private const string AGBKEY = "AGB";
|
|
||||||
|
|
||||||
public TariffDescriptionViewModel(RentalDescription tariff)
|
public TariffDescriptionViewModel(RentalDescription tariff)
|
||||||
{
|
{
|
||||||
Name = tariff?.Name ?? string.Empty;
|
Name = tariff?.Name ?? string.Empty;
|
||||||
|
@ -20,13 +18,8 @@ namespace TINK.ViewModel.Bikes.Bike
|
||||||
: new ObservableCollection<RentalDescription.TariffElement>();
|
: new ObservableCollection<RentalDescription.TariffElement>();
|
||||||
|
|
||||||
InfoEntries = tariff != null && tariff?.InfoEntries != null
|
InfoEntries = tariff != null && tariff?.InfoEntries != null
|
||||||
? new ObservableCollection<string>(tariff.InfoEntries.OrderBy(x => x.Key).Where(x => x.Value.Key != AGBKEY).Select(x => x.Value.Value))
|
? new ObservableCollection<string>(tariff.InfoEntries.OrderBy(x => x.Key).Select(x => x.Value.Value))
|
||||||
: new ObservableCollection<string>();
|
: new ObservableCollection<string>();
|
||||||
|
|
||||||
OperatorAgb = tariff?.InfoEntries != null
|
|
||||||
&& tariff.InfoEntries.Select(x => x.Value.Key).Contains(AGBKEY)
|
|
||||||
? tariff?.InfoEntries.FirstOrDefault(x => x.Value.Key == AGBKEY).Value.Value
|
|
||||||
: string.Empty;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -44,9 +37,6 @@ namespace TINK.ViewModel.Bikes.Bike
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public ObservableCollection<string> InfoEntries { get; private set; }
|
public ObservableCollection<string> InfoEntries { get; private set; }
|
||||||
|
|
||||||
/// <summary> Info about operator agb as HTML (i.g. text and hyperlink). </summary>
|
|
||||||
public string OperatorAgb { get; set; }
|
|
||||||
|
|
||||||
public RentalDescription.TariffElement TarifEntry1 => TariffEntries.Count > 0 ? TariffEntries[0] : new RentalDescription.TariffElement();
|
public RentalDescription.TariffElement TarifEntry1 => TariffEntries.Count > 0 ? TariffEntries[0] : new RentalDescription.TariffElement();
|
||||||
public RentalDescription.TariffElement TarifEntry2 => TariffEntries.Count > 1 ? TariffEntries[1] : new RentalDescription.TariffElement();
|
public RentalDescription.TariffElement TarifEntry2 => TariffEntries.Count > 1 ? TariffEntries[1] : new RentalDescription.TariffElement();
|
||||||
public RentalDescription.TariffElement TarifEntry3 => TariffEntries.Count > 2 ? TariffEntries[2] : new RentalDescription.TariffElement();
|
public RentalDescription.TariffElement TarifEntry3 => TariffEntries.Count > 2 ? TariffEntries[2] : new RentalDescription.TariffElement();
|
||||||
|
|
|
@ -1,5 +1,12 @@
|
||||||
using System.ComponentModel;
|
using System;
|
||||||
|
using System.ComponentModel;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
using Serilog;
|
||||||
|
using TINK.Model;
|
||||||
|
using TINK.Model.Bikes;
|
||||||
|
using TINK.Model.Connector;
|
||||||
|
using TINK.Model.Services.CopriApi;
|
||||||
|
using TINK.ViewModel.Info;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
|
|
||||||
namespace TINK.ViewModel.Contact
|
namespace TINK.ViewModel.Contact
|
||||||
|
@ -12,24 +19,67 @@ namespace TINK.ViewModel.Contact
|
||||||
/// <summary> Holds value wether site caching is on or off.</summary>
|
/// <summary> Holds value wether site caching is on or off.</summary>
|
||||||
bool IsSiteCachingOn { get; }
|
bool IsSiteCachingOn { get; }
|
||||||
|
|
||||||
private string FeesResourcePath { get; }
|
/// <summary>
|
||||||
|
/// Relative path to fees resources of empty if value was not yet querried from backend.
|
||||||
|
/// </summary>
|
||||||
|
private string FeesResourcePath { get; set; }
|
||||||
|
|
||||||
private string BikesResourcePath { get; }
|
/// <summary>
|
||||||
|
/// Relative path to bike info resources of empty if value was not yet querried from backend.
|
||||||
|
/// </summary>
|
||||||
|
private string BikesResourcePath { get; set; }
|
||||||
|
|
||||||
|
private bool _IsIdle = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Is true if no action is pending, false otherwise.
|
||||||
|
/// </summary>
|
||||||
|
public bool IsIdle
|
||||||
|
{
|
||||||
|
get => _IsIdle;
|
||||||
|
private set
|
||||||
|
{
|
||||||
|
if (_IsIdle == value)
|
||||||
|
{
|
||||||
|
// Nothing to do.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_IsIdle = value;
|
||||||
|
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(IsIdle)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Object to querry resources urls object from backend if required.
|
||||||
|
/// This object is used to update resources path values <see cref="FeesResourcePath"/>, and <see cref="BikesResourcePath"/> from.
|
||||||
|
/// </summary>
|
||||||
|
private Func<IQuery> QueryProvider { get; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Action to update shared resources urls object exposed by main model.
|
||||||
|
/// </summary>
|
||||||
|
private Action<IResourceUrls> UpdateUrlsAction { get; }
|
||||||
|
|
||||||
/// <summary> Constructs view model.</summary>
|
/// <summary> Constructs view model.</summary>
|
||||||
/// <param name="isSiteCachingOn">Set of user permissions</param>
|
/// <param name="isSiteCachingOn">Set of user permissions</param>
|
||||||
/// <param name="resourceProvider">Delegate to get an an embedded html ressource. Used as fallback if download from web page does not work and cache is empty.</param>
|
/// <param name="resourceProvider">Delegate to get an an embedded html ressource. Used as fallback if download from web page does not work and cache is empty.</param>
|
||||||
|
/// <param name="query">Object to querry resources path values if required.</param>
|
||||||
public FeesAndBikesPageViewModel(
|
public FeesAndBikesPageViewModel(
|
||||||
string hostName,
|
string hostName,
|
||||||
string feesResourcePath,
|
string feesResourcePath,
|
||||||
string bikesResourcePath,
|
string bikesResourcePath,
|
||||||
bool isSiteCachingOn)
|
bool isSiteCachingOn,
|
||||||
|
Func<IQuery> queryProvider,
|
||||||
|
Action<IResourceUrls> updateUrlsAction)
|
||||||
{
|
{
|
||||||
HostName = hostName;
|
HostName = hostName;
|
||||||
FeesResourcePath = feesResourcePath;
|
FeesResourcePath = feesResourcePath;
|
||||||
BikesResourcePath = bikesResourcePath;
|
BikesResourcePath = bikesResourcePath;
|
||||||
IsSiteCachingOn = isSiteCachingOn;
|
IsSiteCachingOn = isSiteCachingOn;
|
||||||
|
QueryProvider = queryProvider;
|
||||||
|
UpdateUrlsAction = updateUrlsAction;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Holds the name of the host.</summary>
|
/// <summary> Holds the name of the host.</summary>
|
||||||
|
@ -38,10 +88,38 @@ namespace TINK.ViewModel.Contact
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
public async void OnAppearing()
|
public async void OnAppearing()
|
||||||
{
|
{
|
||||||
|
// Get resource urls object from backend.
|
||||||
|
async Task<IResourceUrls> GetUrls()
|
||||||
|
{
|
||||||
|
Result<BikeCollection> bikes;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
bikes = await QueryProvider().GetBikesAsync();
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Log.ForContext<FeesAndBikesPageViewModel>().Error($"Getting resource urls from COPRI failed. {ex.Message}");
|
||||||
|
return new ResourceUrls();
|
||||||
|
}
|
||||||
|
|
||||||
|
return bikes?.GeneralData?.ResourceUrls ?? new ResourceUrls();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set state to busy.
|
||||||
|
IsIdle = false;
|
||||||
|
|
||||||
|
if (string.IsNullOrEmpty(FeesResourcePath))
|
||||||
|
{
|
||||||
|
var urls = await GetUrls();
|
||||||
|
FeesResourcePath = urls.FeesResourcePath;
|
||||||
|
BikesResourcePath = urls.BikesResourcePath;
|
||||||
|
UpdateUrlsAction(urls); // Update main model to prevent duplicate queries.
|
||||||
|
}
|
||||||
|
|
||||||
RentBikeText = new HtmlWebViewSource
|
RentBikeText = new HtmlWebViewSource
|
||||||
{
|
{
|
||||||
Html = !string.IsNullOrEmpty(FeesResourcePath)
|
Html = !string.IsNullOrEmpty(FeesResourcePath)
|
||||||
? await ViewModelHelper.GetSource($"https://{HostName}/{FeesResourcePath}" /* "site/tariff_info_1.html" */, IsSiteCachingOn)
|
? await ViewModelHelper.GetSource($"https://{HostName}/{FeesResourcePath}", IsSiteCachingOn)
|
||||||
: await Task.FromResult(ViewModelHelper.FromBody("No fees resource available. Resource path is null or empty."))
|
: await Task.FromResult(ViewModelHelper.FromBody("No fees resource available. Resource path is null or empty."))
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -51,6 +129,9 @@ namespace TINK.ViewModel.Contact
|
||||||
? await ViewModelHelper.GetSource($"https://{HostName}/{BikesResourcePath}" /*"site/bike_info.html"*/, IsSiteCachingOn)
|
? await ViewModelHelper.GetSource($"https://{HostName}/{BikesResourcePath}" /*"site/bike_info.html"*/, IsSiteCachingOn)
|
||||||
: await Task.FromResult(ViewModelHelper.FromBody("No bikes instruction resource available. Resource path is null or empty."))
|
: await Task.FromResult(ViewModelHelper.FromBody("No bikes instruction resource available. Resource path is null or empty."))
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Set state to idle.
|
||||||
|
IsIdle = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private HtmlWebViewSource rentBikeText;
|
private HtmlWebViewSource rentBikeText;
|
||||||
|
|
|
@ -1,10 +1,14 @@
|
||||||
using System;
|
using System;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Serilog;
|
using Serilog;
|
||||||
|
using TINK.Model.Bikes;
|
||||||
|
using TINK.Model;
|
||||||
using TINK.Model.Device;
|
using TINK.Model.Device;
|
||||||
|
using TINK.Model.Services.CopriApi;
|
||||||
using Xamarin.Essentials;
|
using Xamarin.Essentials;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
|
using TINK.Model.Connector;
|
||||||
|
|
||||||
namespace TINK.ViewModel.Info
|
namespace TINK.ViewModel.Info
|
||||||
{
|
{
|
||||||
|
@ -20,39 +24,80 @@ namespace TINK.ViewModel.Info
|
||||||
/// <summary> Holds value wether site caching is on or off.</summary>
|
/// <summary> Holds value wether site caching is on or off.</summary>
|
||||||
bool IsSiteCachingOn { get; }
|
bool IsSiteCachingOn { get; }
|
||||||
|
|
||||||
private string AgbResourcePath { get; }
|
/// <summary>
|
||||||
|
/// Relative path to agb resources of empty if value was not yet querried from backend.
|
||||||
private string PrivacyResourcePath { get; }
|
/// </summary>
|
||||||
|
private string AgbResourcePath { get; set; }
|
||||||
private string ImpressResourcePath { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Holds the current ui two letter ISO language name.
|
/// Relative path to privacy resources of empty if value was not yet querried from backend.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private string UiIsoLanguageName { get; }
|
private string PrivacyResourcePath { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Relative path to impress resources of empty if value was not yet querried from backend.
|
||||||
|
/// </summary>
|
||||||
|
private string ImpressResourcePath { get; set; }
|
||||||
|
|
||||||
|
private bool _IsIdle = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Is true if no action is pending, false otherwise.
|
||||||
|
/// </summary>
|
||||||
|
public bool IsIdle
|
||||||
|
{
|
||||||
|
get => _IsIdle;
|
||||||
|
private set
|
||||||
|
{
|
||||||
|
if (_IsIdle == value)
|
||||||
|
{
|
||||||
|
// Nothing to do.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_IsIdle = value;
|
||||||
|
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(IsIdle)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Object to querry resources urls object from backend if required.
|
||||||
|
/// This object is used to update resources path values <see cref="AgbResourcePath"/>, <see cref="PrivacyResourcePath"/> and <see cref="ImpressResourcePath"/> from.
|
||||||
|
/// </summary>
|
||||||
|
private Func<IQuery> QueryProvider { get; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Action to update shared resources urls object exposed by main model.
|
||||||
|
/// </summary>
|
||||||
|
private Action<IResourceUrls> UpdateUrlsAction { get; }
|
||||||
|
|
||||||
/// <summary> Constructs Info view model</summary>
|
/// <summary> Constructs Info view model</summary>
|
||||||
|
/// <param name="hostName">Name of the host to get html resources from.</param>
|
||||||
/// <param name="isSiteCachingOn">Holds value wether site caching is on or off.</param>
|
/// <param name="isSiteCachingOn">Holds value wether site caching is on or off.</param>
|
||||||
/// <param name="agbResourcePath"> Agb resouce path received from backend.</param>
|
/// <param name="agbResourcePath"> Agb resouce path received from backend.</param>
|
||||||
/// <param name="privacyResourcePath"> Privacy resouce path received from backend.</param>
|
/// <param name="privacyResourcePath"> Privacy resouce path received from backend.</param>
|
||||||
/// <param name="impressResourcePath"> Impress resouce path received from backend.</param>
|
/// <param name="impressResourcePath"> Impress resouce path received from backend.</param>
|
||||||
/// <param name="uiIsoLangugageName">Two letter ISO language name.</param>
|
|
||||||
/// <param name="resourceProvider">Delegate to get an an embedded html ressource. Used as fallback if download from web page does not work and cache is empty.</param>
|
/// <param name="resourceProvider">Delegate to get an an embedded html ressource. Used as fallback if download from web page does not work and cache is empty.</param>
|
||||||
|
/// <param name="queryProvider">Object to querry resources urls object from backend if required.</param>
|
||||||
|
/// <param name="updateUrlsAction">Action to update shared resources urls object</param>
|
||||||
public InfoPageViewModel(
|
public InfoPageViewModel(
|
||||||
string hostName,
|
string hostName,
|
||||||
string agbResourcePath,
|
string agbResourcePath,
|
||||||
string privacyResourcePath,
|
string privacyResourcePath,
|
||||||
string impressResourcePath,
|
string impressResourcePath,
|
||||||
bool isSiteCachingOn,
|
bool isSiteCachingOn,
|
||||||
string uiIsoLangugageName,
|
Func<string, string> resourceProvider,
|
||||||
Func<string, string> resourceProvider)
|
Func<IQuery> queryProvider,
|
||||||
|
Action<IResourceUrls> updateUrlsAction)
|
||||||
{
|
{
|
||||||
HostName = hostName;
|
HostName = hostName;
|
||||||
AgbResourcePath = agbResourcePath;
|
AgbResourcePath = agbResourcePath;
|
||||||
PrivacyResourcePath = privacyResourcePath;
|
PrivacyResourcePath = privacyResourcePath;
|
||||||
ImpressResourcePath = impressResourcePath;
|
ImpressResourcePath = impressResourcePath;
|
||||||
IsSiteCachingOn = isSiteCachingOn;
|
IsSiteCachingOn = isSiteCachingOn;
|
||||||
UiIsoLanguageName = uiIsoLangugageName;
|
QueryProvider = queryProvider;
|
||||||
|
UpdateUrlsAction = updateUrlsAction;
|
||||||
|
|
||||||
InfoAgb = new HtmlWebViewSource { Html = "<html>Loading...</html>" };
|
InfoAgb = new HtmlWebViewSource { Html = "<html>Loading...</html>" };
|
||||||
|
|
||||||
|
@ -63,6 +108,37 @@ namespace TINK.ViewModel.Info
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
public async void OnAppearing()
|
public async void OnAppearing()
|
||||||
{
|
{
|
||||||
|
// Get resource urls object from backend.
|
||||||
|
async Task<IResourceUrls> GetUrls()
|
||||||
|
{
|
||||||
|
Result<BikeCollection> bikes;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
bikes = await QueryProvider().GetBikesAsync();
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Log.ForContext<InfoPageViewModel>().Error($"Getting resource urls from COPRI failed. {ex.Message}");
|
||||||
|
return new ResourceUrls();
|
||||||
|
}
|
||||||
|
|
||||||
|
IResourceUrls resourceUrls = bikes?.GeneralData?.ResourceUrls ?? new ResourceUrls();
|
||||||
|
return resourceUrls;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set state to busy.
|
||||||
|
IsIdle = false;
|
||||||
|
|
||||||
|
// Check if urls to show info from are already known.
|
||||||
|
if (string.IsNullOrEmpty(PrivacyResourcePath))
|
||||||
|
{
|
||||||
|
var urls = await GetUrls();
|
||||||
|
PrivacyResourcePath = urls.PrivacyResourcePath;
|
||||||
|
ImpressResourcePath = urls.ImpressResourcePath;
|
||||||
|
AgbResourcePath = urls.AgbResourcePath;
|
||||||
|
UpdateUrlsAction(urls); // Update main model to prevent duplicate queries.
|
||||||
|
}
|
||||||
|
|
||||||
// Gets privacy info from server.
|
// Gets privacy info from server.
|
||||||
async Task<HtmlWebViewSource> GetInfoPrivacy()
|
async Task<HtmlWebViewSource> GetInfoPrivacy()
|
||||||
{
|
{
|
||||||
|
@ -113,11 +189,14 @@ namespace TINK.ViewModel.Info
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
InfoAgb = await GetAgb(HostName, AgbResourcePath, IsSiteCachingOn, UiIsoLanguageName);
|
InfoAgb = await GetAgb(HostName, AgbResourcePath, IsSiteCachingOn);
|
||||||
|
|
||||||
InfoPrivacy = await GetInfoPrivacy();
|
InfoPrivacy = await GetInfoPrivacy();
|
||||||
|
|
||||||
InfoImpressum = await GetImpressum();
|
InfoImpressum = await GetImpressum();
|
||||||
|
|
||||||
|
// Set state to idle.
|
||||||
|
IsIdle = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Gets the AGBs</summary>
|
/// <summary> Gets the AGBs</summary>
|
||||||
|
@ -126,8 +205,7 @@ namespace TINK.ViewModel.Info
|
||||||
public static async Task<HtmlWebViewSource> GetAgb(
|
public static async Task<HtmlWebViewSource> GetAgb(
|
||||||
string hostName,
|
string hostName,
|
||||||
string agbResourcePath,
|
string agbResourcePath,
|
||||||
bool isSiteCachingOn,
|
bool isSiteCachingOn)
|
||||||
string uiIsoLangugageName)
|
|
||||||
{
|
{
|
||||||
string GetUriText()
|
string GetUriText()
|
||||||
=> $"https://{hostName}/{agbResourcePath}";
|
=> $"https://{hostName}/{agbResourcePath}";
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
@ -228,27 +228,6 @@ namespace TINK.ViewModel
|
||||||
return l_oError;
|
return l_oError;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// <summary> User tabbed a URI. </summary>
|
|
||||||
/// <param name="sender">Sender of the event.</param>
|
|
||||||
/// <param name="eventArgs">Event arguments</param>
|
|
||||||
public static void OnNavigating(object sender, WebNavigatingEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (!eventArgs.Url.ToUpper().StartsWith("HTTP"))
|
|
||||||
{
|
|
||||||
// An internal link was detected.
|
|
||||||
// Stay inside WebView
|
|
||||||
eventArgs.Cancel = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Do not navigate outside the document.
|
|
||||||
eventArgs.Cancel = true;
|
|
||||||
|
|
||||||
DependencyService.Get<IExternalBrowserService>().OpenUrl(eventArgs.Url);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary> Gets the user group if a user friendly name.</summary>
|
/// <summary> Gets the user group if a user friendly name.</summary>
|
||||||
/// <param name="user"></param>
|
/// <param name="user"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
|
@ -19,11 +19,6 @@ namespace TINK.ViewModel.WhatsNew.Agb
|
||||||
/// <summary> Holds value wether site caching is on or off.</summary>
|
/// <summary> Holds value wether site caching is on or off.</summary>
|
||||||
bool IsSiteCachingOn { get; }
|
bool IsSiteCachingOn { get; }
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Holds the current ui two letter ISO language name.
|
|
||||||
/// </summary>
|
|
||||||
private string UiIsoLanguageName { get; }
|
|
||||||
|
|
||||||
/// <summary> Constructs AGB view model</summary>
|
/// <summary> Constructs AGB view model</summary>
|
||||||
/// <param name="isSiteCachingOn">Holds value wether site caching is on or off.</param>
|
/// <param name="isSiteCachingOn">Holds value wether site caching is on or off.</param>
|
||||||
/// <param name="uiIsoLangugageName">Two letter ISO language name.</param>
|
/// <param name="uiIsoLangugageName">Two letter ISO language name.</param>
|
||||||
|
@ -32,13 +27,11 @@ namespace TINK.ViewModel.WhatsNew.Agb
|
||||||
public AgbViewModel(
|
public AgbViewModel(
|
||||||
string hostName,
|
string hostName,
|
||||||
bool isSiteCachingOn,
|
bool isSiteCachingOn,
|
||||||
string uiIsoLangugageName,
|
|
||||||
Func<string, string> resourceProvider,
|
Func<string, string> resourceProvider,
|
||||||
IViewService viewService)
|
IViewService viewService)
|
||||||
{
|
{
|
||||||
HostName = hostName;
|
HostName = hostName;
|
||||||
IsSiteCachingOn = isSiteCachingOn;
|
IsSiteCachingOn = isSiteCachingOn;
|
||||||
UiIsoLanguageName = uiIsoLangugageName;
|
|
||||||
|
|
||||||
ViewService = viewService
|
ViewService = viewService
|
||||||
?? throw new ArgumentException($"Can not instantiate {typeof(WhatsNewViewModel)}-object. No view available.");
|
?? throw new ArgumentException($"Can not instantiate {typeof(WhatsNewViewModel)}-object. No view available.");
|
||||||
|
@ -67,7 +60,7 @@ namespace TINK.ViewModel.WhatsNew.Agb
|
||||||
/// <summary> Called when page is shown. </summary>
|
/// <summary> Called when page is shown. </summary>
|
||||||
public async Task OnAppearing()
|
public async Task OnAppearing()
|
||||||
{
|
{
|
||||||
InfoAgb = await InfoPageViewModel.GetAgb(HostName, "agbResourcePath", IsSiteCachingOn, UiIsoLanguageName);
|
InfoAgb = await InfoPageViewModel.GetAgb(HostName, "agbResourcePath", IsSiteCachingOn);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> User clicks OK button.</summary>
|
/// <summary> User clicks OK button.</summary>
|
||||||
|
|
|
@ -887,9 +887,8 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Bikes.Bike.BluetoothLock.Re
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1095,9 +1095,8 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Bikes.Bike.BluetoothLock.Re
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -1278,9 +1277,8 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Bikes.Bike.BluetoothLock.Re
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -1341,9 +1339,8 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Bikes.Bike.BluetoothLock.Re
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -1405,9 +1402,8 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Bikes.Bike.BluetoothLock.Re
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
|
|
@ -286,9 +286,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -973,9 +972,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -1036,9 +1034,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -1100,9 +1097,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
|
|
@ -663,9 +663,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -843,9 +842,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -906,9 +904,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
@ -970,9 +967,8 @@ namespace TestShareeLib.ViewModel.Bikes.Bike.BluetoothLock.RequestHandler
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify state "Booked Closed" after action
|
// Verify state "Booked Closed" after action
|
||||||
// Following two assertions are deactivated temporarily in context of issue https://dev.azure.com/TeilRad/sharee.bike%20Buchungsplattform/_workitems/edit/440/.
|
Assert.AreEqual("Return bike", subsequent.ButtonText);
|
||||||
//Assert.AreEqual("Return bike", subsequent.ButtonText);
|
Assert.IsTrue(subsequent.IsButtonVisible);
|
||||||
//Assert.IsTrue(subsequent.IsButtonVisible);
|
|
||||||
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
Assert.AreEqual("Open lock", subsequent.LockitButtonText);
|
||||||
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
Assert.IsTrue(subsequent.IsLockitButtonVisible);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using TINK.Model.Bikes.BikeInfoNS;
|
using TINK.Model.Bikes.BikeInfoNS;
|
||||||
using TINK.ViewModel.Bikes.Bike;
|
using TINK.ViewModel.Bikes.Bike;
|
||||||
|
|
||||||
|
@ -22,7 +22,6 @@ namespace TestShareeLib.ViewModel.Bikes.Bike
|
||||||
InfoEntries = new System.Collections.Generic.Dictionary<string, RentalDescription.InfoElement>
|
InfoEntries = new System.Collections.Generic.Dictionary<string, RentalDescription.InfoElement>
|
||||||
{
|
{
|
||||||
{ "15", new RentalDescription.InfoElement { Key = "Tracking", Value = "Ich stimme der Speicherung (Tracking) meiner Fahrstrecke zwecks wissenschaftlicher Auswertung und Berechnung der CO2-Einsparung zu!" } },
|
{ "15", new RentalDescription.InfoElement { Key = "Tracking", Value = "Ich stimme der Speicherung (Tracking) meiner Fahrstrecke zwecks wissenschaftlicher Auswertung und Berechnung der CO2-Einsparung zu!" } },
|
||||||
{ "22", new RentalDescription.InfoElement { Key = "AGB", Value ="Mit der Mietrad Anmietung wird folgender Betreiber <a href='$varenv->{wwwhost}/site/agb.html' target='_blank'>AGB</a> zugestimmt"} }
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -40,10 +39,6 @@ namespace TestShareeLib.ViewModel.Bikes.Bike
|
||||||
viewModel.InfoEntries.Count,
|
viewModel.InfoEntries.Count,
|
||||||
Is.EqualTo(1));
|
Is.EqualTo(1));
|
||||||
|
|
||||||
Assert.That(
|
|
||||||
viewModel.OperatorAgb,
|
|
||||||
Is.EqualTo("Mit der Mietrad Anmietung wird folgender Betreiber <a href='$varenv->{wwwhost}/site/agb.html' target='_blank'>AGB</a> zugestimmt"));
|
|
||||||
|
|
||||||
Assert.That(
|
Assert.That(
|
||||||
viewModel.TarifEntry1.Value,
|
viewModel.TarifEntry1.Value,
|
||||||
Is.EqualTo("Max Gebühr"));
|
Is.EqualTo("Max Gebühr"));
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using TINK.ViewModel.Info;
|
using TINK.ViewModel.Info;
|
||||||
|
|
||||||
namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Info
|
namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Info
|
||||||
|
@ -9,7 +9,15 @@ namespace TestTINKLib.Fixtures.ObjectTests.ViewModel.Info
|
||||||
[Test]
|
[Test]
|
||||||
public void TestOnAppearing()
|
public void TestOnAppearing()
|
||||||
{
|
{
|
||||||
var viewModel = new InfoPageViewModel("Hosti", "agbResourcePath", "privacyResourcePath", "impressResourcePath", false, "de", (url) => string.Empty);
|
var viewModel = new InfoPageViewModel(
|
||||||
|
"Hosti",
|
||||||
|
"agbResourcePath",
|
||||||
|
"privacyResourcePath",
|
||||||
|
"impressResourcePath",
|
||||||
|
false,
|
||||||
|
(url) => string.Empty,
|
||||||
|
() => null,
|
||||||
|
(resourceUrls) => { });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue