From 6ef16d2ec7d3009ea655a1fd0042843a818ede8a Mon Sep 17 00:00:00 2001 From: rabbitism Date: Sun, 25 Feb 2024 18:00:08 +0800 Subject: [PATCH] feat: update dependency, simplify code, remove navigation control. --- demo/Ursa.Demo/Models/MenuKeys.cs | 1 - demo/Ursa.Demo/Pages/IntroductionDemo.axaml | 45 --- demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml | 66 ---- .../Pages/NavigationMenuDemo.axaml.cs | 15 - .../Ursa.Demo/ViewModels/MainViewViewModel.cs | 1 - demo/Ursa.Demo/ViewModels/MenuViewModel.cs | 3 +- .../ViewModels/NavigationMenuDemoViewModel.cs | 44 --- .../Controls/Navigation.axaml | 338 ------------------ src/Ursa.Themes.Semi/Controls/_index.axaml | 1 - src/Ursa/Controls/Buttons/ButtonGroup.cs | 21 +- .../Controls/EnumSelector/EnumSelector.cs | 2 +- src/Ursa/Controls/Form/FormItem.cs | 2 +- src/Ursa/Controls/Icons/TwoTonePathIcon.cs | 2 +- src/Ursa/Controls/NavMenu/NavMenu.cs | 2 +- src/Ursa/Controls/NavMenu/NavMenuItem.cs | 28 +- .../Controls/Navigation/NavigationMenu.cs | 150 -------- .../Controls/Navigation/NavigationMenuItem.cs | 282 --------------- .../Navigation/NavigationMenuSeparator.cs | 11 - src/Ursa/Ursa.csproj | 2 +- 19 files changed, 19 insertions(+), 997 deletions(-) delete mode 100644 demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml delete mode 100644 demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml.cs delete mode 100644 demo/Ursa.Demo/ViewModels/NavigationMenuDemoViewModel.cs delete mode 100644 src/Ursa.Themes.Semi/Controls/Navigation.axaml delete mode 100644 src/Ursa/Controls/Navigation/NavigationMenu.cs delete mode 100644 src/Ursa/Controls/Navigation/NavigationMenuItem.cs delete mode 100644 src/Ursa/Controls/Navigation/NavigationMenuSeparator.cs diff --git a/demo/Ursa.Demo/Models/MenuKeys.cs b/demo/Ursa.Demo/Models/MenuKeys.cs index 1351630..41b83a2 100644 --- a/demo/Ursa.Demo/Models/MenuKeys.cs +++ b/demo/Ursa.Demo/Models/MenuKeys.cs @@ -20,7 +20,6 @@ public static class MenuKeys public const string MenuKeyKeyGestureInput = "KeyGestureInput"; public const string MenuKeyLoading = "Loading"; public const string MenuKeyMessageBox = "MessageBox"; - public const string MenuKeyNavigation = "Navigation"; public const string MenuKeyNavMenu = "NavMenu"; public const string MenuKeyNumberDisplayer = "NumberDisplayer"; public const string MenuKeyNumericUpDown = "NumericUpDown"; diff --git a/demo/Ursa.Demo/Pages/IntroductionDemo.axaml b/demo/Ursa.Demo/Pages/IntroductionDemo.axaml index f06ee98..902158b 100644 --- a/demo/Ursa.Demo/Pages/IntroductionDemo.axaml +++ b/demo/Ursa.Demo/Pages/IntroductionDemo.axaml @@ -43,51 +43,6 @@ Content="Aesthetic revolution of productivity. " Header="Welcome to IRIHI Technology!" Type="Information" /> - - - - M12 16C13.9818 16 15.7453 14.3394 16.7142 11.8589C17.3163 11.6122 17.8892 10.8644 18.1508 9.88823C18.4909 8.61881 18.4234 7.48536 17.4964 7.13266C17.4064 2.7111 15.6617 1 12 1C8.33858 1 6.59387 2.71088 6.50372 7.13179C5.57454 7.48354 5.50668 8.61777 5.84709 9.8882C6.10904 10.8658 6.68318 11.6143 7.28626 11.8599C8.2552 14.3398 10.0186 16 12 16Z M19.6049 22C20.8385 22 21.7171 20.8487 20.867 19.9547C19.1971 18.1985 15.853 17 12 17C8.14699 17 4.80292 18.1985 3.133 19.9547C2.2829 20.8487 3.16148 22 4.39513 22H19.6049Z - M10.7525 1.90411C11.1451 0.698628 12.8549 0.698631 13.2475 1.90411L15.2395 8.01946H21.6858C22.9565 8.01946 23.4848 9.64143 22.4568 10.3865L17.2417 14.1659L19.2337 20.2813C19.6263 21.4868 18.2431 22.4892 17.2151 21.7442L12 17.9647L6.78489 21.7442C5.75687 22.4892 4.37368 21.4868 4.76635 20.2813L6.75834 14.1659L1.54323 10.3865C0.515206 9.64142 1.04354 8.01946 2.31425 8.01946H8.76048L10.7525 1.90411Z - M7.99973 5.07197C7.19713 5.53535 6.20729 5.53113 5.40866 5.06092L5.1637 4.91669C4.55751 4.55978 3.77662 4.65563 3.34264 5.20927C2.69567 6.03462 2.17585 6.94251 1.79166 7.90124C1.53027 8.55354 1.83733 9.27693 2.449 9.62286L2.69407 9.76145C3.50107 10.2178 4.00002 11.0732 4.00002 12.0003C4.00002 12.9271 3.50145 13.7822 2.69492 14.2387L2.44842 14.3783C1.83596 14.725 1.52888 15.4497 1.79213 16.1024C1.98358 16.577 2.21048 17.044 2.47374 17.5C2.73723 17.9564 3.0285 18.3868 3.34416 18.7902C3.77773 19.3443 4.5588 19.4406 5.16498 19.0834L5.40839 18.9399C6.20714 18.4692 7.19739 18.4648 8.0003 18.9284C8.80291 19.3918 9.29417 20.2511 9.28627 21.1778L9.28386 21.4601C9.27787 22.1629 9.75107 22.7906 10.4468 22.8903C11.4692 23.0368 12.5154 23.0404 13.5537 22.8927C14.2499 22.7936 14.7231 22.1653 14.7169 21.462L14.7143 21.1785C14.7061 20.2514 15.1974 19.3916 16.0003 18.928C16.8029 18.4647 17.7927 18.4689 18.5914 18.9391L18.8363 19.0833C19.4425 19.4402 20.2234 19.3444 20.6574 18.7907C21.3044 17.9654 21.8242 17.0575 22.2084 16.0988C22.4698 15.4465 22.1627 14.7231 21.551 14.3772L21.306 14.2386C20.499 13.7822 20 12.9268 20 11.9997C20 11.0729 20.4986 10.2178 21.3051 9.76126L21.5516 9.62174C22.1641 9.27506 22.4712 8.55029 22.2079 7.89761C22.0165 7.42297 21.7896 6.95598 21.5263 6.50001C21.2628 6.04362 20.9715 5.61325 20.6559 5.20982C20.2223 4.65568 19.4412 4.55944 18.8351 4.91665L18.5916 5.06009C17.7929 5.53078 16.8026 5.53519 15.9997 5.07163C15.1971 4.60825 14.7059 3.74891 14.7138 2.82218L14.7162 2.53994C14.7222 1.83708 14.249 1.20945 13.5532 1.10973C12.5308 0.963214 11.4846 0.959581 10.4464 1.10733C9.75011 1.20641 9.27691 1.83473 9.28317 2.53798L9.28569 2.82154C9.29395 3.74862 8.80264 4.60841 7.99973 5.07197ZM14 15.4641C15.9132 14.3595 16.5687 11.9132 15.4641 9.99999C14.3595 8.08682 11.9132 7.43132 10 8.53589C8.08684 9.64046 7.43134 12.0868 8.53591 14C9.64048 15.9132 12.0868 16.5687 14 15.4641Z - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - M12 16C13.9818 16 15.7453 14.3394 16.7142 11.8589C17.3163 11.6122 17.8892 10.8644 18.1508 9.88823C18.4909 8.61881 18.4234 7.48536 17.4964 7.13266C17.4064 2.7111 15.6617 1 12 1C8.33858 1 6.59387 2.71088 6.50372 7.13179C5.57454 7.48354 5.50668 8.61777 5.84709 9.8882C6.10904 10.8658 6.68318 11.6143 7.28626 11.8599C8.2552 14.3398 10.0186 16 12 16Z M19.6049 22C20.8385 22 21.7171 20.8487 20.867 19.9547C19.1971 18.1985 15.853 17 12 17C8.14699 17 4.80292 18.1985 3.133 19.9547C2.2829 20.8487 3.16148 22 4.39513 22H19.6049Z - M10.7525 1.90411C11.1451 0.698628 12.8549 0.698631 13.2475 1.90411L15.2395 8.01946H21.6858C22.9565 8.01946 23.4848 9.64143 22.4568 10.3865L17.2417 14.1659L19.2337 20.2813C19.6263 21.4868 18.2431 22.4892 17.2151 21.7442L12 17.9647L6.78489 21.7442C5.75687 22.4892 4.37368 21.4868 4.76635 20.2813L6.75834 14.1659L1.54323 10.3865C0.515206 9.64142 1.04354 8.01946 2.31425 8.01946H8.76048L10.7525 1.90411Z - M7.99973 5.07197C7.19713 5.53535 6.20729 5.53113 5.40866 5.06092L5.1637 4.91669C4.55751 4.55978 3.77662 4.65563 3.34264 5.20927C2.69567 6.03462 2.17585 6.94251 1.79166 7.90124C1.53027 8.55354 1.83733 9.27693 2.449 9.62286L2.69407 9.76145C3.50107 10.2178 4.00002 11.0732 4.00002 12.0003C4.00002 12.9271 3.50145 13.7822 2.69492 14.2387L2.44842 14.3783C1.83596 14.725 1.52888 15.4497 1.79213 16.1024C1.98358 16.577 2.21048 17.044 2.47374 17.5C2.73723 17.9564 3.0285 18.3868 3.34416 18.7902C3.77773 19.3443 4.5588 19.4406 5.16498 19.0834L5.40839 18.9399C6.20714 18.4692 7.19739 18.4648 8.0003 18.9284C8.80291 19.3918 9.29417 20.2511 9.28627 21.1778L9.28386 21.4601C9.27787 22.1629 9.75107 22.7906 10.4468 22.8903C11.4692 23.0368 12.5154 23.0404 13.5537 22.8927C14.2499 22.7936 14.7231 22.1653 14.7169 21.462L14.7143 21.1785C14.7061 20.2514 15.1974 19.3916 16.0003 18.928C16.8029 18.4647 17.7927 18.4689 18.5914 18.9391L18.8363 19.0833C19.4425 19.4402 20.2234 19.3444 20.6574 18.7907C21.3044 17.9654 21.8242 17.0575 22.2084 16.0988C22.4698 15.4465 22.1627 14.7231 21.551 14.3772L21.306 14.2386C20.499 13.7822 20 12.9268 20 11.9997C20 11.0729 20.4986 10.2178 21.3051 9.76126L21.5516 9.62174C22.1641 9.27506 22.4712 8.55029 22.2079 7.89761C22.0165 7.42297 21.7896 6.95598 21.5263 6.50001C21.2628 6.04362 20.9715 5.61325 20.6559 5.20982C20.2223 4.65568 19.4412 4.55944 18.8351 4.91665L18.5916 5.06009C17.7929 5.53078 16.8026 5.53519 15.9997 5.07163C15.1971 4.60825 14.7059 3.74891 14.7138 2.82218L14.7162 2.53994C14.7222 1.83708 14.249 1.20945 13.5532 1.10973C12.5308 0.963214 11.4846 0.959581 10.4464 1.10733C9.75011 1.20641 9.27691 1.83473 9.28317 2.53798L9.28569 2.82154C9.29395 3.74862 8.80264 4.60841 7.99973 5.07197ZM14 15.4641C15.9132 14.3595 16.5687 11.9132 15.4641 9.99999C14.3595 8.08682 11.9132 7.43132 10 8.53589C8.08684 9.64046 7.43134 12.0868 8.53591 14C9.64048 15.9132 12.0868 16.5687 14 15.4641Z - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml.cs b/demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml.cs deleted file mode 100644 index 0f369fc..0000000 --- a/demo/Ursa.Demo/Pages/NavigationMenuDemo.axaml.cs +++ /dev/null @@ -1,15 +0,0 @@ -using Avalonia; -using Avalonia.Controls; -using Avalonia.Markup.Xaml; -using Ursa.Demo.ViewModels; - -namespace Ursa.Demo.Pages; - -public partial class NavigationMenuDemo : UserControl -{ - public NavigationMenuDemo() - { - InitializeComponent(); - this.DataContext = new NavigationMenuDemoViewModel(); - } -} \ No newline at end of file diff --git a/demo/Ursa.Demo/ViewModels/MainViewViewModel.cs b/demo/Ursa.Demo/ViewModels/MainViewViewModel.cs index d072e7f..8f9f8c9 100644 --- a/demo/Ursa.Demo/ViewModels/MainViewViewModel.cs +++ b/demo/Ursa.Demo/ViewModels/MainViewViewModel.cs @@ -42,7 +42,6 @@ public class MainViewViewModel : ViewModelBase MenuKeys.MenuKeyKeyGestureInput => new KeyGestureInputDemoViewModel(), MenuKeys.MenuKeyLoading => new LoadingDemoViewModel(), MenuKeys.MenuKeyMessageBox => new MessageBoxDemoViewModel(), - MenuKeys.MenuKeyNavigation => new NavigationMenuDemoViewModel(), MenuKeys.MenuKeyNavMenu => new NavMenuDemoViewModel(), MenuKeys.MenuKeyNumberDisplayer => new NumberDisplayerDemoViewModel(), MenuKeys.MenuKeyNumericUpDown => new NumericUpDownDemoViewModel(), diff --git a/demo/Ursa.Demo/ViewModels/MenuViewModel.cs b/demo/Ursa.Demo/ViewModels/MenuViewModel.cs index 130d16a..41b9521 100644 --- a/demo/Ursa.Demo/ViewModels/MenuViewModel.cs +++ b/demo/Ursa.Demo/ViewModels/MenuViewModel.cs @@ -24,12 +24,11 @@ public class MenuViewModel: ViewModelBase new() { MenuHeader = "Enum Selector", Key = MenuKeys.MenuKeyEnumSelector }, new() { MenuHeader = "Form", Key = MenuKeys.MenuKeyForm }, new() { MenuHeader = "Icon Button", Key = MenuKeys.MenuKeyIconButton }, - new() { MenuHeader = "ImageViewer", Key = MenuKeys.MenuKeyImageViewer }, + new() { MenuHeader = "ImageViewer", Key = MenuKeys.MenuKeyImageViewer, Status = "WIP" }, new() { MenuHeader = "IPv4Box", Key = MenuKeys.MenuKeyIpBox }, new() { MenuHeader = "KeyGestureInput", Key = MenuKeys.MenuKeyKeyGestureInput }, new() { MenuHeader = "Loading", Key = MenuKeys.MenuKeyLoading }, new() { MenuHeader = "Message Box", Key = MenuKeys.MenuKeyMessageBox, Status = "New" }, - new() { MenuHeader = "Navigation", Key = MenuKeys.MenuKeyNavigation, Status = "WIP" }, new() { MenuHeader = "Nav Menu", Key = MenuKeys.MenuKeyNavMenu, Status = "WIP"}, new() { MenuHeader = "Number Displayer", Key = MenuKeys.MenuKeyNumberDisplayer, Status = "New" }, new() { MenuHeader = "Numeric UpDown", Key = MenuKeys.MenuKeyNumericUpDown, Status = "New" }, diff --git a/demo/Ursa.Demo/ViewModels/NavigationMenuDemoViewModel.cs b/demo/Ursa.Demo/ViewModels/NavigationMenuDemoViewModel.cs deleted file mode 100644 index 7633771..0000000 --- a/demo/Ursa.Demo/ViewModels/NavigationMenuDemoViewModel.cs +++ /dev/null @@ -1,44 +0,0 @@ -using System.Collections.ObjectModel; -using CommunityToolkit.Mvvm.ComponentModel; - -namespace Ursa.Demo.ViewModels; - -public class NavigationMenuDemoViewModel: ObservableObject -{ - public ObservableCollection MenuItems { get; set; } = new() - { - new MenuItemViewModel() - { - MenuHeader = "任务管理", - MenuIconName = "User", - Children = new ObservableCollection() - { - new (){ - MenuHeader = "公告管理" , - MenuIconName = "Star", - Children = new ObservableCollection() - { - new () {MenuHeader = "公告设置"}, - new () {MenuHeader = "公告处理"} - }}, - new (){MenuHeader = "任务查询"} - } - }, - new MenuItemViewModel() - { - MenuHeader = "附加功能", - IsSeparator = true, - }, - new MenuItemViewModel() - { - MenuHeader = "任务平台", - MenuIconName = "Gear", - Children = new ObservableCollection() - { - new (){MenuHeader = "任务管理"}, - new (){MenuHeader = "用户任务查询"} - } - } - }; -} - diff --git a/src/Ursa.Themes.Semi/Controls/Navigation.axaml b/src/Ursa.Themes.Semi/Controls/Navigation.axaml deleted file mode 100644 index c635374..0000000 --- a/src/Ursa.Themes.Semi/Controls/Navigation.axaml +++ /dev/null @@ -1,338 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/Ursa.Themes.Semi/Controls/_index.axaml b/src/Ursa.Themes.Semi/Controls/_index.axaml index fdbbda4..fbce535 100644 --- a/src/Ursa.Themes.Semi/Controls/_index.axaml +++ b/src/Ursa.Themes.Semi/Controls/_index.axaml @@ -19,7 +19,6 @@ - diff --git a/src/Ursa/Controls/Buttons/ButtonGroup.cs b/src/Ursa/Controls/Buttons/ButtonGroup.cs index 92f997c..0c8aa6b 100644 --- a/src/Ursa/Controls/Buttons/ButtonGroup.cs +++ b/src/Ursa/Controls/Buttons/ButtonGroup.cs @@ -6,6 +6,7 @@ using Avalonia.Controls.Primitives; using Avalonia.Data; using Avalonia.Media; using Avalonia.Metadata; +using Irihi.Avalonia.Shared.Helpers; namespace Ursa.Controls; @@ -61,22 +62,10 @@ public class ButtonGroup: ItemsControl base.PrepareContainerForItemOverride(container, item, index); if(container is Button button) { - if ( CommandBinding is not null) - { - button[!Button.CommandProperty] = CommandBinding; - } - if ( CommandParameterBinding is not null) - { - button[!Button.CommandParameterProperty] = CommandParameterBinding; - } - if ( ContentBinding is not null) - { - button[!Button.ContentProperty] = ContentBinding; - } - if (ItemTemplate is not null) - { - button.ContentTemplate = ItemTemplate; - } + button.TryBind(Button.CommandProperty, CommandBinding); + button.TryBind(Button.CommandParameterProperty, CommandParameterBinding); + button.TryBind(ContentControl.ContentProperty, ContentBinding); + button.TryBind(ContentControl.ContentTemplateProperty, this[!ItemTemplateProperty]); } } } \ No newline at end of file diff --git a/src/Ursa/Controls/EnumSelector/EnumSelector.cs b/src/Ursa/Controls/EnumSelector/EnumSelector.cs index 821e6fe..6c48970 100644 --- a/src/Ursa/Controls/EnumSelector/EnumSelector.cs +++ b/src/Ursa/Controls/EnumSelector/EnumSelector.cs @@ -37,7 +37,7 @@ public class EnumSelector: TemplatedControl if (o is not EnumSelector selector) return null; if (value is null) return null; if (value.GetType() != selector.EnumType) return null; - var first = selector.Values.FirstOrDefault(a => Equals(a.Value, value)); + var first = selector.Values?.FirstOrDefault(a => Equals(a.Value, value)); if (first is null) return null; return value; } diff --git a/src/Ursa/Controls/Form/FormItem.cs b/src/Ursa/Controls/Form/FormItem.cs index f8e9465..e33d682 100644 --- a/src/Ursa/Controls/Form/FormItem.cs +++ b/src/Ursa/Controls/Form/FormItem.cs @@ -57,7 +57,7 @@ public class FormItem: ContentControl static FormItem() { - PropertyToPseudoClassMixin.Attach(NoLabelProperty, PC_NoLabel); + NoLabelProperty.AffectsPseudoClass(PC_NoLabel); } protected override void OnAttachedToVisualTree(VisualTreeAttachmentEventArgs e) diff --git a/src/Ursa/Controls/Icons/TwoTonePathIcon.cs b/src/Ursa/Controls/Icons/TwoTonePathIcon.cs index 6ee1267..8fdc681 100644 --- a/src/Ursa/Controls/Icons/TwoTonePathIcon.cs +++ b/src/Ursa/Controls/Icons/TwoTonePathIcon.cs @@ -76,7 +76,7 @@ public class TwoTonePathIcon: TemplatedControl ForegroundProperty, ActiveForegroundProperty, ActiveStrokeBrushProperty); - PropertyToPseudoClassMixin.Attach(IsActiveProperty, PC_Active); + IsActiveProperty.AffectsPseudoClass(PC_Active); } protected override void OnApplyTemplate(TemplateAppliedEventArgs e) diff --git a/src/Ursa/Controls/NavMenu/NavMenu.cs b/src/Ursa/Controls/NavMenu/NavMenu.cs index 44d73f8..c09dc86 100644 --- a/src/Ursa/Controls/NavMenu/NavMenu.cs +++ b/src/Ursa/Controls/NavMenu/NavMenu.cs @@ -146,7 +146,7 @@ public class NavMenu: ItemsControl static NavMenu() { SelectedItemProperty.Changed.AddClassHandler((o, e) => o.OnSelectedItemChange(e)); - PropertyToPseudoClassMixin.Attach(IsHorizontalCollapsedProperty, PC_HorizontalCollapsed); + IsHorizontalCollapsedProperty.AffectsPseudoClass(PC_HorizontalCollapsed); CanToggleProperty.Changed.AddClassHandler(OnInputRegisteredAsToggle); } diff --git a/src/Ursa/Controls/NavMenu/NavMenuItem.cs b/src/Ursa/Controls/NavMenu/NavMenuItem.cs index e1c31d3..70bb5cb 100644 --- a/src/Ursa/Controls/NavMenu/NavMenuItem.cs +++ b/src/Ursa/Controls/NavMenu/NavMenuItem.cs @@ -140,10 +140,10 @@ public class NavMenuItem: HeaderedItemsControl // SelectableMixin.Attach(IsSelectedProperty); PressedMixin.Attach(); LevelProperty.Changed.AddClassHandler((item, args) => item.OnLevelChange(args)); - PropertyToPseudoClassMixin.Attach(IsHighlightedProperty, PC_Highlighted); - PropertyToPseudoClassMixin.Attach(IsHorizontalCollapsedProperty, PC_HorizontalCollapsed); - PropertyToPseudoClassMixin.Attach(IsVerticalCollapsedProperty, PC_VerticalCollapsed); - PropertyToPseudoClassMixin.Attach(IsSelectedProperty, ":selected", IsSelectedChangedEvent); + IsHighlightedProperty.AffectsPseudoClass(PC_Highlighted); + IsHorizontalCollapsedProperty.AffectsPseudoClass(PC_HorizontalCollapsed); + IsVerticalCollapsedProperty.AffectsPseudoClass(PC_VerticalCollapsed); + IsSelectedProperty.AffectsPseudoClass(":selected", IsSelectedChangedEvent); IsHorizontalCollapsedProperty.Changed.AddClassHandler((item, args) => item.OnIsHorizontalCollapsedChanged(args)); } @@ -195,22 +195,10 @@ public class NavMenuItem: HeaderedItemsControl _overflowPanel = e.NameScope.Find("PART_OverflowPanel"); if (_rootMenu is not null) { - if (_rootMenu.IconBinding is not null) - { - this[!IconProperty] = _rootMenu.IconBinding; - } - if (_rootMenu.HeaderBinding is not null) - { - this[!HeaderProperty] = _rootMenu.HeaderBinding; - } - if (_rootMenu.SubMenuBinding is not null) - { - this[!ItemsSourceProperty] = _rootMenu.SubMenuBinding; - } - if (_rootMenu.CommandBinding is not null) - { - this[!CommandProperty] = _rootMenu.CommandBinding; - } + this.TryBind(IconProperty, _rootMenu.IconBinding); + this.TryBind(HeaderProperty, _rootMenu.HeaderBinding); + this.TryBind(ItemsSourceProperty, _rootMenu.SubMenuBinding); + this.TryBind(CommandProperty, _rootMenu.CommandBinding); this[!IconTemplateProperty] = _rootMenu[!NavMenu.IconTemplateProperty]; this[!HeaderTemplateProperty] = _rootMenu[!NavMenu.HeaderTemplateProperty]; this[!SubMenuIndentProperty] = _rootMenu[!NavMenu.SubMenuIndentProperty]; diff --git a/src/Ursa/Controls/Navigation/NavigationMenu.cs b/src/Ursa/Controls/Navigation/NavigationMenu.cs deleted file mode 100644 index 52575b6..0000000 --- a/src/Ursa/Controls/Navigation/NavigationMenu.cs +++ /dev/null @@ -1,150 +0,0 @@ -using System.Collections; -using System.Collections.Specialized; -using Avalonia; -using Avalonia.Collections; -using Avalonia.Controls; -using Avalonia.Controls.Metadata; -using Avalonia.Controls.Presenters; -using Avalonia.Controls.Primitives; -using Avalonia.Controls.Templates; -using Avalonia.Input; -using Avalonia.Markup.Xaml.Templates; -using Avalonia.Metadata; - -namespace Ursa.Controls; - -[PseudoClasses(PC_Closed)] -[TemplatePart(Name = PART_CloseButton, Type = typeof(ToggleButton))] - -public class NavigationMenu: HeaderedItemsControl -{ - public const string PC_Closed = ":closed"; - public const string PART_CloseButton = "PART_CloseButton"; - - public static readonly StyledProperty FooterProperty = AvaloniaProperty.Register( - nameof(Footer)); - - public object? Footer - { - get => GetValue(FooterProperty); - set => SetValue(FooterProperty, value); - } - - public static readonly StyledProperty FooterTemplateProperty = AvaloniaProperty.Register( - nameof(FooterTemplate)); - - public IDataTemplate FooterTemplate - { - get => GetValue(FooterTemplateProperty); - set => SetValue(FooterTemplateProperty, value); - } - - public static readonly StyledProperty IconProperty = AvaloniaProperty.Register( - nameof(Icon)); - - public object? Icon - { - get => GetValue(IconProperty); - set => SetValue(IconProperty, value); - } - - - public static readonly StyledProperty SelectedItemProperty = AvaloniaProperty.Register( - nameof(SelectedItem)); - - public object? SelectedItem - { - get => GetValue(SelectedItemProperty); - set => SetValue(SelectedItemProperty, value); - } - - public static readonly StyledProperty ShowCollapseButtonProperty = AvaloniaProperty.Register( - nameof(ShowCollapseButton)); - - public bool ShowCollapseButton - { - get => GetValue(ShowCollapseButtonProperty); - set => SetValue(ShowCollapseButtonProperty, value); - } - - public static readonly StyledProperty IsClosedProperty = AvaloniaProperty.Register( - nameof(IsClosed)); - - public bool IsClosed - { - get => GetValue(IsClosedProperty); - set => SetValue(IsClosedProperty, value); - } - - public static readonly StyledProperty OpenedWidthProperty = AvaloniaProperty.Register( - nameof(OpenedWidth)); - - public double OpenedWidth - { - get => GetValue(OpenedWidthProperty); - set => SetValue(OpenedWidthProperty, value); - } - - public static readonly StyledProperty ClosedWidthProperty = AvaloniaProperty.Register( - nameof(ClosedWidth)); - - public double ClosedWidth - { - get => GetValue(ClosedWidthProperty); - set => SetValue(ClosedWidthProperty, value); - } - - - - static NavigationMenu() - { - SelectedItemProperty.Changed.AddClassHandler((o, e) => o.OnSelectionItemChanged(e)); - IsClosedProperty.Changed.AddClassHandler((o,e)=>o.OnIsClosedChanged(e)); - } - - private void OnSelectionItemChanged(AvaloniaPropertyChangedEventArgs args) - { - var newItem = args.GetNewValue(); - if (newItem is not null) - { - UpdateSelectionFromSelectedItem(newItem); - } - } - - private void OnIsClosedChanged(AvaloniaPropertyChangedEventArgs args) - { - bool newValue = args.GetNewValue(); - PseudoClasses.Set(PC_Closed, newValue); - } - - internal void UpdateSelection(NavigationMenuItem source) - { - var children = this.ItemsPanelRoot?.Children; - if (children is not null) - { - foreach (var child in children) - { - NavigationMenuItem? item = NavigationMenuItem.GetMenuItemFromControl(child); - if (item != null) - { - if(Equals(item, source)) continue; - item.SetSelection(null, false, false); - } - } - } - } - - internal void UpdateSelectionFromSelectedItem(object? o) - { - var children = this.ItemsPanelRoot?.Children; - if (children is not null) - { - foreach (var child in children) - { - NavigationMenuItem? item = NavigationMenuItem.GetMenuItemFromControl(child); - if(item is null) continue; - item.UpdateSelectionFromSelectedItem(o); - } - } - } -} diff --git a/src/Ursa/Controls/Navigation/NavigationMenuItem.cs b/src/Ursa/Controls/Navigation/NavigationMenuItem.cs deleted file mode 100644 index d5ce45e..0000000 --- a/src/Ursa/Controls/Navigation/NavigationMenuItem.cs +++ /dev/null @@ -1,282 +0,0 @@ -using System.Windows.Input; -using Avalonia; -using Avalonia.Controls; -using Avalonia.Controls.Metadata; -using Avalonia.Controls.Mixins; -using Avalonia.Controls.Presenters; -using Avalonia.Controls.Primitives; -using Avalonia.Controls.Templates; -using Avalonia.Data; -using Avalonia.Input; -using Avalonia.LogicalTree; -using Avalonia.Markup.Xaml.Templates; -using Avalonia.Reactive; -using Avalonia.VisualTree; - -namespace Ursa.Controls; - -[PseudoClasses(PC_Closed, PC_Selected, PC_Highlighted, PC_Collapsed, PC_TopLevel)] -[TemplatePart(PART_Popup, typeof(Popup))] -public class NavigationMenuItem: HeaderedSelectingItemsControl -{ - public const string PC_Closed = ":closed"; - public const string PC_Selected = ":selected"; - public const string PC_Highlighted= ":highlighted"; - public const string PC_Collapsed = ":collapsed"; - public const string PC_TopLevel = ":top-level"; - public const string PART_Popup = "PART_Popup"; - - private NavigationMenu? _rootMenu; - private IDisposable? _ownerSubscription; - private IDisposable? _itemsBinding; - private bool _isCollapsed; - private Popup? _popup; - - public static readonly StyledProperty IsClosedProperty = AvaloniaProperty.Register( - nameof(IsClosed)); - - public bool IsClosed - { - get => GetValue(IsClosedProperty); - set => SetValue(IsClosedProperty, value); - } - - public static readonly StyledProperty IconProperty = AvaloniaProperty.Register( - nameof(Icon)); - - public object? Icon - { - get => GetValue(IconProperty); - set => SetValue(IconProperty, value); - } - - public static readonly StyledProperty IconTemplateProperty = AvaloniaProperty.Register( - nameof(IconTemplate)); - - public IDataTemplate IconTemplate - { - get => GetValue(IconTemplateProperty); - set => SetValue(IconTemplateProperty, value); - } - - public static readonly DirectProperty LevelProperty = AvaloniaProperty.RegisterDirect( - nameof(Level), o => o.Level); - private int _level; - public int Level - { - get => _level; - private set => SetAndRaise(LevelProperty, ref _level, value); - } - - public static readonly StyledProperty CommandProperty = AvaloniaProperty.Register( - nameof(Command)); - - public ICommand Command - { - get => GetValue(CommandProperty); - set => SetValue(CommandProperty, value); - } - - public static readonly StyledProperty CommandParameterProperty = AvaloniaProperty.Register( - nameof(CommandParameter)); - - public object? CommandParameter - { - get => GetValue(CommandParameterProperty); - set => SetValue(CommandParameterProperty, value); - } - - public static readonly DirectProperty IsTopLevelMenuItemProperty = AvaloniaProperty.RegisterDirect( - nameof(IsTopLevelMenuItem), o => o.IsTopLevelMenuItem, (o, v) => o.IsTopLevelMenuItem = v); - private bool _isTopLevelMenuItem; - public bool IsTopLevelMenuItem - { - get => _isTopLevelMenuItem; - set => SetAndRaise(IsTopLevelMenuItemProperty, ref _isTopLevelMenuItem, value); - } - - public static readonly StyledProperty IsPopupOpenProperty = AvaloniaProperty.Register( - nameof(IsPopupOpen)); - - public bool IsPopupOpen - { - get => GetValue(IsPopupOpenProperty); - set => SetValue(IsPopupOpenProperty, value); - } - - static NavigationMenuItem() - { - IsClosedProperty.Changed.AddClassHandler((o, e) => o.OnIsClosedChanged(e)); - PressedMixin.Attach(); - } - - private void OnIsClosedChanged(AvaloniaPropertyChangedEventArgs args) - { - bool newValue = args.GetNewValue(); - PseudoClasses.Set(PC_Closed, newValue); - } - - protected override void OnApplyTemplate(TemplateAppliedEventArgs e) - { - base.OnApplyTemplate(e); - GetRootMenu(); - if (ItemTemplate == null && _rootMenu?.ItemTemplate != null) - { - SetCurrentValue(ItemTemplateProperty, _rootMenu.ItemTemplate); - } - if (ItemContainerTheme == null && _rootMenu?.ItemContainerTheme != null) - { - SetCurrentValue(ItemContainerThemeProperty, _rootMenu.ItemContainerTheme); - } - - if (_rootMenu is not null) - { - // IsClosed = _rootMenu.IsClosed; - } - - _rootMenu?.GetObservable(NavigationMenu.IsClosedProperty) - .Subscribe(new AnonymousObserver(a => this.IsClosed = a)); - _rootMenu?.UpdateSelectionFromSelectedItem(_rootMenu.SelectedItem); - _popup = e.NameScope.Find(PART_Popup); - Level = CalculateDistanceFromLogicalParent(this) - 1; - bool isTopLevel = Level == 0; - IsTopLevelMenuItem = isTopLevel; - PseudoClasses.Set(PC_TopLevel, isTopLevel); - } - - private void GetRootMenu() - { - _rootMenu = this.FindAncestorOfType(); - if (_rootMenu is null) - { - var parents = this.FindLogicalAncestorOfType(); - if (parents is not null) - { - _rootMenu = parents; - } - } - } - - protected override void OnPointerPressed(PointerPressedEventArgs e) - { - base.OnPointerPressed(e); - // Leaf menu node, can be selected. - if (this.ItemCount == 0) - { - if (_rootMenu is not null ) - { - object? o = this.DataContext == _rootMenu.DataContext ? this : this.DataContext ?? this; - _rootMenu.SelectedItem = o; - } - SetSelection(this, true, true); - } - // Non-leaf node, act as a toggle button. - else - { - _isCollapsed = !_isCollapsed; - this.PseudoClasses.Set(PC_Collapsed, _isCollapsed); - if (_popup is not null) - { - _popup.IsOpen = !_popup.IsOpen; - } - } - e.Handled = true; - Command?.Execute(CommandParameter); - } - - internal void SetSelection(NavigationMenuItem? source, bool selected, bool propagateToParent = false) - { - if (Equals(this, source) && this.ItemCount == 0) - { - this.PseudoClasses.Set(PC_Highlighted, selected); - this.PseudoClasses.Set(PC_Selected, selected); - } - else - { - this.PseudoClasses.Set(PC_Selected, false); - this.PseudoClasses.Set(PC_Highlighted, selected); - } - var children = this.ItemsPanelRoot?.Children; - if (children is not null) - { - foreach (var child in children) - { - NavigationMenuItem? item = GetMenuItemFromControl(child); - if (item != null) - { - if(Equals(item, source)) continue; - item.SetSelection(this, false, false); - } - } - } - - if (propagateToParent) - { - var parent = this.FindLogicalAncestorOfType(); - if (parent != null) - { - parent.SetSelection(this, selected, true); - } - else - { - if (selected && source!=null) - { - _rootMenu?.UpdateSelection(this); - } - } - } - } - - internal void UpdateSelectionFromSelectedItem(object? o) - { - if (o is null) - { - this.SetSelection(this, false, false); - return; - } - - if (Equals(this, o) || Equals(this.DataContext, o)) - { - this.SetSelection(this, true, true); - } - else - { - var children = this.ItemsPanelRoot?.Children; - if (children is not null) - { - foreach (var child in children) - { - NavigationMenuItem? item = GetMenuItemFromControl(child); - if (item != null) - { - item.UpdateSelectionFromSelectedItem(o); - } - } - } - } - } - - private static int CalculateDistanceFromLogicalParent(ILogical? logical, int @default = -1) where T : class - { - var result = 0; - - while (logical != null && !(logical is T)) - { - if (logical is NavigationMenuItem) - { - result++; - } - logical = logical.LogicalParent; - } - - return logical != null ? result : @default; - } - - public static NavigationMenuItem? GetMenuItemFromControl(Control? control) - { - if (control is null) return null; - if (control is NavigationMenuItem item) return item; - if (control is ContentPresenter { Child: NavigationMenuItem item2 }) return item2; - return null; - } -} \ No newline at end of file diff --git a/src/Ursa/Controls/Navigation/NavigationMenuSeparator.cs b/src/Ursa/Controls/Navigation/NavigationMenuSeparator.cs deleted file mode 100644 index 164d886..0000000 --- a/src/Ursa/Controls/Navigation/NavigationMenuSeparator.cs +++ /dev/null @@ -1,11 +0,0 @@ -using Avalonia.Input; - -namespace Ursa.Controls; - -public class NavigationMenuSeparator: NavigationMenuItem -{ - protected override void OnPointerPressed(PointerPressedEventArgs e) - { - e.Handled = true; - } -} \ No newline at end of file diff --git a/src/Ursa/Ursa.csproj b/src/Ursa/Ursa.csproj index 2bd6329..d3d014f 100644 --- a/src/Ursa/Ursa.csproj +++ b/src/Ursa/Ursa.csproj @@ -14,7 +14,7 @@ - +