From 294c0ba2052ef59d28f24390b6c9e04fad5a10de Mon Sep 17 00:00:00 2001 From: Terry Hearst Date: Sun, 3 Sep 2023 00:21:15 -0400 Subject: [PATCH] Don't hijack marble in cosmetic menu by default --- Config.cs | 8 +++++++- Patches/MarbleHolderPatches.cs | 3 +++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/Config.cs b/Config.cs index b1f4bcc..b89d691 100644 --- a/Config.cs +++ b/Config.cs @@ -16,10 +16,12 @@ namespace CustomCosmeticLoader public const string PROPERTY_ENABLED = "enabled"; public const string PROPERTY_CURRENT_SKIN = "currentSkin"; public const string PROPERTY_SKIN_TO_HIJACK = "skinToHijack"; + public const string PROPERTY_IN_COSMETIC_MENU = "inCosmeticMenu"; public static bool enabled = true; public static string currentSkin; public static string skinToHijack = "Swirl_M"; // Mirage, simple skin with nice properties + public static bool inCosmeticMenu = false; public static Dictionary skins = new Dictionary(); @@ -71,6 +73,9 @@ namespace CustomCosmeticLoader if (data[PROPERTY_SKIN_TO_HIJACK] != null) skinToHijack = data[PROPERTY_SKIN_TO_HIJACK].Value; + + if (data[PROPERTY_IN_COSMETIC_MENU] != null) + inCosmeticMenu = data[PROPERTY_IN_COSMETIC_MENU].AsBool; } public static void SaveConfig() @@ -79,7 +84,8 @@ namespace CustomCosmeticLoader { { PROPERTY_ENABLED, enabled ? "true" : "false" }, { PROPERTY_CURRENT_SKIN, currentSkin }, - { PROPERTY_SKIN_TO_HIJACK, skinToHijack } + { PROPERTY_SKIN_TO_HIJACK, skinToHijack }, + { PROPERTY_IN_COSMETIC_MENU, inCosmeticMenu ? "true" : "false" }, }; File.WriteAllText(GetConfigPath(), node.ToString()); diff --git a/Patches/MarbleHolderPatches.cs b/Patches/MarbleHolderPatches.cs index 54f8554..40954ab 100644 --- a/Patches/MarbleHolderPatches.cs +++ b/Patches/MarbleHolderPatches.cs @@ -14,6 +14,9 @@ namespace CustomCosmeticLoader.Patches if (marbleObject.Id != Config.skinToHijack && Config.skinToHijack != "*") return; + + if (!Config.inCosmeticMenu && __instance == CosmeticPanel.cosmHolder) + return; MeshRenderer[] componentsInChildren = __instance.currentMarble.GetComponentsInChildren(); for (int i = 0; i < componentsInChildren.Length; i++)