Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add new Badged Style
  • Loading branch information
StefanoRivolta-Previero committed Apr 4, 2022
commit 56f742eaecee7dc82d2e3c17df82598b86037341
1 change: 1 addition & 0 deletions MaterialDesignThemes.Wpf/Themes/Generic.xaml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@

<!-- set up default styles for our custom Material Design in XAML Toolkit controls -->
<Style TargetType="{x:Type local:Clock}" BasedOn="{StaticResource MaterialDesignClock}" />
<Style TargetType="{x:Type local:Badged}" BasedOn="{StaticResource MaterialDesignBadge}" />
<Style TargetType="{x:Type local:PopupBox}" BasedOn="{StaticResource MaterialDesignPopupBox}" />
<Style TargetType="{x:Type local:TimePicker}" BasedOn="{StaticResource MaterialDesignTimePicker}" />

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Button.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Badged.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Calendar.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.CheckBox.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Chip.xaml" />
Expand Down Expand Up @@ -50,7 +51,7 @@
<SolidColorBrush x:Key="MaterialDesignDarkForeground" Color="#FFFAFAFA"/>
<SolidColorBrush x:Key="MaterialDesignDarkSeparatorBackground" Color="#1F000000" />
<SolidColorBrush x:Key="MaterialDesignLightSeparatorBackground" Color="#1FFFFFFF" />

<Style TargetType="{x:Type Button}" BasedOn="{StaticResource MaterialDesignRaisedButton}" />
<Style TargetType="{x:Type Calendar}" BasedOn="{StaticResource MaterialDesignCalendarPortrait}" />
<Style TargetType="{x:Type CheckBox}" BasedOn="{StaticResource MaterialDesignCheckBox}" />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesign3.NavigationDrawer.xaml" />

<!-- MaterialDesign2 -->
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Badged.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Button.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Calendar.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.CheckBox.xaml" />
Expand Down
111 changes: 110 additions & 1 deletion MaterialDesignThemes.Wpf/Themes/MaterialDesignTheme.Badged.xaml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
</DoubleAnimationUsingKeyFrames>
</Storyboard>

<Style TargetType="{x:Type wpf:Badged}">
<Style TargetType="{x:Type wpf:Badged}" x:Key="MaterialDesignBadge">
<Setter Property="IsTabStop" Value="False" />
<Setter Property="HorizontalAlignment" Value="Left" />
<Setter Property="VerticalAlignment" Value="Top" />
Expand Down Expand Up @@ -136,4 +136,113 @@
</Style.Triggers>
</Style>

<Style TargetType="{x:Type wpf:Badged}" x:Key="MaterialDesignMiniBadge">
<Setter Property="IsTabStop" Value="False" />
<Setter Property="HorizontalAlignment" Value="Left" />
<Setter Property="VerticalAlignment" Value="Top" />
<Setter Property="BadgeColorZoneMode" Value="PrimaryLight" />
<Setter Property="BadgePlacementMode" Value="TopRight" />
<Setter Property="BadgeChangedStoryboard" Value="{StaticResource BadgeChangedStoryboard}" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type wpf:Badged}">
<Grid>
<Border Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}">
<ContentPresenter Content="{TemplateBinding Content}"
ContentStringFormat="{TemplateBinding ContentStringFormat}"
ContentTemplate="{TemplateBinding ContentTemplate}"
ContentTemplateSelector="{TemplateBinding ContentTemplateSelector}"
Margin="{TemplateBinding Padding}"
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" />
</Border>
<Border x:Name="PART_BadgeContainer"
CornerRadius="{TemplateBinding CornerRadius}" Background="{TemplateBinding BadgeBackground}"
Width="6" Height="6"
HorizontalAlignment="Left" VerticalAlignment="Top" Padding="2"
TextElement.FontSize="11"
TextElement.FontWeight="DemiBold"
RenderTransformOrigin=".5,.5"
Visibility="{TemplateBinding IsBadgeSet, Converter={StaticResource BooleanToVisibilityConverter}}">
<Border.RenderTransform>
<ScaleTransform ScaleX="1" ScaleY="1" />
</Border.RenderTransform>
</Border>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="BadgePlacementMode" Value="TopLeft">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Left" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Top" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="Top">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Center" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Top" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="TopRight">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Right" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Top" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="Right">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Right" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Center" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="BottomRight">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Right" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Bottom" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="Bottom">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Center" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Bottom" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="BottomLeft">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Left" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Bottom" />
</Trigger>
<Trigger Property="BadgePlacementMode" Value="Left">
<Setter TargetName="PART_BadgeContainer" Property="HorizontalAlignment" Value="Left" />
<Setter TargetName="PART_BadgeContainer" Property="VerticalAlignment" Value="Center" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
<Style.Triggers>
<Trigger Property="BadgeColorZoneMode" Value="Standard">
<Setter Property="BadgeBackground" Value="{DynamicResource MaterialDesignPaper}" />
<Setter Property="BadgeForeground" Value="{DynamicResource MaterialDesignBody}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="Inverted">
<Setter Property="BadgeBackground" Value="{DynamicResource MaterialDesignBody}" />
<Setter Property="BadgeForeground" Value="{DynamicResource MaterialDesignPaper}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="PrimaryLight">
<Setter Property="BadgeBackground" Value="{DynamicResource PrimaryHueLightBrush}" />
<Setter Property="BadgeForeground" Value="{DynamicResource PrimaryHueLightForegroundBrush}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="PrimaryMid">
<Setter Property="BadgeBackground" Value="{DynamicResource PrimaryHueMidBrush}" />
<Setter Property="BadgeForeground" Value="{DynamicResource PrimaryHueMidForegroundBrush}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="PrimaryDark">
<Setter Property="BadgeBackground" Value="{DynamicResource PrimaryHueDarkBrush}" />
<Setter Property="BadgeForeground" Value="{DynamicResource PrimaryHueDarkForegroundBrush}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="SecondaryMid">
<Setter Property="BadgeBackground" Value="{DynamicResource SecondaryHueMidBrush}" />
<Setter Property="BadgeForeground" Value="{DynamicResource SecondaryHueMidForegroundBrush}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="Light">
<Setter Property="BadgeBackground" Value="{DynamicResource MaterialDesignLightBackground}" />
<Setter Property="BadgeForeground" Value="{DynamicResource MaterialDesignLightForeground}" />
</Trigger>
<Trigger Property="BadgeColorZoneMode" Value="Dark">
<Setter Property="BadgeBackground" Value="{DynamicResource MaterialDesignDarkBackground}" />
<Setter Property="BadgeForeground" Value="{DynamicResource MaterialDesignDarkForeground}" />
</Trigger>
</Style.Triggers>
</Style>

</ResourceDictionary>