PowerToys/Wox/ViewModel/SettingWindowViewModel.cs

391 lines
13 KiB
C#
Raw Normal View History

2016-05-22 05:44:27 +08:00
using System;
using System.Collections.Generic;
2016-05-23 02:14:59 +08:00
using System.IO;
2016-05-22 05:44:27 +08:00
using System.Linq;
using System.Net;
2016-05-22 06:16:32 +08:00
using System.Windows;
using System.Windows.Controls;
2016-05-23 02:14:59 +08:00
using System.Windows.Media;
using System.Windows.Media.Imaging;
2017-03-06 09:54:06 +08:00
using Wox.Core;
2016-05-22 06:16:32 +08:00
using Wox.Core.Plugin;
2016-05-22 05:44:27 +08:00
using Wox.Core.Resource;
2016-05-23 02:14:59 +08:00
using Wox.Helper;
2016-05-23 06:51:17 +08:00
using Wox.Infrastructure;
2016-06-19 23:18:43 +08:00
using Wox.Infrastructure.Http;
2016-05-22 05:44:27 +08:00
using Wox.Infrastructure.Storage;
2016-06-19 23:18:43 +08:00
using Wox.Infrastructure.UserSettings;
using Wox.Plugin;
2016-05-22 05:44:27 +08:00
namespace Wox.ViewModel
{
public class SettingWindowViewModel : BaseModel
2016-05-22 05:44:27 +08:00
{
private readonly Updater _updater;
private readonly WoxJsonStorage<Settings> _storage;
public SettingWindowViewModel(Updater updater)
2016-05-23 06:51:17 +08:00
{
_updater = updater;
_storage = new WoxJsonStorage<Settings>();
2016-05-23 06:51:17 +08:00
Settings = _storage.Load();
Settings.PropertyChanged += (s, e) =>
{
if (e.PropertyName == nameof(Settings.ActivateTimes))
{
OnPropertyChanged(nameof(ActivatedTimes));
}
};
2016-06-19 23:18:43 +08:00
2016-05-23 06:51:17 +08:00
}
public Settings Settings { get; set; }
public async void UpdateApp()
{
await _updater.UpdateApp();
}
2016-05-23 06:51:17 +08:00
public void Save()
{
_storage.Save();
}
2016-05-23 02:14:59 +08:00
#region general
2016-05-23 06:51:17 +08:00
2017-02-20 04:27:25 +08:00
// todo a better name?
public class LastQueryMode
{
public string Display { get; set; }
public Infrastructure.UserSettings.LastQueryMode Value { get; set; }
}
public List<LastQueryMode> LastQueryModes
{
get
{
List<LastQueryMode> modes = new List<LastQueryMode>();
var enums = (Infrastructure.UserSettings.LastQueryMode[])Enum.GetValues(typeof(Infrastructure.UserSettings.LastQueryMode));
foreach (var e in enums)
{
var key = $"LastQuery{e}";
var display = _translater.GetTranslation(key);
var m = new LastQueryMode { Display = display, Value = e, };
modes.Add(m);
}
return modes;
}
}
2019-09-29 18:04:30 +08:00
public List<string> QuerySearchPrecisionStrings
{
get
{
var precisionStrings = new List<string>();
var enumList = Enum.GetValues(typeof(StringMatcher.SearchPrecisionScore)).Cast<StringMatcher.SearchPrecisionScore>().ToList();
enumList.ForEach(x => precisionStrings.Add(x.ToString()));
return precisionStrings;
}
}
2016-05-23 05:49:41 +08:00
private Internationalization _translater => InternationalizationManager.Instance;
public List<Language> Languages => _translater.LoadAvailableLanguages();
2016-05-22 05:44:27 +08:00
public IEnumerable<int> MaxResultsRange => Enumerable.Range(2, 16);
2016-05-23 06:51:17 +08:00
public string TestProxy()
{
var proxyServer = Settings.Proxy.Server;
var proxyUserName = Settings.Proxy.UserName;
if (string.IsNullOrEmpty(proxyServer))
{
return InternationalizationManager.Instance.GetTranslation("serverCantBeEmpty");
}
if (Settings.Proxy.Port <= 0)
{
return InternationalizationManager.Instance.GetTranslation("portCantBeEmpty");
}
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(_updater.GitHubRepository);
if (string.IsNullOrEmpty(proxyUserName) || string.IsNullOrEmpty(Settings.Proxy.Password))
{
request.Proxy = new WebProxy(proxyServer, Settings.Proxy.Port);
}
else
{
request.Proxy = new WebProxy(proxyServer, Settings.Proxy.Port)
{
Credentials = new NetworkCredential(proxyUserName, Settings.Proxy.Password)
};
}
try
{
var response = (HttpWebResponse)request.GetResponse();
if (response.StatusCode == HttpStatusCode.OK)
{
return InternationalizationManager.Instance.GetTranslation("proxyIsCorrect");
}
else
{
return InternationalizationManager.Instance.GetTranslation("proxyConnectFailed");
}
}
catch
{
return InternationalizationManager.Instance.GetTranslation("proxyConnectFailed");
}
}
2016-05-23 02:14:59 +08:00
#endregion
2016-05-23 06:51:17 +08:00
2016-05-23 02:14:59 +08:00
#region plugin
2016-05-23 06:51:17 +08:00
2018-02-25 02:18:35 +08:00
public static string Plugin => "http://www.wox.one/plugin";
public PluginViewModel SelectedPlugin { get; set; }
2016-05-23 06:51:17 +08:00
2016-05-22 12:51:00 +08:00
public IList<PluginViewModel> PluginViewModels
{
get
{
var plugins = PluginManager.AllPlugins;
var settings = Settings.PluginSettings.Plugins;
plugins.Sort((a, b) =>
{
var d1 = settings[a.Metadata.ID].Disabled;
var d2 = settings[b.Metadata.ID].Disabled;
if (d1 == d2)
{
return string.Compare(a.Metadata.Name, b.Metadata.Name, StringComparison.CurrentCulture);
}
else
{
return d1.CompareTo(d2);
}
});
var metadatas = plugins.Select(p => new PluginViewModel
{
PluginPair = p,
}).ToList();
return metadatas;
}
}
2016-05-22 06:42:23 +08:00
public Control SettingProvider
{
get
{
var settingProvider = SelectedPlugin.PluginPair.Plugin as ISettingProvider;
if (settingProvider != null)
{
2016-05-23 02:23:20 +08:00
var control = settingProvider.CreateSettingPanel();
control.HorizontalAlignment = HorizontalAlignment.Stretch;
control.VerticalAlignment = VerticalAlignment.Stretch;
return control;
}
else
{
return new Control();
}
}
}
2016-05-23 06:51:17 +08:00
2016-05-23 02:14:59 +08:00
#endregion
2016-05-23 06:51:17 +08:00
2016-05-23 02:14:59 +08:00
#region theme
2018-02-25 02:18:35 +08:00
public static string Theme => @"http://www.wox.one/theme/builder";
2016-05-23 06:51:17 +08:00
2016-05-23 02:14:59 +08:00
public string SelectedTheme
2016-05-22 12:51:00 +08:00
{
2016-05-23 06:51:17 +08:00
get { return Settings.Theme; }
2016-05-23 02:14:59 +08:00
set
{
Settings.Theme = value;
ThemeManager.Instance.ChangeTheme(value);
}
}
2016-05-23 06:51:17 +08:00
public List<string> Themes
=> ThemeManager.Instance.LoadAvailableThemes().Select(Path.GetFileNameWithoutExtension).ToList();
2016-05-23 02:14:59 +08:00
public Brush PreviewBackground
{
get
{
var wallpaper = WallpaperPathRetrieval.GetWallpaperPath();
if (wallpaper != null && File.Exists(wallpaper))
{
var memStream = new MemoryStream(File.ReadAllBytes(wallpaper));
var bitmap = new BitmapImage();
bitmap.BeginInit();
bitmap.StreamSource = memStream;
bitmap.EndInit();
var brush = new ImageBrush(bitmap) { Stretch = Stretch.UniformToFill };
2016-05-23 02:14:59 +08:00
return brush;
}
else
{
var wallpaperColor = WallpaperPathRetrieval.GetWallpaperColor();
var brush = new SolidColorBrush(wallpaperColor);
return brush;
}
}
}
public ResultsViewModel PreviewResults
{
get
{
2016-05-23 06:51:17 +08:00
var results = new List<Result>
2016-05-23 02:14:59 +08:00
{
new Result
{
Title = "WoX is a launcher for Windows that simply works.",
2016-05-23 06:51:17 +08:00
SubTitle = "You can call it Windows omni-eXecutor if you want a long name."
2016-05-23 02:14:59 +08:00
},
new Result
{
Title = "Search for everything—applications, folders, files and more.",
2016-05-23 06:51:17 +08:00
SubTitle = "Use pinyin to search for programs. (yyy / wangyiyun → 网易云音乐)"
2016-05-23 02:14:59 +08:00
},
new Result
{
Title = "Keyword plugin search.",
2016-05-23 06:51:17 +08:00
SubTitle = "search google with g search_term."
2016-05-23 02:14:59 +08:00
},
new Result
{
Title = "Build custom themes at: ",
2016-05-23 06:51:17 +08:00
SubTitle = Theme
2016-05-23 02:14:59 +08:00
},
new Result
{
Title = "Install plugins from: ",
2016-05-23 06:51:17 +08:00
SubTitle = Plugin
2016-05-23 02:14:59 +08:00
},
new Result
{
Title = $"Open Source: {_updater.GitHubRepository}",
2016-05-23 06:51:17 +08:00
SubTitle = "Please star it!"
2016-05-23 02:14:59 +08:00
}
};
var vm = new ResultsViewModel();
2016-05-23 02:14:59 +08:00
vm.AddResults(results, "PREVIEW");
return vm;
}
}
public FontFamily SelectedQueryBoxFont
{
get
{
if (Fonts.SystemFontFamilies.Count(o =>
o.FamilyNames.Values != null &&
o.FamilyNames.Values.Contains(Settings.QueryBoxFont)) > 0)
{
var font = new FontFamily(Settings.QueryBoxFont);
return font;
}
else
{
var font = new FontFamily("Segoe UI");
return font;
}
}
set
{
Settings.QueryBoxFont = value.ToString();
ThemeManager.Instance.ChangeTheme(Settings.Theme);
}
}
public FamilyTypeface SelectedQueryBoxFontFaces
{
get
{
var typeface = SyntaxSugars.CallOrRescueDefault(
() => SelectedQueryBoxFont.ConvertFromInvariantStringsOrNormal(
Settings.QueryBoxFontStyle,
Settings.QueryBoxFontWeight,
Settings.QueryBoxFontStretch
));
return typeface;
}
set
{
Settings.QueryBoxFontStretch = value.Stretch.ToString();
Settings.QueryBoxFontWeight = value.Weight.ToString();
Settings.QueryBoxFontStyle = value.Style.ToString();
ThemeManager.Instance.ChangeTheme(Settings.Theme);
}
}
public FontFamily SelectedResultFont
{
get
{
if (Fonts.SystemFontFamilies.Count(o =>
o.FamilyNames.Values != null &&
o.FamilyNames.Values.Contains(Settings.ResultFont)) > 0)
{
var font = new FontFamily(Settings.ResultFont);
return font;
}
else
{
var font = new FontFamily("Segoe UI");
return font;
}
}
set
{
Settings.ResultFont = value.ToString();
ThemeManager.Instance.ChangeTheme(Settings.Theme);
}
2016-05-22 12:51:00 +08:00
}
2016-05-23 02:14:59 +08:00
public FamilyTypeface SelectedResultFontFaces
{
get
{
var typeface = SyntaxSugars.CallOrRescueDefault(
() => SelectedResultFont.ConvertFromInvariantStringsOrNormal(
2016-05-23 02:14:59 +08:00
Settings.ResultFontStyle,
Settings.ResultFontWeight,
Settings.ResultFontStretch
));
return typeface;
}
set
{
Settings.ResultFontStretch = value.Stretch.ToString();
Settings.ResultFontWeight = value.Weight.ToString();
Settings.ResultFontStyle = value.Style.ToString();
ThemeManager.Instance.ChangeTheme(Settings.Theme);
}
}
2016-05-22 12:51:00 +08:00
#endregion
2016-05-23 06:51:17 +08:00
#region hotkey
2016-05-23 06:51:17 +08:00
2016-05-23 05:49:41 +08:00
public CustomPluginHotkey SelectedCustomPluginHotkey { get; set; }
2016-05-23 06:51:17 +08:00
2016-05-23 05:49:41 +08:00
#endregion
2016-05-23 06:51:17 +08:00
2016-05-23 05:49:41 +08:00
#region about
public string Github => _updater.GitHubRepository;
public string ReleaseNotes => _updater.GitHubRepository + @"/releases/latest";
2016-05-23 06:51:17 +08:00
public static string Version => Constant.Version;
public string ActivatedTimes => string.Format(_translater.GetTranslation("about_activate_times"), Settings.ActivateTimes);
2016-05-23 06:51:17 +08:00
#endregion
2016-05-22 05:44:27 +08:00
}
2016-11-21 04:01:47 +08:00
}