using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.Core;
using Tango.Core.Commands;
using Tango.Core.Helpers;
using Tango.PPC.Common;
using Tango.PPC.Common.Application;
using Tango.PPC.Common.MachineSetup;
using Tango.PPC.Common.Navigation;
using Tango.PPC.UI.ViewsContracts;
using Tango.Settings;
using Tango.SharedUI.Helpers;
using Tango.SQLExaminer;
namespace Tango.PPC.UI.ViewModels
{
///
/// Represents the machine setup view ViewModel.
///
///
public class MachineSetupViewVM : PPCViewModel
{
///
/// Represents the various machine setup view states.
///
public enum MachineSetupStates
{
None,
Working,
Completed,
Failed,
}
private MachineSetupResult _setup_result;
#region Properties
///
/// Gets or sets the machine setup manager.
///
public IMachineSetupManager MachineSetupManager { get; set; }
private String _serialNumber;
///
/// Gets or sets the serial number.
///
public String SerialNumber
{
get { return _serialNumber; }
set { _serialNumber = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); }
}
private String _hostAddress;
///
/// Gets or sets the host address.
///
public String HostAddress
{
get { return _hostAddress; }
set { _hostAddress = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); }
}
private String _log;
///
/// Gets or sets the log.
///
public String Log
{
get { return _log; }
set { _log = value; RaisePropertyChangedAuto(); }
}
private MachineSetupStates _state;
///
/// Gets or sets the state.
///
public MachineSetupStates State
{
get { return _state; }
set { _state = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); }
}
#endregion
#region Commands
///
/// Gets or sets the start command.
///
public RelayCommand StartCommand { get; set; }
///
/// Gets or sets the complete command.
///
public RelayCommand CompleteCommand { get; set; }
#endregion
#region Constructors
///
/// Initializes a new instance of the class.
///
/// The application manager.
/// The machine setup manager.
public MachineSetupViewVM(IPPCApplicationManager applicationManager, IMachineSetupManager machineSetupManager)
{
MachineSetupManager = machineSetupManager;
MachineSetupManager.ProgressLog += (x, msg) => AppendLog(msg);
MachineSetupManager.ProgressStep += (x, step) => AppendLog(Environment.NewLine + "-----------" + step.ToDescription().ToUpper() + "-----------" + Environment.NewLine);
HostAddress = "localhost\\SQLEXPRESS";
SerialNumber = "1111";
StartCommand = new RelayCommand(StartSetup, () => !String.IsNullOrWhiteSpace(HostAddress) && !String.IsNullOrWhiteSpace(SerialNumber) && State == MachineSetupStates.None);
CompleteCommand = new RelayCommand(CompleteSetup, () => State == MachineSetupStates.Completed);
applicationManager.SetupRequired += ApplicationManager_SetupRequired;
}
#endregion
#region Event Handlers
///
/// Handles the SetupRequired event of the ApplicationManager.
///
/// The source of the event.
/// The instance containing the event data.
private void ApplicationManager_SetupRequired(object sender, EventArgs e)
{
LogManager.Log("SetupRequired event received. Navigating to MachineSetupView...");
NavigationManager.NavigateTo(NavigationView.MachineSetupView);
}
#endregion
#region Private Methods
///
/// Appends the log.
///
/// The MSG.
private void AppendLog(String msg)
{
if (msg != null && !msg.Contains("SQL Examiner"))
{
InvokeUI(() =>
{
View.AppendLog(msg + Environment.NewLine);
});
}
}
///
/// Starts the setup.
///
private async void StartSetup()
{
LogManager.Log("Starting machine setup...");
State = MachineSetupStates.Working;
try
{
_setup_result = await MachineSetupManager.Setup(SerialNumber, HostAddress);
Settings.ApplicationState = ApplicationStates.SemiSetup;
Settings.Save();
State = MachineSetupStates.Completed;
LogManager.Log("Machine setup completed.");
}
catch (Exception ex)
{
LogManager.Log(ex, "Machine setup failed.");
State = MachineSetupStates.Failed;
await NotificationProvider.ShowInfo(ex.Message);
}
}
///
/// Completes the setup.
///
private void CompleteSetup()
{
String updater_exe = AssemblyHelper.GetCurrentAssemblyFolder() + "\\Tango.PPC.Updater.exe";
LogManager.Log("Completing machine setup...");
LogManager.Log($"Executing '{updater_exe}' with arguments '{_setup_result.UpdatePackagePath}'...");
Process.Start(updater_exe, _setup_result.UpdatePackagePath);
LogManager.Log("Terminating application process!");
Environment.Exit(0);
}
#endregion
}
}