mirror of
https://github.com/microsoft/PowerToys.git
synced 2025-01-22 17:03:06 +08:00
Refactoring ContextMenu
1. Remove ItemDropEvent 2. Remove ShowContextMenus from API 3. Fix context menu item can't be opened ( #535 ), bug introduced from PR #494 (commit 45dbb50) 4. Move open result command and load context menu command back to MainViewModel 5. unify load context menu logic 6. other performance enhancement and potential bug fixed
This commit is contained in:
parent
fbc6f78cb5
commit
5ac0837be3
@ -22,7 +22,6 @@ namespace Wox.Plugin.Folder
|
|||||||
{
|
{
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.context.API.BackKeyDownEvent += ApiBackKeyDownEvent;
|
this.context.API.BackKeyDownEvent += ApiBackKeyDownEvent;
|
||||||
this.context.API.ResultItemDropEvent += ResultDropEvent;
|
|
||||||
InitialDriverList();
|
InitialDriverList();
|
||||||
if (FolderStorage.Instance.FolderLinks == null)
|
if (FolderStorage.Instance.FolderLinks == null)
|
||||||
{
|
{
|
||||||
@ -31,38 +30,6 @@ namespace Wox.Plugin.Folder
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResultDropEvent(Result result, IDataObject dropObject, DragEventArgs e)
|
|
||||||
{
|
|
||||||
if (dropObject.GetDataPresent(DataFormats.FileDrop))
|
|
||||||
{
|
|
||||||
HanldeFilesDrop(result, dropObject);
|
|
||||||
}
|
|
||||||
e.Handled = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void HanldeFilesDrop(Result targetResult, IDataObject dropObject)
|
|
||||||
{
|
|
||||||
List<string> files = ((string[])dropObject.GetData(DataFormats.FileDrop, false)).ToList();
|
|
||||||
context.API.ShowContextMenu(context.CurrentPluginMetadata, GetContextMenusForFileDrop(targetResult, files));
|
|
||||||
}
|
|
||||||
|
|
||||||
private static List<Result> GetContextMenusForFileDrop(Result targetResult, List<string> files)
|
|
||||||
{
|
|
||||||
List<Result> contextMenus = new List<Result>();
|
|
||||||
string folderPath = ((FolderLink) targetResult.ContextData).Path;
|
|
||||||
contextMenus.Add(new Result
|
|
||||||
{
|
|
||||||
Title = "Copy to this folder",
|
|
||||||
IcoPath = "Images/copy.png",
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
MessageBox.Show("Copy");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return contextMenus;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ApiBackKeyDownEvent(WoxKeyDownEventArgs e)
|
private void ApiBackKeyDownEvent(WoxKeyDownEventArgs e)
|
||||||
{
|
{
|
||||||
string query = e.Query;
|
string query = e.Query;
|
||||||
|
@ -61,7 +61,6 @@ namespace Wox.Plugin.Program
|
|||||||
public void Init(PluginInitContext context)
|
public void Init(PluginInitContext context)
|
||||||
{
|
{
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.context.API.ResultItemDropEvent += ResultDropEvent;
|
|
||||||
Stopwatch.Debug("Preload programs", () =>
|
Stopwatch.Debug("Preload programs", () =>
|
||||||
{
|
{
|
||||||
programs = ProgramCacheStorage.Instance.Programs;
|
programs = ProgramCacheStorage.Instance.Programs;
|
||||||
@ -70,12 +69,6 @@ namespace Wox.Plugin.Program
|
|||||||
Stopwatch.Debug("Program Index", IndexPrograms);
|
Stopwatch.Debug("Program Index", IndexPrograms);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResultDropEvent(Result result, IDataObject dropObject, DragEventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
e.Handled = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void IndexPrograms()
|
public static void IndexPrograms()
|
||||||
{
|
{
|
||||||
lock (lockObject)
|
lock (lockObject)
|
||||||
|
@ -229,20 +229,33 @@ namespace Wox.Core.Plugin
|
|||||||
public static List<Result> GetContextMenusForPlugin(Result result)
|
public static List<Result> GetContextMenusForPlugin(Result result)
|
||||||
{
|
{
|
||||||
var pluginPair = _contextMenuPlugins.FirstOrDefault(o => o.Metadata.ID == result.PluginID);
|
var pluginPair = _contextMenuPlugins.FirstOrDefault(o => o.Metadata.ID == result.PluginID);
|
||||||
var plugin = (IContextMenu)pluginPair?.Plugin;
|
if (pluginPair != null)
|
||||||
if (plugin != null)
|
|
||||||
{
|
{
|
||||||
|
var metadata = pluginPair.Metadata;
|
||||||
|
var plugin = (IContextMenu)pluginPair?.Plugin;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
return plugin.LoadContextMenus(result);
|
var results = plugin.LoadContextMenus(result);
|
||||||
|
foreach (var r in results)
|
||||||
|
{
|
||||||
|
r.PluginDirectory = metadata.PluginDirectory;
|
||||||
|
r.PluginID = metadata.ID;
|
||||||
|
r.OriginQuery = result.OriginQuery;
|
||||||
|
}
|
||||||
|
return results;
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(new WoxPluginException(pluginPair.Metadata.Name, $"Couldn't load plugin context menus", e));
|
Log.Error(new WoxPluginException(metadata.Name, "Couldn't load plugin context menus", e));
|
||||||
|
return new List<Result>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return new List<Result>();
|
||||||
|
}
|
||||||
|
|
||||||
return new List<Result>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void UpdateActionKeywordForPlugin(PluginPair plugin, string oldActionKeyword, string newActionKeyword)
|
public static void UpdateActionKeywordForPlugin(PluginPair plugin, string oldActionKeyword, string newActionKeyword)
|
||||||
|
@ -15,12 +15,6 @@ namespace Wox.Plugin
|
|||||||
/// <param name="results"></param>
|
/// <param name="results"></param>
|
||||||
void PushResults(Query query, PluginMetadata plugin, List<Result> results);
|
void PushResults(Query query, PluginMetadata plugin, List<Result> results);
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Show context menu with giving results
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="results"></param>
|
|
||||||
void ShowContextMenu(PluginMetadata plugin, List<Result> results);
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Change Wox query
|
/// Change Wox query
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -115,11 +109,5 @@ namespace Wox.Plugin
|
|||||||
/// if you want to hook something like Ctrl+R, you should use this event
|
/// if you want to hook something like Ctrl+R, you should use this event
|
||||||
/// </summary>
|
/// </summary>
|
||||||
event WoxGlobalKeyboardEventHandler GlobalKeyboardEvent;
|
event WoxGlobalKeyboardEventHandler GlobalKeyboardEvent;
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Fired after drop to result item of current plugin
|
|
||||||
/// </summary>
|
|
||||||
/// todo: ResultItem -> Result
|
|
||||||
event ResultItemDropEventHandler ResultItemDropEvent;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,8 @@
|
|||||||
d:DataContext="{d:DesignInstance vm:MainViewModel, IsDesignTimeCreatable=True}">
|
d:DataContext="{d:DesignInstance vm:MainViewModel, IsDesignTimeCreatable=True}">
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
<DataTemplate DataType="{x:Type vm:ResultsViewModel}">
|
<DataTemplate DataType="{x:Type vm:ResultsViewModel}">
|
||||||
<wox:ResultListBox></wox:ResultListBox>
|
<wox:ResultListBox PreviewMouseDown="OnPreviewMouseButtonDown">
|
||||||
|
</wox:ResultListBox>
|
||||||
</DataTemplate>
|
</DataTemplate>
|
||||||
</Window.Resources>
|
</Window.Resources>
|
||||||
<Border Style="{DynamicResource WindowBorderStyle}" MouseDown="OnMouseDown">
|
<Border Style="{DynamicResource WindowBorderStyle}" MouseDown="OnMouseDown">
|
||||||
@ -43,10 +44,8 @@
|
|||||||
<ToolTip IsOpen="{Binding IsProgressBarTooltipVisible}"></ToolTip>
|
<ToolTip IsOpen="{Binding IsProgressBarTooltipVisible}"></ToolTip>
|
||||||
</Line.ToolTip>
|
</Line.ToolTip>
|
||||||
</Line>
|
</Line>
|
||||||
<ContentControl Content="{Binding Results}" Visibility="{Binding ResultListBoxVisibility}">
|
<ContentControl Content="{Binding Results}" Visibility="{Binding ResultListBoxVisibility}"/>
|
||||||
</ContentControl>
|
<ContentControl Content="{Binding ContextMenu}" Visibility="{Binding ContextMenuVisibility}"/>
|
||||||
<ContentControl Content="{Binding ContextMenu}" Visibility="{Binding ContextMenuVisibility}">
|
|
||||||
</ContentControl>
|
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
</Border>
|
</Border>
|
||||||
</Window>
|
</Window>
|
@ -4,6 +4,7 @@ using System.Windows;
|
|||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
using System.Windows.Media.Animation;
|
using System.Windows.Media.Animation;
|
||||||
|
using System.Windows.Controls;
|
||||||
using Wox.Core.Plugin;
|
using Wox.Core.Plugin;
|
||||||
using Wox.Core.Resource;
|
using Wox.Core.Resource;
|
||||||
using Wox.Core.Updater;
|
using Wox.Core.Updater;
|
||||||
@ -35,9 +36,9 @@ namespace Wox
|
|||||||
private void OnClosing(object sender, CancelEventArgs e)
|
private void OnClosing(object sender, CancelEventArgs e)
|
||||||
{
|
{
|
||||||
|
|
||||||
UserSettingStorage.Instance.WindowLeft = Left;
|
UserSettingStorage.Instance.WindowLeft = Left;
|
||||||
UserSettingStorage.Instance.WindowTop = Top;
|
UserSettingStorage.Instance.WindowTop = Top;
|
||||||
UserSettingStorage.Instance.Save();
|
UserSettingStorage.Instance.Save();
|
||||||
|
|
||||||
e.Cancel = true;
|
e.Cancel = true;
|
||||||
}
|
}
|
||||||
@ -71,12 +72,13 @@ namespace Wox
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
UserSettingStorage.Instance.WindowLeft = Left;
|
UserSettingStorage.Instance.WindowLeft = Left;
|
||||||
UserSettingStorage.Instance.WindowTop = Top;
|
UserSettingStorage.Instance.WindowTop = Top;
|
||||||
UserSettingStorage.Instance.Save();
|
UserSettingStorage.Instance.Save();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// happlebao todo delete
|
||||||
vm.Left = GetWindowsLeft();
|
vm.Left = GetWindowsLeft();
|
||||||
vm.Top = GetWindowsTop();
|
vm.Top = GetWindowsTop();
|
||||||
vm.MainWindowVisibility = Visibility.Visible;
|
vm.MainWindowVisibility = Visibility.Visible;
|
||||||
@ -160,7 +162,6 @@ namespace Wox
|
|||||||
private void OnPreviewKeyDown(object sender, KeyEventArgs e)
|
private void OnPreviewKeyDown(object sender, KeyEventArgs e)
|
||||||
{
|
{
|
||||||
var vm = DataContext as MainViewModel;
|
var vm = DataContext as MainViewModel;
|
||||||
|
|
||||||
if (null == vm) return;
|
if (null == vm) return;
|
||||||
//when alt is pressed, the real key should be e.SystemKey
|
//when alt is pressed, the real key should be e.SystemKey
|
||||||
var key = (e.Key == Key.System ? e.SystemKey : e.Key);
|
var key = (e.Key == Key.System ? e.SystemKey : e.Key);
|
||||||
@ -202,10 +203,22 @@ namespace Wox
|
|||||||
case Key.O:
|
case Key.O:
|
||||||
if (GlobalHotkey.Instance.CheckModifiers().CtrlPressed)
|
if (GlobalHotkey.Instance.CheckModifiers().CtrlPressed)
|
||||||
{
|
{
|
||||||
vm.CtrlOCommand.Execute(null);
|
vm.LoadContextMenuCommand.Execute(null);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case Key.Enter:
|
||||||
|
if (GlobalHotkey.Instance.CheckModifiers().ShiftPressed)
|
||||||
|
{
|
||||||
|
vm.LoadContextMenuCommand.Execute(null);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
vm.OpenResultCommand.Execute(null);
|
||||||
|
}
|
||||||
|
e.Handled = true;
|
||||||
|
break;
|
||||||
|
|
||||||
case Key.Down:
|
case Key.Down:
|
||||||
if (GlobalHotkey.Instance.CheckModifiers().CtrlPressed)
|
if (GlobalHotkey.Instance.CheckModifiers().CtrlPressed)
|
||||||
{
|
{
|
||||||
@ -262,18 +275,6 @@ namespace Wox
|
|||||||
vm.StartHelpCommand.Execute(null);
|
vm.StartHelpCommand.Execute(null);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Key.Enter:
|
|
||||||
if (GlobalHotkey.Instance.CheckModifiers().ShiftPressed)
|
|
||||||
{
|
|
||||||
vm.ShiftEnterCommand.Execute(null);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
vm.OpenResultCommand.Execute(null);
|
|
||||||
}
|
|
||||||
e.Handled = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Key.D1:
|
case Key.D1:
|
||||||
|
|
||||||
if (GlobalHotkey.Instance.CheckModifiers().AltPressed)
|
if (GlobalHotkey.Instance.CheckModifiers().AltPressed)
|
||||||
@ -315,10 +316,45 @@ namespace Wox
|
|||||||
vm.OpenResultCommand.Execute(5);
|
vm.OpenResultCommand.Execute(5);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnPreviewMouseButtonDown(object sender, MouseButtonEventArgs e)
|
||||||
|
{
|
||||||
|
if (sender != null && e.OriginalSource != null)
|
||||||
|
{
|
||||||
|
var r = (ResultListBox)sender;
|
||||||
|
var d = (DependencyObject)e.OriginalSource;
|
||||||
|
var item = ItemsControl.ContainerFromElement(r, d) as ListBoxItem;
|
||||||
|
var result = (ResultViewModel)item?.DataContext;
|
||||||
|
if (result != null)
|
||||||
|
{
|
||||||
|
var vm = DataContext as MainViewModel;
|
||||||
|
if (vm != null)
|
||||||
|
{
|
||||||
|
if (vm.ContextMenuVisibility.IsVisible())
|
||||||
|
{
|
||||||
|
vm.ContextMenu.SelectResult(result);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
vm.Results.SelectResult(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.ChangedButton == MouseButton.Left)
|
||||||
|
{
|
||||||
|
vm.OpenResultCommand.Execute(null);
|
||||||
|
}
|
||||||
|
else if (e.ChangedButton == MouseButton.Right)
|
||||||
|
{
|
||||||
|
vm.LoadContextMenuCommand.Execute(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private void OnDrop(object sender, DragEventArgs e)
|
private void OnDrop(object sender, DragEventArgs e)
|
||||||
{
|
{
|
||||||
if (e.Data.GetDataPresent(DataFormats.FileDrop))
|
if (e.Data.GetDataPresent(DataFormats.FileDrop))
|
||||||
|
@ -30,9 +30,10 @@ namespace Wox
|
|||||||
GlobalHotkey.Instance.hookedKeyboardCallback += KListener_hookedKeyboardCallback;
|
GlobalHotkey.Instance.hookedKeyboardCallback += KListener_hookedKeyboardCallback;
|
||||||
WebRequest.RegisterPrefix("data", new DataWebRequestFactory());
|
WebRequest.RegisterPrefix("data", new DataWebRequestFactory());
|
||||||
|
|
||||||
MainVM.ListeningKeyPressed += (o, e) => {
|
MainVM.ListeningKeyPressed += (o, e) =>
|
||||||
|
{
|
||||||
|
|
||||||
if(e.KeyEventArgs.Key == Key.Back)
|
if (e.KeyEventArgs.Key == Key.Back)
|
||||||
{
|
{
|
||||||
BackKeyDownEvent?.Invoke(new WoxKeyDownEventArgs
|
BackKeyDownEvent?.Invoke(new WoxKeyDownEventArgs
|
||||||
{
|
{
|
||||||
@ -158,20 +159,6 @@ namespace Wox
|
|||||||
MainVM.UpdateResultView(results, plugin, query);
|
MainVM.UpdateResultView(results, plugin, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowContextMenu(PluginMetadata plugin, List<Result> results)
|
|
||||||
{
|
|
||||||
if (results != null && results.Count > 0)
|
|
||||||
{
|
|
||||||
results.ForEach(o =>
|
|
||||||
{
|
|
||||||
o.PluginDirectory = plugin.PluginDirectory;
|
|
||||||
o.PluginID = plugin.ID;
|
|
||||||
});
|
|
||||||
|
|
||||||
MainVM.ShowContextMenu(results, plugin.ID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Private Methods
|
#region Private Methods
|
||||||
|
@ -16,18 +16,14 @@
|
|||||||
<DataTemplate.DataType>
|
<DataTemplate.DataType>
|
||||||
<x:Type TypeName="vm:ResultViewModel" />
|
<x:Type TypeName="vm:ResultViewModel" />
|
||||||
</DataTemplate.DataType>
|
</DataTemplate.DataType>
|
||||||
<Button Command="{Binding OpenResultListBoxItemCommand}">
|
<Button>
|
||||||
<Button.InputBindings>
|
|
||||||
<MouseBinding Command="{Binding OpenContextMenuItemCommand}" MouseAction="RightClick"></MouseBinding>
|
|
||||||
</Button.InputBindings>
|
|
||||||
<Button.Template>
|
<Button.Template>
|
||||||
<ControlTemplate>
|
<ControlTemplate>
|
||||||
<ContentPresenter Content="{TemplateBinding Button.Content}"></ContentPresenter>
|
<ContentPresenter Content="{TemplateBinding Button.Content}"></ContentPresenter>
|
||||||
</ControlTemplate>
|
</ControlTemplate>
|
||||||
</Button.Template>
|
</Button.Template>
|
||||||
<Button.Content>
|
<Button.Content>
|
||||||
<Grid HorizontalAlignment="Stretch" Height="40" VerticalAlignment="Stretch" Margin="5"
|
<Grid HorizontalAlignment="Stretch" Height="40" VerticalAlignment="Stretch" Margin="5" Cursor="Hand">
|
||||||
Cursor="Hand">
|
|
||||||
<Grid.Resources>
|
<Grid.Resources>
|
||||||
<converters:ImagePathConverter x:Key="ImageConverter" />
|
<converters:ImagePathConverter x:Key="ImageConverter" />
|
||||||
</Grid.Resources>
|
</Grid.Resources>
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.ComponentModel;
|
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
@ -9,6 +8,7 @@ using Wox.Core.Plugin;
|
|||||||
using Wox.Core.Resource;
|
using Wox.Core.Resource;
|
||||||
using Wox.Helper;
|
using Wox.Helper;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
|
using Wox.Infrastructure.Hotkey;
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Wox.Storage;
|
using Wox.Storage;
|
||||||
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
||||||
@ -19,8 +19,6 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
#region Private Fields
|
#region Private Fields
|
||||||
|
|
||||||
private string _queryText;
|
|
||||||
|
|
||||||
private bool _isProgressBarTooltipVisible;
|
private bool _isProgressBarTooltipVisible;
|
||||||
private double _left;
|
private double _left;
|
||||||
private double _top;
|
private double _top;
|
||||||
@ -31,10 +29,10 @@ namespace Wox.ViewModel
|
|||||||
private Visibility _mainWindowVisibility;
|
private Visibility _mainWindowVisibility;
|
||||||
|
|
||||||
private bool _queryHasReturn;
|
private bool _queryHasReturn;
|
||||||
private Query _lastQuery = new Query();
|
private Query _lastQuery;
|
||||||
private bool _ignoreTextChange;
|
private bool _ignoreTextChange;
|
||||||
private List<Result> _currentContextMenus = new List<Result>();
|
private string _queryTextBeforeLoadContextMenu;
|
||||||
private string _textBeforeEnterContextMenuMode;
|
private string _queryText;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -42,11 +40,13 @@ namespace Wox.ViewModel
|
|||||||
|
|
||||||
public MainViewModel()
|
public MainViewModel()
|
||||||
{
|
{
|
||||||
|
_queryTextBeforeLoadContextMenu = "";
|
||||||
|
_queryText = "";
|
||||||
|
_lastQuery = new Query();
|
||||||
|
|
||||||
InitializeResultListBox();
|
InitializeResultListBox();
|
||||||
InitializeContextMenu();
|
InitializeContextMenu();
|
||||||
InitializeKeyCommands();
|
InitializeKeyCommands();
|
||||||
|
|
||||||
_queryHasReturn = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
@ -67,7 +67,10 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
_queryText = value;
|
_queryText = value;
|
||||||
OnPropertyChanged();
|
OnPropertyChanged();
|
||||||
HandleQueryTextUpdated();
|
if (_queryText != _queryTextBeforeLoadContextMenu)
|
||||||
|
{
|
||||||
|
HandleQueryTextUpdated();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,6 +114,7 @@ namespace Wox.ViewModel
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Visibility ContextMenuVisibility
|
public Visibility ContextMenuVisibility
|
||||||
|
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
@ -120,6 +124,19 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
_contextMenuVisibility = value;
|
_contextMenuVisibility = value;
|
||||||
OnPropertyChanged();
|
OnPropertyChanged();
|
||||||
|
|
||||||
|
if (!value.IsVisible())
|
||||||
|
{
|
||||||
|
QueryText = _queryTextBeforeLoadContextMenu;
|
||||||
|
ResultListBoxVisibility = Visibility.Visible;
|
||||||
|
OnCursorMovedToEnd();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_queryTextBeforeLoadContextMenu = QueryText;
|
||||||
|
QueryText = "";
|
||||||
|
ResultListBoxVisibility = Visibility.Collapsed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -160,24 +177,18 @@ namespace Wox.ViewModel
|
|||||||
_mainWindowVisibility = value;
|
_mainWindowVisibility = value;
|
||||||
OnPropertyChanged();
|
OnPropertyChanged();
|
||||||
MainWindowVisibilityChanged?.Invoke(this, new EventArgs());
|
MainWindowVisibilityChanged?.Invoke(this, new EventArgs());
|
||||||
|
|
||||||
if (!value.IsVisible() && ContextMenuVisibility.IsVisible())
|
|
||||||
{
|
|
||||||
BackToSearchMode();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ICommand EscCommand { get; set; }
|
public ICommand EscCommand { get; set; }
|
||||||
public ICommand SelectNextItemCommand { get; set; }
|
public ICommand SelectNextItemCommand { get; set; }
|
||||||
public ICommand SelectPrevItemCommand { get; set; }
|
public ICommand SelectPrevItemCommand { get; set; }
|
||||||
public ICommand CtrlOCommand { get; set; }
|
|
||||||
public ICommand DisplayNextQueryCommand { get; set; }
|
public ICommand DisplayNextQueryCommand { get; set; }
|
||||||
public ICommand DisplayPrevQueryCommand { get; set; }
|
public ICommand DisplayPrevQueryCommand { get; set; }
|
||||||
public ICommand SelectNextPageCommand { get; set; }
|
public ICommand SelectNextPageCommand { get; set; }
|
||||||
public ICommand SelectPrevPageCommand { get; set; }
|
public ICommand SelectPrevPageCommand { get; set; }
|
||||||
public ICommand StartHelpCommand { get; set; }
|
public ICommand StartHelpCommand { get; set; }
|
||||||
public ICommand ShiftEnterCommand { get; set; }
|
public ICommand LoadContextMenuCommand { get; set; }
|
||||||
public ICommand OpenResultCommand { get; set; }
|
public ICommand OpenResultCommand { get; set; }
|
||||||
public ICommand BackCommand { get; set; }
|
public ICommand BackCommand { get; set; }
|
||||||
#endregion
|
#endregion
|
||||||
@ -190,7 +201,7 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
if (ContextMenuVisibility.IsVisible())
|
if (ContextMenuVisibility.IsVisible())
|
||||||
{
|
{
|
||||||
BackToSearchMode();
|
ContextMenuVisibility = Visibility.Collapsed;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -222,17 +233,7 @@ namespace Wox.ViewModel
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
CtrlOCommand = new RelayCommand(_ =>
|
|
||||||
{
|
|
||||||
if (ContextMenuVisibility.IsVisible())
|
|
||||||
{
|
|
||||||
BackToSearchMode();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ShowContextMenu(Results.SelectedResult.RawResult);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
DisplayNextQueryCommand = new RelayCommand(_ =>
|
DisplayNextQueryCommand = new RelayCommand(_ =>
|
||||||
{
|
{
|
||||||
@ -261,22 +262,48 @@ namespace Wox.ViewModel
|
|||||||
Process.Start("http://doc.getwox.com");
|
Process.Start("http://doc.getwox.com");
|
||||||
});
|
});
|
||||||
|
|
||||||
ShiftEnterCommand = new RelayCommand(_ =>
|
|
||||||
{
|
|
||||||
if (!ContextMenuVisibility.IsVisible() && null != Results.SelectedResult)
|
|
||||||
{
|
|
||||||
ShowContextMenu(Results.SelectedResult.RawResult);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
OpenResultCommand = new RelayCommand(o =>
|
OpenResultCommand = new RelayCommand(o =>
|
||||||
{
|
{
|
||||||
|
var results = ContextMenuVisibility.IsVisible() ? ContextMenu : Results;
|
||||||
|
|
||||||
if (o != null)
|
if (o != null)
|
||||||
{
|
{
|
||||||
var index = int.Parse(o.ToString());
|
var index = int.Parse(o.ToString());
|
||||||
Results.SelectResult(index);
|
results.SelectResult(index);
|
||||||
|
}
|
||||||
|
|
||||||
|
var result = results.SelectedResult.RawResult;
|
||||||
|
bool hideWindow = result.Action(new ActionContext
|
||||||
|
{
|
||||||
|
SpecialKeyState = GlobalHotkey.Instance.CheckModifiers()
|
||||||
|
});
|
||||||
|
if (hideWindow)
|
||||||
|
{
|
||||||
|
MainWindowVisibility = Visibility.Collapsed;
|
||||||
|
}
|
||||||
|
|
||||||
|
UserSelectedRecordStorage.Instance.Add(result);
|
||||||
|
QueryHistoryStorage.Instance.Add(result.OriginQuery.RawQuery);
|
||||||
|
});
|
||||||
|
|
||||||
|
LoadContextMenuCommand = new RelayCommand(_ =>
|
||||||
|
{
|
||||||
|
if (!ContextMenuVisibility.IsVisible())
|
||||||
|
{
|
||||||
|
var result = Results.SelectedResult.RawResult;
|
||||||
|
var pluginID = result.PluginID;
|
||||||
|
|
||||||
|
var contextMenuResults = PluginManager.GetContextMenusForPlugin(result);
|
||||||
|
contextMenuResults.Add(GetTopMostContextMenu(result));
|
||||||
|
|
||||||
|
ContextMenu.Clear();
|
||||||
|
ContextMenu.AddResults(contextMenuResults, pluginID);
|
||||||
|
ContextMenuVisibility = Visibility.Visible;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ContextMenuVisibility = Visibility.Collapsed;
|
||||||
}
|
}
|
||||||
Results.SelectedResult?.OpenResultListBoxItemCommand.Execute(null);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
BackCommand = new RelayCommand(_ =>
|
BackCommand = new RelayCommand(_ =>
|
||||||
@ -291,69 +318,6 @@ namespace Wox.ViewModel
|
|||||||
ResultListBoxVisibility = Visibility.Collapsed;
|
ResultListBoxVisibility = Visibility.Collapsed;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ShowContextMenu(Result result)
|
|
||||||
{
|
|
||||||
if (result == null) return;
|
|
||||||
ShowContextMenu(result, PluginManager.GetContextMenusForPlugin(result));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ShowContextMenu(Result result, List<Result> actions)
|
|
||||||
{
|
|
||||||
actions.ForEach(o =>
|
|
||||||
{
|
|
||||||
o.PluginDirectory = PluginManager.GetPluginForId(result.PluginID).Metadata.PluginDirectory;
|
|
||||||
o.PluginID = result.PluginID;
|
|
||||||
o.OriginQuery = result.OriginQuery;
|
|
||||||
});
|
|
||||||
|
|
||||||
actions.Add(GetTopMostContextMenu(result));
|
|
||||||
|
|
||||||
DisplayContextMenu(actions, result.PluginID);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void DisplayContextMenu(List<Result> actions, string pluginID)
|
|
||||||
{
|
|
||||||
_textBeforeEnterContextMenuMode = QueryText;
|
|
||||||
|
|
||||||
ContextMenu.Clear();
|
|
||||||
ContextMenu.AddResults(actions, pluginID);
|
|
||||||
_currentContextMenus = actions;
|
|
||||||
|
|
||||||
ContextMenuVisibility = Visibility.Visible;
|
|
||||||
ResultListBoxVisibility = Visibility.Collapsed;
|
|
||||||
|
|
||||||
QueryText = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
private Result GetTopMostContextMenu(Result result)
|
|
||||||
{
|
|
||||||
if (TopMostRecordStorage.Instance.IsTopMost(result))
|
|
||||||
{
|
|
||||||
return new Result(InternationalizationManager.Instance.GetTranslation("cancelTopMostInThisQuery"), "Images\\down.png")
|
|
||||||
{
|
|
||||||
PluginDirectory = WoxDirectroy.Executable,
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
TopMostRecordStorage.Instance.Remove(result);
|
|
||||||
App.API.ShowMsg("Succeed");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return new Result(InternationalizationManager.Instance.GetTranslation("setAsTopMostInThisQuery"), "Images\\up.png")
|
|
||||||
{
|
|
||||||
PluginDirectory = WoxDirectroy.Executable,
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
TopMostRecordStorage.Instance.AddOrUpdate(result);
|
|
||||||
App.API.ShowMsg("Succeed");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void InitializeContextMenu()
|
private void InitializeContextMenu()
|
||||||
{
|
{
|
||||||
@ -363,12 +327,6 @@ namespace Wox.ViewModel
|
|||||||
|
|
||||||
private void HandleQueryTextUpdated()
|
private void HandleQueryTextUpdated()
|
||||||
{
|
{
|
||||||
if (_ignoreTextChange)
|
|
||||||
{
|
|
||||||
_ignoreTextChange = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
IsProgressBarTooltipVisible = false;
|
IsProgressBarTooltipVisible = false;
|
||||||
if (ContextMenuVisibility.IsVisible())
|
if (ContextMenuVisibility.IsVisible())
|
||||||
{
|
{
|
||||||
@ -393,23 +351,20 @@ namespace Wox.ViewModel
|
|||||||
private void QueryContextMenu()
|
private void QueryContextMenu()
|
||||||
{
|
{
|
||||||
var contextMenuId = "Context Menu Id";
|
var contextMenuId = "Context Menu Id";
|
||||||
ContextMenu.Clear();
|
|
||||||
var query = QueryText.ToLower();
|
var query = QueryText.ToLower();
|
||||||
if (string.IsNullOrEmpty(query))
|
if (!string.IsNullOrEmpty(query))
|
||||||
{
|
|
||||||
ContextMenu.AddResults(_currentContextMenus, contextMenuId);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
|
|
||||||
List<Result> filterResults = new List<Result>();
|
List<Result> filterResults = new List<Result>();
|
||||||
foreach (Result contextMenu in _currentContextMenus)
|
foreach (var contextMenu in ContextMenu.Results)
|
||||||
{
|
{
|
||||||
if (StringMatcher.IsMatch(contextMenu.Title, query)
|
if (StringMatcher.IsMatch(contextMenu.Title, query)
|
||||||
|| StringMatcher.IsMatch(contextMenu.SubTitle, query))
|
|| StringMatcher.IsMatch(contextMenu.SubTitle, query))
|
||||||
{
|
{
|
||||||
filterResults.Add(contextMenu);
|
filterResults.Add(contextMenu.RawResult);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ContextMenu.Clear();
|
||||||
ContextMenu.AddResults(filterResults, contextMenuId);
|
ContextMenu.AddResults(filterResults, contextMenuId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -470,14 +425,6 @@ namespace Wox.ViewModel
|
|||||||
() => { Results.AddResults(list, metadata.ID); });
|
() => { Results.AddResults(list, metadata.ID); });
|
||||||
}
|
}
|
||||||
|
|
||||||
private void BackToSearchMode()
|
|
||||||
{
|
|
||||||
QueryText = _textBeforeEnterContextMenuMode;
|
|
||||||
ContextMenuVisibility = Visibility.Collapsed;
|
|
||||||
ResultListBoxVisibility = Visibility.Visible;
|
|
||||||
OnCursorMovedToEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void DisplayQueryHistory(HistoryItem history)
|
private void DisplayQueryHistory(HistoryItem history)
|
||||||
{
|
{
|
||||||
if (history != null)
|
if (history != null)
|
||||||
@ -507,7 +454,35 @@ namespace Wox.ViewModel
|
|||||||
}, historyMetadata);
|
}, historyMetadata);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
private Result GetTopMostContextMenu(Result result)
|
||||||
|
{
|
||||||
|
if (TopMostRecordStorage.Instance.IsTopMost(result))
|
||||||
|
{
|
||||||
|
return new Result(InternationalizationManager.Instance.GetTranslation("cancelTopMostInThisQuery"), "Images\\down.png")
|
||||||
|
{
|
||||||
|
PluginDirectory = WoxDirectroy.Executable,
|
||||||
|
Action = _ =>
|
||||||
|
{
|
||||||
|
TopMostRecordStorage.Instance.Remove(result);
|
||||||
|
App.API.ShowMsg("Succeed");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return new Result(InternationalizationManager.Instance.GetTranslation("setAsTopMostInThisQuery"), "Images\\up.png")
|
||||||
|
{
|
||||||
|
PluginDirectory = WoxDirectroy.Executable,
|
||||||
|
Action = _ =>
|
||||||
|
{
|
||||||
|
TopMostRecordStorage.Instance.AddOrUpdate(result);
|
||||||
|
App.API.ShowMsg("Succeed");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Public Methods
|
#region Public Methods
|
||||||
@ -535,11 +510,6 @@ namespace Wox.ViewModel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowContextMenu(List<Result> actions, string pluginID)
|
|
||||||
{
|
|
||||||
DisplayContextMenu(actions, pluginID);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
public event EventHandler<ListeningKeyPressedEventArgs> ListeningKeyPressed;
|
public event EventHandler<ListeningKeyPressedEventArgs> ListeningKeyPressed;
|
||||||
@ -556,18 +526,15 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
TextBoxSelected?.Invoke(this, new EventArgs());
|
TextBoxSelected?.Invoke(this, new EventArgs());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public class ListeningKeyPressedEventArgs : EventArgs
|
public class ListeningKeyPressedEventArgs : EventArgs
|
||||||
{
|
{
|
||||||
|
|
||||||
public KeyEventArgs KeyEventArgs { get; private set; }
|
public KeyEventArgs KeyEventArgs { get; private set; }
|
||||||
|
|
||||||
public ListeningKeyPressedEventArgs(KeyEventArgs keyEventArgs)
|
public ListeningKeyPressedEventArgs(KeyEventArgs keyEventArgs)
|
||||||
{
|
{
|
||||||
KeyEventArgs = keyEventArgs;
|
KeyEventArgs = keyEventArgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using Wox.Core.Plugin;
|
using System;
|
||||||
|
using Wox.Core.Plugin;
|
||||||
using Wox.Core.Resource;
|
using Wox.Core.Resource;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
using Wox.Infrastructure.Hotkey;
|
using Wox.Infrastructure.Hotkey;
|
||||||
@ -22,41 +23,6 @@ namespace Wox.ViewModel
|
|||||||
if (result != null)
|
if (result != null)
|
||||||
{
|
{
|
||||||
RawResult = result;
|
RawResult = result;
|
||||||
|
|
||||||
OpenResultListBoxItemCommand = new RelayCommand(_ =>
|
|
||||||
{
|
|
||||||
|
|
||||||
bool hideWindow = result.Action(new ActionContext
|
|
||||||
{
|
|
||||||
SpecialKeyState = GlobalHotkey.Instance.CheckModifiers()
|
|
||||||
});
|
|
||||||
|
|
||||||
if (hideWindow)
|
|
||||||
{
|
|
||||||
App.API.HideApp();
|
|
||||||
UserSelectedRecordStorage.Instance.Add(RawResult);
|
|
||||||
QueryHistoryStorage.Instance.Add(RawResult.OriginQuery.RawQuery);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
OpenContextMenuItemCommand = new RelayCommand(_ =>
|
|
||||||
{
|
|
||||||
|
|
||||||
var actions = PluginManager.GetContextMenusForPlugin(result);
|
|
||||||
|
|
||||||
var pluginMetaData = PluginManager.GetPluginForId(result.PluginID).Metadata;
|
|
||||||
actions.ForEach(o =>
|
|
||||||
{
|
|
||||||
o.PluginDirectory = pluginMetaData.PluginDirectory;
|
|
||||||
o.PluginID = result.PluginID;
|
|
||||||
o.OriginQuery = result.OriginQuery;
|
|
||||||
});
|
|
||||||
|
|
||||||
actions.Add(GetTopMostContextMenu(result));
|
|
||||||
|
|
||||||
App.API.ShowContextMenu(pluginMetaData, actions);
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,51 +47,12 @@ namespace Wox.ViewModel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public RelayCommand OpenResultListBoxItemCommand { get; set; }
|
|
||||||
|
|
||||||
public RelayCommand OpenContextMenuItemCommand { get; set; }
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Properties
|
#region Properties
|
||||||
|
|
||||||
public Result RawResult { get; }
|
public Result RawResult { get; }
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private Methods
|
|
||||||
|
|
||||||
private Result GetTopMostContextMenu(Result result)
|
|
||||||
{
|
|
||||||
if (TopMostRecordStorage.Instance.IsTopMost(result))
|
|
||||||
{
|
|
||||||
return new Result(InternationalizationManager.Instance.GetTranslation("cancelTopMostInThisQuery"), "Images\\down.png")
|
|
||||||
{
|
|
||||||
PluginDirectory = WoxDirectroy.Executable,
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
TopMostRecordStorage.Instance.Remove(result);
|
|
||||||
App.API.ShowMsg("Succeed");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return new Result(InternationalizationManager.Instance.GetTranslation("setAsTopMostInThisQuery"), "Images\\up.png")
|
|
||||||
{
|
|
||||||
PluginDirectory = WoxDirectroy.Executable,
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
TopMostRecordStorage.Instance.AddOrUpdate(result);
|
|
||||||
App.API.ShowMsg("Succeed");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
public override bool Equals(object obj)
|
public override bool Equals(object obj)
|
||||||
|
@ -104,6 +104,12 @@ namespace Wox.ViewModel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void SelectResult(ResultViewModel result)
|
||||||
|
{
|
||||||
|
int i = Results.IndexOf(result);
|
||||||
|
SelectResult(i);
|
||||||
|
}
|
||||||
|
|
||||||
public void SelectNextResult()
|
public void SelectNextResult()
|
||||||
{
|
{
|
||||||
if (SelectedResult != null)
|
if (SelectedResult != null)
|
||||||
@ -185,8 +191,7 @@ namespace Wox.ViewModel
|
|||||||
{
|
{
|
||||||
lock (_resultsUpdateLock)
|
lock (_resultsUpdateLock)
|
||||||
{
|
{
|
||||||
var newResults = new List<ResultViewModel>();
|
var newResults = newRawResults.Select(r => new ResultViewModel(r)).ToList();
|
||||||
newRawResults.ForEach((re) => { newResults.Add(new ResultViewModel(re)); });
|
|
||||||
// todo use async to do new result calculation
|
// todo use async to do new result calculation
|
||||||
var resultsCopy = Results.ToList();
|
var resultsCopy = Results.ToList();
|
||||||
var oldResults = resultsCopy.Where(r => r.RawResult.PluginID == resultId).ToList();
|
var oldResults = resultsCopy.Where(r => r.RawResult.PluginID == resultId).ToList();
|
||||||
|
Loading…
Reference in New Issue
Block a user