From 1d850c44815cea4d0b56925e908af71f9acc7847 Mon Sep 17 00:00:00 2001 From: eriklimakc Date: Fri, 24 Nov 2023 17:48:39 +0000 Subject: [PATCH 1/2] chore: Add ControlExtensions.Icon support to TextBox --- doc/material-controls-extensions.md | 2 +- .../Uno.Material/Extensions/ControlExtensions.cs | 10 +++++++++- .../Uno.Material/Styles/Controls/v2/TextBox.xaml | 8 ++++---- 3 files changed, 14 insertions(+), 6 deletions(-) diff --git a/doc/material-controls-extensions.md b/doc/material-controls-extensions.md index 169e7fd79..8ddadb5ca 100644 --- a/doc/material-controls-extensions.md +++ b/doc/material-controls-extensions.md @@ -9,7 +9,7 @@ Below is a summary of the icon support for different controls: | **Button** | ✔️ | ❌ | ❌ | | **Combobox** | ✔️ | ❌ | ❌ | | **PasswordBox** | ✔️ | ❌ | ❌ | -| **TextBox** | ❌ | ✔️ | ✔️ | +| **TextBox** | ✔️ | ✔️ | ✔️ | This feature allows for the addition of icons on the supported controls. Icons can be added in different positions, such as `Icon`, `LeadingIcon`, and `TrailingIcon`. You can choose from various [`IconElement`](https://docs.microsoft.com/en-us/windows/windows-app-sdk/api/winrt/microsoft.ui.xaml.controls.iconelement)s to represent your icons, including ``, ``, ``, or ``. diff --git a/src/library/Uno.Material/Extensions/ControlExtensions.cs b/src/library/Uno.Material/Extensions/ControlExtensions.cs index 8d3110f64..a3bd47f07 100644 --- a/src/library/Uno.Material/Extensions/ControlExtensions.cs +++ b/src/library/Uno.Material/Extensions/ControlExtensions.cs @@ -29,7 +29,7 @@ public static class ControlExtensions "Icon", typeof(IconElement), typeof(ControlExtensions), - new PropertyMetadata(default)); + new PropertyMetadata(default, OnIconChanged)); [DynamicDependency(nameof(SetIcon))] public static IconElement GetIcon(Control obj) => (IconElement)obj.GetValue(IconProperty); @@ -222,6 +222,14 @@ public static class ControlExtensions #endregion + private static void OnIconChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + { + if (d is TextBox textBox) + { + textBox.SetValue(LeadingIconProperty, e.NewValue); + } + } + private static void OnElevationChanged(DependencyObject element, DependencyPropertyChangedEventArgs e) => SurfaceTintExtensions.OnElevationChanged(element, (int)e.NewValue); diff --git a/src/library/Uno.Material/Styles/Controls/v2/TextBox.xaml b/src/library/Uno.Material/Styles/Controls/v2/TextBox.xaml index 0186a1c1d..e2c524a69 100644 --- a/src/library/Uno.Material/Styles/Controls/v2/TextBox.xaml +++ b/src/library/Uno.Material/Styles/Controls/v2/TextBox.xaml @@ -467,7 +467,7 @@ Content="{Binding Path=(um:ControlExtensions.LeadingIcon), RelativeSource={RelativeSource TemplatedParent}}" Command="{Binding Path=(um:ControlExtensions.LeadingCommand), RelativeSource={RelativeSource TemplatedParent}}" Visibility="{Binding Path=(um:ControlExtensions.IsLeadingIconVisible), RelativeSource={RelativeSource TemplatedParent}}" - Style="{ThemeResource MaterialLeadingIconStyle}" + Style="{StaticResource MaterialLeadingIconStyle}" HorizontalAlignment="Center" Margin="0,0,16,0" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/> @@ -530,7 +530,7 @@ Content="{Binding Path=(um:ControlExtensions.TrailingIcon), RelativeSource={RelativeSource TemplatedParent}}" Command="{Binding Path=(um:ControlExtensions.TrailingCommand), RelativeSource={RelativeSource TemplatedParent}}" Visibility="{Binding Path=(um:ControlExtensions.IsTrailingIconVisible), RelativeSource={RelativeSource TemplatedParent}}" - Style="{ThemeResource MaterialTrailingIconStyle}" + Style="{StaticResource MaterialTrailingIconStyle}" HorizontalAlignment="Center" Margin="14,0,0,0" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" /> @@ -702,7 +702,7 @@ Content="{Binding Path=(um:ControlExtensions.LeadingIcon), RelativeSource={RelativeSource TemplatedParent}}" Command="{Binding Path=(um:ControlExtensions.LeadingCommand), RelativeSource={RelativeSource TemplatedParent}}" Visibility="{Binding Path=(um:ControlExtensions.IsLeadingIconVisible), RelativeSource={RelativeSource TemplatedParent}}" - Style="{ThemeResource MaterialLeadingIconStyle}" + Style="{StaticResource MaterialLeadingIconStyle}" HorizontalAlignment="Center" Margin="0,0,16,0" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" /> @@ -764,7 +764,7 @@ Content="{Binding Path=(um:ControlExtensions.TrailingIcon), RelativeSource={RelativeSource TemplatedParent}}" Command="{Binding Path=(um:ControlExtensions.TrailingCommand), RelativeSource={RelativeSource TemplatedParent}}" Visibility="{Binding Path=(um:ControlExtensions.IsTrailingIconVisible), RelativeSource={RelativeSource TemplatedParent}}" - Style="{ThemeResource MaterialTrailingIconStyle}" + Style="{StaticResource MaterialTrailingIconStyle}" HorizontalAlignment="Center" Margin="14,0,0,0" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" /> From fcbeafc893e87690299da55a23cca54224d5a995 Mon Sep 17 00:00:00 2001 From: eriklimakc Date: Mon, 27 Nov 2023 17:30:10 +0000 Subject: [PATCH 2/2] chore: Warn Icons support --- doc/material-controls-extensions.md | 15 +++---- .../Extensions/ControlExtensions.cs | 42 ++++++++++++++----- 2 files changed, 40 insertions(+), 17 deletions(-) diff --git a/doc/material-controls-extensions.md b/doc/material-controls-extensions.md index 8ddadb5ca..109e64fb2 100644 --- a/doc/material-controls-extensions.md +++ b/doc/material-controls-extensions.md @@ -4,13 +4,14 @@ Below is a summary of the icon support for different controls: -| Control | Icon | LeadingIcon | TrailingIcon | -|-----------------|------|-------------|--------------| -| **Button** | ✔️ | ❌ | ❌ | -| **Combobox** | ✔️ | ❌ | ❌ | -| **PasswordBox** | ✔️ | ❌ | ❌ | -| **TextBox** | ✔️ | ✔️ | ✔️ | - +| Control | Icon | LeadingIcon | TrailingIcon | +|-----------------|-------|-------------|--------------| +| **Button** | ✔️ | ❌ | ❌ | +| **Combobox** | ✔️ | ❌ | ❌ | +| **PasswordBox** | ✔️ | ❌ | ❌ | +| **TextBox** | ✔️* | ✔️ | ✔️ | + +\* Setting the `Icon` for a `TextBox` will simply set the `LeadingIcon`. This feature allows for the addition of icons on the supported controls. Icons can be added in different positions, such as `Icon`, `LeadingIcon`, and `TrailingIcon`. You can choose from various [`IconElement`](https://docs.microsoft.com/en-us/windows/windows-app-sdk/api/winrt/microsoft.ui.xaml.controls.iconelement)s to represent your icons, including ``, ``, ``, or ``. diff --git a/src/library/Uno.Material/Extensions/ControlExtensions.cs b/src/library/Uno.Material/Extensions/ControlExtensions.cs index a3bd47f07..d41a5f867 100644 --- a/src/library/Uno.Material/Extensions/ControlExtensions.cs +++ b/src/library/Uno.Material/Extensions/ControlExtensions.cs @@ -5,6 +5,8 @@ using Windows.UI; using Uno.Disposables; using System.Windows.Input; +using Uno.Extensions; +using Microsoft.Extensions.Logging; #if WinUI using Microsoft.UI.Xaml; @@ -66,12 +68,11 @@ public static class ControlExtensions #endregion #region DependencyProperty: LeadingIcon - public static DependencyProperty LeadingIconProperty { [DynamicDependency(nameof(GetLeadingIcon))] get; } = DependencyProperty.RegisterAttached( "LeadingIcon", typeof(IconElement), typeof(ControlExtensions), - new PropertyMetadata(default)); + new PropertyMetadata(default, OnLeadingIconChanged)); [DynamicDependency(nameof(SetLeadingIcon))] public static IconElement GetLeadingIcon(Control obj) => (IconElement)obj.GetValue(LeadingIconProperty); @@ -79,15 +80,16 @@ public static class ControlExtensions [DynamicDependency(nameof(GetLeadingIcon))] public static void SetLeadingIcon(Control obj, IconElement value) => obj.SetValue(LeadingIconProperty, value); + private static void OnLeadingIconChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "LeadingIcon"); #endregion #region DependencyProperty: IsLeadingIconVisible - public static DependencyProperty IsLeadingIconVisibleProperty { [DynamicDependency(nameof(GetIsLeadingIconVisible))] get; } = DependencyProperty.RegisterAttached( "IsLeadingIconVisible", typeof(bool), typeof(ControlExtensions), - new PropertyMetadata(true)); + new PropertyMetadata(true, OnIsLeadingIconVisibleChanged)); [DynamicDependency(nameof(SetIsLeadingIconVisible))] public static bool GetIsLeadingIconVisible(Control obj) => (bool)obj.GetValue(IsLeadingIconVisibleProperty); @@ -95,6 +97,8 @@ public static class ControlExtensions [DynamicDependency(nameof(GetIsLeadingIconVisible))] public static void SetIsLeadingIconVisible(Control obj, bool value) => obj.SetValue(IsLeadingIconVisibleProperty, value); + private static void OnIsLeadingIconVisibleChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "IsLeadingIconVisible"); #endregion #region DependencyProperty: LeadingCommand @@ -102,37 +106,41 @@ public static class ControlExtensions "LeadingCommand", typeof(ICommand), typeof(ControlExtensions), - new PropertyMetadata(default)); + new PropertyMetadata(default, OnLeadingCommandChanged)); [DynamicDependency(nameof(GetLeadingCommand))] public static ICommand GetLeadingCommand(Control obj) => (ICommand)obj.GetValue(LeadingCommandProperty); [DynamicDependency(nameof(SetLeadingCommand))] public static void SetLeadingCommand(Control obj, ICommand value) => obj.SetValue(LeadingCommandProperty, value); + + private static void OnLeadingCommandChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "LeadingCommand"); #endregion #region DependencyProperty: TrailingIcon - public static DependencyProperty TrailingIconProperty { [DynamicDependency(nameof(GetTrailingIcon))] get; } = DependencyProperty.RegisterAttached( "TrailingIcon", typeof(IconElement), typeof(ControlExtensions), - new PropertyMetadata(default)); + new PropertyMetadata(default, OnTrailingIconChanged)); [DynamicDependency(nameof(SetTrailingIcon))] public static IconElement GetTrailingIcon(Control obj) => (IconElement)obj.GetValue(TrailingIconProperty); [DynamicDependency(nameof(GetTrailingIcon))] public static void SetTrailingIcon(Control obj, IconElement value) => obj.SetValue(TrailingIconProperty, value); + + private static void OnTrailingIconChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "TrailingIcon"); #endregion #region DependencyProperty: IsTrailingIconVisible - public static DependencyProperty IsTrailingIconVisibleProperty { [DynamicDependency(nameof(GetIsTrailingIconVisible))] get; } = DependencyProperty.RegisterAttached( "IsTrailingIconVisible", typeof(bool), typeof(ControlExtensions), - new PropertyMetadata(true)); + new PropertyMetadata(true, OnIsTrailingIconVisibleChanged)); [DynamicDependency(nameof(SetIsTrailingIconVisible))] public static bool GetIsTrailingIconVisible(Control obj) => (bool)obj.GetValue(IsTrailingIconVisibleProperty); @@ -140,6 +148,8 @@ public static class ControlExtensions [DynamicDependency(nameof(GetIsTrailingIconVisible))] public static void SetIsTrailingIconVisible(Control obj, bool value) => obj.SetValue(IsTrailingIconVisibleProperty, value); + private static void OnIsTrailingIconVisibleChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "IsTrailingIconVisible"); #endregion #region DependencyProperty: TrailingCommand @@ -147,13 +157,16 @@ public static class ControlExtensions "TrailingCommand", typeof(ICommand), typeof(ControlExtensions), - new PropertyMetadata(default)); + new PropertyMetadata(default, OnTrailingCommandChanged)); [DynamicDependency(nameof(GetTrailingCommand))] public static ICommand GetTrailingCommand(Control obj) => (ICommand)obj.GetValue(TrailingCommandProperty); [DynamicDependency(nameof(SetTrailingCommand))] public static void SetTrailingCommand(Control obj, ICommand value) => obj.SetValue(TrailingCommandProperty, value); + + private static void OnTrailingCommandChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + => WarnNotSupportedProperty(d, "TrailingCommand"); #endregion #region DependencyProperty: AlternateContent @@ -205,6 +218,7 @@ public static class ControlExtensions public static void SetTintedBackground(UIElement obj, SolidColorBrush value) => obj.SetValue(TintedBackgroundProperty, value); #endregion + #region DependencyProperty: IsTintEnabled /// /// Gets or sets whether or not the SurfaceTintColor should be applied for elevated views @@ -230,6 +244,14 @@ private static void OnIconChanged(DependencyObject d, DependencyPropertyChangedE } } + private static void WarnNotSupportedProperty(DependencyObject d, string propertyName) + { + if (d is not TextBox) + { + d.Log().LogWarning($"Warning: {propertyName} is only supported on TextBox controls."); + } + } + private static void OnElevationChanged(DependencyObject element, DependencyPropertyChangedEventArgs e) => SurfaceTintExtensions.OnElevationChanged(element, (int)e.NewValue);