2
0
mirror of https://github.com/9ParsonsB/Pulsar.git synced 2025-10-25 04:39:49 -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/>
</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>

View File

@@ -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));
}
}

View File

@@ -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;

View File

@@ -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));
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);
}
}
});

View File

@@ -23,11 +23,26 @@ namespace Observatory.Framework
public object UI;
/// <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>
/// </summary>
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>
/// Instantiate PluginUI of UIType.Basic.
/// </summary>