aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs
diff options
context:
space:
mode:
authorShlomo Hecht <shlomo@twine-s.com>2020-09-14 15:47:23 +0300
committerShlomo Hecht <shlomo@twine-s.com>2020-09-14 15:47:23 +0300
commitf8205189c94e0a62b3027385beb9c6c1a6f1fa6a (patch)
tree76104e1bd1f3be5f33d7569f5c6cea9b0b38cae0 /Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs
parentf8177fb4afb1446b3b02e249e96f33c36b55e416 (diff)
parent13afc37417c9281f5fbaacd174fd151d793151eb (diff)
downloadTango-f8205189c94e0a62b3027385beb9c6c1a6f1fa6a.tar.gz
Tango-f8205189c94e0a62b3027385beb9c6c1a6f1fa6a.zip
Merge branch 'master' of https://twinetfs.visualstudio.com/Tango/_git/Tango
Diffstat (limited to 'Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs')
-rw-r--r--Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs50
1 files changed, 50 insertions, 0 deletions
diff --git a/Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs b/Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs
new file mode 100644
index 000000000..5656300a7
--- /dev/null
+++ b/Software/Visual_Studio/PPC/Tango.PPC.UI/ThreadLoading/DefaultThreadLoadingService.cs
@@ -0,0 +1,50 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.Integration.Operation;
+using Tango.PPC.Common.Connection;
+using Tango.PPC.Common.Notifications;
+using Tango.PPC.Common.Threading;
+using Tango.PPC.Common.ThreadLoading;
+using Tango.PPC.UI.Dialogs;
+
+namespace Tango.PPC.UI.ThreadLoading
+{
+ public class DefaultThreadLoadingService : IThreadLoadingService
+ {
+ private INotificationProvider _notificationsProvider;
+ private IMachineProvider _machineProvider;
+ private IDispatcherProvider _dispatcher;
+ private bool _dialogShown;
+
+ public DefaultThreadLoadingService(INotificationProvider notificationsProvider, IMachineProvider machineProvider, IDispatcherProvider dispatcher)
+ {
+ _notificationsProvider = notificationsProvider;
+ _machineProvider = machineProvider;
+ _dispatcher = dispatcher;
+ _machineProvider.MachineOperator.ThreadLoadingStatusChanged += MachineOperator_ThreadLoadingStatusChanged;
+ }
+
+ private void MachineOperator_ThreadLoadingStatusChanged(object sender, PMR.ThreadLoading.StartThreadLoadingResponse e)
+ {
+ if (!_dialogShown && e.State != PMR.ThreadLoading.ThreadLoadingState.None)
+ {
+ _dialogShown = true;
+ _dispatcher.Invoke(async () =>
+ {
+ await _notificationsProvider.ShowDialog<ThreadLoadingViewVM>(new ThreadLoadingViewVM());
+ _dialogShown = false;
+ });
+ }
+ }
+
+ public async void StartThreadLoading()
+ {
+ _dialogShown = true;
+ await _notificationsProvider.ShowDialog<ThreadLoadingViewVM>(new ThreadLoadingViewVM(true));
+ _dialogShown = false;
+ }
+ }
+}