/*
* Copyright (c) 2022 ETH Zürich, Educational Development and Technology (LET)
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
using System;
using SafeExamBrowser.Browser.Contracts.Events;
using SafeExamBrowser.Core.Contracts.Resources.Icons;
using SafeExamBrowser.UserInterface.Contracts.Browser.Data;
using SafeExamBrowser.UserInterface.Contracts.Browser.Events;
using SafeExamBrowser.UserInterface.Contracts.Windows;
namespace SafeExamBrowser.UserInterface.Contracts.Browser
{
///
/// Defines the functionality of a browser window, i.e. a window with an embedded browser instance (see ).
///
public interface IBrowserWindow : IWindow
{
///
/// Enables the backward navigation button.
///
bool CanNavigateBackwards { set; }
///
/// Enables the forward navigation button.
///
bool CanNavigateForwards { set; }
///
/// The native handle of the window.
///
IntPtr Handle { get; }
///
/// Event fired when the user changed the URL.
///
event AddressChangedEventHandler AddressChanged;
///
/// Event fired when the user would like to navigate backwards.
///
event ActionRequestedEventHandler BackwardNavigationRequested;
///
/// Event fired when the user would like to open the developer console.
///
event ActionRequestedEventHandler DeveloperConsoleRequested;
///
/// Event fired when the user would like to search the current page.
///
event FindRequestedEventHandler FindRequested;
///
/// Event fired when the user would like to navigate forwards.
///
event ActionRequestedEventHandler ForwardNavigationRequested;
///
/// Event fired when the user would like to navigate home.
///
event ActionRequestedEventHandler HomeNavigationRequested;
///
/// Event fired when the browser window wants to lose focus to the taskbar.
///
event LoseFocusRequestedEventHandler LoseFocusRequested;
///
/// Event fired when the user would like to reload the current page.
///
event ActionRequestedEventHandler ReloadRequested;
///
/// Event fired when the user would like to zoom in.
///
event ActionRequestedEventHandler ZoomInRequested;
///
/// Event fired when the user would like to zoom out.
///
event ActionRequestedEventHandler ZoomOutRequested;
///
/// Event fired when the user would like to reset the zoom factor.
///
event ActionRequestedEventHandler ZoomResetRequested;
///
/// Sets the focus on the address bar of the window.
///
void FocusAddressBar();
///
/// Sets the focus on the browser content of the window.
///
void FocusBrowser();
///
/// Sets the focus on the toolbar of the window. If the parameter is set to true, the first focusable control on the toolbar gets focused.
/// If it is set to false, the last one.
///
void FocusToolbar(bool forward);
///
/// Displays the find toolbar to search the content of a page.
///
void ShowFindbar();
///
/// Updates the address bar of the browser window to the given value.
///
void UpdateAddress(string adress);
///
/// Updates the icon of the browser window.
///
void UpdateIcon(IconResource icon);
///
/// Updates the download state for the given item.
///
void UpdateDownloadState(DownloadItemState state);
///
/// Updates the loading state according to the given value.
///
void UpdateLoadingState(bool isLoading);
///
/// Updates the page load progress according to the given value.
///
void UpdateProgress(double value);
///
/// Sets the title of the browser window to the given value.
///
void UpdateTitle(string title);
///
/// Updates the display value of the current page zoom. Value is expected to be in percentage.
///
void UpdateZoomLevel(double value);
}
}