Allow properties in PropertyGrid to set Enabled, Visible, ReadOnly, override sort order.
This commit is contained in:
@@ -271,6 +271,7 @@
|
|||||||
<Compile Include="Views\DictionaryEditor.xaml.cs">
|
<Compile Include="Views\DictionaryEditor.xaml.cs">
|
||||||
<DependentUpon>DictionaryEditor.xaml</DependentUpon>
|
<DependentUpon>DictionaryEditor.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Views\DisplayAttribute.cs" />
|
||||||
<Compile Include="Views\ObjectCollectionEditor.xaml.cs">
|
<Compile Include="Views\ObjectCollectionEditor.xaml.cs">
|
||||||
<DependentUpon>ObjectCollectionEditor.xaml</DependentUpon>
|
<DependentUpon>ObjectCollectionEditor.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
34
Torch/Views/DisplayAttribute.cs
Normal file
34
Torch/Views/DisplayAttribute.cs
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace Torch.Views
|
||||||
|
{
|
||||||
|
public class DisplayAttribute : Attribute
|
||||||
|
{
|
||||||
|
public string Name;
|
||||||
|
public string Description;
|
||||||
|
public string ToolTip;
|
||||||
|
public string GroupName;
|
||||||
|
public int? Order;
|
||||||
|
public bool? Enabled;
|
||||||
|
public bool? Visible;
|
||||||
|
public bool? ReadOnly;
|
||||||
|
|
||||||
|
public DisplayAttribute()
|
||||||
|
{ }
|
||||||
|
|
||||||
|
public static implicit operator DisplayAttribute(System.ComponentModel.DataAnnotations.DisplayAttribute da)
|
||||||
|
{
|
||||||
|
return new DisplayAttribute()
|
||||||
|
{
|
||||||
|
Name = da.GetName(),
|
||||||
|
Description = da.GetDescription(),
|
||||||
|
GroupName = da.GetGroupName(),
|
||||||
|
Order = da.GetOrder()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -73,9 +73,13 @@ namespace Torch.Views
|
|||||||
|
|
||||||
foreach (var property in properties)
|
foreach (var property in properties)
|
||||||
{
|
{
|
||||||
|
//Attempt to load our custom DisplayAttribute
|
||||||
var a = property.GetCustomAttribute<DisplayAttribute>();
|
var a = property.GetCustomAttribute<DisplayAttribute>();
|
||||||
if (IgnoreDisplay)
|
//If not found and IgnoreDisplay is not set, fall back to system DisplayAttribute
|
||||||
a = null;
|
if (a == null && !IgnoreDisplay)
|
||||||
|
a = property.GetCustomAttribute<System.ComponentModel.DataAnnotations.DisplayAttribute>();
|
||||||
|
if (a?.Visible == false)
|
||||||
|
continue;
|
||||||
descriptors[property] = a;
|
descriptors[property] = a;
|
||||||
string category = a?.GroupName ?? "Misc";
|
string category = a?.GroupName ?? "Misc";
|
||||||
|
|
||||||
@@ -104,7 +108,13 @@ namespace Torch.Views
|
|||||||
grid.Children.Add(cl);
|
grid.Children.Add(cl);
|
||||||
curRow++;
|
curRow++;
|
||||||
|
|
||||||
c.Value.Sort((a,b)=> string.Compare((descriptors[a]?.Name ?? a.Name), descriptors[b]?.Name ?? b.Name, StringComparison.Ordinal));
|
c.Value.Sort((a, b) =>
|
||||||
|
{
|
||||||
|
var c1 = descriptors[a]?.Order?.CompareTo(descriptors[b]?.Order);
|
||||||
|
if (c1.HasValue && c1.Value != 0)
|
||||||
|
return c1.Value;
|
||||||
|
return string.Compare((descriptors[a]?.Name ?? a.Name), descriptors[b]?.Name ?? b.Name, StringComparison.Ordinal);
|
||||||
|
});
|
||||||
|
|
||||||
foreach (var property in c.Value)
|
foreach (var property in c.Value)
|
||||||
{
|
{
|
||||||
@@ -120,7 +130,7 @@ namespace Torch.Views
|
|||||||
var text = new TextBlock
|
var text = new TextBlock
|
||||||
{
|
{
|
||||||
Text = displayName ?? property.Name,
|
Text = displayName ?? property.Name,
|
||||||
ToolTip = displayName,
|
ToolTip = descriptor?.ToolTip ?? displayName,
|
||||||
VerticalAlignment = VerticalAlignment.Center
|
VerticalAlignment = VerticalAlignment.Center
|
||||||
};
|
};
|
||||||
text.SetValue(Grid.ColumnProperty, 0);
|
text.SetValue(Grid.ColumnProperty, 0);
|
||||||
@@ -128,10 +138,12 @@ namespace Torch.Views
|
|||||||
text.Margin = new Thickness(3);
|
text.Margin = new Thickness(3);
|
||||||
text.Tag = $"{text.Text}: {descriptor?.Description}";
|
text.Tag = $"{text.Text}: {descriptor?.Description}";
|
||||||
text.IsMouseDirectlyOverChanged += Text_IsMouseDirectlyOverChanged;
|
text.IsMouseDirectlyOverChanged += Text_IsMouseDirectlyOverChanged;
|
||||||
|
if (descriptor?.Enabled == false)
|
||||||
|
text.IsEnabled = false;
|
||||||
grid.Children.Add(text);
|
grid.Children.Add(text);
|
||||||
|
|
||||||
FrameworkElement valueControl;
|
FrameworkElement valueControl;
|
||||||
if (property.GetSetMethod() == null)
|
if (property.GetSetMethod() == null || descriptor?.ReadOnly == true)
|
||||||
{
|
{
|
||||||
valueControl = new TextBlock();
|
valueControl = new TextBlock();
|
||||||
var binding = new Binding(property.Name)
|
var binding = new Binding(property.Name)
|
||||||
@@ -218,6 +230,8 @@ namespace Torch.Views
|
|||||||
valueControl.SetValue(Grid.ColumnProperty, 1);
|
valueControl.SetValue(Grid.ColumnProperty, 1);
|
||||||
valueControl.SetValue(Grid.RowProperty, curRow);
|
valueControl.SetValue(Grid.RowProperty, curRow);
|
||||||
valueControl.IsMouseDirectlyOverChanged += Text_IsMouseDirectlyOverChanged;
|
valueControl.IsMouseDirectlyOverChanged += Text_IsMouseDirectlyOverChanged;
|
||||||
|
if (descriptor?.Enabled == false)
|
||||||
|
valueControl.IsEnabled = false;
|
||||||
grid.Children.Add(valueControl);
|
grid.Children.Add(valueControl);
|
||||||
|
|
||||||
curRow++;
|
curRow++;
|
||||||
|
Reference in New Issue
Block a user