2017-07-07 15:46:32 +02:00
|
|
|
|
/*
|
2023-03-08 00:30:20 +01:00
|
|
|
|
* Copyright (c) 2023 ETH Zürich, Educational Development and Technology (LET)
|
2017-07-07 15:46:32 +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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2019-12-02 15:48:06 +01:00
|
|
|
|
using System;
|
2019-11-28 17:22:04 +01:00
|
|
|
|
using System.Collections.Generic;
|
2019-08-30 12:30:00 +02:00
|
|
|
|
using SafeExamBrowser.Applications.Contracts.Events;
|
2021-03-18 23:12:07 +01:00
|
|
|
|
using SafeExamBrowser.Core.Contracts.Resources.Icons;
|
2019-08-30 12:30:00 +02:00
|
|
|
|
|
2019-08-30 09:55:26 +02:00
|
|
|
|
namespace SafeExamBrowser.Applications.Contracts
|
2017-07-07 15:46:32 +02:00
|
|
|
|
{
|
2018-03-02 15:41:04 +01:00
|
|
|
|
/// <summary>
|
2019-11-05 10:08:19 +01:00
|
|
|
|
/// Controls the lifetime and functionality of an application.
|
2018-03-02 15:41:04 +01:00
|
|
|
|
/// </summary>
|
2024-02-13 11:04:36 +01:00
|
|
|
|
public interface IApplication<out TWindow> where TWindow : IApplicationWindow
|
2017-07-07 15:46:32 +02:00
|
|
|
|
{
|
2019-08-30 12:30:00 +02:00
|
|
|
|
/// <summary>
|
2019-12-02 15:48:06 +01:00
|
|
|
|
/// Indicates whether the application should be automatically started.
|
2019-08-30 12:30:00 +02:00
|
|
|
|
/// </summary>
|
2019-12-02 15:48:06 +01:00
|
|
|
|
bool AutoStart { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The resource providing the application icon.
|
|
|
|
|
/// </summary>
|
|
|
|
|
IconResource Icon { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The unique identifier of the application.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Guid Id { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The name of the application.
|
|
|
|
|
/// </summary>
|
|
|
|
|
string Name { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The tooltip for the application.
|
|
|
|
|
/// </summary>
|
|
|
|
|
string Tooltip { get; }
|
2019-08-30 12:30:00 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-11-28 17:22:04 +01:00
|
|
|
|
/// Event fired when the windows of the application have changed.
|
2019-08-30 12:30:00 +02:00
|
|
|
|
/// </summary>
|
2019-11-28 17:22:04 +01:00
|
|
|
|
event WindowsChangedEventHandler WindowsChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Returns all windows of the application.
|
|
|
|
|
/// </summary>
|
2024-02-13 11:04:36 +01:00
|
|
|
|
IEnumerable<TWindow> GetWindows();
|
2019-08-30 12:30:00 +02:00
|
|
|
|
|
2017-07-24 17:31:28 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Performs any initialization work, if necessary.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Initialize();
|
|
|
|
|
|
2018-11-15 08:45:17 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Starts the execution of the application.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Start();
|
|
|
|
|
|
2017-07-24 17:31:28 +02:00
|
|
|
|
/// <summary>
|
2018-03-02 15:41:04 +01:00
|
|
|
|
/// Performs any termination work, e.g. releasing of used resources.
|
2017-07-24 17:31:28 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
void Terminate();
|
2017-07-07 15:46:32 +02:00
|
|
|
|
}
|
|
|
|
|
}
|