mirror of
https://github.com/microsoft/PowerToys.git
synced 2024-12-13 19:19:23 +08:00
#21 Add Disable option for each plugin.
This commit is contained in:
parent
6352408d87
commit
e275ce6063
@ -15,6 +15,14 @@ namespace Wox.Infrastructure.Storage
|
|||||||
private static object locker = new object();
|
private static object locker = new object();
|
||||||
private static T storage;
|
private static T storage;
|
||||||
|
|
||||||
|
public event Action<T> AfterLoadConfig;
|
||||||
|
|
||||||
|
protected virtual void OnAfterLoadConfig(T obj)
|
||||||
|
{
|
||||||
|
Action<T> handler = AfterLoadConfig;
|
||||||
|
if (handler != null) handler(obj);
|
||||||
|
}
|
||||||
|
|
||||||
protected abstract string ConfigName { get; }
|
protected abstract string ConfigName { get; }
|
||||||
|
|
||||||
public static T Instance
|
public static T Instance
|
||||||
@ -53,6 +61,7 @@ namespace Wox.Infrastructure.Storage
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
storage = JsonConvert.DeserializeObject<T>(json);
|
storage = JsonConvert.DeserializeObject<T>(json);
|
||||||
|
OnAfterLoadConfig(storage);
|
||||||
}
|
}
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
|
@ -0,0 +1,18 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace Wox.Infrastructure.Storage.UserSettings
|
||||||
|
{
|
||||||
|
public class CustomizedPluginConfig
|
||||||
|
{
|
||||||
|
public string ID { get; set; }
|
||||||
|
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
public string Actionword { get; set; }
|
||||||
|
|
||||||
|
public bool Disabled { get; set; }
|
||||||
|
}
|
||||||
|
}
|
@ -56,6 +56,8 @@ namespace Wox.Infrastructure.Storage.UserSettings
|
|||||||
[JsonProperty]
|
[JsonProperty]
|
||||||
public List<FolderLink> FolderLinks { get; set; } //Aaron
|
public List<FolderLink> FolderLinks { get; set; } //Aaron
|
||||||
|
|
||||||
|
public List<CustomizedPluginConfig> CustomizedPluginConfigs { get; set; }
|
||||||
|
|
||||||
[JsonProperty]
|
[JsonProperty]
|
||||||
public List<CustomPluginHotkey> CustomPluginHotkeys { get; set; }
|
public List<CustomPluginHotkey> CustomPluginHotkeys { get; set; }
|
||||||
|
|
||||||
@ -147,6 +149,7 @@ namespace Wox.Infrastructure.Storage.UserSettings
|
|||||||
ReplaceWinR = true;
|
ReplaceWinR = true;
|
||||||
WebSearches = LoadDefaultWebSearches();
|
WebSearches = LoadDefaultWebSearches();
|
||||||
ProgramSources = LoadDefaultProgramSources();
|
ProgramSources = LoadDefaultProgramSources();
|
||||||
|
CustomizedPluginConfigs = new List<CustomizedPluginConfig>();
|
||||||
Hotkey = "Alt + Space";
|
Hotkey = "Alt + Space";
|
||||||
QueryBoxFont = FontFamily.GenericSansSerif.Name;
|
QueryBoxFont = FontFamily.GenericSansSerif.Name;
|
||||||
ResultItemFont = FontFamily.GenericSansSerif.Name;
|
ResultItemFont = FontFamily.GenericSansSerif.Name;
|
||||||
@ -156,6 +159,13 @@ namespace Wox.Infrastructure.Storage.UserSettings
|
|||||||
HideWhenDeactive = false;
|
HideWhenDeactive = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void OnAfterLoadConfig(UserSettingStorage storage)
|
||||||
|
{
|
||||||
|
if (storage.CustomizedPluginConfigs == null)
|
||||||
|
{
|
||||||
|
storage.CustomizedPluginConfigs = new List<CustomizedPluginConfig>();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum OpacityMode
|
public enum OpacityMode
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="PeHeaderReader.cs" />
|
<Compile Include="PeHeaderReader.cs" />
|
||||||
|
<Compile Include="Storage\UserSettings\CustomizedPluginConfig.cs" />
|
||||||
<Compile Include="Storage\UserSettings\FolderLink.cs" />
|
<Compile Include="Storage\UserSettings\FolderLink.cs" />
|
||||||
<Compile Include="Unidecoder.Characters.cs" />
|
<Compile Include="Unidecoder.Characters.cs" />
|
||||||
<Compile Include="ChineseToPinYin.cs" />
|
<Compile Include="ChineseToPinYin.cs" />
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using Wox.Infrastructure.Storage.UserSettings;
|
||||||
|
|
||||||
namespace Wox.Plugin.SystemPlugins
|
namespace Wox.Plugin.SystemPlugins
|
||||||
{
|
{
|
||||||
@ -6,6 +8,8 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
public abstract class BaseSystemPlugin : ISystemPlugin
|
public abstract class BaseSystemPlugin : ISystemPlugin
|
||||||
{
|
{
|
||||||
public string PluginDirectory { get; set; }
|
public string PluginDirectory { get; set; }
|
||||||
|
|
||||||
|
public abstract string ID { get; }
|
||||||
public virtual string Name { get { return "System workflow"; } }
|
public virtual string Name { get { return "System workflow"; } }
|
||||||
public virtual string Description { get { return "System workflow"; } }
|
public virtual string Description { get { return "System workflow"; } }
|
||||||
public virtual string IcoPath { get { return null; } }
|
public virtual string IcoPath { get { return null; } }
|
||||||
@ -17,6 +21,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
public List<Result> Query(Query query)
|
public List<Result> Query(Query query)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(query.RawQuery)) return new List<Result>();
|
if (string.IsNullOrEmpty(query.RawQuery)) return new List<Result>();
|
||||||
|
var customizedPluginConfig = UserSettingStorage.Instance.CustomizedPluginConfigs.FirstOrDefault(o => o.ID == ID);
|
||||||
|
if (customizedPluginConfig != null && customizedPluginConfig.Disabled)
|
||||||
|
{
|
||||||
|
return new List<Result>();
|
||||||
|
}
|
||||||
return QueryInternal(query);
|
return QueryInternal(query);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,6 +148,11 @@ namespace Wox.Plugin.SystemPlugins.CMD
|
|||||||
this.context = context;
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "D409510CD0D2481F853690A07E6DC426"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Shell"; }
|
get { return "Shell"; }
|
||||||
|
@ -85,6 +85,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
this.context = context;
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "CEA0FDFC6D3B4085823D60DC76F28855"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Calculator"; }
|
get { return "Calculator"; }
|
||||||
|
@ -101,6 +101,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
return string.Format("{0}{1}.png", ColorsDirectory.FullName, name.Substring(1));
|
return string.Format("{0}{1}.png", ColorsDirectory.FullName, name.Substring(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "9B36CE6181FC47FBB597AA2C29CD9B0A"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Colors"; }
|
get { return "Colors"; }
|
||||||
|
@ -23,7 +23,12 @@ namespace Wox.Plugin.SystemPlugins.Folder {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string Name { get { return "Folder"; } }
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "B4D3B69656E14D44865C8D818EAE47C4"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string Name { get { return "Folder"; } }
|
||||||
public override string IcoPath { get { return @"Images\folder.png"; } }
|
public override string IcoPath { get { return @"Images\folder.png"; } }
|
||||||
|
|
||||||
#endregion Properties
|
#endregion Properties
|
||||||
|
@ -7,6 +7,7 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
{
|
{
|
||||||
public interface ISystemPlugin : IPlugin
|
public interface ISystemPlugin : IPlugin
|
||||||
{
|
{
|
||||||
|
string ID { get; }
|
||||||
string Name { get; }
|
string Name { get; }
|
||||||
string Description { get; }
|
string Description { get; }
|
||||||
}
|
}
|
||||||
|
@ -140,6 +140,11 @@ namespace Wox.Plugin.SystemPlugins.Program
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "791FC278BA414111B8D1886DFE447410"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Programs"; }
|
get { return "Programs"; }
|
||||||
|
@ -118,6 +118,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "CEA08895D2544B019B2E9C5009600DF4"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "System Commands"; }
|
get { return "System Commands"; }
|
||||||
|
@ -22,6 +22,12 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
if (metadata.ActionKeyword.StartsWith(query.RawQuery))
|
if (metadata.ActionKeyword.StartsWith(query.RawQuery))
|
||||||
{
|
{
|
||||||
PluginMetadata metadataCopy = metadata;
|
PluginMetadata metadataCopy = metadata;
|
||||||
|
var customizedPluginConfig = UserSettingStorage.Instance.CustomizedPluginConfigs.FirstOrDefault(o => o.ID == metadataCopy.ID);
|
||||||
|
if (customizedPluginConfig != null && customizedPluginConfig.Disabled)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
Result result = new Result
|
Result result = new Result
|
||||||
{
|
{
|
||||||
Title = metadata.ActionKeyword,
|
Title = metadata.ActionKeyword,
|
||||||
@ -61,6 +67,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "6A122269676E40EB86EB543B945932B9"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Third-party Plugin Indicator"; }
|
get { return "Third-party Plugin Indicator"; }
|
||||||
|
@ -31,6 +31,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
return new List<Result>(0);
|
return new List<Result>(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "0308FD86DE0A4DEE8D62B9B535370992"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name { get { return "URL handler"; } }
|
public override string Name { get { return "URL handler"; } }
|
||||||
public override string Description { get { return "Provide Opening the typed URL from Wox."; } }
|
public override string Description { get { return "Provide Opening the typed URL from Wox."; } }
|
||||||
public override string IcoPath { get { return "Images/url2.png"; } }
|
public override string IcoPath { get { return "Images/url2.png"; } }
|
||||||
|
@ -81,6 +81,11 @@ namespace Wox.Plugin.SystemPlugins
|
|||||||
UserSettingStorage.Instance.WebSearches = UserSettingStorage.Instance.LoadDefaultWebSearches();
|
UserSettingStorage.Instance.WebSearches = UserSettingStorage.Instance.LoadDefaultWebSearches();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override string ID
|
||||||
|
{
|
||||||
|
get { return "565B73353DBF4806919830B9202EE3BF"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override string Name
|
public override string Name
|
||||||
{
|
{
|
||||||
get { return "Web Searches"; }
|
get { return "Web Searches"; }
|
||||||
|
@ -4,6 +4,7 @@ using System.Linq;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using Python.Runtime;
|
using Python.Runtime;
|
||||||
using Wox.Helper;
|
using Wox.Helper;
|
||||||
|
using Wox.Infrastructure.Storage.UserSettings;
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Wox.PluginLoader;
|
using Wox.PluginLoader;
|
||||||
|
|
||||||
@ -19,6 +20,13 @@ namespace Wox.Commands
|
|||||||
PluginPair thirdPlugin = Plugins.AllPlugins.FirstOrDefault(o => o.Metadata.ActionKeyword == q.ActionName);
|
PluginPair thirdPlugin = Plugins.AllPlugins.FirstOrDefault(o => o.Metadata.ActionKeyword == q.ActionName);
|
||||||
if (thirdPlugin != null && !string.IsNullOrEmpty(thirdPlugin.Metadata.ActionKeyword))
|
if (thirdPlugin != null && !string.IsNullOrEmpty(thirdPlugin.Metadata.ActionKeyword))
|
||||||
{
|
{
|
||||||
|
var customizedPluginConfig = UserSettingStorage.Instance.CustomizedPluginConfigs.FirstOrDefault(o => o.ID == thirdPlugin.Metadata.ID);
|
||||||
|
if (customizedPluginConfig != null && customizedPluginConfig.Disabled)
|
||||||
|
{
|
||||||
|
UpdateResultView(null);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (thirdPlugin.Metadata.Language == AllowedLanguage.Python)
|
if (thirdPlugin.Metadata.Language == AllowedLanguage.Python)
|
||||||
{
|
{
|
||||||
SwitchPythonEnv(thirdPlugin);
|
SwitchPythonEnv(thirdPlugin);
|
||||||
@ -29,12 +37,15 @@ namespace Wox.Commands
|
|||||||
{
|
{
|
||||||
thirdPlugin.InitContext.PushResults = (qu, r) =>
|
thirdPlugin.InitContext.PushResults = (qu, r) =>
|
||||||
{
|
{
|
||||||
r.ForEach(o =>
|
if (r != null)
|
||||||
{
|
{
|
||||||
o.PluginDirectory = thirdPlugin.Metadata.PluginDirecotry;
|
r.ForEach(o =>
|
||||||
o.OriginQuery = qu;
|
{
|
||||||
});
|
o.PluginDirectory = thirdPlugin.Metadata.PluginDirecotry;
|
||||||
UpdateResultView(r);
|
o.OriginQuery = qu;
|
||||||
|
});
|
||||||
|
UpdateResultView(r);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
List<Result> results = thirdPlugin.Plugin.Query(q) ?? new List<Result>();
|
List<Result> results = thirdPlugin.Plugin.Query(q) ?? new List<Result>();
|
||||||
thirdPlugin.InitContext.PushResults(q, results);
|
thirdPlugin.InitContext.PushResults(q, results);
|
||||||
|
@ -3,6 +3,7 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
|
using Wox.Infrastructure.Storage.UserSettings;
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Wox.PluginLoader;
|
using Wox.PluginLoader;
|
||||||
|
|
||||||
@ -15,11 +16,11 @@ namespace Wox.Commands
|
|||||||
foreach (PluginPair pair in Plugins.AllPlugins.Where(o => o.Metadata.PluginType == PluginType.System))
|
foreach (PluginPair pair in Plugins.AllPlugins.Where(o => o.Metadata.PluginType == PluginType.System))
|
||||||
{
|
{
|
||||||
PluginPair pair1 = pair;
|
PluginPair pair1 = pair;
|
||||||
|
|
||||||
ThreadPool.QueueUserWorkItem(state =>
|
ThreadPool.QueueUserWorkItem(state =>
|
||||||
{
|
{
|
||||||
pair1.InitContext.PushResults = (q, r) =>
|
pair1.InitContext.PushResults = (q, r) =>
|
||||||
{
|
{
|
||||||
if (r == null || r.Count == 0) return;
|
|
||||||
foreach (Result result in r)
|
foreach (Result result in r)
|
||||||
{
|
{
|
||||||
result.PluginDirectory = pair1.Metadata.PluginDirecotry;
|
result.PluginDirectory = pair1.Metadata.PluginDirecotry;
|
||||||
|
@ -246,9 +246,9 @@ namespace Wox {
|
|||||||
// didn't.
|
// didn't.
|
||||||
if (resultCtrl.Dirty) resultCtrl.Clear();
|
if (resultCtrl.Dirty) resultCtrl.Clear();
|
||||||
}, TimeSpan.FromMilliseconds(100), null);
|
}, TimeSpan.FromMilliseconds(100), null);
|
||||||
|
queryHasReturn = false;
|
||||||
var q = new Query(lastQuery);
|
var q = new Query(lastQuery);
|
||||||
CommandFactory.DispatchCommand(q);
|
CommandFactory.DispatchCommand(q);
|
||||||
queryHasReturn = false;
|
|
||||||
if (Plugins.HitThirdpartyKeyword(q)) {
|
if (Plugins.HitThirdpartyKeyword(q)) {
|
||||||
Dispatcher.DelayInvoke("ShowProgressbar", originQuery => {
|
Dispatcher.DelayInvoke("ShowProgressbar", originQuery => {
|
||||||
if (!queryHasReturn && originQuery == lastQuery) {
|
if (!queryHasReturn && originQuery == lastQuery) {
|
||||||
@ -455,10 +455,10 @@ namespace Wox {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void OnUpdateResultView(List<Result> list) {
|
public void OnUpdateResultView(List<Result> list) {
|
||||||
if (list == null) return;
|
queryHasReturn = true;
|
||||||
|
progressBar.Dispatcher.Invoke(new Action(StopProgress));
|
||||||
|
if (list == null || list.Count == 0) return;
|
||||||
|
|
||||||
queryHasReturn = true;
|
|
||||||
progressBar.Dispatcher.Invoke(new Action(StopProgress));
|
|
||||||
if (list.Count > 0)
|
if (list.Count > 0)
|
||||||
{
|
{
|
||||||
//todo:this should be opened to users, it's their choice to use it or not in their workflows
|
//todo:this should be opened to users, it's their choice to use it or not in their workflows
|
||||||
|
@ -129,7 +129,7 @@
|
|||||||
<TextBlock Opacity="0.5" x:Name="pluginAuthor"></TextBlock>
|
<TextBlock Opacity="0.5" x:Name="pluginAuthor"></TextBlock>
|
||||||
<TextBlock Opacity="0.5" x:Name="pluginWebsite" HorizontalAlignment="Right"></TextBlock>
|
<TextBlock Opacity="0.5" x:Name="pluginWebsite" HorizontalAlignment="Right"></TextBlock>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
<CheckBox Grid.Row="4" x:Name="pluginEnabled">Enable</CheckBox>
|
<CheckBox Grid.Row="4" x:Name="cbDisablePlugin" Click="CbDisablePlugin_OnClick">Disable</CheckBox>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
</ContentControl>
|
</ContentControl>
|
||||||
|
@ -15,6 +15,7 @@ using Wox.Infrastructure.Storage.UserSettings;
|
|||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Wox.Helper;
|
using Wox.Helper;
|
||||||
using Wox.Plugin.SystemPlugins;
|
using Wox.Plugin.SystemPlugins;
|
||||||
|
using Wox.PluginLoader;
|
||||||
using Application = System.Windows.Forms.Application;
|
using Application = System.Windows.Forms.Application;
|
||||||
using File = System.IO.File;
|
using File = System.IO.File;
|
||||||
using MessageBox = System.Windows.MessageBox;
|
using MessageBox = System.Windows.MessageBox;
|
||||||
@ -422,6 +423,8 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
ISettingProvider provider = null;
|
ISettingProvider provider = null;
|
||||||
var pair = lbPlugins.SelectedItem as PluginPair;
|
var pair = lbPlugins.SelectedItem as PluginPair;
|
||||||
|
string pluginId = string.Empty;
|
||||||
|
|
||||||
if (pair != null)
|
if (pair != null)
|
||||||
{
|
{
|
||||||
//third-party plugin
|
//third-party plugin
|
||||||
@ -434,6 +437,7 @@ namespace Wox
|
|||||||
pluginAuthor.Text = "Author: " + pair.Metadata.Author;
|
pluginAuthor.Text = "Author: " + pair.Metadata.Author;
|
||||||
pluginWebsite.Text = "Website: " + pair.Metadata.Website;
|
pluginWebsite.Text = "Website: " + pair.Metadata.Website;
|
||||||
pluginSubTitle.Text = pair.Metadata.Description;
|
pluginSubTitle.Text = pair.Metadata.Description;
|
||||||
|
pluginId = pair.Metadata.ID;
|
||||||
SyntaxSugars.CallOrRescueDefault(
|
SyntaxSugars.CallOrRescueDefault(
|
||||||
() =>
|
() =>
|
||||||
pluginIcon.Source = (ImageSource)new ImagePathConverter().Convert(
|
pluginIcon.Source = (ImageSource)new ImagePathConverter().Convert(
|
||||||
@ -452,6 +456,7 @@ namespace Wox
|
|||||||
if (sys != null)
|
if (sys != null)
|
||||||
{
|
{
|
||||||
pluginTitle.Text = sys.Name;
|
pluginTitle.Text = sys.Name;
|
||||||
|
pluginId = sys.ID;
|
||||||
pluginSubTitle.Text = sys.Description;
|
pluginSubTitle.Text = sys.Description;
|
||||||
pluginAuthor.Visibility = Visibility.Collapsed;
|
pluginAuthor.Visibility = Visibility.Collapsed;
|
||||||
pluginActionKeyword.Visibility = Visibility.Collapsed;
|
pluginActionKeyword.Visibility = Visibility.Collapsed;
|
||||||
@ -466,7 +471,10 @@ namespace Wox
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.PluginContentPanel.Content = null;
|
var customizedPluginConfig = UserSettingStorage.Instance.CustomizedPluginConfigs.FirstOrDefault(o => o.ID == pluginId);
|
||||||
|
cbDisablePlugin.IsChecked = customizedPluginConfig != null && customizedPluginConfig.Disabled;
|
||||||
|
|
||||||
|
PluginContentPanel.Content = null;
|
||||||
if (provider != null)
|
if (provider != null)
|
||||||
{
|
{
|
||||||
Control control = null;
|
Control control = null;
|
||||||
@ -482,5 +490,47 @@ namespace Wox
|
|||||||
// featureControls
|
// featureControls
|
||||||
// throw new NotImplementedException();
|
// throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void CbDisablePlugin_OnClick(object sender, RoutedEventArgs e)
|
||||||
|
{
|
||||||
|
CheckBox cbDisabled = e.Source as CheckBox;
|
||||||
|
if (cbDisabled == null) return;
|
||||||
|
|
||||||
|
var pair = lbPlugins.SelectedItem as PluginPair;
|
||||||
|
var id = string.Empty;
|
||||||
|
var name = string.Empty;
|
||||||
|
if (pair != null)
|
||||||
|
{
|
||||||
|
//third-party plugin
|
||||||
|
id = pair.Metadata.ID;
|
||||||
|
name = pair.Metadata.Name;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//system plugin
|
||||||
|
var sys = lbPlugins.SelectedItem as BaseSystemPlugin;
|
||||||
|
if (sys != null)
|
||||||
|
{
|
||||||
|
id = sys.ID;
|
||||||
|
name = sys.Name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var customizedPluginConfig = UserSettingStorage.Instance.CustomizedPluginConfigs.FirstOrDefault(o => o.ID == id);
|
||||||
|
if (customizedPluginConfig == null)
|
||||||
|
{
|
||||||
|
UserSettingStorage.Instance.CustomizedPluginConfigs.Add(new CustomizedPluginConfig()
|
||||||
|
{
|
||||||
|
Disabled = cbDisabled.IsChecked ?? true,
|
||||||
|
ID = id,
|
||||||
|
Name = name,
|
||||||
|
Actionword = string.Empty
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
customizedPluginConfig.Disabled = cbDisabled.IsChecked ?? true;
|
||||||
|
}
|
||||||
|
UserSettingStorage.Instance.Save();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user