mirror of
https://github.com/microsoft/PowerToys.git
synced 2025-06-07 09:28:03 +08:00
Removed folder plugin
This commit is contained in:
parent
c3bded6947
commit
064d638588
@ -162,7 +162,6 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Wox", "src\modules\launcher
|
|||||||
{59BD9891-3837-438A-958D-ADC7F91F6F7E} = {59BD9891-3837-438A-958D-ADC7F91F6F7E}
|
{59BD9891-3837-438A-958D-ADC7F91F6F7E} = {59BD9891-3837-438A-958D-ADC7F91F6F7E}
|
||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E} = {74F1B9ED-F59C-4FE7-B473-7B453E30837E}
|
{74F1B9ED-F59C-4FE7-B473-7B453E30837E} = {74F1B9ED-F59C-4FE7-B473-7B453E30837E}
|
||||||
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0} = {C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}
|
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0} = {C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4} = {787B8AA6-CA93-4C84-96FE-DF31110AD1C4}
|
|
||||||
{F8B870EB-D5F5-45BA-9CF7-A5C459818820} = {F8B870EB-D5F5-45BA-9CF7-A5C459818820}
|
{F8B870EB-D5F5-45BA-9CF7-A5C459818820} = {F8B870EB-D5F5-45BA-9CF7-A5C459818820}
|
||||||
EndProjectSection
|
EndProjectSection
|
||||||
EndProject
|
EndProject
|
||||||
@ -184,8 +183,6 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Wox.Plugin.Program", "src\m
|
|||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Wox.Plugin.Shell", "src\modules\launcher\Plugins\Wox.Plugin.Shell\Wox.Plugin.Shell.csproj", "{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Wox.Plugin.Shell", "src\modules\launcher\Plugins\Wox.Plugin.Shell\Wox.Plugin.Shell.csproj", "{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Wox.Plugin.Folder", "src\modules\launcher\Plugins\Wox.Plugin.Folder\Wox.Plugin.Folder.csproj", "{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}"
|
|
||||||
EndProject
|
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.Plugin.Indexer", "src\modules\launcher\Plugins\Microsoft.Plugin.Indexer\Microsoft.Plugin.Indexer.csproj", "{F8B870EB-D5F5-45BA-9CF7-A5C459818820}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.Plugin.Indexer", "src\modules\launcher\Plugins\Microsoft.Plugin.Indexer\Microsoft.Plugin.Indexer.csproj", "{F8B870EB-D5F5-45BA-9CF7-A5C459818820}"
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
ProjectSection(ProjectDependencies) = postProject
|
||||||
{8451ECDD-2EA4-4966-BB0A-7BBC40138E80} = {8451ECDD-2EA4-4966-BB0A-7BBC40138E80}
|
{8451ECDD-2EA4-4966-BB0A-7BBC40138E80} = {8451ECDD-2EA4-4966-BB0A-7BBC40138E80}
|
||||||
@ -564,10 +561,6 @@ Global
|
|||||||
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x64.ActiveCfg = Release|x64
|
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x64.ActiveCfg = Release|x64
|
||||||
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x64.Build.0 = Release|x64
|
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x64.Build.0 = Release|x64
|
||||||
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x86.ActiveCfg = Release|x64
|
{FF742965-9A80-41A5-B042-D6C7D3A21708}.Release|x86.ActiveCfg = Release|x64
|
||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E}.Debug|x64.ActiveCfg = Debug|x64
|
|
||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E}.Debug|x64.Build.0 = Debug|x64
|
|
||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E}.Release|x64.ActiveCfg = Release|x64
|
|
||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E}.Release|x64.Build.0 = Release|x64
|
|
||||||
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|ARM.ActiveCfg = Debug|x64
|
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|ARM.ActiveCfg = Debug|x64
|
||||||
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|ARM64.ActiveCfg = Debug|x64
|
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|ARM64.ActiveCfg = Debug|x64
|
||||||
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|x64.ActiveCfg = Debug|x64
|
{59BD9891-3837-438A-958D-ADC7F91F6F7E}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
@ -608,16 +601,6 @@ Global
|
|||||||
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x64.ActiveCfg = Release|x64
|
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x64.ActiveCfg = Release|x64
|
||||||
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x64.Build.0 = Release|x64
|
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x64.Build.0 = Release|x64
|
||||||
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x86.ActiveCfg = Release|x64
|
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0}.Release|x86.ActiveCfg = Release|x64
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Debug|ARM.ActiveCfg = Debug|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Debug|ARM64.ActiveCfg = Debug|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Debug|x64.ActiveCfg = Debug|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Debug|x64.Build.0 = Debug|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Debug|x86.ActiveCfg = Debug|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Release|ARM.ActiveCfg = Release|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Release|ARM64.ActiveCfg = Release|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Release|x64.ActiveCfg = Release|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Release|x64.Build.0 = Release|x64
|
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}.Release|x86.ActiveCfg = Release|x64
|
|
||||||
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|ARM.ActiveCfg = Debug|x64
|
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|ARM.ActiveCfg = Debug|x64
|
||||||
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|ARM64.ActiveCfg = Debug|x64
|
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|ARM64.ActiveCfg = Debug|x64
|
||||||
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|x64.ActiveCfg = Debug|x64
|
{F8B870EB-D5F5-45BA-9CF7-A5C459818820}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
@ -800,7 +783,6 @@ Global
|
|||||||
{74F1B9ED-F59C-4FE7-B473-7B453E30837E} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
{74F1B9ED-F59C-4FE7-B473-7B453E30837E} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
||||||
{FDB3555B-58EF-4AE6-B5F1-904719637AB4} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
{FDB3555B-58EF-4AE6-B5F1-904719637AB4} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
||||||
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
{C21BFF9C-2C99-4B5F-B7C9-A5E6DDDB37B0} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
||||||
{787B8AA6-CA93-4C84-96FE-DF31110AD1C4} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
|
||||||
{F8B870EB-D5F5-45BA-9CF7-A5C459818820} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
{F8B870EB-D5F5-45BA-9CF7-A5C459818820} = {4AFC9975-2456-4C70-94A4-84073C1CED93}
|
||||||
{E364F67B-BB12-4E91-B639-355866EBCD8B} = {C140A3EF-6DBF-4084-9D4C-4EB5A99FEE68}
|
{E364F67B-BB12-4E91-B639-355866EBCD8B} = {C140A3EF-6DBF-4084-9D4C-4EB5A99FEE68}
|
||||||
{F97E5003-F263-4D4A-A964-0F1F3C82DEF2} = {C140A3EF-6DBF-4084-9D4C-4EB5A99FEE68}
|
{F97E5003-F263-4D4A-A964-0F1F3C82DEF2} = {C140A3EF-6DBF-4084-9D4C-4EB5A99FEE68}
|
||||||
|
@ -1,151 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Diagnostics;
|
|
||||||
using System.IO;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using System.Windows;
|
|
||||||
using Wox.Infrastructure.Logger;
|
|
||||||
using Wox.Infrastructure.Image;
|
|
||||||
using Wox.Plugin.SharedCommands;
|
|
||||||
|
|
||||||
namespace Wox.Plugin.Folder
|
|
||||||
{
|
|
||||||
internal class ContextMenuLoader : IContextMenu
|
|
||||||
{
|
|
||||||
private readonly PluginInitContext _context;
|
|
||||||
|
|
||||||
public ContextMenuLoader(PluginInitContext context)
|
|
||||||
{
|
|
||||||
_context = context;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<ContextMenuResult> LoadContextMenus(Result selectedResult)
|
|
||||||
{
|
|
||||||
var contextMenus = new List<ContextMenuResult>();
|
|
||||||
if (selectedResult.ContextData is SearchResult record)
|
|
||||||
{
|
|
||||||
if (record.Type == ResultType.File)
|
|
||||||
{
|
|
||||||
contextMenus.Add(CreateOpenContainingFolderResult(record));
|
|
||||||
}
|
|
||||||
|
|
||||||
var icoPath = (record.Type == ResultType.File) ? Main.FileImagePath : Main.FolderImagePath;
|
|
||||||
var fileOrFolder = (record.Type == ResultType.File) ? "file" : "folder";
|
|
||||||
contextMenus.Add(new ContextMenuResult
|
|
||||||
{
|
|
||||||
Title = "Copy path",
|
|
||||||
Glyph = "\xE8C8",
|
|
||||||
FontFamily = "Segoe MDL2 Assets",
|
|
||||||
SubTitle = $"Copy the current {fileOrFolder} path to clipboard",
|
|
||||||
AcceleratorKey = "C",
|
|
||||||
AcceleratorModifiers = "Control",
|
|
||||||
Action = (context) =>
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Clipboard.SetText(record.FullPath);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
var message = "Fail to set text in clipboard";
|
|
||||||
LogException(message, e);
|
|
||||||
_context.API.ShowMsg(message);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return contextMenus;
|
|
||||||
}
|
|
||||||
|
|
||||||
private ContextMenuResult CreateOpenContainingFolderResult(SearchResult record)
|
|
||||||
{
|
|
||||||
return new ContextMenuResult
|
|
||||||
{
|
|
||||||
Title = "Open containing folder",
|
|
||||||
Glyph = "\xE838",
|
|
||||||
FontFamily = "Segoe MDL2 Assets",
|
|
||||||
AcceleratorKey = "E",
|
|
||||||
AcceleratorModifiers = "Control,Shift",
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Process.Start("explorer.exe", $" /select,\"{record.FullPath}\"");
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
var message = $"Fail to open file at {record.FullPath}";
|
|
||||||
LogException(message, e);
|
|
||||||
_context.API.ShowMsg(message);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private Result CreateOpenWithEditorResult(SearchResult record)
|
|
||||||
{
|
|
||||||
string editorPath = "notepad.exe"; // TODO add the ability to create a custom editor
|
|
||||||
|
|
||||||
var name = "Open With Editor: " + Path.GetFileNameWithoutExtension(editorPath);
|
|
||||||
return new Result
|
|
||||||
{
|
|
||||||
Title = name,
|
|
||||||
Action = _ =>
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Process.Start(editorPath, record.FullPath);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
var message = $"Fail to editor for file at {record.FullPath}";
|
|
||||||
LogException(message, e);
|
|
||||||
_context.API.ShowMsg(message);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
IcoPath = editorPath
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
public void LogException(string message, Exception e)
|
|
||||||
{
|
|
||||||
Log.Exception($"|Wox.Plugin.Folder.ContextMenu|{message}", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
private bool CanRunAsDifferentUser(string path)
|
|
||||||
{
|
|
||||||
switch(Path.GetExtension(path))
|
|
||||||
{
|
|
||||||
case ".exe":
|
|
||||||
case ".bat":
|
|
||||||
return true;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class SearchResult
|
|
||||||
{
|
|
||||||
public string FullPath { get; set; }
|
|
||||||
public ResultType Type { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum ResultType
|
|
||||||
{
|
|
||||||
Volume,
|
|
||||||
Folder,
|
|
||||||
File
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,18 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
|
|
||||||
namespace Wox.Plugin.Folder
|
|
||||||
{
|
|
||||||
[JsonObject(MemberSerialization.OptIn)]
|
|
||||||
public class FolderLink
|
|
||||||
{
|
|
||||||
[JsonProperty]
|
|
||||||
public string Path { get; set; }
|
|
||||||
|
|
||||||
public string Nickname =>
|
|
||||||
Path.Split(new[] { System.IO.Path.DirectorySeparatorChar }, StringSplitOptions.None)
|
|
||||||
.Last()
|
|
||||||
+ " (" + System.IO.Path.GetDirectoryName(Path) + ")";
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
<UserControl x:Class="Wox.Plugin.Folder.FileSystemSettings"
|
|
||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
|
||||||
mc:Ignorable="d"
|
|
||||||
d:DesignHeight="300" d:DesignWidth="500">
|
|
||||||
<Grid Margin="10">
|
|
||||||
<Grid.RowDefinitions>
|
|
||||||
<RowDefinition Height="*"/>
|
|
||||||
<RowDefinition Height="50"/>
|
|
||||||
</Grid.RowDefinitions>
|
|
||||||
<ListView x:Name="lbxFolders" Grid.Row="0" AllowDrop="True"
|
|
||||||
Drop="lbxFolders_Drop"
|
|
||||||
DragEnter="lbxFolders_DragEnter">
|
|
||||||
<ListView.View>
|
|
||||||
<GridView>
|
|
||||||
<GridViewColumn Header="{DynamicResource wox_plugin_folder_folder_path}" Width="180">
|
|
||||||
<GridViewColumn.CellTemplate>
|
|
||||||
<DataTemplate>
|
|
||||||
<TextBlock Text="{Binding Path}"/>
|
|
||||||
</DataTemplate>
|
|
||||||
</GridViewColumn.CellTemplate>
|
|
||||||
</GridViewColumn>
|
|
||||||
</GridView>
|
|
||||||
</ListView.View>
|
|
||||||
</ListView>
|
|
||||||
<StackPanel Grid.Row="1" HorizontalAlignment="Right" Orientation="Horizontal">
|
|
||||||
<Button x:Name="btnDelete" Click="btnDelete_Click" Width="100" Margin="10" Content="{DynamicResource wox_plugin_folder_delete}"/>
|
|
||||||
<Button x:Name="btnEdit" Click="btnEdit_Click" Width="100" Margin="10" Content="{DynamicResource wox_plugin_folder_edit}"/>
|
|
||||||
<Button x:Name="btnAdd" Click="btnAdd_Click" Width="100" Margin="10" Content="{DynamicResource wox_plugin_folder_add}"/>
|
|
||||||
</StackPanel>
|
|
||||||
</Grid>
|
|
||||||
</UserControl>
|
|
@ -1,130 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Windows;
|
|
||||||
using System.Windows.Forms;
|
|
||||||
using DataFormats = System.Windows.DataFormats;
|
|
||||||
using DragDropEffects = System.Windows.DragDropEffects;
|
|
||||||
using DragEventArgs = System.Windows.DragEventArgs;
|
|
||||||
using MessageBox = System.Windows.MessageBox;
|
|
||||||
|
|
||||||
namespace Wox.Plugin.Folder
|
|
||||||
{
|
|
||||||
|
|
||||||
public partial class FileSystemSettings
|
|
||||||
{
|
|
||||||
private IPublicAPI woxAPI;
|
|
||||||
private Settings _settings;
|
|
||||||
|
|
||||||
public FileSystemSettings(IPublicAPI woxAPI, Settings settings)
|
|
||||||
{
|
|
||||||
this.woxAPI = woxAPI;
|
|
||||||
InitializeComponent();
|
|
||||||
_settings = settings;
|
|
||||||
lbxFolders.ItemsSource = _settings.FolderLinks;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void btnDelete_Click(object sender, RoutedEventArgs e)
|
|
||||||
{
|
|
||||||
var selectedFolder = lbxFolders.SelectedItem as FolderLink;
|
|
||||||
if (selectedFolder != null)
|
|
||||||
{
|
|
||||||
string msg = string.Format(woxAPI.GetTranslation("wox_plugin_folder_delete_folder_link"), selectedFolder.Path);
|
|
||||||
|
|
||||||
if (MessageBox.Show(msg, string.Empty, MessageBoxButton.YesNo) == MessageBoxResult.Yes)
|
|
||||||
{
|
|
||||||
_settings.FolderLinks.Remove(selectedFolder);
|
|
||||||
lbxFolders.Items.Refresh();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
string warning = woxAPI.GetTranslation("wox_plugin_folder_select_folder_link_warning");
|
|
||||||
MessageBox.Show(warning);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void btnEdit_Click(object sender, RoutedEventArgs e)
|
|
||||||
{
|
|
||||||
var selectedFolder = lbxFolders.SelectedItem as FolderLink;
|
|
||||||
if (selectedFolder != null)
|
|
||||||
{
|
|
||||||
var folderBrowserDialog = new FolderBrowserDialog();
|
|
||||||
folderBrowserDialog.SelectedPath = selectedFolder.Path;
|
|
||||||
if (folderBrowserDialog.ShowDialog() == DialogResult.OK)
|
|
||||||
{
|
|
||||||
var link = _settings.FolderLinks.First(x => x.Path == selectedFolder.Path);
|
|
||||||
link.Path = folderBrowserDialog.SelectedPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
lbxFolders.Items.Refresh();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
string warning = woxAPI.GetTranslation("wox_plugin_folder_select_folder_link_warning");
|
|
||||||
MessageBox.Show(warning);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void btnAdd_Click(object sender, RoutedEventArgs e)
|
|
||||||
{
|
|
||||||
var folderBrowserDialog = new FolderBrowserDialog();
|
|
||||||
if (folderBrowserDialog.ShowDialog() == DialogResult.OK)
|
|
||||||
{
|
|
||||||
var newFolder = new FolderLink
|
|
||||||
{
|
|
||||||
Path = folderBrowserDialog.SelectedPath
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_settings.FolderLinks == null)
|
|
||||||
{
|
|
||||||
_settings.FolderLinks = new List<FolderLink>();
|
|
||||||
}
|
|
||||||
|
|
||||||
_settings.FolderLinks.Add(newFolder);
|
|
||||||
}
|
|
||||||
|
|
||||||
lbxFolders.Items.Refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void lbxFolders_Drop(object sender, DragEventArgs e)
|
|
||||||
{
|
|
||||||
string[] files = (string[])e.Data.GetData(DataFormats.FileDrop);
|
|
||||||
|
|
||||||
if (files != null && files.Count() > 0)
|
|
||||||
{
|
|
||||||
if (_settings.FolderLinks == null)
|
|
||||||
{
|
|
||||||
_settings.FolderLinks = new List<FolderLink>();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (string s in files)
|
|
||||||
{
|
|
||||||
if (Directory.Exists(s))
|
|
||||||
{
|
|
||||||
var newFolder = new FolderLink
|
|
||||||
{
|
|
||||||
Path = s
|
|
||||||
};
|
|
||||||
|
|
||||||
_settings.FolderLinks.Add(newFolder);
|
|
||||||
}
|
|
||||||
|
|
||||||
lbxFolders.Items.Refresh();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void lbxFolders_DragEnter(object sender, DragEventArgs e)
|
|
||||||
{
|
|
||||||
if (e.Data.GetDataPresent(DataFormats.FileDrop))
|
|
||||||
{
|
|
||||||
e.Effects = DragDropEffects.Link;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
e.Effects = DragDropEffects.None;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Binary file not shown.
Before Width: | Height: | Size: 501 B |
Binary file not shown.
Before Width: | Height: | Size: 19 KiB |
Binary file not shown.
Before Width: | Height: | Size: 290 B |
Binary file not shown.
Before Width: | Height: | Size: 468 B |
Binary file not shown.
Before Width: | Height: | Size: 64 KiB |
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">Löschen</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">Bearbeiten</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">Hinzufügen</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">Ordnerpfad</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">Bitte wähle eine Ordnerverknüpfung</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">Bist du sicher {0} zu löschen?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">Ordner</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">Öffne deine Lieblingsordner direkt von Wox aus</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">Delete</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">Edit</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">Add</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">Folder Path</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">Please select a folder link</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">Are you sure you want to delete {0}?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">Folder</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">Open favorite folder from Wox directly</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">Usuń</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">Edytuj</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">Dodaj</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">Ścieżka folderu</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">Musisz wybrać któryś folder z listy</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">Czy jesteś pewien że chcesz usunąć {0}?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">Foldery</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">Otwórz ulubione foldery bezpośrednio z poziomu Woxa</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">Sil</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">Düzenle</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">Ekle</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">Klasör Konumu</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">Lütfen bir klasör bağlantısı seçin</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">{0} bağlantısını silmek istediğinize emin misiniz?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">Klasör</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">Favori klasörünüzü doğrudan Wox'tan açın</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">删除</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">编辑</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">添加</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">文件夹路径</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">请选择一个文件夹</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">你确定要删除{0}吗?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">文件夹</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">在Wox中直接打开收藏的文件夹</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,15 +0,0 @@
|
|||||||
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
||||||
xmlns:system="clr-namespace:System;assembly=mscorlib">
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete">刪除</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_edit">編輯</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_add">新增</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_folder_path">資料夾路徑</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_select_folder_link_warning">請選擇一個資料夾</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_delete_folder_link">你確認要刪除{0}嗎?</system:String>
|
|
||||||
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_name">資料夾</system:String>
|
|
||||||
<system:String x:Key="wox_plugin_folder_plugin_description">在 Wox 中直接開啟收藏的資料夾</system:String>
|
|
||||||
|
|
||||||
</ResourceDictionary>
|
|
@ -1,310 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Diagnostics;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Windows;
|
|
||||||
using System.Windows.Controls;
|
|
||||||
using Wox.Infrastructure;
|
|
||||||
using Wox.Infrastructure.Storage;
|
|
||||||
|
|
||||||
namespace Wox.Plugin.Folder
|
|
||||||
{
|
|
||||||
public class Main : IPlugin, ISettingProvider, IPluginI18n, ISavable, IContextMenu
|
|
||||||
{
|
|
||||||
public const string FolderImagePath = "Images\\folder.png";
|
|
||||||
public const string FileImagePath = "Images\\file.png";
|
|
||||||
public const string DeleteFileFolderImagePath = "Images\\deletefilefolder.png";
|
|
||||||
public const string CopyImagePath = "Images\\copy.png";
|
|
||||||
|
|
||||||
private string DefaultFolderSubtitleString = "Ctrl + Enter to open the directory";
|
|
||||||
|
|
||||||
private const string _fileExplorerProgramName = "explorer";
|
|
||||||
private static List<string> _driverNames;
|
|
||||||
private PluginInitContext _context;
|
|
||||||
|
|
||||||
private readonly Settings _settings;
|
|
||||||
private readonly PluginJsonStorage<Settings> _storage;
|
|
||||||
private IContextMenu _contextMenuLoader;
|
|
||||||
|
|
||||||
public Main()
|
|
||||||
{
|
|
||||||
_storage = new PluginJsonStorage<Settings>();
|
|
||||||
_settings = _storage.Load();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Save()
|
|
||||||
{
|
|
||||||
_storage.Save();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Control CreateSettingPanel()
|
|
||||||
{
|
|
||||||
return new FileSystemSettings(_context.API, _settings);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Init(PluginInitContext context)
|
|
||||||
{
|
|
||||||
_context = context;
|
|
||||||
_contextMenuLoader = new ContextMenuLoader(context);
|
|
||||||
InitialDriverList();
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Result> Query(Query query)
|
|
||||||
{
|
|
||||||
var results = GetUserFolderResults(query);
|
|
||||||
|
|
||||||
string search = query.Search.ToLower();
|
|
||||||
if (!IsDriveOrSharedFolder(search))
|
|
||||||
return results;
|
|
||||||
|
|
||||||
results.AddRange(QueryInternal_Directory_Exists(query));
|
|
||||||
|
|
||||||
// todo why was this hack here?
|
|
||||||
foreach (var result in results)
|
|
||||||
{
|
|
||||||
result.Score += 10;
|
|
||||||
}
|
|
||||||
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static bool IsDriveOrSharedFolder(string search)
|
|
||||||
{
|
|
||||||
if (search.StartsWith(@"\\"))
|
|
||||||
{ // share folder
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_driverNames != null && _driverNames.Any(search.StartsWith))
|
|
||||||
{ // normal drive letter
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_driverNames == null && search.Length > 2 && char.IsLetter(search[0]) && search[1] == ':')
|
|
||||||
{ // when we don't have the drive letters we can try...
|
|
||||||
return true; // we don't know so let's give it the possibility
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Result CreateFolderResult(string title, string subtitle, string path, Query query)
|
|
||||||
{
|
|
||||||
return new Result
|
|
||||||
{
|
|
||||||
Title = title,
|
|
||||||
IcoPath = path,
|
|
||||||
SubTitle = subtitle,
|
|
||||||
TitleHighlightData = StringMatcher.FuzzySearch(query.Search, title).MatchData,
|
|
||||||
Action = c =>
|
|
||||||
{
|
|
||||||
if (c.SpecialKeyState.CtrlPressed)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Process.Start(_fileExplorerProgramName, path);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
MessageBox.Show(ex.Message, "Could not start " + path);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
string changeTo = path.EndsWith("\\") ? path : path + "\\";
|
|
||||||
_context.API.ChangeQuery(string.IsNullOrEmpty(query.ActionKeyword) ?
|
|
||||||
changeTo :
|
|
||||||
query.ActionKeyword + " " + changeTo);
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
ContextData = new SearchResult { Type = ResultType.Folder, FullPath = path }
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<Result> GetUserFolderResults(Query query)
|
|
||||||
{
|
|
||||||
string search = query.Search.ToLower();
|
|
||||||
var userFolderLinks = _settings.FolderLinks.Where(
|
|
||||||
x => x.Nickname.StartsWith(search, StringComparison.OrdinalIgnoreCase));
|
|
||||||
var results = userFolderLinks.Select(item =>
|
|
||||||
CreateFolderResult(item.Nickname, DefaultFolderSubtitleString, item.Path, query)).ToList();
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void InitialDriverList()
|
|
||||||
{
|
|
||||||
if (_driverNames == null)
|
|
||||||
{
|
|
||||||
_driverNames = new List<string>();
|
|
||||||
var allDrives = DriveInfo.GetDrives();
|
|
||||||
foreach (DriveInfo driver in allDrives)
|
|
||||||
{
|
|
||||||
_driverNames.Add(driver.Name.ToLower().TrimEnd('\\'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static readonly char[] _specialSearchChars = new char[]
|
|
||||||
{
|
|
||||||
'?', '*', '>'
|
|
||||||
};
|
|
||||||
|
|
||||||
private List<Result> QueryInternal_Directory_Exists(Query query)
|
|
||||||
{
|
|
||||||
var search = query.Search;
|
|
||||||
var results = new List<Result>();
|
|
||||||
var hasSpecial = search.IndexOfAny(_specialSearchChars) >= 0;
|
|
||||||
string incompleteName = "";
|
|
||||||
if (hasSpecial || !Directory.Exists(search + "\\"))
|
|
||||||
{
|
|
||||||
// if folder doesn't exist, we want to take the last part and use it afterwards to help the user
|
|
||||||
// find the right folder.
|
|
||||||
int index = search.LastIndexOf('\\');
|
|
||||||
if (index > 0 && index < (search.Length - 1))
|
|
||||||
{
|
|
||||||
incompleteName = search.Substring(index + 1).ToLower();
|
|
||||||
search = search.Substring(0, index + 1);
|
|
||||||
if (!Directory.Exists(search))
|
|
||||||
{
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// folder exist, add \ at the end of doesn't exist
|
|
||||||
if (!search.EndsWith("\\"))
|
|
||||||
{
|
|
||||||
search += "\\";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
results.Add(CreateOpenCurrentFolderResult(incompleteName, search));
|
|
||||||
|
|
||||||
var searchOption = SearchOption.TopDirectoryOnly;
|
|
||||||
incompleteName += "*";
|
|
||||||
|
|
||||||
// give the ability to search all folder when starting with >
|
|
||||||
if (incompleteName.StartsWith(">"))
|
|
||||||
{
|
|
||||||
searchOption = SearchOption.AllDirectories;
|
|
||||||
|
|
||||||
// match everything before and after search term using supported wildcard '*', ie. *searchterm*
|
|
||||||
incompleteName = "*" + incompleteName.Substring(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
var folderList = new List<Result>();
|
|
||||||
var fileList = new List<Result>();
|
|
||||||
|
|
||||||
var folderSubtitleString = DefaultFolderSubtitleString;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
// search folder and add results
|
|
||||||
var directoryInfo = new DirectoryInfo(search);
|
|
||||||
var fileSystemInfos = directoryInfo.GetFileSystemInfos(incompleteName, searchOption);
|
|
||||||
|
|
||||||
foreach (var fileSystemInfo in fileSystemInfos)
|
|
||||||
{
|
|
||||||
if ((fileSystemInfo.Attributes & FileAttributes.Hidden) == FileAttributes.Hidden) continue;
|
|
||||||
|
|
||||||
if(fileSystemInfo is DirectoryInfo)
|
|
||||||
{
|
|
||||||
if (searchOption == SearchOption.AllDirectories)
|
|
||||||
folderSubtitleString = fileSystemInfo.FullName;
|
|
||||||
|
|
||||||
folderList.Add(CreateFolderResult(fileSystemInfo.Name, folderSubtitleString, fileSystemInfo.FullName, query));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
fileList.Add(CreateFileResult(fileSystemInfo.FullName, query));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
if (e is UnauthorizedAccessException || e is ArgumentException)
|
|
||||||
{
|
|
||||||
results.Add(new Result { Title = e.Message, Score = 501 });
|
|
||||||
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Intial ordering, this order can be updated later by UpdateResultView.MainViewModel based on history of user selection.
|
|
||||||
return results.Concat(folderList.OrderBy(x => x.Title)).Concat(fileList.OrderBy(x => x.Title)).ToList();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Result CreateFileResult(string filePath, Query query)
|
|
||||||
{
|
|
||||||
var result = new Result
|
|
||||||
{
|
|
||||||
Title = Path.GetFileName(filePath),
|
|
||||||
SubTitle = filePath,
|
|
||||||
IcoPath = filePath,
|
|
||||||
TitleHighlightData = StringMatcher.FuzzySearch(query.Search, Path.GetFileName(filePath)).MatchData,
|
|
||||||
Action = c =>
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Process.Start(_fileExplorerProgramName, filePath);
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
MessageBox.Show(ex.Message, "Could not start " + filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
ContextData = new SearchResult { Type = ResultType.File, FullPath = filePath}
|
|
||||||
};
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Result CreateOpenCurrentFolderResult(string incompleteName, string search)
|
|
||||||
{
|
|
||||||
var firstResult = "Open current directory";
|
|
||||||
if (incompleteName.Length > 0)
|
|
||||||
firstResult = "Open " + search;
|
|
||||||
|
|
||||||
var folderName = search.TrimEnd('\\').Split(new[] { Path.DirectorySeparatorChar }, StringSplitOptions.None).Last();
|
|
||||||
|
|
||||||
return new Result
|
|
||||||
{
|
|
||||||
Title = firstResult,
|
|
||||||
SubTitle = $"Use > to search files and subfolders within {folderName}, " +
|
|
||||||
$"* to search for file extensions in {folderName} or both >* to combine the search",
|
|
||||||
IcoPath = search,
|
|
||||||
Score = 500,
|
|
||||||
Action = c =>
|
|
||||||
{
|
|
||||||
Process.Start(_fileExplorerProgramName, search);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
public string GetTranslatedPluginTitle()
|
|
||||||
{
|
|
||||||
return _context.API.GetTranslation("wox_plugin_folder_plugin_name");
|
|
||||||
}
|
|
||||||
|
|
||||||
public string GetTranslatedPluginDescription()
|
|
||||||
{
|
|
||||||
return _context.API.GetTranslation("wox_plugin_folder_plugin_description");
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<ContextMenuResult> LoadContextMenus(Result selectedResult)
|
|
||||||
{
|
|
||||||
return _contextMenuLoader.LoadContextMenus(selectedResult);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,12 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
using Wox.Infrastructure.Storage;
|
|
||||||
|
|
||||||
namespace Wox.Plugin.Folder
|
|
||||||
{
|
|
||||||
public class Settings
|
|
||||||
{
|
|
||||||
[JsonProperty]
|
|
||||||
public List<FolderLink> FolderLinks { get; set; } = new List<FolderLink>();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,112 +0,0 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk.WindowsDesktop">
|
|
||||||
|
|
||||||
<PropertyGroup>
|
|
||||||
<TargetFramework>netcoreapp3.1</TargetFramework>
|
|
||||||
<ProjectGuid>{787B8AA6-CA93-4C84-96FE-DF31110AD1C4}</ProjectGuid>
|
|
||||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
|
||||||
<RootNamespace>Wox.Plugin.Folder</RootNamespace>
|
|
||||||
<AssemblyName>Wox.Plugin.Folder</AssemblyName>
|
|
||||||
<UseWindowsForms>true</UseWindowsForms>
|
|
||||||
<AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath>
|
|
||||||
<AppendRuntimeIdentifierToOutputPath>false</AppendRuntimeIdentifierToOutputPath>
|
|
||||||
<Platforms>x64</Platforms>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
|
||||||
<DebugSymbols>true</DebugSymbols>
|
|
||||||
<OutputPath>..\..\..\..\..\x64\Debug\modules\launcher\Plugins\Wox.Plugin.Folder\</OutputPath>
|
|
||||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
|
||||||
<DebugType>full</DebugType>
|
|
||||||
<PlatformTarget>x64</PlatformTarget>
|
|
||||||
<LangVersion>7.3</LangVersion>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<Optimize>false</Optimize>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
|
||||||
<OutputPath>..\..\..\..\..\x64\Release\modules\launcher\Plugins\Wox.Plugin.Folder\</OutputPath>
|
|
||||||
<DefineConstants>TRACE</DefineConstants>
|
|
||||||
<Optimize>true</Optimize>
|
|
||||||
<DebugType>pdbonly</DebugType>
|
|
||||||
<PlatformTarget>x64</PlatformTarget>
|
|
||||||
<LangVersion>7.3</LangVersion>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="plugin.json">
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<Page Include="FolderPluginSettings.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
</Page>
|
|
||||||
<None Include="Images\copy.png">
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
<None Include="Images\deletefilefolder.png">
|
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
<Content Include="Images\file.png">
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<None Include="Images\user.png">
|
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
<Content Include="Languages\en.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<Content Include="Languages\zh-cn.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<Content Include="Languages\zh-tw.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<Content Include="Languages\de.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<Content Include="Languages\pl.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
<Content Include="Languages\tr.xaml">
|
|
||||||
<Generator>MSBuild:Compile</Generator>
|
|
||||||
<SubType>Designer</SubType>
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\..\Wox.Infrastructure\Wox.Infrastructure.csproj" />
|
|
||||||
<ProjectReference Include="..\..\Wox.Plugin\Wox.Plugin.csproj" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="Images\folder.png">
|
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="JetBrains.Annotations" Version="2019.1.3" />
|
|
||||||
<PackageReference Include="Newtonsoft.Json" Version="12.0.3" />
|
|
||||||
<PackageReference Include="System.Runtime" Version="4.3.1" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
</Project>
|
|
@ -1,12 +0,0 @@
|
|||||||
{
|
|
||||||
"ID":"B4D3B69656E14D44865C8D818EAE47C4",
|
|
||||||
"ActionKeyword":"*",
|
|
||||||
"Name":"Folder",
|
|
||||||
"Description":"Open favorite folder from wox directorily",
|
|
||||||
"Author":"qianlifeng",
|
|
||||||
"Version":"1.0.0",
|
|
||||||
"Language":"csharp",
|
|
||||||
"Website":"http://www.wox.one/plugin",
|
|
||||||
"ExecuteFileName":"Wox.Plugin.Folder.dll",
|
|
||||||
"IcoPath":"Images\\folder.png"
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user