Merge pull request #1073 from Araxeus/add-starting-page-option

add starting page option
This commit is contained in:
th-ch
2023-03-22 22:04:36 +01:00
committed by GitHub
4 changed files with 51 additions and 5 deletions

View File

@ -16,6 +16,7 @@ const defaultConfig = {
autoResetAppCache: false, autoResetAppCache: false,
resumeOnStart: true, resumeOnStart: true,
proxy: "", proxy: "",
startingPage: "",
}, },
plugins: { plugins: {
// Enabled plugins // Enabled plugins

12
menu.js
View File

@ -7,6 +7,7 @@ const { restart } = require("./providers/app-controls");
const { getAllPlugins } = require("./plugins/utils"); const { getAllPlugins } = require("./plugins/utils");
const config = require("./config"); const config = require("./config");
const { startingPages } = require("./providers/extracted-data");
const prompt = require("custom-electron-prompt"); const prompt = require("custom-electron-prompt");
const promptOptions = require("./providers/prompt-options"); const promptOptions = require("./providers/prompt-options");
@ -81,6 +82,17 @@ const mainMenuTemplate = (win) => {
config.setMenuOption("options.resumeOnStart", item.checked); config.setMenuOption("options.resumeOnStart", item.checked);
}, },
}, },
{
label: 'Starting page',
submenu: Object.keys(startingPages).map((name) => ({
label: name,
type: 'radio',
checked: config.get('options.startingPage') === name,
click: () => {
config.set('options.startingPage', name);
},
}))
},
{ {
label: "Visual Tweaks", label: "Visual Tweaks",
submenu: [ submenu: [

View File

@ -5,8 +5,12 @@ const { setupSongControls } = require("./providers/song-controls-front");
const { ipcRenderer } = require("electron"); const { ipcRenderer } = require("electron");
const is = require("electron-is"); const is = require("electron-is");
const { startingPages } = require("./providers/extracted-data");
const plugins = config.plugins.getEnabled(); const plugins = config.plugins.getEnabled();
const $ = document.querySelector.bind(document);
let api; let api;
plugins.forEach(async ([plugin, options]) => { plugins.forEach(async ([plugin, options]) => {
@ -79,14 +83,14 @@ document.addEventListener("DOMContentLoaded", () => {
}); });
function listenForApiLoad() { function listenForApiLoad() {
api = document.querySelector('#movie_player'); api = $('#movie_player');
if (api) { if (api) {
onApiLoaded(); onApiLoaded();
return; return;
} }
const observer = new MutationObserver(() => { const observer = new MutationObserver(() => {
api = document.querySelector('#movie_player'); api = $('#movie_player');
if (api) { if (api) {
observer.disconnect(); observer.disconnect();
onApiLoaded(); onApiLoaded();
@ -97,7 +101,7 @@ function listenForApiLoad() {
} }
function onApiLoaded() { function onApiLoaded() {
const video = document.querySelector("video"); const video = $("video");
const audioContext = new AudioContext(); const audioContext = new AudioContext();
const audioSource = audioContext.createMediaElementSource(video); const audioSource = audioContext.createMediaElementSource(video);
audioSource.connect(audioContext.destination); audioSource.connect(audioContext.destination);
@ -127,9 +131,15 @@ function onApiLoaded() {
document.dispatchEvent(new CustomEvent('apiLoaded', { detail: api })); document.dispatchEvent(new CustomEvent('apiLoaded', { detail: api }));
ipcRenderer.send('apiLoaded'); ipcRenderer.send('apiLoaded');
// Navigate to "Starting page"
const startingPage = config.get("options.startingPage");
if (startingPage && startingPages[startingPage]) {
$('ytmusic-app')?.navigate_(startingPages[startingPage]);
}
// Remove upgrade button // Remove upgrade button
if (config.get("options.removeUpgradeButton")) { if (config.get("options.removeUpgradeButton")) {
const upgradeButton = document.querySelector('ytmusic-pivot-bar-item-renderer[tab-id="SPunlimited"]') const upgradeButton = $('ytmusic-pivot-bar-item-renderer[tab-id="SPunlimited"]')
if (upgradeButton) { if (upgradeButton) {
upgradeButton.style.display = "none"; upgradeButton.style.display = "none";
} }
@ -139,7 +149,7 @@ function onApiLoaded() {
// Hide / Force show like buttons // Hide / Force show like buttons
const likeButtonsOptions = config.get("options.likeButtons"); const likeButtonsOptions = config.get("options.likeButtons");
if (likeButtonsOptions) { if (likeButtonsOptions) {
const likeButtons = document.querySelector("ytmusic-like-button-renderer"); const likeButtons = $("ytmusic-like-button-renderer");
if (likeButtons) { if (likeButtons) {
likeButtons.style.display = likeButtons.style.display =
{ {

View File

@ -0,0 +1,23 @@
const startingPages = {
Default: '',
Home: 'FEmusic_home',
Explore: 'FEmusic_explore',
'New Releases': 'FEmusic_new_releases',
Charts: 'FEmusic_charts',
'Moods & Genres': 'FEmusic_moods_and_genres',
Library: 'FEmusic_library_landing',
Playlists: 'FEmusic_liked_playlists',
Songs: 'FEmusic_liked_videos',
Albums: 'FEmusic_liked_albums',
Artists: 'FEmusic_library_corpus_track_artists',
'Subscribed Artists': 'FEmusic_library_corpus_artists',
Uploads: 'FEmusic_library_privately_owned_landing',
'Uploaded Playlists': 'FEmusic_liked_playlists',
'Uploaded Songs': 'FEmusic_library_privately_owned_tracks',
'Uploaded Albums': 'FEmusic_library_privately_owned_releases',
'Uploaded Artists': 'FEmusic_library_privately_owned_artists',
};
module.exports = {
startingPages,
};