feat(YouTube Music): Add Change start page patch

Co-authored-by: ILoveOpenSourceApplications <117499019+iloveopensourceapplications@users.noreply.github.com>
This commit is contained in:
oSumAtrIX 2026-03-08 21:44:31 +01:00
parent f22ea5507d
commit bc08ecf785
No known key found for this signature in database
GPG key ID: A9B3094ACDB604B4
7 changed files with 271 additions and 11 deletions

View file

@ -0,0 +1,98 @@
package app.revanced.extension.music.patches;
import static java.lang.Boolean.TRUE;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import app.revanced.extension.shared.Logger;
import app.revanced.extension.music.settings.Settings;
@SuppressWarnings("unused")
public final class ChangeStartPagePatch {
private static final String SHORTCUT_ACTION = "com.google.android.youtube.music.action.shortcut";
private static final String SHORTCUT_CLASS_DESCRIPTOR = "com.google.android.apps.youtube.music.activities.InternalMusicActivity";
private static final String SHORTCUT_TYPE = "com.google.android.youtube.music.action.shortcut_type";
private static final String SHORTCUT_ID_SEARCH = "Eh4IBRDTnQEYmgMiEwiZn+H0r5WLAxVV5OcDHcHRBmPqpd25AQA=";
private static final int SHORTCUT_TYPE_SEARCH = 1;
public enum StartPage {
DEFAULT("", null),
CHARTS("FEmusic_charts", TRUE),
EXPLORE("FEmusic_explore", TRUE),
HISTORY("FEmusic_history", TRUE),
LIBRARY("FEmusic_library_landing", TRUE),
PLAYLISTS("FEmusic_liked_playlists", TRUE),
PODCASTS("FEmusic_non_music_audio", TRUE),
SUBSCRIPTIONS("FEmusic_library_corpus_artists", TRUE),
EPISODES_FOR_LATER("VLSE", TRUE),
LIKED_MUSIC("VLLM", TRUE),
SEARCH("", false);
@NonNull
final String id;
@Nullable
final Boolean isBrowseId;
StartPage(@NonNull String id, @Nullable Boolean isBrowseId) {
this.id = id;
this.isBrowseId = isBrowseId;
}
private boolean isBrowseId() {
return TRUE.equals(isBrowseId);
}
}
private static final String ACTION_MAIN = "android.intent.action.MAIN";
public static String overrideBrowseId(@Nullable String original) {
var startPage = Settings.CHANGE_START_PAGE.get();
if (!startPage.isBrowseId()) {
return original;
}
if (!"FEmusic_home".equals(original)) {
return original;
}
String overrideBrowseId = startPage.id;
if (overrideBrowseId.isEmpty()) {
return original;
}
Logger.printDebug(() -> "Changing browseId to: " + startPage.name());
return overrideBrowseId;
}
public static void overrideIntentActionOnCreate(@NonNull Activity activity,
@Nullable Bundle savedInstanceState) {
if (savedInstanceState != null) return;
var startPage = Settings.CHANGE_START_PAGE.get();
if (startPage != StartPage.SEARCH) return;
var originalIntent = activity.getIntent();
if (originalIntent == null) return;
if (ACTION_MAIN.equals(originalIntent.getAction())) {
Logger.printDebug(() -> "Cold start: Launching search activity directly");
var searchIntent = new Intent();
searchIntent.setAction(SHORTCUT_ACTION);
searchIntent.setClassName(activity, SHORTCUT_CLASS_DESCRIPTOR);
searchIntent.setPackage(activity.getPackageName());
searchIntent.putExtra(SHORTCUT_TYPE, SHORTCUT_TYPE_SEARCH);
searchIntent.putExtra(SHORTCUT_ACTION, SHORTCUT_ID_SEARCH);
activity.startActivity(searchIntent);
}
}
}

View file

@ -3,6 +3,7 @@ package app.revanced.extension.music.settings;
import static java.lang.Boolean.FALSE;
import static java.lang.Boolean.TRUE;
import static app.revanced.extension.music.patches.ChangeHeaderPatch.*;
import static app.revanced.extension.music.patches.ChangeStartPagePatch.*;
import static app.revanced.extension.shared.settings.Setting.parent;
import app.revanced.extension.shared.settings.YouTubeAndMusicSettings;
@ -17,6 +18,7 @@ public class Settings extends YouTubeAndMusicSettings {
public static final BooleanSetting HIDE_GET_PREMIUM_LABEL = new BooleanSetting("revanced_music_hide_get_premium_label", TRUE, true);
// General
public static final EnumSetting<StartPage> CHANGE_START_PAGE = new EnumSetting<>("revanced_change_start_page", StartPage.DEFAULT, true);
public static final BooleanSetting HIDE_CAST_BUTTON = new BooleanSetting("revanced_music_hide_cast_button", TRUE, true);
public static final BooleanSetting HIDE_CATEGORY_BAR = new BooleanSetting("revanced_music_hide_category_bar", FALSE, true);
public static final BooleanSetting HIDE_HISTORY_BUTTON = new BooleanSetting("revanced_music_hide_history_button", FALSE, true);