using NeoUI.Assets; using NeoUI.Controls; namespace NeoUI.Assists; /// /// ButtonAssist 类提供了对按钮控件外观类型的辅助功能。 /// 通过此辅助类,可以方便地获取或设置按钮的AppearanceType属性, /// 从而控制按钮的视觉样式。支持的样式包括Primary、Info、Success、Warning和Error。 /// public class ButtonAssist { /// /// 获取指定对象的外观类型。 /// /// 要获取其外观类型的依赖对象。 /// 返回指定对象的AppearanceType枚举值,表示其外观类型。 public static AppearanceType GetAppearanceType(DependencyObject obj) { return (AppearanceType)obj.GetValue(AppearanceTypeProperty); } /// /// 设置指定对象的外观类型。 /// /// 要设置其外观类型的依赖对象。 /// AppearanceType枚举值,表示要设置的外观类型。 public static void SetAppearanceType(DependencyObject obj, AppearanceType value) { obj.SetValue(AppearanceTypeProperty, value); } /// /// 代表按钮控件的外观类型依赖属性。通过此属性,可以设置或获取按钮的视觉样式。 /// 支持的样式包括Primary、Info、Success、Warning和Error,分别对应不同的视觉效果。 /// public static readonly DependencyProperty AppearanceTypeProperty = DependencyProperty.RegisterAttached("AppearanceType", typeof(AppearanceType), typeof(ButtonAssist), new PropertyMetadata(AppearanceType.None)); /// /// 获取指定对象的图标。 /// /// 要获取其图标的依赖对象。 /// 返回指定对象的MaterialSymbol枚举值,表示其图标。 public static MaterialSymbol GetIcon(DependencyObject obj) { return (MaterialSymbol)obj.GetValue(IconProperty); } /// /// 为指定对象设置图标。 /// /// 要为其设置图标的依赖对象。 /// 要设置的MaterialSymbol图标值。 public static void SetIcon(DependencyObject obj, MaterialSymbol value) { obj.SetValue(IconProperty, value); } /// /// 代表按钮控件的图标依赖属性。通过此属性,可以设置或获取按钮上显示的图标。 /// 支持使用MaterialSymbol枚举中的值来指定具体的图标样式。 /// public static readonly DependencyProperty IconProperty = DependencyProperty.RegisterAttached("Icon", typeof(MaterialSymbol), typeof(ButtonAssist), new PropertyMetadata(MaterialSymbol.Cr)); /// /// 获取指定对象的图标放置位置。 /// /// 要获取其图标放置位置的依赖对象。 /// 返回指定对象的Dock枚举值,表示图标的放置位置。 public static Dock GetIconPlacement(DependencyObject obj) { return (Dock)obj.GetValue(IconPlacementProperty); } /// /// 设置指定对象的图标放置位置。 /// /// 要设置其图标放置位置的依赖对象。 /// 图标放置位置的值,使用Dock枚举表示。 public static void SetIconPlacement(DependencyObject obj, Dock value) { obj.SetValue(IconPlacementProperty, value); } /// /// 代表按钮控件的图标位置依赖属性。通过此属性,可以设置或获取按钮上图标的放置位置。 /// 支持使用Dock枚举中的值来指定图标相对于按钮文本的位置,例如左对齐、右对齐等。 /// public static readonly DependencyProperty IconPlacementProperty = DependencyProperty.RegisterAttached("IconPlacement", typeof(Dock), typeof(ButtonAssist), new PropertyMetadata(Dock.Left)); /// /// 代表按钮控件是否正在运行的依赖属性。通过此属性,可以设置或获取按钮的运行状态。 /// 此属性通常用于指示按钮关联的操作是否正在进行中,例如数据加载或处理过程。 /// public static readonly DependencyProperty IsRunningProperty = DependencyProperty.RegisterAttached("IsRunning", typeof(bool), typeof(ButtonAssist), new PropertyMetadata(false)); /// /// 获取指定对象的IsRunning状态。 /// /// 要获取其IsRunning状态的依赖对象。 /// 返回一个布尔值,表示指定对象是否正在运行。 public static bool GetIsRunning(DependencyObject obj) => (bool)obj.GetValue(IsRunningProperty); /// /// 设置指定对象的运行状态。 /// /// 要设置其运行状态的依赖对象。 /// 布尔值,表示对象是否处于运行状态。 public static void SetIsRunning(DependencyObject obj, bool value) => obj.SetValue(IsRunningProperty, value); }