// --------------------------------------------------------------------------------------------------------------------
//
// This file is part of the HandBrake source code - It may be used under the terms of the GNU General Public License.
//
//
// The Countdown Alert View Model
//
// --------------------------------------------------------------------------------------------------------------------
namespace HandBrakeWPF.ViewModels
{
using System;
using System.Windows.Threading;
using HandBrakeWPF.Model.Options;
using HandBrakeWPF.Properties;
using HandBrakeWPF.Utilities;
using HandBrakeWPF.ViewModels.Interfaces;
///
/// The Countdown Alert View Model
///
public class CountdownAlertViewModel : ViewModelBase, ICountdownAlertViewModel
{
#region Private Fields
///
/// The countdown time.
///
private const int CountdownTime = 60;
///
/// The action.
///
private string action;
///
/// The timer.
///
private DispatcherTimer timer;
#endregion
#region Constructors and Destructors
///
/// Initializes a new instance of the class.
///
public CountdownAlertViewModel()
{
this.IsCancelled = false;
Caliburn.Micro.Execute.OnUIThread(
() =>
{
timer = new DispatcherTimer { Interval = TimeSpan.FromSeconds(1) };
timer.Tick += this.timer_Tick;
timer.Start();
});
}
#endregion
#region Public Properties
///
/// Gets or sets a value indicating whether is cancelled.
///
public bool IsCancelled { get; set; }
///
/// Gets the notice message.
///
public string NoticeMessage
{
get
{
return string.Format(Resources.CountdownAlertViewModel_NoticeMessage, action, CountdownTime - this.Ticks);
}
}
///
/// Gets or sets the ticks.
///
public int Ticks { get; set; }
#endregion
#region Public Methods and Operators
///
/// The cancel.
///
public void Cancel()
{
this.IsCancelled = true;
timer.Stop();
this.Ticks = 0;
this.TryCloseAsync();
}
///
/// The proceed.
///
public void Proceed()
{
this.IsCancelled = false;
timer.Stop();
this.Ticks = 0;
this.TryCloseAsync();
}
///
/// The set action.
///
///
/// The action.
///
public void SetAction(WhenDone actionMsg)
{
this.IsCancelled = false;
this.Ticks = 0;
timer.Start();
this.action = EnumHelper.GetDisplay(actionMsg);
}
#endregion
#region Methods
///
/// The timer_ tick.
///
///
/// The sender.
///
///
/// The e.
///
private void timer_Tick(object sender, EventArgs e)
{
this.Ticks = this.Ticks + 1;
this.NotifyOfPropertyChange(() => this.NoticeMessage);
if (this.Ticks > CountdownTime)
{
timer.Stop();
this.Ticks = 0;
this.TryCloseAsync();
}
}
#endregion
}
}