mirror of
https://github.com/Flow-Launcher/Flow.Launcher.git
synced 2026-03-11 08:54:32 +00:00
- Add i18n injection to Application.Resources for DynamicResource bindings - Create Avalonia settings views for plugins: - Explorer (ExplorerSettings + QuickAccessLinkSettings dialog) - BrowserBookmark (SettingsControl + CustomBrowserSettingWindow) - Calculator (CalculatorSettings) - ProcessKiller (SettingsControl) - PluginsManager (PluginsManagerSettings) - WebSearch (SettingsControl) - Shell (ShellSetting + converter) - Program (ProgramSetting) - Add IsAvalonia detection pattern for dual-framework dialog support - Update 11 plugin .csproj files with CopyToAvaloniaOutput targets - Add System.Threading.Tasks using for async RelayCommand support
80 lines
2.9 KiB
C#
80 lines
2.9 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Windows.Controls;
|
|
using AvaloniaControl = Avalonia.Controls.Control;
|
|
using System.Threading.Tasks;
|
|
using System.Threading;
|
|
using Flow.Launcher.Plugin.PluginsManager.ViewModels;
|
|
using Flow.Launcher.Plugin.PluginsManager.Views;
|
|
using Flow.Launcher.Plugin.PluginsManager.Views.Avalonia;
|
|
|
|
namespace Flow.Launcher.Plugin.PluginsManager
|
|
{
|
|
public class Main : ISettingProvider, IAsyncPlugin, IContextMenu, IPluginI18n
|
|
{
|
|
internal static PluginInitContext Context { get; set; }
|
|
|
|
internal Settings Settings;
|
|
|
|
private SettingsViewModel viewModel;
|
|
|
|
private IContextMenu contextMenu;
|
|
|
|
internal PluginsManager pluginManager;
|
|
|
|
public Control CreateSettingPanel()
|
|
{
|
|
return new Views.PluginsManagerSettings(viewModel);
|
|
}
|
|
|
|
public AvaloniaControl CreateSettingPanelAvalonia()
|
|
{
|
|
return new Views.Avalonia.PluginsManagerSettings(viewModel);
|
|
}
|
|
|
|
public async Task InitAsync(PluginInitContext context)
|
|
{
|
|
Context = context;
|
|
Settings = context.API.LoadSettingJsonStorage<Settings>();
|
|
viewModel = new SettingsViewModel(context, Settings);
|
|
contextMenu = new ContextMenu(Context);
|
|
pluginManager = new PluginsManager(Context, Settings);
|
|
|
|
await Context.API.UpdatePluginManifestAsync();
|
|
}
|
|
|
|
public List<Result> LoadContextMenus(Result selectedResult)
|
|
{
|
|
return contextMenu.LoadContextMenus(selectedResult);
|
|
}
|
|
|
|
public async Task<List<Result>> QueryAsync(Query query, CancellationToken token)
|
|
{
|
|
if (string.IsNullOrWhiteSpace(query.Search))
|
|
return pluginManager.GetDefaultHotKeys();
|
|
|
|
return query.FirstSearch.ToLower() switch
|
|
{
|
|
//search could be url, no need ToLower() when passed in
|
|
Settings.InstallCommand => await pluginManager.RequestInstallOrUpdateAsync(query.SecondToEndSearch, token, query.IsReQuery),
|
|
Settings.UninstallCommand => pluginManager.RequestUninstall(query.SecondToEndSearch),
|
|
Settings.UpdateCommand => await pluginManager.RequestUpdateAsync(query.SecondToEndSearch, token, query.IsReQuery),
|
|
_ => pluginManager.GetDefaultHotKeys().Where(hotkey =>
|
|
{
|
|
hotkey.Score = Context.API.FuzzySearch(query.Search, hotkey.Title).Score;
|
|
return hotkey.Score > 0;
|
|
}).ToList()
|
|
};
|
|
}
|
|
|
|
public string GetTranslatedPluginTitle()
|
|
{
|
|
return Context.API.GetTranslation("plugin_pluginsmanager_plugin_name");
|
|
}
|
|
|
|
public string GetTranslatedPluginDescription()
|
|
{
|
|
return Context.API.GetTranslation("plugin_pluginsmanager_plugin_description");
|
|
}
|
|
}
|
|
}
|