mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-12 11:01:45 +00:00
69 lines
1.8 KiB
JavaScript
69 lines
1.8 KiB
JavaScript
const path = require("path");
|
|
|
|
const { Menu } = require("electron");
|
|
const electronLocalshortcut = require("electron-localshortcut");
|
|
|
|
const config = require("../../config");
|
|
const { mainMenuTemplate } = require("../../menu");
|
|
const { injectCSS } = require("../utils");
|
|
|
|
//check that menu doesn't get created twice
|
|
let done = false;
|
|
|
|
module.exports = (win) => {
|
|
// css for custom scrollbar + disable drag area(was causing bugs)
|
|
injectCSS(win.webContents, path.join(__dirname, "style.css"));
|
|
|
|
win.on("ready-to-show", () => {
|
|
// (apparently ready-to-show is called twice)
|
|
if (done) {
|
|
return;
|
|
}
|
|
done = true;
|
|
let template = mainMenuTemplate(win, false, false);
|
|
updateCheckboxesAndRadioButtons(win, template);
|
|
let menu = Menu.buildFromTemplate(template);
|
|
Menu.setApplicationMenu(menu);
|
|
|
|
//register keyboard shortcut && hide menu if hideMenu is enabled
|
|
if (config.get("options.hideMenu")) {
|
|
switchMenuVisibility(win);
|
|
electronLocalshortcut.register(win, "Esc", () => {
|
|
switchMenuVisibility(win);
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
let visible = true;
|
|
function switchMenuVisibility(win) {
|
|
visible = !visible;
|
|
win.webContents.send("updateMenu", visible);
|
|
}
|
|
|
|
function checkCheckbox(win, item) {
|
|
//check item
|
|
item.checked = !item.checked;
|
|
//update menu (closes it)
|
|
win.webContents.send("updateMenu", true);
|
|
}
|
|
|
|
// Update checkboxes/radio buttons
|
|
function updateCheckboxesAndRadioButtons(win, template) {
|
|
for (let index in template) {
|
|
let item = template[index];
|
|
// Apply function on submenu
|
|
if (item.submenu != null) {
|
|
updateCheckboxesAndRadioButtons(win, item.submenu);
|
|
}
|
|
// Change onClick of checkbox+radio
|
|
else if (item.type === "checkbox" || item.type === "radio") {
|
|
let originalOnclick = item.click;
|
|
item.click = (itemClicked) => {
|
|
originalOnclick(itemClicked);
|
|
checkCheckbox(win, itemClicked);
|
|
};
|
|
}
|
|
}
|
|
}
|