aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views
diff options
context:
space:
mode:
Diffstat (limited to 'Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views')
-rw-r--r--Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml77
-rw-r--r--Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml.cs211
-rw-r--r--Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml23
-rw-r--r--Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml.cs29
4 files changed, 0 insertions, 340 deletions
diff --git a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml b/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml
deleted file mode 100644
index ce28d660e..000000000
--- a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml
+++ /dev/null
@@ -1,77 +0,0 @@
-<UserControl x:Class="Tango.PPC.Browser.Views.BrowserView"
- xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
- xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
- xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
- xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
- xmlns:vm="clr-namespace:Tango.PPC.Browser.ViewModels"
- xmlns:wpf="clr-namespace:CefSharp.Wpf;assembly=CefSharp.Wpf"
- xmlns:experimental="clr-namespace:CefSharp.Wpf.Experimental;assembly=CefSharp.Wpf"
- xmlns:global="clr-namespace:Tango.PPC.Browser"
- xmlns:touch="clr-namespace:Tango.Touch.Controls;assembly=Tango.Touch"
- xmlns:keyboard="clr-namespace:Tango.Touch.Keyboard;assembly=Tango.Touch"
- xmlns:local="clr-namespace:Tango.PPC.Browser.Views"
- mc:Ignorable="d"
- d:DesignHeight="1280" d:DesignWidth="800" d:DataContext="{d:DesignInstance Type=vm:BrowserViewVM, IsDesignTimeCreatable=False}" DataContext="{x:Static global:ViewModelLocator.BrowserViewVM}" Background="{StaticResource TangoPrimaryBackgroundBrush}">
- <Grid>
- <DockPanel>
- <Border DockPanel.Dock="Top" Padding="10" BorderBrush="{StaticResource TangoGrayBrush}" BorderThickness="0 0 0 1" Visibility="{Binding DisplayAddressBar,Converter={StaticResource BooleanToVisibilityConverter}}">
- <DockPanel>
- <touch:TouchButton x:Name="btnGo" Command="{Binding GoCommand}" DockPanel.Dock="Right" Padding="10" Width="150" CornerRadius="20" Margin="20 0 0 0">
- <touch:TouchIcon Icon="ArrowRightBold" Height="20" />
- </touch:TouchButton>
- <Grid>
- <Border Background="{StaticResource TangoMidBackgroundBrush}" Padding="2" BorderBrush="{StaticResource TangoLightBorderBrush}" BorderThickness="1" CornerRadius="20">
- <TextBox x:Name="txtAddress" PreviewMouseDoubleClick="TxtAddress_PreviewMouseDoubleClick" GotFocus="TxtAddress_GotFocus" PreviewMouseUp="TxtAddress_MouseUp" LostFocus="TxtAddress_LostFocus" KeyDown="TxtAddress_KeyDown" VerticalContentAlignment="Center" Text="{Binding Address,UpdateSourceTrigger=PropertyChanged}" BorderThickness="0" FontSize="{StaticResource TangoDefaultFontSize}" Padding="5" Background="Transparent"></TextBox>
- </Border>
- <Border CornerRadius="20" IsHitTestVisible="False" Visibility="{Binding ElementName=Browser,Path=IsLoading,Converter={StaticResource BooleanToVisibilityConverter}}">
- <Border.Background>
- <LinearGradientBrush>
- <GradientStop Offset="0" Color="Transparent" />
- <GradientStop Offset="0.5" Color="#7612D433" />
- <GradientStop Offset="1" Color="Transparent" />
- </LinearGradientBrush>
- </Border.Background>
- <Border.Style>
- <Style TargetType="Border">
- <Style.Triggers>
- <DataTrigger Binding="{Binding ElementName=Browser,Path=IsLoading}" Value="True">
- <DataTrigger.EnterActions>
- <BeginStoryboard Name="loadingStory">
- <Storyboard>
- <DoubleAnimation Storyboard.TargetProperty="Background.GradientStops[1].Offset" From="0" To="1" AutoReverse="True" RepeatBehavior="Forever" />
- </Storyboard>
- </BeginStoryboard>
- </DataTrigger.EnterActions>
- <DataTrigger.ExitActions>
- <RemoveStoryboard BeginStoryboardName="loadingStory" />
- </DataTrigger.ExitActions>
- </DataTrigger>
- </Style.Triggers>
- </Style>
- </Border.Style>
- </Border>
- </Grid>
- </DockPanel>
- </Border>
-
- <Grid>
- <experimental:ChromiumWebBrowserWithTouchSupport x:Name="Browser" />
- <Grid Background="White" IsHitTestVisible="False" Visibility="Hidden" x:Name="gridError">
- <StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
- <touch:TouchIcon Icon="Alert" Foreground="{StaticResource TangoGrayTextBrush}" Width="100" Height="100" />
- <TextBlock HorizontalAlignment="Center" Foreground="{StaticResource TangoGrayTextBrush}" FontSize="40" Margin="0 20 0 0">Page Not Found</TextBlock>
- <TextBlock Margin="0 10 0 0" Foreground="{StaticResource TangoGrayTextBrush}" HorizontalAlignment="Center" Width="600" TextAlignment="Center" TextWrapping="Wrap">
- <Run>The page at '</Run><Run Text="{Binding ElementName=txtAddress,Path=Text,Mode=OneWay}"></Run><Run>'</Run>
- <Run>could not be reached.</Run>
- <LineBreak/>
- <Run>Please check your internet connection.</Run>
- <LineBreak/>
- <LineBreak/>
- <Run x:Name="runError" Text="Unspecified"></Run>
- </TextBlock>
- </StackPanel>
- </Grid>
- </Grid>
- </DockPanel>
- </Grid>
-</UserControl>
diff --git a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml.cs b/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml.cs
deleted file mode 100644
index e7fe1ca27..000000000
--- a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/BrowserView.xaml.cs
+++ /dev/null
@@ -1,211 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Diagnostics;
-using System.Linq;
-using System.Text;
-using System.Text.RegularExpressions;
-using System.Threading.Tasks;
-using System.Windows;
-using System.Windows.Controls;
-using System.Windows.Data;
-using System.Windows.Documents;
-using System.Windows.Input;
-using System.Windows.Media;
-using System.Windows.Media.Imaging;
-using System.Windows.Navigation;
-using System.Windows.Shapes;
-using System.Windows.Threading;
-using CefSharp;
-using CefSharp.Wpf;
-using Tango.Core.DI;
-using Tango.Core.Helpers;
-using Tango.Logging;
-using Tango.PPC.Browser.BoundsObjects;
-using Tango.PPC.Browser.ViewContracts;
-using Tango.PPC.Common.Helpers;
-using Tango.Touch.Keyboard;
-
-namespace Tango.PPC.Browser.Views
-{
- /// <summary>
- /// Interaction logic for MainView.xaml
- /// </summary>
- public partial class BrowserView : UserControl, IBrowserView
- {
- public event EventHandler<string> AddressChanged;
-
- public static BrowserView Instance { get; set; }
-
- public BrowserView()
- {
- try
- {
- var settings = new CefSettings();
- settings.BrowserSubprocessPath = @"x86\CefSharp.BrowserSubprocess.exe";
- settings.UserAgent = "Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148";
-
- Cef.Initialize(settings, performDependencyCheck: false, browserProcessHandler: null);
- }
- catch (Exception ex)
- {
- LogManager.Default.Log(ex, "Error loading cef.");
- }
-
- InitializeComponent();
-
- Instance = this;
-
- TangoIOC.Default.Register<IBrowserView>(this);
-
- Helpers.BoundObjectsHelper.RegisterAllBoundObjects(Browser, Dispatcher);
-
- KeyboardView.Default.KeyboardOpened += Default_KeyboardOpened;
- KeyboardView.Default.KeyboardClosed += Default_KeyboardClosed;
-
- var handler = new RequestHandlers.ChromiumRequestHandler();
- handler.AddressChanged += Handler_AddressChanged;
- Browser.RequestHandler = handler;
- Browser.LoadError += Browser_LoadError;
- Browser.LoadingStateChanged += Browser_LoadingStateChanged;
- }
-
- private void Browser_LoadError(object sender, LoadErrorEventArgs e)
- {
- //if (e.ErrorCode == CefErrorCode.ConnectionTimedOut || e.ErrorCode == CefErrorCode.NameNotResolved)
- //{
- InvokeUI(() =>
- {
- runError.Text = e.ErrorText;
- gridError.Visibility = Visibility.Visible;
- });
- //}
- }
-
- private void Browser_LoadingStateChanged(object sender, LoadingStateChangedEventArgs e)
- {
- if (!e.IsLoading)
- {
- InvokeUI(() =>
- {
- KeyboardHelper.CloseKeyboard();
- });
- }
- else
- {
- InvokeUI(() =>
- {
- gridError.Visibility = Visibility.Hidden;
- });
- }
- }
-
- private void Handler_AddressChanged(object sender, string address)
- {
- InvokeUI(() =>
- {
- AddressChanged?.Invoke(this, address);
- });
- }
-
- private void Default_KeyboardClosed(object sender, EventArgs e)
- {
- Browser.VerticalAlignment = VerticalAlignment.Stretch;
- Browser.Height = double.NaN;
- }
-
- private void Default_KeyboardOpened(object sender, EventArgs e)
- {
- Browser.VerticalAlignment = VerticalAlignment.Top;
- Browser.Height = 780;
- }
-
- public bool CanGoBack()
- {
- return Browser.CanGoBack;
- }
-
- public void NavigateTo(string address)
- {
- if (Browser.Address != address)
- {
- String uri;
-
- if (ValidHttpURL(address, out uri))
- {
- Browser.Address = uri;
- }
- else
- {
- Browser.Address = $"google.com/search?q={address.Replace(" ", "+")}";
- }
- }
- else
- {
- Browser.Reload();
- }
- }
-
- public static bool ValidHttpURL(string s, out string result)
- {
- if (Uri.IsWellFormedUriString(s, UriKind.Absolute))
- {
- result = s;
- return true;
- }
- else if (s.StartsWith("www."))
- {
- result = "http://" + s;
- return true;
- }
-
- result = s;
- return false;
- }
-
- public void GoBack()
- {
- if (Browser.CanGoBack)
- {
- Browser.Back();
- }
- }
-
- private async void TxtAddress_GotFocus(object sender, RoutedEventArgs e)
- {
- KeyboardHelper.OpenKeyboard(KeyboardActionKeyMode.Go);
- await Task.Delay(100);
- txtAddress.SelectAll();
- }
-
- private void TxtAddress_LostFocus(object sender, RoutedEventArgs e)
- {
- KeyboardHelper.CloseKeyboard();
- }
-
- private void TxtAddress_KeyDown(object sender, KeyEventArgs e)
- {
- if (e.Key == Key.Return)
- {
- KeyboardHelper.CloseKeyboard();
- NavigateTo(txtAddress.Text);
- }
- }
-
- private void TxtAddress_MouseUp(object sender, MouseButtonEventArgs e)
- {
- KeyboardHelper.OpenKeyboard(KeyboardActionKeyMode.Go);
- }
-
- private async void TxtAddress_PreviewMouseDoubleClick(object sender, MouseButtonEventArgs e)
- {
- KeyboardHelper.OpenKeyboard(KeyboardActionKeyMode.Go);
- await Task.Delay(100);
- txtAddress.SelectAll();
- }
-
- private void InvokeUI(Action action)
- {
- Dispatcher.BeginInvoke(action);
- }
- }
-}
diff --git a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml b/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml
deleted file mode 100644
index 25e3381ba..000000000
--- a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml
+++ /dev/null
@@ -1,23 +0,0 @@
-<UserControl x:Class="Tango.PPC.Browser.Views.ErrorView"
- xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
- xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
- xmlns:vm="clr-namespace:Tango.PPC.Browser.ViewModels"
- xmlns:global="clr-namespace:Tango.PPC.Browser"
- xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
- xmlns:touch="clr-namespace:Tango.Touch.Controls;assembly=Tango.Touch"
- xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
- xmlns:local="clr-namespace:Tango.PPC.Browser.Views"
- mc:Ignorable="d"
- d:DesignHeight="1280" d:DesignWidth="800" d:DataContext="{d:DesignInstance Type=vm:BrowserViewVM, IsDesignTimeCreatable=False}" DataContext="{x:Static global:ViewModelLocator.BrowserViewVM}" Background="{StaticResource TangoPrimaryBackgroundBrush}">
- <Grid>
- <Grid Background="White" IsHitTestVisible="False">
- <StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
- <touch:TouchIcon Icon="Alert" Foreground="{StaticResource TangoGrayTextBrush}" Width="100" Height="100" />
- <TextBlock HorizontalAlignment="Center" Foreground="{StaticResource TangoGrayTextBrush}" FontSize="40" Margin="0 20 0 0">Browser Not Loaded</TextBlock>
- <TextBlock Margin="0 10 0 0" Foreground="{StaticResource TangoGrayTextBrush}" HorizontalAlignment="Center" Width="600" TextAlignment="Center" TextWrapping="Wrap">
- The browser module was not loaded properly or has caused some error.
- </TextBlock>
- </StackPanel>
- </Grid>
- </Grid>
-</UserControl>
diff --git a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml.cs b/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml.cs
deleted file mode 100644
index 0d59b80f0..000000000
--- a/Software/Visual_Studio/PPC/Modules/Tango.PPC.Browser/Views/ErrorView.xaml.cs
+++ /dev/null
@@ -1,29 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using System.Windows;
-using System.Windows.Controls;
-using System.Windows.Data;
-using System.Windows.Documents;
-using System.Windows.Input;
-using System.Windows.Media;
-using System.Windows.Media.Imaging;
-using System.Windows.Navigation;
-using System.Windows.Shapes;
-using Tango.PPC.Browser.ViewContracts;
-
-namespace Tango.PPC.Browser.Views
-{
- /// <summary>
- /// Interaction logic for ErrorView.xaml
- /// </summary>
- public partial class ErrorView : UserControl
- {
- public ErrorView()
- {
- InitializeComponent();
- }
- }
-}