Fixing modiufiers.
This commit is contained in:
@@ -0,0 +1,58 @@
|
||||
using Windows.System;
|
||||
using Wino.Core.Domain.Enums;
|
||||
|
||||
namespace Wino.Mail.WinUI.Extensions;
|
||||
|
||||
/// <summary>
|
||||
/// Extension methods for converting between Windows VirtualKeyModifiers and Domain ModifierKeys.
|
||||
/// </summary>
|
||||
public static class ModifierKeysExtensions
|
||||
{
|
||||
/// <summary>
|
||||
/// Converts Windows VirtualKeyModifiers to Domain ModifierKeys.
|
||||
/// </summary>
|
||||
/// <param name="virtualKeyModifiers">The Windows VirtualKeyModifiers to convert.</param>
|
||||
/// <returns>The equivalent Domain ModifierKeys.</returns>
|
||||
public static ModifierKeys ToDomainModifierKeys(this VirtualKeyModifiers virtualKeyModifiers)
|
||||
{
|
||||
var modifierKeys = ModifierKeys.None;
|
||||
|
||||
if (virtualKeyModifiers.HasFlag(VirtualKeyModifiers.Control))
|
||||
modifierKeys |= ModifierKeys.Control;
|
||||
|
||||
if (virtualKeyModifiers.HasFlag(VirtualKeyModifiers.Menu)) // Alt key
|
||||
modifierKeys |= ModifierKeys.Alt;
|
||||
|
||||
if (virtualKeyModifiers.HasFlag(VirtualKeyModifiers.Shift))
|
||||
modifierKeys |= ModifierKeys.Shift;
|
||||
|
||||
if (virtualKeyModifiers.HasFlag(VirtualKeyModifiers.Windows))
|
||||
modifierKeys |= ModifierKeys.Windows;
|
||||
|
||||
return modifierKeys;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Converts Domain ModifierKeys to Windows VirtualKeyModifiers.
|
||||
/// </summary>
|
||||
/// <param name="modifierKeys">The Domain ModifierKeys to convert.</param>
|
||||
/// <returns>The equivalent Windows VirtualKeyModifiers.</returns>
|
||||
public static VirtualKeyModifiers ToVirtualKeyModifiers(this ModifierKeys modifierKeys)
|
||||
{
|
||||
var virtualKeyModifiers = VirtualKeyModifiers.None;
|
||||
|
||||
if (modifierKeys.HasFlag(ModifierKeys.Control))
|
||||
virtualKeyModifiers |= VirtualKeyModifiers.Control;
|
||||
|
||||
if (modifierKeys.HasFlag(ModifierKeys.Alt))
|
||||
virtualKeyModifiers |= VirtualKeyModifiers.Menu; // Alt key
|
||||
|
||||
if (modifierKeys.HasFlag(ModifierKeys.Shift))
|
||||
virtualKeyModifiers |= VirtualKeyModifiers.Shift;
|
||||
|
||||
if (modifierKeys.HasFlag(ModifierKeys.Windows))
|
||||
virtualKeyModifiers |= VirtualKeyModifiers.Windows;
|
||||
|
||||
return virtualKeyModifiers;
|
||||
}
|
||||
}
|
||||
@@ -24,6 +24,7 @@ using Wino.Core.Domain.Models.Navigation;
|
||||
using Wino.Mail.ViewModels.Data;
|
||||
using Wino.Mail.ViewModels.Messages;
|
||||
using Wino.Mail.WinUI.Controls.ListView;
|
||||
using Wino.Mail.WinUI.Extensions;
|
||||
using Wino.MenuFlyouts.Context;
|
||||
using Wino.Messaging.Client.Mails;
|
||||
using Wino.Views.Abstract;
|
||||
@@ -40,7 +41,7 @@ public sealed partial class MailListPage : MailListPageAbstract,
|
||||
|
||||
private IStatePersistanceService StatePersistenceService { get; } = Core.WinUI.WinoApplication.Current.Services.GetService<IStatePersistanceService>() ?? throw new Exception($"Can't resolve {nameof(KeyPressService)}");
|
||||
private IKeyPressService KeyPressService { get; } = Core.WinUI.WinoApplication.Current.Services.GetService<IKeyPressService>() ?? throw new Exception($"Can't resolve {nameof(KeyPressService)}");
|
||||
|
||||
private IKeyboardShortcutService KeyboardShortcutService { get; } = Core.WinUI.WinoApplication.Current.Services.GetService<IKeyboardShortcutService>() ?? throw new Exception($"Can't resolve {nameof(IKeyboardShortcutService)}");
|
||||
public MailListPage()
|
||||
{
|
||||
InitializeComponent();
|
||||
@@ -540,6 +541,22 @@ public sealed partial class MailListPage : MailListPageAbstract,
|
||||
{
|
||||
await ViewModel.MailCollection.ToggleSelectAllAsync();
|
||||
}
|
||||
else
|
||||
{
|
||||
// Check keyboard shortcuts from service.
|
||||
ModifierKeys modifiers = args.Modifiers.ToDomainModifierKeys();
|
||||
|
||||
var operation = await KeyboardShortcutService.GetMailOperationForKeyAsync(args.Key.ToString(), modifiers);
|
||||
|
||||
if (operation != null)
|
||||
{
|
||||
ViewModel.ExecuteMailOperationCommand.Execute(operation);
|
||||
}
|
||||
else
|
||||
{
|
||||
args.Handled = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private async void WinoListViewItemClicked(object sender, ItemClickEventArgs e)
|
||||
|
||||
Reference in New Issue
Block a user