mirror of
https://github.com/microsoft/PowerToys.git
synced 2026-04-03 17:56:44 +02:00
_targets #45572_ This change allows our contact menu factory to actually create and add additional context menu commands for pinning commands to the top level. Now for any command provider built with the latest SDK that return subcommands with an ID, we will add additional context menu commands that allows you to pin that command to the top level. <img width="540" height="181" alt="image" src="https://github.com/user-attachments/assets/6c2cfe3c-4143-44d1-9308-bfc71db4c842" /> <img width="729" height="317" alt="image" src="https://github.com/user-attachments/assets/4ff75c9f-1f35-4c1e-a03e-6fab5cbab423" /> related to https://github.com/microsoft/PowerToys/issues/45191 related to https://github.com/microsoft/PowerToys/issues/45201 This PR notably does not remove pinning from the apps extension. I thought that made sense to do as a follow-up PR for the sake of reviewability. --- description from #45676 which was merged into this Removes the code that the apps provider was using to support pinning apps to the top level list of commands. Now the all apps provider just uses the global support for pinning commands to the top level. This does have the side effect of removing the separation of pinned apps from unpinned apps on the All Apps page. However, we all pretty much agree that wasn't a particularly widely used feature, and it's safe to remove. With this, we can finally call this issue done 🎉 closes https://github.com/microsoft/PowerToys/issues/45191
54 lines
1.6 KiB
C#
54 lines
1.6 KiB
C#
// Copyright (c) Microsoft Corporation
|
|
// The Microsoft Corporation licenses this file to you under the MIT license.
|
|
// See the LICENSE file in the project root for more information.
|
|
|
|
using System.Diagnostics.CodeAnalysis;
|
|
using Microsoft.CmdPal.UI.ViewModels.Models;
|
|
using Microsoft.CommandPalette.Extensions;
|
|
|
|
namespace Microsoft.CmdPal.UI.ViewModels;
|
|
|
|
[DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.All)]
|
|
public partial class CommandContextItemViewModel : CommandItemViewModel, IContextItemViewModel
|
|
{
|
|
private readonly KeyChord nullKeyChord = new(0, 0, 0);
|
|
|
|
public new ExtensionObject<ICommandContextItem> Model { get; }
|
|
|
|
public bool IsCritical { get; private set; }
|
|
|
|
public KeyChord? RequestedShortcut { get; private set; }
|
|
|
|
public bool HasRequestedShortcut => RequestedShortcut is not null && (RequestedShortcut.Value != nullKeyChord);
|
|
|
|
public CommandContextItemViewModel(ICommandContextItem contextItem, WeakReference<IPageContext> context)
|
|
: base(new(contextItem), context, contextMenuFactory: null)
|
|
{
|
|
Model = new(contextItem);
|
|
IsContextMenuItem = true;
|
|
}
|
|
|
|
public override void InitializeProperties()
|
|
{
|
|
if (IsInitialized)
|
|
{
|
|
return;
|
|
}
|
|
|
|
base.InitializeProperties();
|
|
|
|
var contextItem = Model.Unsafe;
|
|
if (contextItem is null)
|
|
{
|
|
return; // throw?
|
|
}
|
|
|
|
IsCritical = contextItem.IsCritical;
|
|
|
|
RequestedShortcut = new(
|
|
contextItem.RequestedShortcut.Modifiers,
|
|
contextItem.RequestedShortcut.Vkey,
|
|
contextItem.RequestedShortcut.ScanCode);
|
|
}
|
|
}
|