Refresh menu on plugin enable/disable

This commit is contained in:
Araxeus
2021-04-01 18:10:08 +03:00
parent 76f88686da
commit 58481e3133

View File

@ -7,7 +7,7 @@ const is = require("electron-is");
const { getAllPlugins } = require("./plugins/utils"); const { getAllPlugins } = require("./plugins/utils");
const config = require("./config"); const config = require("./config");
const pluginEnabledMenu = (plugin, label = "") => ({ const pluginEnabledMenu = (win, plugin, label = "") => ({
label: label || plugin, label: label || plugin,
type: "checkbox", type: "checkbox",
checked: config.plugins.isEnabled(plugin), checked: config.plugins.isEnabled(plugin),
@ -17,6 +17,7 @@ const pluginEnabledMenu = (plugin, label = "") => ({
} else { } else {
config.plugins.disable(plugin); config.plugins.disable(plugin);
} }
this.setApplicationMenu(win);
}, },
}); });
@ -28,7 +29,7 @@ const mainMenuTemplate = (win) => [
const pluginPath = path.join(__dirname, "plugins", plugin, "menu.js"); const pluginPath = path.join(__dirname, "plugins", plugin, "menu.js");
if (!config.plugins.isEnabled(plugin)) { if (!config.plugins.isEnabled(plugin)) {
return pluginEnabledMenu(plugin); return pluginEnabledMenu(win, plugin);
} }
if (existsSync(pluginPath)) { if (existsSync(pluginPath)) {
@ -36,7 +37,7 @@ const mainMenuTemplate = (win) => [
return { return {
label: plugin, label: plugin,
submenu: [ submenu: [
pluginEnabledMenu(plugin, "Enabled"), pluginEnabledMenu(win, plugin, "Enabled"),
...getPluginMenu(win, config.plugins.getOptions(plugin), () => ...getPluginMenu(win, config.plugins.getOptions(plugin), () =>
module.exports.setApplicationMenu(win) module.exports.setApplicationMenu(win)
), ),
@ -44,7 +45,7 @@ const mainMenuTemplate = (win) => [
}; };
} }
return pluginEnabledMenu(plugin); return pluginEnabledMenu(win, plugin);
}), }),
{ type: "separator" }, { type: "separator" },
{ {