Files
Walleby/Wallet.Avalonia/ItemHeaderView.axaml
T
2024-07-13 11:04:03 +01:00

155 lines
8.3 KiB
XML

<UserControl
x:Class="Wallet.Avalonia.ItemHeaderView"
xmlns="https://github.com/avaloniaui"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:ui="using:FluentAvalonia.UI.Controls"
xmlns:vm="using:Wallet"
Margin="0,0,0,-18"
x:DataType="vm:ItemHeaderViewModel">
<UserControl.Resources>
<ResourceDictionary>
<ResourceDictionary.ThemeDictionaries>
<ResourceDictionary x:Key="Light">
<StaticResource x:Key="TextControlBorderBrush" ResourceKey="ControlStrokeColorDefaultBrush" />
<StaticResource x:Key="TextControlBorderBrushPointerOver" ResourceKey="ControlStrokeColorDefaultBrush" />
</ResourceDictionary>
<ResourceDictionary x:Key="Dark">
<StaticResource x:Key="TextControlBorderBrush" ResourceKey="SubtleFillColorTransparentBrush" />
<StaticResource x:Key="TextControlBorderBrushPointerOver" ResourceKey="SubtleFillColorTransparentBrush" />
</ResourceDictionary>
</ResourceDictionary.ThemeDictionaries>
</ResourceDictionary>
<x:Double x:Key="PersonPictureSize">144</x:Double>
<x:Double x:Key="ButtonSize">36</x:Double>
<x:Double x:Key="TextBoxMaxWidth">360</x:Double>
<x:Double x:Key="TextBoxMinWidth">264</x:Double>
<Thickness x:Key="ButtonMargin">0,0,6,6</Thickness>
<CornerRadius x:Key="ButtonCornerRadius">18</CornerRadius>
</UserControl.Resources>
<StackPanel Grid.Column="1" Spacing="12">
<Grid HorizontalAlignment="Center">
<PersonPicture
Width="{StaticResource PersonPictureSize}"
Height="{StaticResource PersonPictureSize}"
DisplayName="{Binding Value}"
ProfilePicture="{Binding ImageDescriptor.Image}" />
<DropDownButton
Width="{StaticResource ButtonSize}"
Height="{StaticResource ButtonSize}"
Margin="{StaticResource ButtonMargin}"
Padding="0"
HorizontalAlignment="Right"
VerticalAlignment="Bottom"
HorizontalContentAlignment="Center"
VerticalContentAlignment="Center"
CornerRadius="{StaticResource ButtonCornerRadius}">
<DropDownButton.Styles>
<Style Selector="DropDownButton.Write">
<Setter Property="IsVisible" Value="True" />
</Style>
<Style Selector="DropDownButton.Read">
<Setter Property="IsVisible" Value="False" />
</Style>
<Style Selector="DropDownButton /template/ ui|FontIcon#DropDownGlyph">
<Setter Property="IsVisible" Value="False" />
</Style>
</DropDownButton.Styles>
<Interaction.Behaviors>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.Read}">
<AddClassAction ClassName="Read" RemoveIfExists="True" />
<RemoveClassAction ClassName="Write" />
</DataTriggerBehavior>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.New}">
<AddClassAction ClassName="Write" RemoveIfExists="True" />
<RemoveClassAction ClassName="Read" />
</DataTriggerBehavior>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.Write}">
<AddClassAction ClassName="Write" RemoveIfExists="True" />
<RemoveClassAction ClassName="Read" />
</DataTriggerBehavior>
</Interaction.Behaviors>
<DropDownButton.Flyout>
<MenuFlyout>
<MenuItem Command="{Binding ImportCommand}" Header="Import image" />
<MenuItem
Command="{Binding RemoveCommand}"
Header="Remove image"
IsEnabled="{Binding ImageDescriptor, Converter={x:Static ObjectConverters.IsNotNull}}" />
</MenuFlyout>
</DropDownButton.Flyout>
<TextBlock
Margin="0,3,0,0"
VerticalAlignment="Center"
FontFamily="{DynamicResource FluentThemeFontFamily}"
FontSize="18"
Text="&#xE36A;" />
</DropDownButton>
</Grid>
<StackPanel>
<TextBox
MaxWidth="{StaticResource TextBoxMaxWidth}"
Text="{Binding Value}"
TextAlignment="Center"
Watermark="Enter name">
<TextBox.Styles>
<Style Selector="TextBox.Write">
<Setter Property="MinWidth" Value="{StaticResource TextBoxMinWidth}" />
</Style>
<Style Selector="TextBox.Read">
<Setter Property="MinWidth" Value="0" />
<Setter Property="IsReadOnly" Value="True" />
<Setter Property="BorderBrush" Value="Transparent" />
<Setter Property="Background" Value="Transparent" />
<Setter Property="Foreground">
<Setter.Value>
<SolidColorBrush Opacity="0.7" Color="{DynamicResource TextFillColorPrimary}" />
</Setter.Value>
</Setter>
<Style Selector="^:pointerover">
<Setter Property="Foreground">
<Setter.Value>
<SolidColorBrush Opacity="0.7" Color="{DynamicResource TextFillColorPrimary}" />
</Setter.Value>
</Setter>
<Style Selector="^ /template/ Border#PART_BorderElement">
<Setter Property="BorderBrush" Value="Transparent" />
<Setter Property="Background" Value="Transparent" />
</Style>
</Style>
<Style Selector="^:focus">
<Setter Property="Foreground">
<Setter.Value>
<SolidColorBrush Opacity="0.7" Color="{DynamicResource TextFillColorPrimary}" />
</Setter.Value>
</Setter>
<Style Selector="^ /template/ Border#PART_BorderElement">
<Setter Property="Background" Value="Transparent" />
<Setter Property="BorderBrush" Value="Transparent" />
</Style>
</Style>
</Style>
</TextBox.Styles>
<Interaction.Behaviors>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.Read}">
<AddClassAction ClassName="Read" RemoveIfExists="True" />
<RemoveClassAction ClassName="Write" />
</DataTriggerBehavior>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.New}">
<AddClassAction ClassName="Write" RemoveIfExists="True" />
<RemoveClassAction ClassName="Read" />
</DataTriggerBehavior>
<DataTriggerBehavior Binding="{Binding State}" Value="{x:Static vm:ItemState.Write}">
<AddClassAction ClassName="Write" RemoveIfExists="True" />
<RemoveClassAction ClassName="Read" />
</DataTriggerBehavior>
</Interaction.Behaviors>
</TextBox>
<TextBlock
Margin="0,4,0,0"
HorizontalAlignment="Center"
Foreground="{DynamicResource SystemFillColorCriticalBrush}"
Text="{ReflectionBinding Validation.Errors[Value]}" />
</StackPanel>
</StackPanel>
</UserControl>