aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs
diff options
context:
space:
mode:
authorRoy Ben-Shabat <Roy@Twine-s.com>2018-11-29 18:59:41 +0200
committerRoy Ben-Shabat <Roy@Twine-s.com>2018-11-29 18:59:41 +0200
commitdd724f118f584eea84a11af90292a88c62ecd022 (patch)
tree714e7c0dfb12887ed20d85b0aa5c2b6c24743b44 /Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs
parent1e2ae1c1973fd5661815f18c93ee1171a5c08da5 (diff)
downloadTango-dd724f118f584eea84a11af90292a88c62ecd022.tar.gz
Tango-dd724f118f584eea84a11af90292a88c62ecd022.zip
Working on Firmware upgrade !
Diffstat (limited to 'Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs')
-rw-r--r--Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs100
1 files changed, 100 insertions, 0 deletions
diff --git a/Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs b/Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs
new file mode 100644
index 000000000..ce8b09aa4
--- /dev/null
+++ b/Software/Visual_Studio/MachineStudio/Tango.MachineStudio.UI/ViewModels/FirmwareUpgradeViewVM.cs
@@ -0,0 +1,100 @@
+using Microsoft.Win32;
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.Core.Commands;
+using Tango.Integration.Operation;
+using Tango.SharedUI;
+
+namespace Tango.MachineStudio.UI.ViewModels
+{
+ public class FirmwareUpgradeViewVM : DialogViewVM
+ {
+ private IMachineOperator _operator;
+ private FileStream _stream;
+
+ private FirmwareUpgradeHandler _handler;
+ public FirmwareUpgradeHandler Handler
+ {
+ get { return _handler; }
+ set { _handler = value; RaisePropertyChangedAuto(); }
+ }
+
+ private String _selectedFile;
+ public String SelectedFile
+ {
+ get { return _selectedFile; }
+ set { _selectedFile = value; RaisePropertyChangedAuto(); }
+ }
+
+ private int _currentPage;
+ public int CurrentPage
+ {
+ get { return _currentPage; }
+ set { _currentPage = value; RaisePropertyChangedAuto(); }
+ }
+
+ public RelayCommand SelectCommand { get; set; }
+
+ public RelayCommand UpgradeCommand { get; set; }
+
+ public RelayCommand AbortCommand { get; set; }
+
+ public FirmwareUpgradeViewVM(IMachineOperator machineOperator) : base()
+ {
+ _operator = machineOperator;
+ SelectCommand = new RelayCommand(BrowseForFile);
+ UpgradeCommand = new RelayCommand(StartUpgrade, () => SelectedFile != null);
+ AbortCommand = new RelayCommand(AbortUpgrade, () => Handler != null && Handler.Status != FirmwareUpgradeStatus.Validating && Handler.Status != FirmwareUpgradeStatus.Activating);
+ }
+
+ private void BrowseForFile()
+ {
+ OpenFileDialog dlg = new OpenFileDialog();
+ dlg.Title = "Select tango firmware package file";
+ dlg.Filter = "Tango Firmware Package|*.tfp";
+ if (dlg.ShowDialog().Value)
+ {
+ SelectedFile = dlg.FileName;
+ InvalidateRelayCommands();
+ }
+ }
+
+ private async void StartUpgrade()
+ {
+ CurrentPage = 1;
+
+ _stream = new FileStream(SelectedFile, FileMode.Open);
+ Handler = await _operator.UpgradeFirmware(_stream);
+ Handler.Progress += (_, e) =>
+ {
+ InvokeUI(() =>
+ {
+ AbortCommand.RaiseCanExecuteChanged();
+ });
+ };
+ Handler.Completed += (_, __) =>
+ {
+ _stream.Dispose();
+ CurrentPage = 2;
+ };
+ Handler.Canceled += (_, __) =>
+ {
+ _stream.Dispose();
+ };
+ Handler.Failed += (_, __) =>
+ {
+ _stream.Dispose();
+ };
+
+ }
+
+ private async void AbortUpgrade()
+ {
+ await Handler.Cancel();
+ }
+ }
+}