diff --git a/Patches/CosmeticPanelPatches.cs b/Patches/CosmeticPanelPatches.cs new file mode 100644 index 0000000..f9a9ab1 --- /dev/null +++ b/Patches/CosmeticPanelPatches.cs @@ -0,0 +1,25 @@ +using HarmonyLib; +using System; + +namespace CustomCosmeticLoader.Patches +{ + /* + * Override the marble cosmetic to be the hijacked marble if configured to appear in cosmetic menu. + */ + [HarmonyPatch(typeof(CosmeticPanel), nameof(CosmeticPanel.SelectCosmetic), new Type[] { typeof(Cosmetic), typeof(CosmeticType), typeof(bool) })] + internal class CosmeticPanelSelectCosmeticPatch + { + static void Postfix(CosmeticType ctype) + { + if (!Config.enabled) + return; + + if (ctype == CosmeticType.Skin && Config.inCosmeticMenu && Config.skinNameToHijack != "*") + { + MarbleHolder holder = CosmeticPanel.cosmHolder; + holder.SetMarble(Shared.SkinToHijack); + Shared.ApplyCustomTexture(holder.currentMarble); + } + } + } +} diff --git a/Patches/MarbleHolderPatches.cs b/Patches/MarbleHolderPatches.cs index 1772e4b..36edae5 100644 --- a/Patches/MarbleHolderPatches.cs +++ b/Patches/MarbleHolderPatches.cs @@ -33,9 +33,6 @@ namespace CustomCosmeticLoader.Patches if (marbleObject.Id != Config.skinNameToHijack && Config.skinNameToHijack != "*") return; - if (!Config.inCosmeticMenu && __instance == CosmeticPanel.cosmHolder) - return; - MarbleController controller = MarbleHolderValues.MbcField.GetValue(__instance) as MarbleController; if (controller == null) return;