2017-07-24 17:31:28 +02:00
|
|
|
|
/*
|
2023-03-08 00:30:20 +01:00
|
|
|
|
* Copyright (c) 2023 ETH Zürich, Educational Development and Technology (LET)
|
2017-07-24 17:31:28 +02:00
|
|
|
|
*
|
|
|
|
|
* 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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2022-05-13 16:47:18 +02:00
|
|
|
|
using System;
|
2022-05-03 12:53:07 +02:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.Browser.Data;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.Browser.Events;
|
2018-07-06 15:57:38 +02:00
|
|
|
|
|
2019-08-30 09:55:26 +02:00
|
|
|
|
namespace SafeExamBrowser.UserInterface.Contracts.Browser
|
2017-07-24 17:31:28 +02:00
|
|
|
|
{
|
2018-03-06 11:38:12 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Defines the functionality of a browser control (i.e. an instance of the browser resp. its user interface) and is normally embedded
|
|
|
|
|
/// within an <see cref="IBrowserWindow"/>.
|
|
|
|
|
/// </summary>
|
2017-07-24 17:31:28 +02:00
|
|
|
|
public interface IBrowserControl
|
|
|
|
|
{
|
2019-12-13 16:10:10 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// The address which is currently loaded.
|
|
|
|
|
/// </summary>
|
|
|
|
|
string Address { get; }
|
|
|
|
|
|
2019-01-23 09:37:47 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Indicates whether a backward navigation can be performed.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool CanNavigateBackwards { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Indicates whether a forward navigation can be performed.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool CanNavigateForwards { get; }
|
|
|
|
|
|
2022-02-23 13:59:36 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// The user interface control to be embedded in an <see cref="IBrowserWindow"/>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
object EmbeddableControl { get; }
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the address of the browser control changes.
|
|
|
|
|
/// </summary>
|
2017-08-02 08:31:12 +02:00
|
|
|
|
event AddressChangedEventHandler AddressChanged;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
|
2020-05-15 16:13:15 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when a load error occurs.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event LoadFailedEventHandler LoadFailed;
|
|
|
|
|
|
2018-03-01 08:50:08 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the loading state of the browser control changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event LoadingStateChangedEventHandler LoadingStateChanged;
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the current page (and thus the title) of the browser control changes.
|
|
|
|
|
/// </summary>
|
2017-08-02 08:31:12 +02:00
|
|
|
|
event TitleChangedEventHandler TitleChanged;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
|
2020-06-23 16:53:43 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Finalizes the browser control (e.g. stops audio / video playback) and releases all used resources.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Destroy();
|
|
|
|
|
|
2021-11-24 08:42:07 +01:00
|
|
|
|
/// <summary>
|
2024-03-04 14:27:49 +01:00
|
|
|
|
/// Executes the given JavaScript code in the browser. An optional callback may be used to process a potential <see cref="JavaScriptResult"/>.
|
2021-11-24 08:42:07 +01:00
|
|
|
|
/// </summary>
|
2024-03-04 14:27:49 +01:00
|
|
|
|
void ExecuteJavaScript(string code, Action<JavaScriptResult> callback = default);
|
2021-11-24 08:42:07 +01:00
|
|
|
|
|
2020-08-10 21:42:51 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Attempts to find the given term on the current page according to the specified parameters.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Find(string term, bool isInitial, bool caseSensitive, bool forward = true);
|
|
|
|
|
|
2019-01-11 08:25:40 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Initializes the browser control.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Initialize();
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Navigates to the previous page in the browser control history.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void NavigateBackwards();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Navigates to the next page in the browser control history.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void NavigateForwards();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Navigates to the specified web address.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void NavigateTo(string address);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
/// Opens the developer console or actives it, if it is already open.
|
2017-07-31 20:22:53 +02:00
|
|
|
|
/// </summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
void ShowDeveloperConsole();
|
2019-01-18 16:11:33 +01:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
/// Reloads the current web page.
|
2019-01-18 16:11:33 +01:00
|
|
|
|
/// </summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
void Reload();
|
2019-01-18 16:11:33 +01:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
/// Sets the page zoom to the given level. A value of <c>0</c> resets the page zoom.
|
2019-01-18 16:11:33 +01:00
|
|
|
|
/// </summary>
|
2019-05-22 11:42:31 +02:00
|
|
|
|
void Zoom(double level);
|
2017-07-24 17:31:28 +02:00
|
|
|
|
}
|
|
|
|
|
}
|