SEBWIN-219: Implemented simple loading state indicator for browser window.

This commit is contained in:
dbuechel 2018-03-01 08:50:08 +01:00
parent 40fd49126f
commit f2e3b35730
8 changed files with 150 additions and 116 deletions

View file

@ -32,6 +32,7 @@ namespace SafeExamBrowser.Browser
control = new BrowserControl(settings, text);
control.AddressChanged += Control_AddressChanged;
control.LoadingStateChanged += Control_LoadingStateChanged;
control.TitleChanged += Control_TitleChanged;
window = uiFactory.CreateBrowserWindow(control, settings);
@ -48,6 +49,11 @@ namespace SafeExamBrowser.Browser
window.UpdateAddress(address);
}
private void Control_LoadingStateChanged(bool isLoading)
{
window.UpdateLoadingState(isLoading);
}
private void Control_TitleChanged(string title)
{
window.UpdateTitle(title);

View file

@ -15,19 +15,27 @@ using BrowserSettings = SafeExamBrowser.Contracts.Configuration.Settings.Browser
namespace SafeExamBrowser.Browser
{
class BrowserControl : ChromiumWebBrowser, IBrowserControl
internal class BrowserControl : ChromiumWebBrowser, IBrowserControl
{
private AddressChangedEventHandler addressChanged;
private BrowserSettings settings;
private TitleChangedEventHandler titleChanged;
private IText text;
private AddressChangedEventHandler addressChanged;
private LoadingStateChangedEventHandler loadingStateChanged;
private TitleChangedEventHandler titleChanged;
event AddressChangedEventHandler IBrowserControl.AddressChanged
{
add { addressChanged += value; }
remove { addressChanged -= value; }
}
event LoadingStateChangedEventHandler IBrowserControl.LoadingStateChanged
{
add { loadingStateChanged += value; }
remove { loadingStateChanged -= value; }
}
event TitleChangedEventHandler IBrowserControl.TitleChanged
{
add { titleChanged += value; }
@ -68,6 +76,7 @@ namespace SafeExamBrowser.Browser
private void Initialize()
{
AddressChanged += (o, args) => addressChanged?.Invoke(args.Address);
LoadingStateChanged += (o, args) => loadingStateChanged?.Invoke(args.IsLoading);
TitleChanged += (o, args) => titleChanged?.Invoke(args.Title);
MenuHandler = new BrowserContextMenuHandler(settings, text);

View file

@ -9,6 +9,7 @@
namespace SafeExamBrowser.Contracts.UserInterface
{
public delegate void AddressChangedEventHandler(string address);
public delegate void LoadingStateChangedEventHandler(bool isLoading);
public delegate void TitleChangedEventHandler(string title);
public interface IBrowserControl
@ -18,6 +19,11 @@ namespace SafeExamBrowser.Contracts.UserInterface
/// </summary>
event AddressChangedEventHandler AddressChanged;
/// <summary>
/// Event fired when the loading state of the browser control changes.
/// </summary>
event LoadingStateChangedEventHandler LoadingStateChanged;
/// <summary>
/// Event fired when the current page (and thus the title) of the browser control changes.
/// </summary>

View file

@ -42,6 +42,11 @@ namespace SafeExamBrowser.Contracts.UserInterface
/// </summary>
void UpdateAddress(string adress);
/// <summary>
/// Updates the loading state according to the given value.
/// </summary>
void UpdateLoadingState(bool isLoading);
/// <summary>
/// Sets the title of the browser window to the given value;
/// </summary>

View file

@ -3,8 +3,9 @@
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:fa="http://schemas.fontawesome.io/icons/"
xmlns:local="clr-namespace:SafeExamBrowser.UserInterface.Classic"
mc:Ignorable="d" Title="BrowserWindow" Background="#FFF0F0F0" Height="500" Width="500" WindowState="Maximized" Icon=".\Images\SafeExamBrowser.ico">
mc:Ignorable="d" Title="BrowserWindow" Background="#FFF0F0F0" Height="500" Width="750" WindowState="Maximized" Icon=".\Images\SafeExamBrowser.ico">
<Window.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
@ -26,7 +27,10 @@
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<TextBox Grid.Column="0" x:Name="UrlTextBox" Height="25" HorizontalAlignment="Stretch" Padding="5,0" Margin="10" VerticalContentAlignment="Center" />
<Grid Grid.Column="0" Height="25" Margin="10">
<TextBox x:Name="UrlTextBox" HorizontalAlignment="Stretch" Padding="5,0" VerticalContentAlignment="Center" />
<fa:ImageAwesome x:Name="LoadingIcon" Foreground="Gray" HorizontalAlignment="Right" Icon="Spinner" Margin="5,3" Spin="True" SpinDuration="1.5" Visibility="Collapsed" />
</Grid>
<Button Grid.Column="1" x:Name="ReloadButton" Height="30" HorizontalAlignment="Center" Margin="2.5,5,2.5,5" Template="{StaticResource BrowserButton}" VerticalAlignment="Center" />
<Button Grid.Column="2" x:Name="BackButton" Height="30" HorizontalAlignment="Center" Margin="2.5,5,2.5,5" Template="{StaticResource BrowserButton}" VerticalAlignment="Center" />
<Button Grid.Column="3" x:Name="ForwardButton" Height="30" HorizontalAlignment="Center" Margin="2.5,5,5,5" Template="{StaticResource BrowserButton}" VerticalAlignment="Center" />

View file

@ -86,6 +86,11 @@ namespace SafeExamBrowser.UserInterface.Classic
Dispatcher.Invoke(() => UrlTextBox.Text = url);
}
public void UpdateLoadingState(bool isLoading)
{
Dispatcher.Invoke(() => LoadingIcon.Visibility = isLoading ? Visibility.Visible : Visibility.Collapsed);
}
public void UpdateTitle(string title)
{
Dispatcher.Invoke(() => Title = title);

View file

@ -7,141 +7,138 @@
*/
using System.Windows;
using System.Windows.Input;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.UserInterface;
namespace SafeExamBrowser.UserInterface.Windows10
{
public partial class BrowserWindow : Window, IBrowserWindow
public partial class BrowserWindow : Window // TODO, IBrowserWindow
{
private bool isMainWindow;
private BrowserSettings settings;
public WindowClosingEventHandler closing;
//private bool isMainWindow;
//private BrowserSettings settings;
//public WindowClosingEventHandler closing;
public bool IsMainWindow
{
get
{
return isMainWindow;
}
set
{
isMainWindow = value;
ApplySettings();
}
}
public event AddressChangedEventHandler AddressChanged;
public event ActionRequestedEventHandler BackwardNavigationRequested;
public event ActionRequestedEventHandler ForwardNavigationRequested;
public event ActionRequestedEventHandler ReloadRequested;
event WindowClosingEventHandler IWindow.Closing
{
add { closing += value; }
remove { closing -= value; }
}
public BrowserWindow(IBrowserControl browserControl, BrowserSettings settings)
{
this.settings = settings;
InitializeComponent();
InitializeBrowserWindow(browserControl);
}
public void BringToForeground()
{
Dispatcher.Invoke(() =>
{
if (WindowState == WindowState.Minimized)
{
WindowState = WindowState.Normal;
}
Activate();
});
}
public new void Close()
{
Dispatcher.Invoke(base.Close);
}
public new void Hide()
{
Dispatcher.Invoke(base.Hide);
}
public new void Show()
{
Dispatcher.Invoke(base.Show);
}
public void UpdateAddress(string url)
{
Dispatcher.Invoke(() => UrlTextBox.Text = url);
}
public void UpdateTitle(string title)
{
Dispatcher.Invoke(() => Title = title);
}
private void InitializeBrowserWindow(IBrowserControl browserControl)
{
if (browserControl is System.Windows.Forms.Control control)
{
BrowserControlHost.Child = control;
}
Closing += (o, args) => closing?.Invoke();
KeyUp += BrowserWindow_KeyUp;
UrlTextBox.KeyUp += UrlTextBox_KeyUp;
ReloadButton.Click += (o, args) => ReloadRequested?.Invoke();
BackButton.Click += (o, args) => BackwardNavigationRequested?.Invoke();
ForwardButton.Click += (o, args) => ForwardNavigationRequested?.Invoke();
ApplySettings();
}
private void BrowserWindow_KeyUp(object sender, KeyEventArgs e)
{
if (e.Key == Key.F5)
{
ReloadRequested?.Invoke();
}
}
private void UrlTextBox_KeyUp(object sender, KeyEventArgs e)
{
if (e.Key == Key.Enter)
{
AddressChanged?.Invoke(UrlTextBox.Text);
}
}
private void ApplySettings()
{
if (IsMainWindow && settings.FullScreenMode)
{
MaxHeight = SystemParameters.WorkArea.Height;
ResizeMode = ResizeMode.NoResize;
WindowState = WindowState.Maximized;
WindowStyle = WindowStyle.None;
}
UrlTextBox.IsEnabled = settings.AllowAddressBar;
ReloadButton.IsEnabled = settings.AllowReloading;
ReloadButton.Visibility = settings.AllowReloading ? Visibility.Visible : Visibility.Collapsed;
BackButton.IsEnabled = settings.AllowBackwardNavigation;
BackButton.Visibility = settings.AllowBackwardNavigation ? Visibility.Visible : Visibility.Collapsed;
ForwardButton.IsEnabled = settings.AllowForwardNavigation;
ForwardButton.Visibility = settings.AllowForwardNavigation ? Visibility.Visible : Visibility.Collapsed;
}
//public bool IsMainWindow
//{
// get
// {
// return isMainWindow;
// }
// set
// {
// isMainWindow = value;
// ApplySettings();
// }
//}
//public event AddressChangedEventHandler AddressChanged;
//public event ActionRequestedEventHandler BackwardNavigationRequested;
//public event ActionRequestedEventHandler ForwardNavigationRequested;
//public event ActionRequestedEventHandler ReloadRequested;
//event WindowClosingEventHandler IWindow.Closing
//{
// add { closing += value; }
// remove { closing -= value; }
//}
//public BrowserWindow(IBrowserControl browserControl, BrowserSettings settings)
//{
// this.settings = settings;
// InitializeComponent();
// InitializeBrowserWindow(browserControl);
//}
//public void BringToForeground()
//{
// Dispatcher.Invoke(() =>
// {
// if (WindowState == WindowState.Minimized)
// {
// WindowState = WindowState.Normal;
// }
// Activate();
// });
//}
//public new void Close()
//{
// Dispatcher.Invoke(base.Close);
//}
//public new void Hide()
//{
// Dispatcher.Invoke(base.Hide);
//}
//public new void Show()
//{
// Dispatcher.Invoke(base.Show);
//}
//public void UpdateAddress(string url)
//{
// Dispatcher.Invoke(() => UrlTextBox.Text = url);
//}
//public void UpdateTitle(string title)
//{
// Dispatcher.Invoke(() => Title = title);
//}
//private void InitializeBrowserWindow(IBrowserControl browserControl)
//{
// if (browserControl is System.Windows.Forms.Control control)
// {
// BrowserControlHost.Child = control;
// }
// Closing += (o, args) => closing?.Invoke();
// KeyUp += BrowserWindow_KeyUp;
// UrlTextBox.KeyUp += UrlTextBox_KeyUp;
// ReloadButton.Click += (o, args) => ReloadRequested?.Invoke();
// BackButton.Click += (o, args) => BackwardNavigationRequested?.Invoke();
// ForwardButton.Click += (o, args) => ForwardNavigationRequested?.Invoke();
// ApplySettings();
//}
//private void BrowserWindow_KeyUp(object sender, KeyEventArgs e)
//{
// if (e.Key == Key.F5)
// {
// ReloadRequested?.Invoke();
// }
//}
//private void UrlTextBox_KeyUp(object sender, KeyEventArgs e)
//{
// if (e.Key == Key.Enter)
// {
// AddressChanged?.Invoke(UrlTextBox.Text);
// }
//}
//private void ApplySettings()
//{
// if (IsMainWindow && settings.FullScreenMode)
// {
// MaxHeight = SystemParameters.WorkArea.Height;
// ResizeMode = ResizeMode.NoResize;
// WindowState = WindowState.Maximized;
// WindowStyle = WindowStyle.None;
// }
// UrlTextBox.IsEnabled = settings.AllowAddressBar;
// ReloadButton.IsEnabled = settings.AllowReloading;
// ReloadButton.Visibility = settings.AllowReloading ? Visibility.Visible : Visibility.Collapsed;
// BackButton.IsEnabled = settings.AllowBackwardNavigation;
// BackButton.Visibility = settings.AllowBackwardNavigation ? Visibility.Visible : Visibility.Collapsed;
// ForwardButton.IsEnabled = settings.AllowForwardNavigation;
// ForwardButton.Visibility = settings.AllowForwardNavigation ? Visibility.Visible : Visibility.Collapsed;
//}
}
}

View file

@ -40,7 +40,9 @@ namespace SafeExamBrowser.UserInterface.Windows10
public IBrowserWindow CreateBrowserWindow(IBrowserControl control, BrowserSettings settings)
{
return new BrowserWindow(control, settings);
// TODO
// return new BrowserWindow(control, settings);
throw new System.NotImplementedException();
}
public IWindow CreateLogWindow(ILogger logger)