mirror of
https://github.com/microsoft/PowerToys.git
synced 2024-12-21 23:37:54 +08:00
d881fc2fe0
[Settings v2] UX tweaks
221 lines
10 KiB
XML
221 lines
10 KiB
XML
<Page
|
|
x:Class="Microsoft.PowerToys.Settings.UI.Views.KeyboardManagerPage"
|
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
xmlns:local="using:Microsoft.PowerToys.Settings.UI.Views"
|
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
|
xmlns:viewModel="using:Microsoft.PowerToys.Settings.UI.ViewModels"
|
|
xmlns:extensions="using:Microsoft.Toolkit.Uwp.UI.Extensions"
|
|
xmlns:Lib="using:Microsoft.PowerToys.Settings.UI.Lib"
|
|
mc:Ignorable="d"
|
|
Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
|
|
|
|
<Page.Resources>
|
|
<viewModel:KeyboardManagerViewModel x:Key="eventViewModel"/>
|
|
<local:VisibleIfNotEmpty x:Key="visibleIfNotEmptyConverter" />
|
|
<DataTemplate x:Name="KeysListViewTemplate" x:DataType="Lib:KeysDataModel">
|
|
<StackPanel
|
|
Orientation="Horizontal"
|
|
Height="56">
|
|
<ItemsControl
|
|
ItemsSource="{x:Bind GetOriginalKeys()}">
|
|
<ItemsControl.ItemsPanel>
|
|
<ItemsPanelTemplate>
|
|
<StackPanel Orientation="Horizontal"/>
|
|
</ItemsPanelTemplate>
|
|
</ItemsControl.ItemsPanel>
|
|
<ItemsControl.ItemTemplate>
|
|
<DataTemplate>
|
|
<Border
|
|
Background="{ThemeResource SystemBaseLowColor}"
|
|
CornerRadius="4"
|
|
Padding="14,0,14,0"
|
|
Margin="5,0,5,0"
|
|
Height="36"
|
|
VerticalAlignment="Center"
|
|
HorizontalAlignment="Left">
|
|
<TextBlock
|
|
FontWeight="SemiBold"
|
|
VerticalAlignment="Center"
|
|
TextAlignment="Center"
|
|
FontSize="12"
|
|
Text="{Binding}" />
|
|
</Border>
|
|
</DataTemplate>
|
|
</ItemsControl.ItemTemplate>
|
|
</ItemsControl>
|
|
<FontIcon Glyph=""
|
|
Grid.Column="1"
|
|
FontSize="14"
|
|
VerticalAlignment="Center"
|
|
Margin="5,0,5,0"/>
|
|
<ItemsControl
|
|
ItemsSource="{x:Bind GetNewRemapKeys()}"
|
|
Grid.Column="2">
|
|
<ItemsControl.ItemsPanel>
|
|
<ItemsPanelTemplate>
|
|
<StackPanel Orientation="Horizontal"/>
|
|
</ItemsPanelTemplate>
|
|
</ItemsControl.ItemsPanel>
|
|
<ItemsControl.ItemTemplate>
|
|
<DataTemplate>
|
|
<Border
|
|
Background="{ThemeResource SystemAccentColor}"
|
|
CornerRadius="4"
|
|
Padding="14,0,14,0"
|
|
Margin="5,0,5,0"
|
|
Height="36"
|
|
VerticalAlignment="Center"
|
|
HorizontalAlignment="Left">
|
|
<TextBlock
|
|
FontWeight="SemiBold"
|
|
VerticalAlignment="Center"
|
|
TextAlignment="Center"
|
|
Foreground="White"
|
|
FontSize="12"
|
|
Text="{Binding}" />
|
|
</Border>
|
|
</DataTemplate>
|
|
</ItemsControl.ItemTemplate>
|
|
</ItemsControl>
|
|
</StackPanel>
|
|
</DataTemplate>
|
|
</Page.Resources>
|
|
|
|
<Grid ColumnSpacing="{StaticResource DefaultColumnSpacing}" RowSpacing="{StaticResource DefaultRowSpacing}">
|
|
<VisualStateManager.VisualStateGroups>
|
|
<VisualStateGroup x:Name="LayoutVisualStates">
|
|
<VisualState x:Name="WideLayout">
|
|
<VisualState.StateTriggers>
|
|
<AdaptiveTrigger MinWindowWidth="{StaticResource WideLayoutMinWidth}" />
|
|
</VisualState.StateTriggers>
|
|
<VisualState.Setters>
|
|
<Setter Target="SidePanel.(Grid.Column)" Value="1" />
|
|
<Setter Target="SidePanel.(Grid.Row)" Value="0" />
|
|
</VisualState.Setters>
|
|
</VisualState>
|
|
<VisualState x:Name="SmallLayout">
|
|
<VisualState.StateTriggers>
|
|
<AdaptiveTrigger MinWindowWidth="{StaticResource SmallLayoutMinWidth}" />
|
|
</VisualState.StateTriggers>
|
|
<VisualState.Setters>
|
|
<Setter Target="SidePanel.(Grid.Column)" Value="0" />
|
|
<Setter Target="SidePanel.(Grid.Row)" Value="1" />
|
|
</VisualState.Setters>
|
|
</VisualState>
|
|
</VisualStateGroup>
|
|
</VisualStateManager.VisualStateGroups>
|
|
<Grid.ColumnDefinitions>
|
|
<ColumnDefinition Width="*"/>
|
|
<ColumnDefinition Width="Auto"/>
|
|
</Grid.ColumnDefinitions>
|
|
<Grid.RowDefinitions>
|
|
<RowDefinition Height="Auto"/>
|
|
<RowDefinition Height="Auto" />
|
|
</Grid.RowDefinitions>
|
|
|
|
<StackPanel Orientation="Vertical">
|
|
<TextBlock x:Uid="KeyboardManager_Description"
|
|
TextWrapping="Wrap"/>
|
|
|
|
<ToggleSwitch x:Uid="KeyboardManager_EnableToggle"
|
|
IsOn="{x:Bind Path=ViewModel.Enabled, Mode=TwoWay}"
|
|
Margin="{StaticResource MediumTopMargin}" />
|
|
|
|
<!--<TextBlock x:Uid="KeyboardManager_ConfigHeader"
|
|
Style="{StaticResource SettingsGroupTitleStyle}"/>
|
|
|
|
<TextBlock x:Uid="KeyboardManager_ProfileDescription"
|
|
Margin="{StaticResource SmallTopMargin}"/>
|
|
|
|
<ComboBox SelectedIndex="1" MinWidth="160"
|
|
Margin="{StaticResource SmallTopMargin}">
|
|
<ComboBoxItem Content="Config-1"/>
|
|
<ComboBoxItem Content="Config-2"/>
|
|
<ComboBoxItem Content="Config-3"/>
|
|
</ComboBox>-->
|
|
|
|
<TextBlock x:Uid="KeyboardManager_RemapKeyboardHeader"
|
|
Style="{StaticResource SettingsGroupTitleStyle}"/>
|
|
|
|
<TextBlock Text="Click below to remap a single key to another key"
|
|
Margin="{StaticResource SmallTopMargin}"
|
|
TextWrapping="Wrap"/>
|
|
|
|
<Button x:Uid="KeyboardManager_RemapKeyboardButton"
|
|
Margin="{StaticResource SmallTopMargin}"
|
|
Style="{StaticResource AccentButtonStyle}"
|
|
Command="{Binding Path=RemapKeyboardCommand}"
|
|
IsEnabled="{x:Bind Path=ViewModel.Enabled, Mode=OneWay}"/>
|
|
|
|
<ListView x:Name="RemapKeysList"
|
|
extensions:ListViewExtensions.AlternateColor="{ThemeResource SystemControlBackgroundListLowBrush}"
|
|
ItemsSource="{x:Bind Path=ViewModel.RemapKeys, Mode=OneWay}"
|
|
ItemTemplate="{StaticResource KeysListViewTemplate}"
|
|
BorderBrush="{ThemeResource SystemControlForegroundBaseMediumLowBrush}"
|
|
BorderThickness="1"
|
|
CornerRadius="4"
|
|
MinWidth="350"
|
|
MaxHeight="200"
|
|
Margin="{StaticResource MediumTopBottomMargin}"
|
|
HorizontalAlignment="Left"
|
|
SelectionMode="None"
|
|
IsSwipeEnabled="False"
|
|
Visibility="{x:Bind Path=ViewModel.RemapKeys, Mode=OneWay, Converter={StaticResource visibleIfNotEmptyConverter}}"
|
|
/>
|
|
|
|
|
|
<TextBlock x:Uid="KeyboardManager_RemapShortcutsHeader"
|
|
Style="{StaticResource SettingsGroupTitleStyle}"/>
|
|
|
|
<TextBlock Text="Click below to remap a shortcut (hotkey) to another shortcut"
|
|
TextWrapping="Wrap" Margin="{StaticResource SmallTopMargin}"/>
|
|
|
|
<Button x:Uid="KeyboardManager_RemapShortcutsButton"
|
|
Margin="{StaticResource SmallTopMargin}"
|
|
Style="{StaticResource AccentButtonStyle}"
|
|
Command="{Binding Path=EditShortcutCommand}"
|
|
IsEnabled="{x:Bind Path=ViewModel.Enabled, Mode=OneWay}"
|
|
/>
|
|
|
|
<ListView x:Name="RemapShortcutsList"
|
|
extensions:ListViewExtensions.AlternateColor="{ThemeResource SystemControlBackgroundListLowBrush}"
|
|
ItemsSource="{x:Bind Path=ViewModel.RemapShortcuts, Mode=OneWay}"
|
|
ItemTemplate="{StaticResource KeysListViewTemplate}"
|
|
BorderBrush="{ThemeResource SystemControlForegroundBaseMediumLowBrush}"
|
|
BorderThickness="1"
|
|
CornerRadius="4"
|
|
MinWidth="350"
|
|
MaxHeight="200"
|
|
Margin="{StaticResource MediumTopBottomMargin}"
|
|
HorizontalAlignment="Left"
|
|
SelectionMode="None"
|
|
IsSwipeEnabled="False"
|
|
Visibility="{x:Bind Path=ViewModel.RemapShortcuts, Mode=OneWay, Converter={StaticResource visibleIfNotEmptyConverter}}"
|
|
/>
|
|
</StackPanel>
|
|
|
|
<StackPanel
|
|
x:Name="SidePanel"
|
|
Orientation="Vertical"
|
|
HorizontalAlignment="Left"
|
|
Width="{StaticResource SidePanelWidth}"
|
|
Grid.Column="1">
|
|
|
|
<TextBlock
|
|
Text="About this feature"
|
|
Style="{StaticResource SettingsGroupTitleStyle}"
|
|
Margin="{StaticResource XSmallBottomMargin}"/>
|
|
|
|
<HyperlinkButton>
|
|
<TextBlock x:Uid="Module_overview" />
|
|
</HyperlinkButton>
|
|
|
|
<HyperlinkButton NavigateUri="https://github.com/microsoft/PowerToys/issues">
|
|
<TextBlock x:Uid="Give_Feedback" />
|
|
</HyperlinkButton>
|
|
</StackPanel>
|
|
</Grid>
|
|
</Page>
|