summaryrefslogtreecommitdiff
path: root/windows/WinUI/ToolbarItem.xaml.cs
diff options
context:
space:
mode:
Diffstat (limited to 'windows/WinUI/ToolbarItem.xaml.cs')
-rw-r--r--windows/WinUI/ToolbarItem.xaml.cs310
1 files changed, 310 insertions, 0 deletions
diff --git a/windows/WinUI/ToolbarItem.xaml.cs b/windows/WinUI/ToolbarItem.xaml.cs
new file mode 100644
index 00000000..29791a4e
--- /dev/null
+++ b/windows/WinUI/ToolbarItem.xaml.cs
@@ -0,0 +1,310 @@
+using System;
+using System.Collections.Generic;
+using System.Collections.ObjectModel;
+using System.ComponentModel;
+using System.Linq;
+using System.Runtime.CompilerServices;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows;
+using System.Windows.Controls;
+using System.Windows.Data;
+using System.Windows.Documents;
+using System.Windows.Input;
+using System.Windows.Media;
+using System.Windows.Media.Imaging;
+using System.Windows.Shapes;
+using System.Text.RegularExpressions;
+using System.Timers;
+using System.Windows.Threading;
+using System.IO;
+using System.Diagnostics;
+using Microsoft.Win32;
+
+namespace WinUI
+{
+ /// <summary>
+ /// Interaction logic for ToolbarItem.xaml
+ /// </summary>
+ public partial class ToolbarItem : Window, INotifyPropertyChanged
+ {
+ private APIHandler handler = APIHandler.Instance;
+
+ private Point netListLocation = new Point(0, 0);
+ private Point joinNetLocation = new Point(0, 0);
+ private Point aboutViewLocation = new Point(0, 0);
+ private Point prefsViewLocation = new Point(0, 0);
+
+ private NetworkListView netListView = new NetworkListView();
+ private JoinNetworkView joinNetView = null;
+ private AboutView aboutView = null;
+ private PreferencesView prefsView = null;
+
+ private NetworkMonitor mon = NetworkMonitor.Instance;
+
+ private ObservableCollection<MenuItem> _networkCollection = new ObservableCollection<MenuItem>();
+
+ public ObservableCollection<MenuItem> NetworkCollection
+ {
+ get { return _networkCollection; }
+ set { _networkCollection = value; }
+ }
+
+ private string nodeId;
+
+ public ToolbarItem()
+ {
+ InitializeComponent();
+
+ mon.SubscribeNetworkUpdates(updateNetworks);
+ mon.SubscribeStatusUpdates(updateStatus);
+
+ SystemEvents.DisplaySettingsChanged += new EventHandler(SystemEvents_DisplaySettingsChanged);
+ }
+
+ ~ToolbarItem()
+ {
+ mon.UnsubscribeNetworkUpdates(updateNetworks);
+ mon.UnsubscribeStatusUpdates(updateStatus);
+ }
+
+ public event PropertyChangedEventHandler PropertyChanged;
+
+ protected void NotifyPropertyChanged([CallerMemberName] string propertyName = null)
+ {
+ PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
+ }
+
+ private void updateNetworks(List<ZeroTierNetwork> networks)
+ {
+ if (networks != null)
+ {
+ this.Dispatcher.BeginInvoke(DispatcherPriority.Normal, new Action(() =>
+ {
+ NetworkCollection.Clear();
+ foreach (ZeroTierNetwork n in networks)
+ {
+ MenuItem item = new MenuItem();
+ item.Header = n.Title;
+ item.DataContext = n;
+ item.IsChecked = n.IsConnected;
+ item.Click += ToolbarItem_NetworkClicked;
+
+ NetworkCollection.Add(item);
+ }
+ }));
+ }
+ }
+
+ private void updateStatus(ZeroTierStatus status)
+ {
+ if (status != null)
+ {
+ Dispatcher.BeginInvoke(DispatcherPriority.Normal, new Action(() =>
+ {
+ nodeIdMenuItem.Header = "Node ID: " + status.Address;
+ nodeIdMenuItem.IsEnabled = true;
+ nodeId = status.Address;
+ }));
+ }
+ }
+
+ private void ToolbarItem_NodeIDClicked(object sender, System.Windows.RoutedEventArgs e)
+ {
+ Clipboard.SetText(nodeId);
+ }
+
+ private void ToolbarItem_ShowNetworksClicked(object sender, System.Windows.RoutedEventArgs e)
+ {
+ if (netListView == null)
+ {
+ netListView = new WinUI.NetworkListView();
+ netListView.Closed += ShowNetworksClosed;
+ }
+
+ bool netListNeedsMoving = true;
+ if (netListLocation.X > 0 && netListLocation.Y > 0)
+ {
+ netListView.Left = netListLocation.X;
+ netListView.Top = netListLocation.Y;
+ netListNeedsMoving = false;
+ }
+
+ netListView.Show();
+
+ if (netListNeedsMoving)
+ {
+ setWindowPosition(netListView);
+ netListLocation.X = netListView.Left;
+ netListLocation.Y = netListView.Top;
+ }
+
+ netListView.Activate();
+ }
+
+ private void ShowNetworksClosed(object sender, System.EventArgs e)
+ {
+ netListView = null;
+ }
+
+ private void ToolbarItem_JoinNetworkClicked(object sender, System.EventArgs e)
+ {
+ if (joinNetView == null)
+ {
+ joinNetView = new JoinNetworkView();
+ joinNetView.Closed += JoinNetworkClosed;
+
+ bool needsMove = true;
+ if (joinNetLocation.X > 0 && joinNetLocation.Y > 0)
+ {
+ joinNetView.Left = joinNetLocation.X;
+ joinNetView.Top = joinNetLocation.Y;
+ needsMove = false;
+ }
+
+ joinNetView.Show();
+
+ if (needsMove)
+ {
+ setWindowPosition(joinNetView);
+ joinNetLocation.X = joinNetView.Left;
+ joinNetLocation.Y = joinNetView.Top;
+ }
+ }
+ else
+ {
+ joinNetView.Activate();
+ }
+ }
+
+ private void JoinNetworkClosed(object sender, System.EventArgs e)
+ {
+ joinNetView = null;
+ }
+
+ private void ToolbarItem_AboutClicked(object sender, System.EventArgs e)
+ {
+ if (aboutView == null)
+ {
+ aboutView = new AboutView();
+ aboutView.Closed += AboutClosed;
+
+ bool needsMove = true;
+ if (aboutViewLocation.X > 0 && aboutViewLocation.Y > 0)
+ {
+ aboutView.Left = aboutViewLocation.X;
+ aboutView.Top = aboutViewLocation.Y;
+ needsMove = false;
+ }
+
+ aboutView.Show();
+
+ if (needsMove)
+ {
+ setWindowPosition(aboutView);
+ aboutViewLocation.X = aboutView.Left;
+ aboutViewLocation.Y = aboutView.Top;
+ }
+ }
+ else
+ {
+ aboutView.Activate();
+ }
+ }
+
+ private void AboutClosed(object sender, System.EventArgs e)
+ {
+ aboutView = null;
+ }
+
+ private void ToolbarItem_PreferencesClicked(object sender, System.EventArgs e)
+ {
+ if (prefsView == null)
+ {
+ prefsView = new PreferencesView();
+ prefsView.Closed += PreferencesClosed;
+
+ bool needsMove = true;
+ if (prefsViewLocation.X > 0 && prefsViewLocation.Y > 0)
+ {
+ prefsView.Left = prefsViewLocation.X;
+ prefsView.Top = prefsViewLocation.Y;
+ needsMove = false;
+ }
+
+ prefsView.Show();
+
+ if (needsMove)
+ {
+ setWindowPosition(prefsView);
+ prefsViewLocation.X = prefsView.Left;
+ prefsViewLocation.Y = prefsView.Top;
+ }
+ }
+ else
+ {
+ prefsView.Activate();
+ }
+ }
+
+ private void PreferencesClosed(object sender, System.EventArgs e)
+ {
+ prefsView = null;
+ }
+
+ private void ToolbarItem_QuitClicked(object sender, System.EventArgs e)
+ {
+ NetworkMonitor.Instance.StopMonitor();
+ this.Close();
+ Application.Current.Shutdown();
+ }
+
+ private void ToolbarItem_NetworkClicked(object sender, System.Windows.RoutedEventArgs e)
+ {
+ if(sender.GetType() == typeof(MenuItem))
+ {
+ MenuItem item = e.Source as MenuItem;
+ if (item.DataContext != null)
+ {
+ ZeroTierNetwork network = item.DataContext as ZeroTierNetwork;
+ if (item.IsChecked)
+ {
+ APIHandler.Instance.LeaveNetwork(network.NetworkId);
+ }
+ else
+ {
+ APIHandler.Instance.JoinNetwork(network.NetworkId, network.AllowManaged, network.AllowGlobal, network.AllowDefault);
+ }
+ }
+ }
+ }
+
+ private void setWindowPosition(Window w)
+ {
+ double width = w.ActualWidth;
+ double height = w.ActualHeight;
+
+ double screenHeight = SystemParameters.PrimaryScreenHeight;
+ double screenWidth = SystemParameters.PrimaryScreenWidth;
+
+ double top = screenHeight - height - 40;
+ double left = screenWidth - width - 20;
+
+ w.Top = top;
+ w.Left = left;
+ }
+
+ private void SystemEvents_DisplaySettingsChanged(object sender, EventArgs e)
+ {
+ // reset cached locations to (0, 0) when display size changes
+ netListLocation.X = 0;
+ netListLocation.Y = 0;
+ joinNetLocation.X = 0;
+ joinNetLocation.Y = 0;
+ aboutViewLocation.X = 0;
+ aboutViewLocation.Y = 0;
+ prefsViewLocation.X = 0;
+ prefsViewLocation.Y = 0;
+ }
+ }
+}