Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add: contextMenu items for Run.Plugin.VSCodeWorkspaces #36517

Open
wants to merge 6 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,21 @@
using System.ComponentModel;
using System.Diagnostics;
using System.Linq;
using System.Windows;
using System.Windows.Input;

using Community.PowerToys.Run.Plugin.VSCodeWorkspaces.Properties;
using Community.PowerToys.Run.Plugin.VSCodeWorkspaces.RemoteMachinesHelper;
using Community.PowerToys.Run.Plugin.VSCodeWorkspaces.VSCodeHelper;
using Community.PowerToys.Run.Plugin.VSCodeWorkspaces.WorkspacesHelper;

using Wox.Infrastructure;
using Wox.Plugin;
using Wox.Plugin.Logger;

namespace Community.PowerToys.Run.Plugin.VSCodeWorkspaces
{
public class Main : IPlugin, IPluginI18n
public class Main : IPlugin, IPluginI18n, IContextMenu
{
private PluginInitContext _context;

Expand Down Expand Up @@ -76,11 +81,9 @@ public List<Result> Query(Query query)

hide = true;
}
catch (Win32Exception)
catch (Win32Exception ex)
{
var name = $"Plugin: {_context.CurrentPluginMetadata.Name}";
var msg = "Can't Open this file";
_context.API.ShowMsg(name, msg, string.Empty);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why removing existing functionality? Please add message box again.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

image

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Technically this works. But logging and showing all message are different things. Either you rename the method or you split the methods.

HandleError("Can't Open this file", ex, showMsg: true);
hide = false;
}

Expand Down Expand Up @@ -124,11 +127,9 @@ public List<Result> Query(Query query)

hide = true;
}
catch (Win32Exception)
catch (Win32Exception ex)
{
var name = $"Plugin: {_context.CurrentPluginMetadata.Name}";
var msg = "Can't Open this file";
_context.API.ShowMsg(name, msg, string.Empty);
HandleError("Can't Open this file", ex, showMsg: true);
hide = false;
}

Expand All @@ -142,23 +143,23 @@ public List<Result> Query(Query query)
results = results.Where(a => a.Title.Contains(query.Search, StringComparison.InvariantCultureIgnoreCase)).ToList();

results.ForEach(x =>
{
if (x.Score == 0)
{
x.Score = 100;
}
{
if (x.Score == 0)
{
x.Score = 100;
}

// intersect the title with the query
var intersection = Convert.ToInt32(x.Title.ToLowerInvariant().Intersect(query.Search.ToLowerInvariant()).Count() * query.Search.Length);
var differenceWithQuery = Convert.ToInt32((x.Title.Length - intersection) * query.Search.Length * 0.7);
x.Score = x.Score - differenceWithQuery + intersection;
// intersect the title with the query
var intersection = Convert.ToInt32(x.Title.ToLowerInvariant().Intersect(query.Search.ToLowerInvariant()).Count() * query.Search.Length);
var differenceWithQuery = Convert.ToInt32((x.Title.Length - intersection) * query.Search.Length * 0.7);
x.Score = x.Score - differenceWithQuery + intersection;

// if is a remote machine give it 12 extra points
if (x.ContextData is VSCodeRemoteMachine)
{
x.Score = Convert.ToInt32(x.Score + (intersection * 2));
}
});
// if is a remote machine give it 12 extra points
if (x.ContextData is VSCodeRemoteMachine)
{
x.Score = Convert.ToInt32(x.Score + (intersection * 2));
}
});

results = results.OrderByDescending(x => x.Score).ToList();
if (query.Search == string.Empty || query.Search.Replace(" ", string.Empty) == string.Empty)
Expand All @@ -174,6 +175,108 @@ public void Init(PluginInitContext context)
_context = context;
}

public List<ContextMenuResult> LoadContextMenus(Result selectedResult)
{
if (selectedResult?.ContextData is not VSCodeWorkspace workspace)
{
return new List<ContextMenuResult>();
}

string realPath = SystemPath.RealPath(workspace.RelativePath);

return new List<ContextMenuResult>
{
new ContextMenuResult
{
PluginName = Name,
Title = $"{Resources.CopyPath} (Ctrl+C)",
Glyph = "\xE8C8", // Copy
FontFamily = "Segoe Fluent Icons,Segoe MDL2 Assets",
AcceleratorKey = Key.C,
AcceleratorModifiers = ModifierKeys.Control,
Action = context => CopyToClipboard(realPath),
},
new ContextMenuResult
{
PluginName = Name,
Title = $"{Resources.OpenInExplorer} (Ctrl+Shift+F)",
Glyph = "\xEC50", // File Explorer
FontFamily = "Segoe Fluent Icons,Segoe MDL2 Assets",
AcceleratorKey = Key.F,
AcceleratorModifiers = ModifierKeys.Control | ModifierKeys.Shift,
Action = context => OpenInExplorer(realPath),
},
new ContextMenuResult
{
PluginName = Name,
Title = $"{Resources.OpenInConsole} (Ctrl+Shift+C)",
Glyph = "\xE756", // Command Prompt
FontFamily = "Segoe Fluent Icons,Segoe MDL2 Assets",
AcceleratorKey = Key.C,
AcceleratorModifiers = ModifierKeys.Control | ModifierKeys.Shift,
Action = context => OpenInConsole(realPath),
},
};
}

private bool CopyToClipboard(string path)
{
try
{
Clipboard.SetText(path);
return true;
}
catch (Exception ex)
{
HandleError("Can't copy to clipboard", ex, showMsg: true);
return false;
}
}

private bool OpenInConsole(string path)
{
try
{
Helper.OpenInConsole(path);
return true;
}
catch (Exception ex)
{
HandleError($"Unable to open the specified path in the console: {path}", ex, showMsg: true);
return false;
}
}

private bool OpenInExplorer(string path)
{
if (!Helper.OpenInShell("explorer.exe", $"\"{path}\""))
{
HandleError($"Failed to open folder in Explorer at path: {path}", showMsg: true);
return false;
}

return true;
}

private void HandleError(string msg, Exception exception = null, bool showMsg = false)
{
if (exception != null)
{
Log.Exception(msg, exception, exception.GetType());
}
else
{
Log.Error(msg, typeof(VSCodeWorkspaces.Main));
}

if (showMsg)
{
_context.API.ShowMsg(
$"Plugin: {_context.CurrentPluginMetadata.Name}",
msg);
}
}

public string GetTranslatedPluginTitle()
{
return Resources.PluginTitle;
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -151,4 +151,13 @@
<value>Project Folder</value>
<comment>It refers to the Visual Studio Code Project Folders</comment>
</data>
<data name="CopyPath" xml:space="preserve">
<value>Copy path</value>
</data>
<data name="OpenInConsole" xml:space="preserve">
<value>Open in console</value>
</data>
<data name="OpenInExplorer" xml:space="preserve">
<value>Open in Explorer</value>
</data>
</root>
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"ActionKeyword": "{",
"Name": "VS Code Workspaces",
"Author": "ricardosantos9521",
"Version": "1.1.0",
"Version": "1.2.0",
"Language": "csharp",
"Website": "https://github.com/ricardosantos9521/PowerToys/",
"ExecuteFileName": "Community.PowerToys.Run.Plugin.VSCodeWorkspaces.dll",
Expand Down
Loading