Files
Shrlalgo.RvKits/NeuWPF/NeoUI/Controls/Badge.xaml

357 lines
19 KiB
Plaintext
Raw Normal View History

2025-07-31 20:12:01 +08:00
<ResourceDictionary
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
2025-08-20 12:10:13 +08:00
xmlns:controls="clr-namespace:NeumUI.Controls"
xmlns:converter="clr-namespace:NeumUI.Converters"
2025-07-31 20:12:01 +08:00
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<ResourceDictionary.MergedDictionaries>
2025-08-20 12:10:13 +08:00
<ResourceDictionary Source="/NeumUI;component/Animations/Animations.xaml" />
2025-07-31 20:12:01 +08:00
</ResourceDictionary.MergedDictionaries>
2025-08-12 23:08:54 +08:00
<Storyboard x:Key="NeuBadgeEffectStoryboard">
2025-07-31 20:12:01 +08:00
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.5"
RepeatBehavior="Forever"
Storyboard.TargetName="Effect"
Storyboard.TargetProperty="(UIElement.Opacity)"
To="0" />
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.8"
RepeatBehavior="Forever"
Storyboard.TargetName="EffectTransform"
Storyboard.TargetProperty="ScaleX"
To="2.4" />
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.8"
RepeatBehavior="Forever"
Storyboard.TargetName="EffectTransform"
Storyboard.TargetProperty="ScaleY"
To="2.4" />
</Storyboard>
2025-08-12 23:08:54 +08:00
<!--<ControlTemplate TargetType="{x:Type controls:Badge}" x:Key="NeuBadgeTemplate">
2025-07-31 20:12:01 +08:00
<Grid>
2025-08-12 23:08:54 +08:00
-->
<!-- Effect -->
<!--<Ellipse x:Name="Effect"
2025-07-31 20:12:01 +08:00
Opacity="0"
StrokeThickness="1"
RenderTransformOrigin="0.5,0.5"
Width="{TemplateBinding BadgeHeight}"
Height="{TemplateBinding BadgeHeight}"
2025-08-12 23:08:54 +08:00
Stroke="{DynamicResource PrimaryNormalBrush}">
2025-07-31 20:12:01 +08:00
<Ellipse.RenderTransform>
<ScaleTransform x:Name="EffectTransform" />
</Ellipse.RenderTransform>
</Ellipse>-->
2025-08-12 23:08:54 +08:00
<!-- Content -->
<!--
2025-07-31 20:12:01 +08:00
<Border
Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}">
<ContentPresenter
Content="{TemplateBinding Content}"
ContentStringFormat="{TemplateBinding ContentStringFormat}"
ContentTemplate="{TemplateBinding ContentTemplate}"
ContentTemplateSelector="{TemplateBinding ContentTemplateSelector}"
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
Margin="{TemplateBinding Padding}"
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"
VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
</Border>
2025-08-12 23:08:54 +08:00
-->
<!-- Count -->
<!--
2025-07-31 20:12:01 +08:00
<Border
Background="{TemplateBinding BadgeBackground}"
2025-08-12 23:08:54 +08:00
CornerRadius="{Binding Height, RelativeSource={RelativeSource Self}, Converter={x:Static converter:DoubleToCornerRadiusConverter.Instance}, ConverterParameter=2}"
2025-07-31 20:12:01 +08:00
Height="{TemplateBinding BadgeHeight}"
HorizontalAlignment="Right"
MinWidth="{TemplateBinding Height}"
Padding="6,0"
2025-08-12 23:08:54 +08:00
TextElement.FontSize="12"
TextElement.FontWeight="Normal"
2025-07-31 20:12:01 +08:00
TextElement.Foreground="{TemplateBinding BadgeForeground}"
VerticalAlignment="Top"
x:Name="PART_BadgeContainer">
<Border.RenderTransform>
<TranslateTransform X="-10" Y="-10" />
</Border.RenderTransform>
<ContentPresenter
HorizontalAlignment="Center"
VerticalAlignment="Center"
x:Name="PART_Count" />
</Border>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="Dot" Value="True">
<Setter Property="Visibility" TargetName="PART_Count" Value="Collapsed" />
<Setter Property="Padding" TargetName="PART_BadgeContainer" Value="0" />
<Setter Property="MinWidth" TargetName="PART_BadgeContainer" Value="0" />
2025-08-12 23:08:54 +08:00
<Setter Property="Width" TargetName="PART_BadgeContainer" Value="6" />
<Setter Property="Height" TargetName="PART_BadgeContainer" Value="6" />
2025-07-31 20:12:01 +08:00
</Trigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="Count" Value="0" />
<Condition Property="ShowZero" Value="False" />
</MultiTrigger.Conditions>
<Setter Property="Visibility" TargetName="PART_BadgeContainer" Value="Collapsed" />
</MultiTrigger>
</ControlTemplate.Triggers>
2025-08-12 23:08:54 +08:00
</ControlTemplate>-->
<!-- 状态徽章 -->
<!--<ControlTemplate TargetType="{x:Type controls:Badge}" x:Key="NeuBadgeStatusTemplate">
2025-07-31 20:12:01 +08:00
<Grid>
<Grid.ColumnDefinitions>
2025-08-12 23:08:54 +08:00
-->
<!-- Dot -->
<!--
2025-07-31 20:12:01 +08:00
<ColumnDefinition Width="*" />
2025-08-12 23:08:54 +08:00
-->
<!-- Text -->
<!--
2025-07-31 20:12:01 +08:00
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
2025-08-12 23:08:54 +08:00
-->
<!-- Effect -->
<!--
2025-07-31 20:12:01 +08:00
<Ellipse
Height="{TemplateBinding BadgeHeight}"
Opacity="0"
RenderTransformOrigin="0.5,0.5"
Stroke="{TemplateBinding BadgeBackground}"
StrokeThickness="1"
UseLayoutRounding="True"
Width="{TemplateBinding BadgeHeight}"
x:Name="Effect">
<Ellipse.RenderTransform>
<ScaleTransform x:Name="EffectTransform" />
</Ellipse.RenderTransform>
</Ellipse>
2025-08-12 23:08:54 +08:00
-->
<!-- Dot -->
<!--
2025-07-31 20:12:01 +08:00
<Ellipse
Fill="{TemplateBinding BadgeBackground}"
Height="{TemplateBinding BadgeHeight}"
UseLayoutRounding="True"
VerticalAlignment="Center"
Width="{TemplateBinding BadgeHeight}"
x:Name="Dot" />
2025-08-12 23:08:54 +08:00
-->
<!-- Content -->
<!--
2025-07-31 20:12:01 +08:00
<ContentControl
Content="{TemplateBinding Text}"
Grid.Column="1"
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
Margin="{TemplateBinding Padding}"
VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="Status" Value="Processing">
<Trigger.EnterActions>
2025-08-12 23:08:54 +08:00
<BeginStoryboard Storyboard="{StaticResource NeuBadgeEffectStoryboard}" />
2025-07-31 20:12:01 +08:00
</Trigger.EnterActions>
</Trigger>
</ControlTemplate.Triggers>
2025-08-12 23:08:54 +08:00
</ControlTemplate>-->
2025-07-31 20:12:01 +08:00
<Style TargetType="{x:Type controls:Badge}">
<Setter Property="Foreground" Value="White" />
2025-08-12 23:08:54 +08:00
<Setter Property="FontSize" Value="12" />
<Setter Property="FontWeight" Value="Normal" />
<Setter Property="BadgeHeight" Value="20" />
<Setter Property="HorizontalAlignment" Value="Center" />
<Setter Property="VerticalAlignment" Value="Center" />
<Setter Property="Background" Value="{DynamicResource ErrorBrush}" />
2025-07-31 20:12:01 +08:00
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type controls:Badge}">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<!-- Content -->
<ContentPresenter
Content="{TemplateBinding Content}"
ContentStringFormat="{TemplateBinding ContentStringFormat}"
ContentTemplate="{TemplateBinding ContentTemplate}"
ContentTemplateSelector="{TemplateBinding ContentTemplateSelector}"
Grid.ColumnSpan="2"
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
Margin="{TemplateBinding Padding}"
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
x:Name="Content" />
<!-- Effect -->
<Ellipse
2025-08-12 23:08:54 +08:00
Height="6.5"
2025-07-31 20:12:01 +08:00
Opacity="0"
RenderTransformOrigin="0.5,0.5"
2025-08-12 23:08:54 +08:00
Stroke="{DynamicResource PrimaryNormalBrush}"
2025-07-31 20:12:01 +08:00
StrokeThickness="1"
UseLayoutRounding="True"
2025-08-12 23:08:54 +08:00
Width="6.5"
2025-07-31 20:12:01 +08:00
x:Name="Effect">
<Ellipse.RenderTransform>
<ScaleTransform x:Name="EffectTransform" />
</Ellipse.RenderTransform>
</Ellipse>
<!-- Dot -->
<Border
Background="{TemplateBinding Background}"
2025-08-12 23:08:54 +08:00
CornerRadius="{Binding Height, RelativeSource={RelativeSource Self}, Converter={x:Static converter:DoubleToCornerRadiusConverter.Instance}, ConverterParameter=2}"
2025-07-31 20:12:01 +08:00
Grid.ColumnSpan="2"
Height="{TemplateBinding BadgeHeight}"
HorizontalAlignment="Right"
MinWidth="{TemplateBinding BadgeHeight}"
UseLayoutRounding="True"
VerticalAlignment="Top"
x:Name="Dot">
<ContentPresenter
HorizontalAlignment="Center"
Margin="6,0"
VerticalAlignment="Center"
x:Name="PART_Count" />
</Border>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="Dot" Value="True">
<Setter Property="Visibility" TargetName="PART_Count" Value="Collapsed" />
2025-08-12 23:08:54 +08:00
<Setter Property="Width" TargetName="Dot" Value="6" />
<Setter Property="Height" TargetName="Dot" Value="6" />
2025-07-31 20:12:01 +08:00
<Setter Property="MinWidth" TargetName="Dot" Value="0" />
</Trigger>
<Trigger Property="Status" Value="Success">
2025-08-12 23:08:54 +08:00
<Setter Property="Background" TargetName="Dot" Value="{DynamicResource SuccessBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Processing">
<Trigger.EnterActions>
<BeginStoryboard>
<Storyboard>
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.5"
RepeatBehavior="Forever"
Storyboard.TargetName="Effect"
Storyboard.TargetProperty="(UIElement.Opacity)"
To="0" />
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.8"
RepeatBehavior="Forever"
Storyboard.TargetName="EffectTransform"
Storyboard.TargetProperty="ScaleX"
To="2.4" />
<DoubleAnimation
Duration="0:0:1.2"
EasingFunction="{StaticResource EaseInOut}"
From="0.8"
RepeatBehavior="Forever"
Storyboard.TargetName="EffectTransform"
Storyboard.TargetProperty="ScaleY"
To="2.4" />
</Storyboard>
</BeginStoryboard>
</Trigger.EnterActions>
2025-08-12 23:08:54 +08:00
<Setter Property="Background" TargetName="Dot" Value="{DynamicResource PrimaryNormalBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Default">
2025-08-12 23:08:54 +08:00
<Setter Property="Background" TargetName="Dot" Value="{DynamicResource ControlBackgroundNormalBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Error">
2025-08-12 23:08:54 +08:00
<Setter Property="Background" TargetName="Dot" Value="{DynamicResource ErrorBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Warning">
2025-08-12 23:08:54 +08:00
<Setter Property="Background" TargetName="Dot" Value="{DynamicResource WarningBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="Count" Value="0" />
<Condition Property="ShowZero" Value="False" />
</MultiTrigger.Conditions>
<Setter Property="Visibility" TargetName="Dot" Value="Collapsed" />
</MultiTrigger>
2025-08-20 12:10:13 +08:00
<DataTrigger Binding="{Binding Status, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="False">
2025-07-31 20:12:01 +08:00
<Setter Property="Visibility" TargetName="PART_Count" Value="Collapsed" />
2025-08-12 23:08:54 +08:00
<Setter Property="Width" TargetName="Dot" Value="6.5" />
<Setter Property="Height" TargetName="Dot" Value="6.5" />
2025-07-31 20:12:01 +08:00
<Setter Property="Visibility" TargetName="Dot" Value="Visible" />
<Setter Property="MinWidth" TargetName="Dot" Value="0" />
</DataTrigger>
<!-- Stateful and no content -->
<MultiDataTrigger>
<MultiDataTrigger.Conditions>
2025-08-20 12:10:13 +08:00
<Condition Binding="{Binding Content, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="True" />
<Condition Binding="{Binding Status, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="False" />
2025-07-31 20:12:01 +08:00
</MultiDataTrigger.Conditions>
2025-08-12 23:08:54 +08:00
<Setter Property="Foreground" Value="{DynamicResource TextPrimaryBrush}" />
<Setter Property="FontSize" Value="14" />
2025-07-31 20:12:01 +08:00
<Setter Property="VerticalAlignment" TargetName="Dot" Value="Center" />
<Setter Property="HorizontalAlignment" TargetName="Dot" Value="Left" />
<Setter Property="Grid.ColumnSpan" TargetName="Dot" Value="1" />
<Setter Property="VerticalAlignment" TargetName="Content" Value="Center" />
<Setter Property="HorizontalAlignment" TargetName="Content" Value="Left" />
<Setter Property="Margin" TargetName="Content" Value="8,0,0,0" />
<Setter Property="Grid.ColumnSpan" TargetName="Content" Value="1" />
<Setter Property="Grid.Column" TargetName="Content" Value="1" />
<Setter Property="Content" TargetName="Content" Value="{Binding Text, RelativeSource={RelativeSource Mode=TemplatedParent}}" />
</MultiDataTrigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
2025-08-12 23:08:54 +08:00
<!--<Style TargetType="{x:Type controls:Badge}" x:Key="NeuBadge">
2025-07-31 20:12:01 +08:00
<Setter Property="BadgeForeground" Value="White" />
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeHeight" Value="20" />
<Setter Property="BadgeBackground" Value="{DynamicResource ErrorNormalBrush}" />
<Setter Property="Template" Value="{StaticResource NeuBadgeTemplate}" />
2025-07-31 20:12:01 +08:00
<Style.Triggers>
<Trigger Property="Status" Value="Success">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeBackground" Value="{DynamicResource SuccessNormalBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Processing">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeBackground" Value="{DynamicResource PrimaryBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Default">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeBackground" Value="{DynamicResource Background.Label}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Error">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeBackground" Value="{DynamicResource ErrorNormalBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
<Trigger Property="Status" Value="Warning">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeBackground" Value="{DynamicResource WarningBrush}" />
2025-07-31 20:12:01 +08:00
</Trigger>
2025-08-20 12:10:13 +08:00
<DataTrigger Binding="{Binding Status, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="False">
2025-08-12 23:08:54 +08:00
<Setter Property="BadgeHeight" Value="6.5" />
2025-07-31 20:12:01 +08:00
</DataTrigger>
<MultiDataTrigger>
<MultiDataTrigger.Conditions>
2025-08-20 12:10:13 +08:00
<Condition Binding="{Binding Content, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="True" />
<Condition Binding="{Binding Status, RelativeSource={RelativeSource Self}, Converter={x:Static converter:NullOrEmptyConverter.Instance}}" Value="False" />
2025-07-31 20:12:01 +08:00
</MultiDataTrigger.Conditions>
<Setter Property="Padding" Value="8,0,0,0" />
<Setter Property="VerticalAlignment" Value="Center" />
<Setter Property="HorizontalAlignment" Value="Left" />
2025-08-12 23:08:54 +08:00
<Setter Property="Foreground" Value="{DynamicResource Text.Main}" />
<Setter Property="FontSize" Value="14" />
<Setter Property="Template" Value="{StaticResource NeuBadgeStatusTemplate}" />
2025-07-31 20:12:01 +08:00
</MultiDataTrigger>
</Style.Triggers>
2025-08-12 23:08:54 +08:00
</Style>-->
2025-07-31 20:12:01 +08:00
</ResourceDictionary>