2
0
mirror of https://github.com/9ParsonsB/Pulsar.git synced 2025-04-05 17:39:39 -04:00

Initial overhaul work

This commit is contained in:
Xjph 2023-01-04 09:26:48 -03:30
parent 523710ce25
commit e2c6816d45
5 changed files with 93 additions and 30 deletions

View File

@ -7,9 +7,9 @@
<local:ViewLocator/> <local:ViewLocator/>
</Application.DataTemplates> </Application.DataTemplates>
<Application.Styles> <Application.Styles>
<FluentTheme Mode="Light"/> <FluentTheme Mode="Dark"/>
<StyleInclude Source="avares://Avalonia.Controls.DataGrid/Themes/Fluent.xaml"/> <StyleInclude Source="avares://Avalonia.Controls.DataGrid/Themes/Fluent.xaml"/>
<StyleInclude Source="avares://Egorozh.ColorPicker.Avalonia.Dialog/Themes/Default.axaml" /> <StyleInclude Source="avares://Egorozh.ColorPicker.Avalonia.Dialog/Themes/Default.axaml" />
<dialog:FluentColorPickerTheme Mode="Light" /> <dialog:FluentColorPickerTheme Mode="Dark" />
</Application.Styles> </Application.Styles>
</Application> </Application>

View File

@ -9,38 +9,73 @@ using Observatory.UI.Models;
using ReactiveUI; using ReactiveUI;
using System.Reactive.Linq; using System.Reactive.Linq;
using Observatory.Framework; using Observatory.Framework;
using System.Collections.Specialized;
namespace Observatory.UI.ViewModels namespace Observatory.UI.ViewModels
{ {
public class BasicUIViewModel : ViewModelBase 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 System.Collections.IList SelectedItems { get; set; }
public ObservableCollection<object> BasicUIGrid
public ObservableCollection<string> Headers
{ {
get => basicUIGrid; get => _headers;
set set
{ {
basicUIGrid = value; _headers = value;
this.RaisePropertyChanged(nameof(BasicUIGrid)); _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 public PluginUI.UIType UIType
{ {
get => uiType; get => _uiType;
set set
{ {
uiType = value; _uiType = value;
this.RaisePropertyChanged(nameof(UIType)); this.RaisePropertyChanged(nameof(UIType));
} }
} }

View File

@ -47,8 +47,8 @@ namespace Observatory.UI.ViewModels
foreach(var notifier in notifiers.Select(p => p.plugin)) foreach(var notifier in notifiers.Select(p => p.plugin))
{ {
Panel notifierPanel = new Panel(); Panel notifierPanel = new();
TextBlock notifierTextBlock = new TextBlock(); TextBlock notifierTextBlock = new();
notifierTextBlock.Text = notifier.Name; notifierTextBlock.Text = notifier.Name;
notifierPanel.Children.Add(notifierTextBlock); notifierPanel.Children.Add(notifierTextBlock);
//tabs.Add(new CoreModel() { Name = notifier.ShortName, UI = (ViewModelBase)notifier.UI }); //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(); 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"); ProcessStartInfo githubOpen = new("https://github.com/Xjph/ObservatoryCore");
githubOpen.UseShellExecute = true; githubOpen.UseShellExecute = true;
Process.Start(githubOpen); Process.Start(githubOpen);
} }
public void OpenDonate() public static void OpenDonate()
{ {
ProcessStartInfo donateOpen = new("https://paypal.me/eliteobservatory"); ProcessStartInfo donateOpen = new("https://paypal.me/eliteobservatory");
donateOpen.UseShellExecute = true; donateOpen.UseShellExecute = true;
Process.Start(donateOpen); Process.Start(donateOpen);
} }
public void GetUpdate() public static void GetUpdate()
{ {
ProcessStartInfo githubOpen = new("https://github.com/Xjph/ObservatoryCore/releases"); ProcessStartInfo githubOpen = new("https://github.com/Xjph/ObservatoryCore/releases");
githubOpen.UseShellExecute = true; githubOpen.UseShellExecute = true;

View File

@ -15,6 +15,7 @@ using Avalonia.Media;
using Avalonia.Controls.ApplicationLifetimes; using Avalonia.Controls.ApplicationLifetimes;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
using System.IO; using System.IO;
using Avalonia.Platform.Storage;
namespace Observatory.UI.Views namespace Observatory.UI.Views
{ {
@ -71,6 +72,7 @@ namespace Observatory.UI.Views
e.Column.CanUserResize = true; e.Column.CanUserResize = true;
e.Column.CanUserSort = true; e.Column.CanUserSort = true;
} }
private void UITypeChange() private void UITypeChange()
{ {
var uiPanel = this.Find<Panel>("UIPanel"); var uiPanel = this.Find<Panel>("UIPanel");
@ -83,10 +85,9 @@ namespace Observatory.UI.Views
case PluginUI.UIType.Basic: case PluginUI.UIType.Basic:
dataGrid = new() dataGrid = new()
{ {
[!DataGrid.ItemsProperty] = new Binding("BasicUIGrid"), [!DataGrid.ItemsProperty] = new Binding("Items"),
SelectionMode = DataGridSelectionMode.Extended, SelectionMode = DataGridSelectionMode.Extended,
GridLinesVisibility = DataGridGridLinesVisibility.Vertical, GridLinesVisibility = DataGridGridLinesVisibility.Vertical,
AutoGenerateColumns = true,
IsReadOnly = true IsReadOnly = true
}; };
dataGrid.AutoGeneratingColumn += ColumnGeneration; dataGrid.AutoGeneratingColumn += ColumnGeneration;
@ -1028,21 +1029,33 @@ namespace Observatory.UI.Views
settingBrowse.Click += (object source, RoutedEventArgs e) => 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) => browseTask.ContinueWith((task) =>
{ {
if (task.Result?.Count() > 0) if (task.Result?.Count() > 0)
{ {
string path = browseTask.Result[0]; if (browseTask.Result[0].TryGetUri(out Uri path))
Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => { settingPath.Text = path; }); {
setting.Key.SetValue(plugin.Settings, new FileInfo(path)); Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => { settingPath.Text = path.AbsolutePath; });
PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); setting.Key.SetValue(plugin.Settings, new FileInfo(path.AbsolutePath));
PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings);
}
} }
}); });

View File

@ -23,11 +23,26 @@ namespace Observatory.Framework
public object UI; public object UI;
/// <summary> /// <summary>
/// <para>Collection bound to DataGrid used byu plugins with UIType.Basic.</para> /// <para>Collection bound to DataGrid used by plugins with UIType.Basic.</para>
/// <para>Objects in collection should be of a class defined within the plugin consisting of string properties.<br/>Each object is a single row, and the property names are used as column headers.</para> /// <para>Objects in collection should be of a class defined within the plugin consisting of string properties.<br/>Each object is a single row, and the property names are used as column headers.</para>
/// </summary> /// </summary>
public ObservableCollection<object> DataGrid; public ObservableCollection<object> DataGrid;
/// <summary>
/// <para>Collection bound to DataGrid headers used by plugins with UIType.Basic.</para>
/// </summary>
public ObservableCollection<string> Headers;
/// <summary>
/// <para>Collection used to specify formatting of items in respective columns.</para>
/// </summary>
public ObservableCollection<string> Formats;
/// <summary>
/// <para>Two-dimensional collection of items to display in UI grid.</para>
/// </summary>
public ObservableCollection<ObservableCollection<object>> Items;
/// <summary> /// <summary>
/// Instantiate PluginUI of UIType.Basic. /// Instantiate PluginUI of UIType.Basic.
/// </summary> /// </summary>