mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 20:39:51 -04:00 
			
		
		
		
	Initial overhaul work
This commit is contained in:
		| @@ -7,9 +7,9 @@ | ||||
|     <local:ViewLocator/> | ||||
|   </Application.DataTemplates> | ||||
|   <Application.Styles> | ||||
|     <FluentTheme Mode="Light"/> | ||||
|     <FluentTheme Mode="Dark"/> | ||||
|     <StyleInclude Source="avares://Avalonia.Controls.DataGrid/Themes/Fluent.xaml"/> | ||||
|     <StyleInclude Source="avares://Egorozh.ColorPicker.Avalonia.Dialog/Themes/Default.axaml" /> | ||||
|     <dialog:FluentColorPickerTheme Mode="Light" /> | ||||
|     <dialog:FluentColorPickerTheme Mode="Dark" /> | ||||
|   </Application.Styles> | ||||
| </Application> | ||||
| @@ -9,38 +9,73 @@ using Observatory.UI.Models; | ||||
| using ReactiveUI; | ||||
| using System.Reactive.Linq; | ||||
| using Observatory.Framework; | ||||
| using System.Collections.Specialized; | ||||
|  | ||||
| namespace Observatory.UI.ViewModels | ||||
| { | ||||
|     public class BasicUIViewModel : ViewModelBase | ||||
|     { | ||||
|         private ObservableCollection<object> basicUIGrid; | ||||
|         private ObservableCollection<string> _headers; | ||||
|         private ObservableCollection<string> _formats; | ||||
|         private ObservableCollection<ObservableCollection<object>> _items; | ||||
|  | ||||
|         public System.Collections.IList SelectedItems { get; set; }         | ||||
|  | ||||
|         public ObservableCollection<object> BasicUIGrid | ||||
|          | ||||
|         public ObservableCollection<string> Headers | ||||
|         { | ||||
|             get => basicUIGrid; | ||||
|             get => _headers; | ||||
|             set | ||||
|             { | ||||
|                 basicUIGrid = value; | ||||
|                 this.RaisePropertyChanged(nameof(BasicUIGrid)); | ||||
|                 _headers = value; | ||||
|                 _headers.CollectionChanged += (o, e) => this.RaisePropertyChanged(nameof(Headers)); | ||||
|                 this.RaisePropertyChanged(nameof(Headers)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public BasicUIViewModel(ObservableCollection<object> BasicUIGrid) | ||||
|         public ObservableCollection<string> Formats | ||||
|         { | ||||
|             this.BasicUIGrid = BasicUIGrid; | ||||
|             get => _formats; | ||||
|             set | ||||
|             { | ||||
|                 _formats = value; | ||||
|                 _formats.CollectionChanged += (o, e) => this.RaisePropertyChanged(nameof(Formats)); | ||||
|                 this.RaisePropertyChanged(nameof(Formats)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private PluginUI.UIType uiType; | ||||
|         public ObservableCollection<ObservableCollection<object>> Items | ||||
|         { | ||||
|             get => _items; | ||||
|             set | ||||
|             { | ||||
|                 void raiseItemChanged(object o, NotifyCollectionChangedEventArgs e) { this.RaisePropertyChanged(nameof(Items)); } | ||||
|  | ||||
|                 _items = value; | ||||
|                 _items.CollectionChanged += raiseItemChanged; | ||||
|                 this.RaisePropertyChanged(nameof(Items)); | ||||
|                 foreach (var itemColumn in value) | ||||
|                 { | ||||
|                     itemColumn.CollectionChanged += raiseItemChanged; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|  | ||||
|         public BasicUIViewModel(ObservableCollection<string> headers, ObservableCollection<string> formats) | ||||
|         { | ||||
|             Headers = headers; | ||||
|             Formats = formats; | ||||
|         } | ||||
|  | ||||
|         private PluginUI.UIType _uiType; | ||||
|  | ||||
|         public PluginUI.UIType UIType | ||||
|         { | ||||
|             get => uiType; | ||||
|             get => _uiType; | ||||
|             set | ||||
|             { | ||||
|                 uiType = value; | ||||
|                 _uiType = value; | ||||
|                 this.RaisePropertyChanged(nameof(UIType)); | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -47,8 +47,8 @@ namespace Observatory.UI.ViewModels | ||||
|  | ||||
|             foreach(var notifier in notifiers.Select(p => p.plugin)) | ||||
|             { | ||||
|                 Panel notifierPanel = new Panel(); | ||||
|                 TextBlock notifierTextBlock = new TextBlock(); | ||||
|                 Panel notifierPanel = new(); | ||||
|                 TextBlock notifierTextBlock = new(); | ||||
|                 notifierTextBlock.Text = notifier.Name; | ||||
|                 notifierPanel.Children.Add(notifierTextBlock); | ||||
|                 //tabs.Add(new CoreModel() { Name = notifier.ShortName, UI = (ViewModelBase)notifier.UI }); | ||||
| @@ -65,7 +65,7 @@ namespace Observatory.UI.ViewModels | ||||
|  | ||||
|         } | ||||
|  | ||||
|         public void ReadAll() | ||||
|         public static void ReadAll() | ||||
|         { | ||||
|             LogMonitor.GetInstance.ReadAllJournals(); | ||||
|         } | ||||
| @@ -86,21 +86,21 @@ namespace Observatory.UI.ViewModels | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public void OpenGithub() | ||||
|         public static void OpenGithub() | ||||
|         { | ||||
|             ProcessStartInfo githubOpen = new("https://github.com/Xjph/ObservatoryCore"); | ||||
|             githubOpen.UseShellExecute = true; | ||||
|             Process.Start(githubOpen); | ||||
|         } | ||||
|  | ||||
|         public void OpenDonate() | ||||
|         public static void OpenDonate() | ||||
|         { | ||||
|             ProcessStartInfo donateOpen = new("https://paypal.me/eliteobservatory"); | ||||
|             donateOpen.UseShellExecute = true; | ||||
|             Process.Start(donateOpen); | ||||
|         } | ||||
|  | ||||
|         public void GetUpdate() | ||||
|         public static void GetUpdate() | ||||
|         { | ||||
|             ProcessStartInfo githubOpen = new("https://github.com/Xjph/ObservatoryCore/releases"); | ||||
|             githubOpen.UseShellExecute = true; | ||||
|   | ||||
| @@ -15,6 +15,7 @@ using Avalonia.Media; | ||||
| using Avalonia.Controls.ApplicationLifetimes; | ||||
| using System.Runtime.InteropServices; | ||||
| using System.IO; | ||||
| using Avalonia.Platform.Storage; | ||||
|  | ||||
| namespace Observatory.UI.Views | ||||
| { | ||||
| @@ -71,6 +72,7 @@ namespace Observatory.UI.Views | ||||
|             e.Column.CanUserResize = true; | ||||
|             e.Column.CanUserSort = true; | ||||
|         } | ||||
|  | ||||
|         private void UITypeChange() | ||||
|         { | ||||
|             var uiPanel = this.Find<Panel>("UIPanel"); | ||||
| @@ -83,10 +85,9 @@ namespace Observatory.UI.Views | ||||
|                 case PluginUI.UIType.Basic: | ||||
|                     dataGrid = new() | ||||
|                     { | ||||
|                         [!DataGrid.ItemsProperty] = new Binding("BasicUIGrid"), | ||||
|                         [!DataGrid.ItemsProperty] = new Binding("Items"), | ||||
|                         SelectionMode = DataGridSelectionMode.Extended, | ||||
|                         GridLinesVisibility = DataGridGridLinesVisibility.Vertical, | ||||
|                         AutoGenerateColumns = true, | ||||
|                         IsReadOnly = true | ||||
|                     }; | ||||
|                     dataGrid.AutoGeneratingColumn += ColumnGeneration; | ||||
| @@ -1028,21 +1029,33 @@ namespace Observatory.UI.Views | ||||
|  | ||||
|                             settingBrowse.Click += (object source, RoutedEventArgs e) => | ||||
|                             { | ||||
|                                 OpenFileDialog openFileDialog = new() | ||||
|                                 var currentFolder = new Avalonia.Platform.Storage.FileIO.BclStorageFolder(fileSetting.DirectoryName); | ||||
|                                 var fileOptions = new FilePickerOpenOptions() | ||||
|                                 { | ||||
|                                     Directory = fileSetting.DirectoryName, | ||||
|                                     AllowMultiple = false | ||||
|                                     AllowMultiple = false, | ||||
|                                     SuggestedStartLocation = currentFolder | ||||
|                                 }; | ||||
|                                 var browseTask = openFileDialog.ShowAsync((Window)((Button)source).GetVisualRoot()); | ||||
|  | ||||
|                                 var browseTask = ((Window)settingBrowse.FindAncestorOfType<Window>()).StorageProvider.OpenFilePickerAsync(fileOptions); | ||||
|                                  | ||||
|                                 //OpenFileDialog openFileDialog = new() | ||||
|                                 //{ | ||||
|                                 //    Directory = fileSetting.DirectoryName, | ||||
|                                 //    AllowMultiple = false | ||||
|                                 //}; | ||||
|                                  | ||||
|                                 // = openFileDialog.ShowAsync((Window)((Button)source).GetVisualRoot()); | ||||
|                                  | ||||
|                                 browseTask.ContinueWith((task) =>  | ||||
|                                 { | ||||
|                                     if (task.Result?.Count() > 0) | ||||
|                                     { | ||||
|                                         string path = browseTask.Result[0]; | ||||
|                                         Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => { settingPath.Text = path; }); | ||||
|                                         setting.Key.SetValue(plugin.Settings, new FileInfo(path)); | ||||
|                                         PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); | ||||
|  | ||||
|                                         if (browseTask.Result[0].TryGetUri(out Uri path)) | ||||
|                                         { | ||||
|                                             Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => { settingPath.Text = path.AbsolutePath; }); | ||||
|                                             setting.Key.SetValue(plugin.Settings, new FileInfo(path.AbsolutePath)); | ||||
|                                             PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); | ||||
|                                         } | ||||
|                                     } | ||||
|                                 }); | ||||
|                                  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user