2017-08-15 15:30:31 +02:00
|
|
|
|
/*
|
2018-01-16 08:24:00 +01:00
|
|
|
|
* Copyright (c) 2018 ETH Zürich, Educational Development and Technology (LET)
|
2017-08-15 15:30:31 +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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-08-17 12:17:58 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Timers;
|
|
|
|
|
using SafeExamBrowser.Contracts.I18n;
|
2017-08-15 15:30:31 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Logging;
|
|
|
|
|
using SafeExamBrowser.Contracts.SystemComponents;
|
|
|
|
|
using SafeExamBrowser.Contracts.UserInterface.Taskbar;
|
2017-08-17 12:17:58 +02:00
|
|
|
|
using PowerLineStatus = System.Windows.Forms.PowerLineStatus;
|
|
|
|
|
using SystemInformation = System.Windows.Forms.SystemInformation;
|
2017-08-15 15:30:31 +02:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.SystemComponents
|
|
|
|
|
{
|
|
|
|
|
public class PowerSupply : ISystemComponent<ISystemPowerSupplyControl>
|
|
|
|
|
{
|
2017-08-17 12:17:58 +02:00
|
|
|
|
private const int TWO_SECONDS = 2000;
|
|
|
|
|
|
|
|
|
|
private bool infoShown, warningShown;
|
2017-08-15 15:30:31 +02:00
|
|
|
|
private ILogger logger;
|
|
|
|
|
private ISystemPowerSupplyControl control;
|
2017-08-17 12:17:58 +02:00
|
|
|
|
private IText text;
|
|
|
|
|
private Timer timer;
|
2017-08-15 15:30:31 +02:00
|
|
|
|
|
2017-08-17 12:17:58 +02:00
|
|
|
|
public PowerSupply(ILogger logger, IText text)
|
2017-08-15 15:30:31 +02:00
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
2017-08-17 12:17:58 +02:00
|
|
|
|
this.text = text;
|
2017-08-15 15:30:31 +02:00
|
|
|
|
}
|
|
|
|
|
|
2017-08-17 12:17:58 +02:00
|
|
|
|
public void Initialize(ISystemPowerSupplyControl control)
|
2017-08-15 15:30:31 +02:00
|
|
|
|
{
|
2017-08-17 12:17:58 +02:00
|
|
|
|
this.control = control;
|
|
|
|
|
|
|
|
|
|
UpdateControl();
|
|
|
|
|
|
|
|
|
|
timer = new Timer(TWO_SECONDS);
|
|
|
|
|
timer.Elapsed += Timer_Elapsed;
|
|
|
|
|
timer.AutoReset = true;
|
|
|
|
|
timer.Start();
|
|
|
|
|
|
|
|
|
|
logger.Info("Started monitoring the power supply.");
|
2017-08-15 15:30:31 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Terminate()
|
|
|
|
|
{
|
2017-08-17 12:17:58 +02:00
|
|
|
|
timer?.Stop();
|
|
|
|
|
control?.Close();
|
|
|
|
|
logger.Info("Stopped monitoring the power supply.");
|
|
|
|
|
}
|
|
|
|
|
|
2017-09-13 08:33:12 +02:00
|
|
|
|
private void Timer_Elapsed(object sender, ElapsedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
UpdateControl();
|
|
|
|
|
}
|
|
|
|
|
|
2017-08-17 12:17:58 +02:00
|
|
|
|
private void UpdateControl()
|
|
|
|
|
{
|
|
|
|
|
var charge = SystemInformation.PowerStatus.BatteryLifePercent;
|
|
|
|
|
var percentage = Math.Round(charge * 100);
|
|
|
|
|
var status = charge <= 0.35 ? (charge <= 0.2 ? BatteryChargeStatus.Critical : BatteryChargeStatus.Low) : BatteryChargeStatus.Okay;
|
|
|
|
|
var online = SystemInformation.PowerStatus.PowerLineStatus == PowerLineStatus.Online;
|
|
|
|
|
var tooltip = string.Empty;
|
|
|
|
|
|
|
|
|
|
if (online)
|
|
|
|
|
{
|
|
|
|
|
tooltip = text.Get(percentage == 100 ? TextKey.SystemControl_BatteryCharged : TextKey.SystemControl_BatteryCharging);
|
|
|
|
|
infoShown = false;
|
|
|
|
|
warningShown = false;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
var hours = SystemInformation.PowerStatus.BatteryLifeRemaining / 3600;
|
|
|
|
|
var minutes = (SystemInformation.PowerStatus.BatteryLifeRemaining - (hours * 3600)) / 60;
|
|
|
|
|
|
2017-08-17 15:04:19 +02:00
|
|
|
|
HandleBatteryStatus(status);
|
2017-08-17 12:17:58 +02:00
|
|
|
|
|
|
|
|
|
tooltip = text.Get(TextKey.SystemControl_BatteryRemainingCharge);
|
|
|
|
|
tooltip = tooltip.Replace("%%HOURS%%", hours.ToString());
|
|
|
|
|
tooltip = tooltip.Replace("%%MINUTES%%", minutes.ToString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
tooltip = tooltip.Replace("%%CHARGE%%", percentage.ToString());
|
|
|
|
|
|
|
|
|
|
control.SetBatteryCharge(charge, status);
|
|
|
|
|
control.SetPowerGridConnection(online);
|
|
|
|
|
control.SetTooltip(tooltip);
|
2017-08-15 15:30:31 +02:00
|
|
|
|
}
|
2017-08-17 15:04:19 +02:00
|
|
|
|
|
|
|
|
|
private void HandleBatteryStatus(BatteryChargeStatus status)
|
|
|
|
|
{
|
|
|
|
|
if (status == BatteryChargeStatus.Low && !infoShown)
|
|
|
|
|
{
|
|
|
|
|
control.ShowLowBatteryInfo(text.Get(TextKey.SystemControl_BatteryChargeLowInfo));
|
|
|
|
|
infoShown = true;
|
|
|
|
|
logger.Info("Informed the user about low battery charge.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (status == BatteryChargeStatus.Critical && !warningShown)
|
|
|
|
|
{
|
|
|
|
|
control.ShowCriticalBatteryWarning(text.Get(TextKey.SystemControl_BatteryChargeCriticalWarning));
|
|
|
|
|
warningShown = true;
|
|
|
|
|
logger.Warn("Warned the user about critical battery charge.");
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-08-15 15:30:31 +02:00
|
|
|
|
}
|
|
|
|
|
}
|