Files
ShrlAlgoToolkit/Melskin/Controls/Calendar.xaml

342 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"
2026-01-02 17:30:41 +08:00
xmlns:controls="clr-namespace:Melskin.Controls"
2026-01-02 17:30:30 +08:00
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
2025-07-31 20:12:24 +08:00
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="FlattenButton.xaml" />
</ResourceDictionary.MergedDictionaries>
2025-07-31 20:12:01 +08:00
<!-- 年月按钮 -->
2026-01-02 17:30:30 +08:00
<Style TargetType="{x:Type CalendarButton}" x:Key="DefaultCalendarButtonStyle">
2025-08-12 23:08:54 +08:00
<Setter Property="Background" Value="{DynamicResource BackgroundLayoutBrush}" />
<Setter Property="BorderBrush" Value="{DynamicResource PrimaryNormalBrush}" />
2025-07-11 09:20:23 +08:00
<Setter Property="BorderThickness" Value="1" />
<Setter Property="MinWidth" Value="48" />
<Setter Property="MinHeight" Value="42" />
<Setter Property="FontSize" Value="12" />
<Setter Property="HorizontalContentAlignment" Value="Center" />
<Setter Property="VerticalContentAlignment" Value="Center" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type CalendarButton}">
<Grid>
2025-07-31 20:12:01 +08:00
<Rectangle
2025-12-23 21:35:54 +08:00
Fill="{DynamicResource ControlBackgroundSelectedBrush}"
2026-01-02 17:30:30 +08:00
Margin="2"
2025-07-31 20:12:01 +08:00
RadiusX="4"
RadiusY="4"
StrokeThickness="{TemplateBinding BorderThickness}"
2026-01-02 17:30:30 +08:00
Visibility="Hidden"
x:Name="SelectionMark" />
2025-07-31 20:12:01 +08:00
<Border
2025-08-12 23:08:54 +08:00
Background="{DynamicResource PrimaryNormalBrush}"
2025-07-31 20:12:01 +08:00
CornerRadius="4"
2026-01-02 17:30:30 +08:00
Margin="2"
Visibility="Hidden"
x:Name="SelectedBorder" />
2025-07-31 20:12:01 +08:00
<ContentPresenter
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
2026-01-02 17:30:30 +08:00
TextElement.Foreground="{DynamicResource TextPrimaryBrush}"
2025-07-31 20:12:01 +08:00
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
2026-01-02 17:30:30 +08:00
x:Name="NormalText" />
2025-07-11 09:20:23 +08:00
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="HasSelectedDays" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="SelectedBorder" Value="Visible" />
<Setter Property="TextElement.Foreground" TargetName="NormalText" Value="{DynamicResource TextAccentBrush}" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsMouseOver" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="SelectionMark" Value="Visible" />
<Setter Property="Background" TargetName="SelectedBorder" Value="{DynamicResource PrimaryFocusedBrush}" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsInactive" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="TextElement.Foreground" TargetName="NormalText" Value="{DynamicResource TextSecondaryBrush}" />
2025-07-11 09:20:23 +08:00
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
2025-07-31 20:12:01 +08:00
<!-- 日期按钮 -->
2026-01-02 17:30:30 +08:00
<Style TargetType="{x:Type CalendarDayButton}" x:Key="DefaultCalendarDayButtonStyle">
2025-07-11 09:20:23 +08:00
<Setter Property="MinWidth" Value="28" />
<Setter Property="MinHeight" Value="26" />
<Setter Property="FontSize" Value="12" />
<Setter Property="HorizontalContentAlignment" Value="Center" />
<Setter Property="VerticalContentAlignment" Value="Center" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type CalendarDayButton}">
<Grid>
2025-07-31 20:12:01 +08:00
<!-- 选中背景 -->
<Rectangle
2025-08-12 23:08:54 +08:00
Fill="{DynamicResource ControlBackgroundSelectedBrush}"
2025-07-31 20:12:01 +08:00
RadiusX="4"
RadiusY="4"
2026-01-02 17:30:30 +08:00
Visibility="Hidden"
x:Name="SelectedBackground" />
2025-07-31 20:12:01 +08:00
<!-- 鼠标划过背景 -->
<Rectangle
2025-08-12 23:08:54 +08:00
Fill="{DynamicResource ControlBackgroundHoverBrush}"
2025-07-31 20:12:01 +08:00
RadiusX="4"
RadiusY="4"
2026-01-02 17:30:30 +08:00
Visibility="Hidden"
x:Name="HighlightBackground" />
2025-07-31 20:12:01 +08:00
<!-- 今日背景 -->
<Rectangle
2025-08-12 23:08:54 +08:00
Fill="{DynamicResource PrimaryNormalBrush}"
2025-07-31 20:12:01 +08:00
RadiusX="4"
RadiusY="4"
2025-08-12 23:08:54 +08:00
Stroke="{DynamicResource PrimaryVariantBrush}"
2025-07-31 20:12:01 +08:00
StrokeThickness="0"
2026-01-02 17:30:30 +08:00
Visibility="Hidden"
x:Name="TodayBackground" />
2025-07-31 20:12:01 +08:00
<ContentPresenter
2025-12-23 21:35:54 +08:00
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
2026-01-02 17:30:30 +08:00
Margin="5,1,5,1"
TextElement.Foreground="{DynamicResource TextPrimaryBrush}"
2025-07-31 20:12:01 +08:00
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
2026-01-02 17:30:30 +08:00
x:Name="NormalText" />
2025-07-31 20:12:01 +08:00
<!-- 叉 -->
<controls:IconElement
2025-12-23 21:35:54 +08:00
Foreground="{DynamicResource ErrorBrush}"
2026-01-02 17:30:30 +08:00
Margin="4"
2025-07-31 20:12:01 +08:00
Opacity="0"
RenderTransformOrigin="0.5,0.5"
2026-01-02 17:30:30 +08:00
Symbol="Close"
x:Name="Blackout" />
2025-07-11 09:20:23 +08:00
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="HighlightBackground" Value="Visible" />
<Setter Property="Fill" TargetName="TodayBackground" Value="{DynamicResource PrimaryFocusedBrush}" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsSelected" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="StrokeThickness" TargetName="TodayBackground" Value="1" />
<Setter Property="Visibility" TargetName="SelectedBackground" Value="Visible" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsToday" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="TextElement.Foreground" TargetName="NormalText" Value="#e0e0e0" />
<Setter Property="Visibility" TargetName="TodayBackground" Value="Visible" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsBlackedOut" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="Blackout" Value="Visible" />
2025-07-11 09:20:23 +08:00
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Foreground" Value="{DynamicResource TextDisabledBrush}" />
</Trigger>
<Trigger Property="IsInactive" Value="True">
2026-01-02 17:30:30 +08:00
<Setter Property="TextElement.Foreground" TargetName="NormalText" Value="{DynamicResource TextSecondaryBrush}" />
2025-07-11 09:20:23 +08:00
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
2026-01-02 17:30:30 +08:00
<Style TargetType="{x:Type CalendarItem}" x:Key="DefaultCalendarItemStyle">
2025-07-11 09:20:23 +08:00
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type CalendarItem}">
<ControlTemplate.Resources>
2025-07-31 20:12:01 +08:00
<!-- 星期标题 -->
2025-07-11 09:20:23 +08:00
<DataTemplate x:Key="{x:Static CalendarItem.DayTitleTemplateResourceKey}">
2025-07-31 20:12:01 +08:00
<TextBlock
FontFamily="Verdana"
FontSize="12"
FontWeight="Bold"
Foreground="{DynamicResource PrimaryVariantBrush}"
2026-01-02 17:30:30 +08:00
HorizontalAlignment="Center"
Margin="0,6,0,6"
Text="{Binding}"
VerticalAlignment="Center" />
2025-07-11 09:20:23 +08:00
</DataTemplate>
</ControlTemplate.Resources>
<Grid x:Name="PART_Root">
2025-07-31 20:12:01 +08:00
<Border
Background="{TemplateBinding Background}"
BorderThickness="{TemplateBinding BorderThickness}"
CornerRadius="8"
2026-01-02 17:30:30 +08:00
Effect="{DynamicResource PopupShadow}"
Margin="4">
2025-07-11 09:20:23 +08:00
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="32" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="32" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="*" />
</Grid.RowDefinitions>
2025-07-31 20:12:01 +08:00
<!-- 上方背景 -->
<Border
2025-12-23 21:35:54 +08:00
Background="{DynamicResource PrimaryNormalBrush}"
2026-01-02 17:30:30 +08:00
CornerRadius="6,6,0,0"
Grid.ColumnSpan="3"
Margin="2" />
2025-07-31 20:12:01 +08:00
<!-- 向左按钮 -->
<Button
2026-01-02 17:30:30 +08:00
Background="{DynamicResource PrimaryNormalBrush}"
Focusable="False"
2025-12-23 21:35:54 +08:00
Grid.Column="0"
2026-01-02 17:30:30 +08:00
Grid.Row="0"
2025-07-31 20:12:01 +08:00
Margin="3"
Padding="4"
2026-01-02 17:30:30 +08:00
Style="{StaticResource FlattenButtonStyle}"
x:Name="PART_PreviousButton">
<controls:IconElement Foreground="#e0e0e0" Symbol="ArrowBackIos" />
2025-07-11 09:20:23 +08:00
</Button>
2025-07-31 20:12:01 +08:00
<!-- 中间按钮 -->
<Button
2025-08-12 23:08:54 +08:00
Background="{DynamicResource PrimaryNormalBrush}"
2025-07-31 20:12:01 +08:00
Focusable="False"
FontSize="12"
FontWeight="Bold"
Foreground="#e0e0e0"
2026-01-02 17:30:30 +08:00
Grid.Column="1"
Grid.Row="0"
HorizontalAlignment="Stretch"
Margin="0,3"
Style="{StaticResource FlattenButtonStyle}"
x:Name="PART_HeaderButton" />
2025-07-31 20:12:01 +08:00
<!-- 右侧按钮 -->
<Button
2026-01-02 17:30:30 +08:00
Background="{DynamicResource PrimaryNormalBrush}"
Focusable="False"
2025-12-23 21:35:54 +08:00
Grid.Column="2"
2026-01-02 17:30:30 +08:00
Grid.Row="0"
2025-07-31 20:12:01 +08:00
Margin="3"
Padding="4"
2026-01-02 17:30:30 +08:00
Style="{StaticResource FlattenButtonStyle}"
x:Name="PART_NextButton">
<controls:IconElement Foreground="#e0e0e0" Symbol="ArrowForwardIos" />
2025-07-11 09:20:23 +08:00
</Button>
2025-07-31 20:12:01 +08:00
<!-- 月份视图 -->
<Grid
2025-07-31 20:12:24 +08:00
Grid.Column="0"
2025-07-31 20:12:01 +08:00
Grid.ColumnSpan="3"
2026-01-02 17:30:30 +08:00
Grid.Row="1"
2025-12-23 21:35:54 +08:00
HorizontalAlignment="Center"
2026-01-02 17:30:30 +08:00
Margin="6,2,6,6"
Visibility="Visible"
x:Name="PART_MonthView">
2025-07-11 09:20:23 +08:00
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
</Grid>
2025-07-31 20:12:01 +08:00
<!-- 年份视图 -->
<Grid
2025-07-31 20:12:24 +08:00
Grid.Column="0"
2025-07-31 20:12:01 +08:00
Grid.ColumnSpan="3"
2026-01-02 17:30:30 +08:00
Grid.Row="1"
2025-12-23 21:35:54 +08:00
HorizontalAlignment="Center"
2026-01-02 17:30:30 +08:00
Margin="6,2,6,6"
Visibility="Hidden"
x:Name="PART_YearView">
2025-07-11 09:20:23 +08:00
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
</Grid>
</Grid>
</Border>
2025-07-31 20:12:01 +08:00
<!-- 禁用遮罩 -->
<Rectangle
2025-12-23 21:35:54 +08:00
Fill="{DynamicResource ControlBackgroundDisabledBrush}"
2026-01-02 17:30:30 +08:00
Margin="4"
2025-07-31 20:12:01 +08:00
Opacity="0"
RadiusX="6"
RadiusY="6"
Stretch="Fill"
2026-01-02 17:30:30 +08:00
Visibility="Collapsed"
x:Name="PART_DisabledVisual" />
2025-07-31 20:12:01 +08:00
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="CommonStates">
<VisualState x:Name="Normal" />
<VisualState x:Name="Disabled">
<Storyboard>
<DoubleAnimation
2026-01-02 17:30:30 +08:00
Duration="0"
2025-07-31 20:12:01 +08:00
Storyboard.TargetName="PART_DisabledVisual"
Storyboard.TargetProperty="Opacity"
2026-01-02 17:30:30 +08:00
To="0.5" />
2025-07-31 20:12:01 +08:00
</Storyboard>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
2025-07-11 09:20:23 +08:00
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsEnabled" Value="False">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="PART_DisabledVisual" Value="Visible" />
2025-07-11 09:20:23 +08:00
</Trigger>
2025-07-31 20:12:01 +08:00
<DataTrigger Binding="{Binding DisplayMode, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Calendar}}}" Value="Year">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="PART_MonthView" Value="Hidden" />
<Setter Property="Visibility" TargetName="PART_YearView" Value="Visible" />
2025-07-11 09:20:23 +08:00
</DataTrigger>
2025-07-31 20:12:01 +08:00
<DataTrigger Binding="{Binding DisplayMode, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Calendar}}}" Value="Decade">
2026-01-02 17:30:30 +08:00
<Setter Property="Visibility" TargetName="PART_MonthView" Value="Hidden" />
<Setter Property="Visibility" TargetName="PART_YearView" Value="Visible" />
2025-07-11 09:20:23 +08:00
</DataTrigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
2026-01-02 17:30:30 +08:00
<Style TargetType="{x:Type Calendar}" x:Key="DefaultCalendarStyle">
2025-10-10 11:19:58 +08:00
<Setter Property="CalendarItemStyle" Value="{StaticResource DefaultCalendarItemStyle}" />
<Setter Property="CalendarDayButtonStyle" Value="{StaticResource DefaultCalendarDayButtonStyle}" />
<Setter Property="CalendarButtonStyle" Value="{StaticResource DefaultCalendarButtonStyle}" />
2025-08-26 21:33:20 +08:00
<Setter Property="Background" Value="{DynamicResource ControlBackgroundNormalBrush}" />
2025-08-12 23:08:54 +08:00
<Setter Property="BorderBrush" Value="{DynamicResource BorderGradientBrush}" />
2025-07-11 09:20:23 +08:00
<Setter Property="BorderThickness" Value="1" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Calendar}">
2026-01-02 17:30:30 +08:00
<StackPanel HorizontalAlignment="Center" x:Name="PART_Root">
2025-07-31 20:12:01 +08:00
<CalendarItem
Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}"
2026-01-02 17:30:30 +08:00
Style="{TemplateBinding CalendarItemStyle}"
x:Name="PART_CalendarItem" />
2025-07-11 09:20:23 +08:00
</StackPanel>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
2025-10-10 11:19:58 +08:00
<Style BasedOn="{StaticResource DefaultCalendarStyle}" TargetType="{x:Type Calendar}" />
2025-07-31 20:12:01 +08:00
<Style
2025-10-10 11:19:58 +08:00
BasedOn="{StaticResource DefaultCalendarStyle}"
2026-01-02 17:30:30 +08:00
TargetType="{x:Type Calendar}"
x:Key="DefaultCalendarPickerStyle">
2025-07-31 20:12:01 +08:00
<Setter Property="Margin" Value="8" />
2025-07-11 09:20:23 +08:00
</Style>
</ResourceDictionary>