mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-11 10:31:47 +00:00
Merge pull request #1073 from Araxeus/add-starting-page-option
add starting page option
This commit is contained in:
@ -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
12
menu.js
@ -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: [
|
||||||
|
|||||||
20
preload.js
20
preload.js
@ -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 =
|
||||||
{
|
{
|
||||||
|
|||||||
23
providers/extracted-data.js
Normal file
23
providers/extracted-data.js
Normal 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,
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user