Decompiled source of LethalModManager v0.1.6
LethalModManager.dll
Decompiled 7 months ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.CodeDom.Compiler; using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.IO; using System.IO.Compression; using System.Linq; using System.Net; using System.Net.Http; using System.Reflection; using System.Reflection.Emit; using System.Resources; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; using BepInEx; using BepInEx.Bootstrap; using BepInEx.Configuration; using BepInEx.Logging; using HarmonyLib; using Microsoft.CodeAnalysis; using Newtonsoft.Json; using Steamworks; using Steamworks.Data; using TMPro; using UnityEngine; using UnityEngine.Events; using UnityEngine.Networking; using UnityEngine.Rendering; using UnityEngine.SceneManagement; using UnityEngine.UI; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.Default | DebuggableAttribute.DebuggingModes.DisableOptimizations | DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints | DebuggableAttribute.DebuggingModes.EnableEditAndContinue)] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: AssemblyCompany("LethalModManager")] [assembly: AssemblyConfiguration("Debug")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+d0e680e28ecd8bba0834b1100bf96a5649243635")] [assembly: AssemblyProduct("LethalModManager")] [assembly: AssemblyTitle("LethalModManager")] [assembly: AssemblyMetadata("RepositoryUrl", "https://github.com/Kyxino/LethalModManager")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace LethalModManager { [JsonConverter(typeof(ModInfo))] internal class ModInfoConverter : JsonConverter<ModInfo> { public override bool CanRead => true; public override bool CanWrite => true; public override void WriteJson(JsonWriter writer, ModInfo value, JsonSerializer serializer) { writer.WriteValue(value.ToString()); } public override ModInfo ReadJson(JsonReader reader, Type objectType, ModInfo existingValue, bool hasExistingValue, JsonSerializer serializer) { return ModInfo.Parse(reader.Value.ToString()); } } public class ModInfo { public static Dictionary<string, ModInfo> CachedModInfos = new Dictionary<string, ModInfo>(); public static readonly ModInfo BepInEx_Offline = new ModInfo("BepInEx", "BepInExPack", new Version("5.4.2100")); public static readonly ModInfo LethalModManager_Offline = new ModInfo("kyxino", "LethalModManager", new Version("0.1.6")); private string _Creator; private string _Name; private Version _Version; public string Full_Name; public string Full_Version; public static ModInfo BepInEx => BepInEx_Offline; public static ModInfo LethalModManager => LethalModManager_Offline; public string Creator { get { return _Creator; } set { _Creator = value; Full_Name = value + "-" + _Name; Full_Version = ((_Version != null) ? $"{Full_Name}-{Version}" : null); } } public string Name { get { return _Name; } set { _Name = value; Full_Name = _Creator + "-" + value; Full_Version = ((_Version != null) ? $"{Full_Name}-{Version}" : null); } } public Version Version { get { return _Version; } set { _Version = value; Full_Version = ((value != null) ? $"{_Creator}-{_Name}-{value}" : null); } } public Uri DownloadURL => new Uri($"https://thunderstore.io/package/download/{Creator}/{Name}/{Version}/"); public ModInfo(string ModCreator, string ModName, Version ModVersion = null) { _Creator = ModCreator; _Name = ModName; _Version = ModVersion; Full_Name = ModCreator + "-" + ModName; Full_Version = ((ModVersion != null) ? $"{ModCreator}-{ModName}-{ModVersion}" : null); base..ctor(); } public ModListing GetMod() { ModListing value; return LMM_ModHandler.ThunderstoreData.TryGetValue(Full_Name, out value) ? value : null; } public VersionListing GetVersion(ModListing AltModClassData = null) { return (AltModClassData ?? GetMod())?.Versions?.FirstOrDefault((VersionListing x) => x.Version == Version); } public void Download(bool IncludeDependencies = true, string Profile = null, bool SaveToTempProfile = false, bool IgnoreConfigs = false) { if (IncludeDependencies) { VersionListing version = GetVersion(); IEnumerable<KeyValuePair<ModInfo, int>> enumerable = version.FilteredDependencies.Where((KeyValuePair<ModInfo, int> x) => x.Key.Full_Name != "BepInEx-BepInExPack" && x.Key.Full_Name != "kyxino-LethalModManager"); LMM_ModHandler.DownloadMod(this, Profile, SaveToTempProfile, IgnoreConfigs); foreach (KeyValuePair<ModInfo, int> item in enumerable) { LMM_ModHandler.DownloadMod(item.Key, Profile, SaveToTempProfile, IgnoreConfigs); } } else { LMM_ModHandler.DownloadMod(this, Profile, SaveToTempProfile, IgnoreConfigs); } ModManager.MLS.LogFatal((object)"DONE DOWNLOADING."); } public void SetInfo(string ModCreator, string ModName, Version ModVersion = null) { _Creator = ModCreator; Name = ModName; Version = ModVersion; } public void SetInfo(string ModVersionString) { if (CachedModInfos.TryGetValue(ModVersionString, out var value)) { _Creator = value.Creator; Name = value.Name; Version = value.Version; } else { string[] array = ModVersionString.Split('-'); Version result; int num = ((!Version.TryParse(array[^1], out result)) ? 1 : 2); _Creator = string.Join('-', array, 0, array.Length - num); Name = array[^num]; Version = result; } } public ModInfo WithVersion(Version ModVersion) { return new ModInfo(Creator, Name, ModVersion); } public static ModInfo Parse(string input) { if (CachedModInfos.TryGetValue(input, out var value)) { return value; } string[] array = input.Split('-'); Version result; int num = ((!Version.TryParse(array[^1], out result)) ? 1 : 2); return CachedModInfos[input] = new ModInfo(string.Join('-', array, 0, array.Length - num), array[^num], result); } public static bool TryParse(string input, out ModInfo result) { if (Utility.IsNullOrWhiteSpace(input) || input.Count((char x) => x == '-') < 2) { return (result = null) != null; } result = Parse(input); return true; } public bool Equals(ModInfo B) { return GetHashCode() == B.GetHashCode(); } public override bool Equals(object obj) { return GetHashCode() == obj.GetHashCode(); } public override int GetHashCode() { return HashCode.Combine(Creator, Name, Version); } public static bool operator ==(ModInfo A, ModInfo B) { return A?.GetHashCode() == B?.GetHashCode(); } public static bool operator !=(ModInfo A, ModInfo B) { return A?.GetHashCode() != B?.GetHashCode(); } } public enum ModStatus { Missing, Downloading, Downloaded, Extracting, Installed } public class Profile { public string Name; public string Desc; public string Author; public string Linked; public DirectoryInfo ProfilePath; public Dictionary<string, LocalMod> Mods; } public class LocalMod { public bool Active = false; public ModStatus Status = ModStatus.Missing; public Profile LinkedProfile; public static ModManifestV1 Manifest; public ModInfo Mod; public List<string> LinkedConfigs; public string CorePath; public string PatchersPath; public string PluginsPath; public string TempZipPath; public string CachedZipPath; } public class ModPage { } public class ModListPage { } public class ModListing { public int Downloads = 0; public int Dependents = 0; public int OnceDependents = 0; public int CurrentDependents = 0; [JsonProperty("date_created")] public DateTime Created; [JsonProperty("date_updated")] public DateTime Updated; [JsonProperty("rating_score")] public int Likes; [JsonProperty("is_pinned")] public bool Pinned; [JsonProperty("is_deprecated")] public bool Deprecated; [JsonProperty("has_nsfw_content")] public bool NSFW; [JsonProperty("categories")] public List<string> Tags; [JsonProperty("versions")] public List<VersionListing> Versions; [JsonProperty("full_name")] public ModInfo Info { get; set; } public string Creator => Info.Creator; public string Name => Info.Name; public string Full_Name => Info.Full_Name; } public class ModManifestV1 { [JsonProperty("name")] public string Name; [JsonProperty("version_number")] public Version Version; [JsonProperty("website_url")] public string Website; [JsonProperty("description")] public string Desc; [JsonProperty("dependencies")] public List<ModInfo> Dependencies; public bool UserEnabled = false; public string DirectoryPath; } public class VersionListing { public ModListing Mod; public Version Version; [JsonProperty("full_name")] public string Full_Version; [JsonProperty("description")] public string Desc; public string Icon; [JsonProperty("dependencies")] public List<ModInfo> Dependencies; public Dictionary<ModInfo, int> FilteredDependencies; [JsonProperty("downloads")] public int Downloads; public int Dependents = 0; public int OnceDependents = 0; public int CurrentDependents = 0; [JsonProperty("date_created")] public DateTime Created; [JsonProperty("is_active")] public bool Active; [JsonProperty("file_size")] public long Size; public ModInfo Info => Mod.Info; public string Creator => Info.Creator; public string Name => Info.Name; public string Full_Name => Info.Full_Name; } public enum ModSlotState { Required, Preferred, Optional, Forced, Enabled, Disabled } internal class LMM_ModSlot : MonoBehaviour { public ModInfo ModInfo; public ModManifestV1 ModManifest; public ModSlotState State; public IEnumerator ImageEnumerator; public Button Button; public Image Border; public Image Panel; public RawImage Logo; public Text Label; public Text Desc; public Button Website; public Transform Data; public Text Creator; public Text Downloads; public Text Dependents; public Text Likes; public Text Dependencies; public Text Size; public Text TinyDesc; public Transform Options; public Image OptionsFrame; public Button ProfileDownload; public Dropdown ProfileDropdown; public Button ModToggle; public Button ModDelete; public Dropdown VersionDropdown; private UnityWebRequest LogoRequest; private Texture2D DownloadedTexture; public void SetModInfo(string ModCreator, string ModName, Version ModVersion = null) { if (ModInfo != null) { ModInfo.SetInfo(ModCreator, ModName, ModVersion); } else { ModInfo = new ModInfo(ModCreator, ModName, ModVersion); } } public void SetModInfo(string ModVersionString) { if (ModInfo != null) { ModInfo.SetInfo(ModVersionString); } else { ModInfo = ModInfo.Parse(ModVersionString); } } private void Awake() { //IL_01f2: Unknown result type (might be due to invalid IL or missing references) //IL_01fc: Expected O, but got Unknown //IL_024c: Unknown result type (might be due to invalid IL or missing references) //IL_0256: Expected O, but got Unknown //IL_0269: Unknown result type (might be due to invalid IL or missing references) //IL_0273: Expected O, but got Unknown //IL_0286: Unknown result type (might be due to invalid IL or missing references) //IL_0290: Expected O, but got Unknown //IL_02a3: Unknown result type (might be due to invalid IL or missing references) //IL_02ad: Expected O, but got Unknown Button = ((Component)this).transform.Find<Button>(); Border = ((Component)this).transform.Find<Image>(); Panel = ((Component)this).transform.Find<Image>("Panel"); Logo = ((Component)this).transform.Find<RawImage>("Logo"); Label = ((Component)this).transform.Find<Text>("ModText"); Desc = ((Component)this).transform.Find<Text>("Description"); Website = ((Component)this).transform.Find<Button>("Website"); Data = ((Component)this).transform.Find("Data"); Creator = Data.Find<Text>("CTEXT"); Downloads = Data.Find<Text>("DTEXT"); Dependents = Data.Find<Text>("DPTTEXT"); Likes = Data.Find<Text>("LTEXT"); Dependencies = Data.Find<Text>("DPCTEXT"); Size = ((Component)this).transform.Find<Text>("ModSize"); TinyDesc = ((Component)this).transform.Find<Text>("TinyDesc"); Options = ((Component)this).transform.Find("Options"); OptionsFrame = Options.Find<Image>(); ProfileDownload = Options.Find<Button>("ProfileDownload"); ProfileDropdown = Options.Find<Dropdown>("ProfileDropdown"); ModToggle = Options.Find<Button>("ModToggle"); ModDelete = Options.Find<Button>("ModDelete"); VersionDropdown = Options.Find<Dropdown>("VersionDropdown"); UpdateBorderByState(); ((UnityEvent)Website.onClick).AddListener((UnityAction)delegate { Application.OpenURL("https://thunderstore.io/c/lethal-company/p/" + ModInfo.Creator + "/" + ModInfo.Name + "/" + ((ModInfo.GetVersion() != null && ModManager.SpecificModVersionLink.Value) ? $"v/{ModInfo.Version}/" : "")); }); ((UnityEvent<int>)(object)VersionDropdown.onValueChanged).AddListener((UnityAction<int>)delegate(int VersionId) { ModListing mod = ModInfo.GetMod(); if (mod != null) { ModListing value; List<VersionListing> LocalModVersions = ((mod == null) ? null : (LMM_ModHandler.LocalMods.TryGetValue(mod.Full_Name, out value) ? value : null)?.Versions); List<VersionListing> list = mod?.Versions?.ToList() ?? LocalModVersions; if (LocalModVersions != null) { int i2; for (i2 = 0; i2 < LocalModVersions?.Count; i2++) { if (list.FirstOrDefault((VersionListing x) => x.Version == LocalModVersions[i2].Version) == null) { list.Add(LocalModVersions[i2]); } } } list.Sort((VersionListing x, VersionListing y) => y.Version.CompareTo(x.Version)); ModInfo.Version = list.FirstOrDefault((VersionListing x) => VersionDropdown.options[VersionId].text.EndsWith($": {x.Version}"))?.Version; bool? showOptions = true; UpdateModSlot(null, showOptions); } }); ProfileDropdown.AddOptions(LMM_UI.Actions.Find<Dropdown>("Local/ProfileSelectionDropdown").options); ((UnityEvent)ProfileDownload.onClick).AddListener((UnityAction)delegate { Text obj = ((Component)ProfileDropdown).transform.Find<Text>("Text"); string obj2 = ((obj != null) ? obj.text : null); Transform actions = LMM_UI.Actions; object obj3; if (actions == null) { obj3 = null; } else { Text obj4 = actions.Find<Text>("Local/ProfileSelectionDropdown/Text"); obj3 = ((obj4 != null) ? obj4.text : null); } if (obj2 == (string?)obj3) { LMM_UI.Instance.AddModToUI(ModInfo.Full_Version, LMM_UI.LP_Local); VersionListing version = ModInfo.GetVersion(); foreach (KeyValuePair<ModInfo, int> item in version.FilteredDependencies.Where((KeyValuePair<ModInfo, int> x) => x.Key.Full_Name != "BepInEx-BepInExPack" && x.Key.Full_Name != "kyxino-LethalModManager")) { LMM_UI.Instance.AddModToUI(item.Key.Full_Version, LMM_UI.LP_Local); } } Task.Run(delegate { LMM_UI.DisableInteracts.Add(ProfileDownload); ModInfo.Download(IncludeDependencies: true, ProfileDropdown.options[ProfileDropdown.value].text); LMM_UI.EnableInteracts.Add(ProfileDownload); }); }); ((UnityEvent)Button.onClick).AddListener((UnityAction)delegate { if (State == ModSlotState.Enabled || State == ModSlotState.Disabled) { ((Component)Options).gameObject.SetActive(!((Component)Options).gameObject.activeSelf); } else if (State != ModSlotState.Forced) { SetState((State == ModSlotState.Optional) ? ModSlotState.Preferred : ((State != ModSlotState.Preferred) ? ModSlotState.Optional : ModSlotState.Required)); UpdateBorderByState(); } }); ((UnityEvent)ModToggle.onClick).AddListener((UnityAction)delegate { bool userEnabled = ModManifest.UserEnabled; ((Selectable)ModToggle).interactable = false; DirectoryInfo parent2 = Directory.GetParent(ModManifest.DirectoryPath); if (Directory.Exists(Path.Combine(parent2.Parent.FullName, "plugins", parent2.Name))) { string[] files5 = Directory.GetFiles(Path.Combine(parent2.Parent.FullName, "plugins", parent2.Name), userEnabled ? "*" : "*.old", SearchOption.AllDirectories); foreach (string text8 in files5) { try { string destFileName; if (!userEnabled) { string text9 = text8; destFileName = text9.Substring(0, text9.Length - 4); } else { destFileName = text8 + ".old"; } File.Move(text8, destFileName); } catch (Exception ex5) { ModManager.MLS.LogWarning((object)ex5.Message); } } } if (Directory.Exists(Path.Combine(parent2.Parent.FullName, "patchers", parent2.Name))) { string[] files6 = Directory.GetFiles(Path.Combine(parent2.Parent.FullName, "patchers", parent2.Name), userEnabled ? "*" : "*.old", SearchOption.AllDirectories); foreach (string text10 in files6) { try { string destFileName2; if (!userEnabled) { string text9 = text10; destFileName2 = text9.Substring(0, text9.Length - 4); } else { destFileName2 = text10 + ".old"; } File.Move(text10, destFileName2); } catch (Exception ex6) { ModManager.MLS.LogWarning((object)ex6.Message); } } } if (Directory.Exists(Path.Combine(parent2.Parent.FullName, "core", parent2.Name))) { string[] files7 = Directory.GetFiles(Path.Combine(parent2.Parent.FullName, "core", parent2.Name), userEnabled ? "*" : "*.old", SearchOption.AllDirectories); foreach (string text11 in files7) { try { string destFileName3; if (!userEnabled) { string text9 = text11; destFileName3 = text9.Substring(0, text9.Length - 4); } else { destFileName3 = text11 + ".old"; } File.Move(text11, destFileName3); } catch (Exception ex7) { ModManager.MLS.LogWarning((object)ex7.Message); } } } ((Component)ModToggle).transform.Find<Text>().text = (userEnabled ? "Disable Mod" : "Enable Mod"); ((Selectable)ModToggle).interactable = true; ModManifest.UserEnabled = !userEnabled; UpdateBorderByState(); }); ((UnityEvent)ModDelete.onClick).AddListener((UnityAction)delegate { State = ModSlotState.Disabled; ((Selectable)ModToggle).interactable = false; ((Selectable)ModDelete).interactable = false; DirectoryInfo parent = Directory.GetParent(ModManifest.DirectoryPath); string text = Path.Combine(parent.Parent.FullName, "plugins", parent.Name); string text2 = Path.Combine(parent.Parent.FullName, "patchers", parent.Name); string text3 = Path.Combine(parent.Parent.FullName, "core", parent.Name); try { Directory.Delete(ModManifest.DirectoryPath, recursive: true); } catch (Exception) { string[] files = Directory.GetFiles(ModManifest.DirectoryPath, "*", SearchOption.AllDirectories); foreach (string text4 in files) { File.Move(text4, text4 + ".lmm-delete"); } Directory.Move(ModManifest.DirectoryPath, Path.Combine(Paths.GameRootPath, "DELETE", Random.Range(0, 10000000).ToString("X"))); } try { if (Directory.Exists(text)) { Directory.Delete(text, recursive: true); } } catch (Exception) { if (Directory.Exists(text2)) { string[] files2 = Directory.GetFiles(text, "*", SearchOption.AllDirectories); foreach (string text5 in files2) { File.Move(text5, text5 + ".lmm-delete"); } Directory.Move(text, Path.Combine(Paths.GameRootPath, "DELETE", Random.Range(0, 10000000).ToString("X"))); } } try { if (Directory.Exists(text2)) { Directory.Delete(text2, recursive: true); } } catch (Exception) { if (Directory.Exists(text2)) { string[] files3 = Directory.GetFiles(text2, "*", SearchOption.AllDirectories); foreach (string text6 in files3) { File.Move(text6, text6 + ".lmm-delete"); } Directory.Move(text2, Path.Combine(Paths.GameRootPath, "DELETE", Random.Range(0, 10000000).ToString("X"))); } } try { if (Directory.Exists(text3)) { Directory.Delete(text3, recursive: true); } } catch (Exception) { if (Directory.Exists(text3)) { string[] files4 = Directory.GetFiles(text3, "*", SearchOption.AllDirectories); foreach (string text7 in files4) { File.Move(text7, text7 + ".lmm-delete"); } Directory.Move(text3, Path.Combine(Paths.GameRootPath, "DELETE", Random.Range(0, 10000000).ToString("X"))); } } ModManifest.UserEnabled = false; UpdateBorderByState(); }); } public void SetState(ModSlotState NewState) { if (State != ModSlotState.Forced && State != ModSlotState.Enabled && State != ModSlotState.Disabled) { ((Component)Options).gameObject.SetActive(false); State = NewState; UpdateBorderByState(); } } public void UpdateBorderByState() { //IL_0061: Unknown result type (might be due to invalid IL or missing references) //IL_0066: Unknown result type (might be due to invalid IL or missing references) //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_006c: Unknown result type (might be due to invalid IL or missing references) //IL_0073: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Unknown result type (might be due to invalid IL or missing references) //IL_005a: Unknown result type (might be due to invalid IL or missing references) //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_009e: Unknown result type (might be due to invalid IL or missing references) //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) Image optionsFrame = OptionsFrame; Image border = Border; ModManifestV1 modManifest = ModManifest; Color color = (((Graphic)border).color = Color32.op_Implicit((modManifest != null && !modManifest.UserEnabled) ? LMM_Colors.Secondary_Border : ((State == ModSlotState.Required || State == ModSlotState.Forced) ? Color32.op_Implicit(Color.white) : ((State == ModSlotState.Preferred || State == ModSlotState.Enabled) ? LMM_Colors.Primary_Border : LMM_Colors.Secondary_Border)))); ((Graphic)optionsFrame).color = color; Image panel = Panel; ModManifestV1 modManifest2 = ModManifest; ((Graphic)panel).color = ((modManifest2 != null && !modManifest2.UserEnabled) ? Color.black : Color.white); } public void OnDestroy() { LMM_UI.UpdateUI = true; } public void UpdateDataLayout() { //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0054: Unknown result type (might be due to invalid IL or missing references) //IL_008b: Unknown result type (might be due to invalid IL or missing references) //IL_008e: Unknown result type (might be due to invalid IL or missing references) //IL_0093: Unknown result type (might be due to invalid IL or missing references) //IL_00a7: Unknown result type (might be due to invalid IL or missing references) //IL_00ac: Unknown result type (might be due to invalid IL or missing references) //IL_00b1: Unknown result type (might be due to invalid IL or missing references) //IL_0080: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)Data == (Object)null) { return; } Vector2 val = Vector2.zero; RectTransform[] componentsInChildren = ((Component)Data).GetComponentsInChildren<RectTransform>(true); foreach (RectTransform val2 in componentsInChildren) { if (!((Object)(object)val2 == (Object)(object)Data.Find<RectTransform>())) { val2.anchoredPosition = val; Text component = ((Component)val2).GetComponent<Text>(); if ((Object)(object)component != (Object)null) { val2.sizeDelta = new Vector2(component.preferredWidth, 24f); } Vector2 val3 = val; Rect rect = val2.rect; val = val3 + new Vector2(((Rect)(ref rect)).width + 2f, 0f); } } } public IEnumerator DownloadImage(string MediaUrl) { if ((Object)(object)Logo.texture != (Object)null) { Object.Destroy((Object)(object)Logo.texture); } Logo.texture = null; UnityWebRequest logoRequest = LogoRequest; if (logoRequest != null) { logoRequest.Abort(); } UnityWebRequest logoRequest2 = LogoRequest; if (logoRequest2 != null) { logoRequest2.Dispose(); } LogoRequest = UnityWebRequestTexture.GetTexture(MediaUrl); for (int i = 0; i < ModManager.RetryLogoLoadingTimes.Value; i++) { if (((object)Logo).Equals((object?)null)) { break; } yield return LogoRequest.SendWebRequest(); if (((object)Logo).Equals((object?)null)) { break; } if ((int)LogoRequest.result == 2 || (int)LogoRequest.result == 3) { LogoRequest = UnityWebRequestTexture.GetTexture(MediaUrl); continue; } if ((Object)(object)DownloadedTexture != (Object)null) { Object.Destroy((Object)(object)DownloadedTexture); } DownloadedTexture = DownloadHandlerTexture.GetContent(LogoRequest); if (!((object)Logo).Equals((object?)null)) { Logo.texture = (Texture)(object)DownloadedTexture; } break; } } public void UpdateModSlot(bool? SetActive = null, bool? ShowOptions = false) { if (ImageEnumerator != null) { ((MonoBehaviour)LMM_UI.Instance).StopCoroutine(ImageEnumerator); } ImageEnumerator = null; if (SetActive.HasValue) { ((Component)this).gameObject.SetActive(SetActive.Value); } if (ShowOptions.HasValue) { ((Component)Options).gameObject.SetActive(ShowOptions.Value); } ModListing mod = ModInfo.GetMod(); VersionListing version = ModInfo.GetVersion(mod); string text = ModInfo.Name.Replace('_', ' ') + ((ModInfo.Version != null) ? $" v{ModInfo.Version}" : ""); Label.text = text; Desc.text = version?.Desc ?? ""; ((Component)Website).gameObject.SetActive(version != null || !ModManager.HideLinkIfMissingVersion.Value); Creator.text = ModInfo.Creator ?? "-"; Downloads.text = ((mod == null && (!ModManager.SpecificModVersionDownloads.Value || version == null)) ? "-" : ((!ModManager.SpecificModVersionDownloads.Value) ? mod?.Downloads : version?.Downloads)?.ToString("N0")); Text dependents = Dependents; string text2; if (ModManager.SpecificModVersionDependents.Value ? (version != null) : (mod != null)) { DependentVersionChecks value = ModManager.ModpackVersionCheck.Value; if (1 == 0) { } int num = value switch { DependentVersionChecks.All => ModManager.SpecificModVersionDependents.Value ? version.Dependents : mod.Dependents, DependentVersionChecks.Latest => ModManager.SpecificModVersionDependents.Value ? version.CurrentDependents : mod.CurrentDependents, _ => ModManager.SpecificModVersionDependents.Value ? version.OnceDependents : mod.OnceDependents, }; if (1 == 0) { } text2 = num.ToString("N0"); } else { text2 = "-"; } dependents.text = text2; Likes.text = mod?.Likes.ToString("N0") ?? "-"; Dependencies.text = ((!ModManager.CountFlattenedDependencies.Value) ? version?.Dependencies?.Count : version?.FilteredDependencies?.Count)?.ToString("N0") ?? "-"; UpdateDataLayout(); Text size = Size; object text3; if (version != null) { _ = version.Size; text3 = string.Format("{0}{1}", Math.Round((decimal)((version.Size > 999999) ? ((float)version.Size / 1000000f) : ((version.Size > 999) ? ((float)version.Size / 1000f) : ((float)version.Size)))), (version.Size > 999999) ? "MB" : ((version.Size > 999) ? "KB" : "B")); } else { text3 = ""; } size.text = (string)text3; Text tinyDesc = TinyDesc; object text4; if (mod == null) { text4 = ""; } else { string[] obj = new string[6] { "Tags: ", null, null, null, null, null }; List<string> tags = mod.Tags; obj[1] = ((tags != null) ? GeneralExtensions.Join<string>((IEnumerable<string>)tags, (Func<string, string>)null, ", ") : null) ?? "-"; obj[2] = " | Updated: "; obj[3] = ((mod.Updated == default(DateTime)) ? "-" : LMM_Utils.HowLongAgo(mod.Updated)); obj[4] = " | Created: "; obj[5] = ((mod.Created == default(DateTime)) ? "-" : LMM_Utils.HowLongAgo(mod.Created)); text4 = string.Concat(obj); } tinyDesc.text = (string)text4; Button modDelete = ModDelete; bool interactable = (((Selectable)ModToggle).interactable = ModManifest != null && ModManifest.Version == version?.Version); ((Selectable)modDelete).interactable = interactable; VersionDropdown.ClearOptions(); ModListing value2; List<VersionListing> LocalModVersions = (LMM_ModHandler.LocalMods.TryGetValue(ModInfo.Full_Name, out value2) ? value2 : null)?.Versions; List<VersionListing> list = mod?.Versions?.ToList() ?? LocalModVersions; if (LocalModVersions != null) { int i; for (i = 0; i < LocalModVersions.Count; i++) { if (list.FirstOrDefault((VersionListing x) => x.Version == LocalModVersions[i].Version) == null) { list.Add(LocalModVersions[i]); } } } list?.Sort((VersionListing x, VersionListing y) => y.Version.CompareTo(x.Version)); if (list != null && mod != null) { VersionDropdown.AddOptions(list.Select(delegate(VersionListing x) { bool? flag2 = LMM_ModHandler.UserMods.FirstOrDefault((KeyValuePair<string, ModManifestV1> y) => $"{y.Key}-{y.Value.Version}" == x.Full_Version).Value?.UserEnabled; if (1 == 0) { } string arg = ((!flag2.HasValue) ? (File.Exists(".\\LethalModManager\\ModStorage\\" + x.Full_Version + ".zip") ? "Downloaded " : "") : ((!flag2.GetValueOrDefault()) ? "Inactive " : "Installed ")); if (1 == 0) { } return $"{arg}Version: {x.Version}"; }).ToList()); } if (list != null && version != null) { VersionDropdown.SetValueWithoutNotify(list.IndexOf(version)); } if (version != null) { ((MonoBehaviour)LMM_UI.Instance).StartCoroutine(ImageEnumerator = DownloadImage(version.Icon ?? ("https://gcdn.thunderstore.io/live/repository/icons/" + version.Full_Version + ".png"))); } } public void Update() { if (LMM_UI.BreakUI) { return; } if (LMM_ModHandler.FinishedDownloads.Contains(ModInfo.Full_Version)) { VersionListing version = ModInfo.GetVersion(); Text size = Size; object text; if (version != null) { _ = version.Size; text = string.Format("{0}{1}", Math.Round((decimal)((version.Size > 999999) ? ((float)version.Size / 1000000f) : ((version.Size > 999) ? ((float)version.Size / 1000f) : ((float)version.Size)))), (version.Size > 999999) ? "MB" : ((version.Size > 999) ? "KB" : "B")); } else { text = ""; } size.text = (string)text; LMM_ModHandler.FinishedDownloads.Remove(ModInfo.Full_Version); } else if (LMM_ModHandler.QueuedDownloads.ContainsKey(ModInfo.Full_Version)) { DownloadProgressChangedEventArgs downloadProgressChangedEventArgs = LMM_ModHandler.QueuedDownloads[ModInfo.Full_Version]; Size.text = string.Format("{0}{1}/{2}{3}", Math.Round((decimal)((downloadProgressChangedEventArgs.BytesReceived > 999999) ? ((float)downloadProgressChangedEventArgs.BytesReceived / 1000000f) : ((downloadProgressChangedEventArgs.BytesReceived > 999) ? ((float)downloadProgressChangedEventArgs.BytesReceived / 1000f) : ((float)downloadProgressChangedEventArgs.BytesReceived)))), (downloadProgressChangedEventArgs.BytesReceived > 999999) ? "MB" : ((downloadProgressChangedEventArgs.BytesReceived > 999) ? "KB" : "B"), Math.Round((decimal)((downloadProgressChangedEventArgs.TotalBytesToReceive > 999999) ? ((float)downloadProgressChangedEventArgs.TotalBytesToReceive / 1000000f) : ((downloadProgressChangedEventArgs.TotalBytesToReceive > 999) ? ((float)downloadProgressChangedEventArgs.TotalBytesToReceive / 1000f) : ((float)downloadProgressChangedEventArgs.TotalBytesToReceive)))), (downloadProgressChangedEventArgs.TotalBytesToReceive > 999999) ? "MB" : ((downloadProgressChangedEventArgs.TotalBytesToReceive > 999) ? "KB" : "B")); } } } [StructLayout(LayoutKind.Sequential, Size = 1)] public struct LMM_Colors { public static Color32 Background_Tint = new Color32((byte)58, (byte)0, (byte)0, (byte)201); public static Color32 Logo_Mult = new Color32(byte.MaxValue, byte.MaxValue, byte.MaxValue, byte.MaxValue); public static Color32 Primary_Frame = new Color32((byte)79, (byte)0, (byte)0, byte.MaxValue); public static Color32 Primary_Border = new Color32((byte)202, (byte)48, (byte)0, byte.MaxValue); public static Color32 Secondary_Border = new Color32((byte)64, (byte)0, (byte)0, byte.MaxValue); public static Color32 Primary_Text = new Color32(byte.MaxValue, (byte)122, (byte)0, byte.MaxValue); public static Color32 Secondary_Text_Icons = new Color32((byte)202, (byte)48, (byte)0, byte.MaxValue); public static Color32 Unknown_1 = new Color32(byte.MaxValue, byte.MaxValue, byte.MaxValue, (byte)0); public static Color32 Dropdown_Normal = new Color32((byte)87, (byte)0, (byte)0, byte.MaxValue); public static Color32 Dropdown_Highlighted = new Color32((byte)118, (byte)0, (byte)0, byte.MaxValue); public static Color32 Dropdown_Selected = new Color32((byte)118, (byte)0, (byte)0, byte.MaxValue); public static Color32 Dropdown_Pressed = new Color32((byte)0, (byte)0, (byte)0, byte.MaxValue); } internal class LMM_UI : MonoBehaviour { [CompilerGenerated] private static class <>O { public static Func<string, string> <0>__GetFileName; public static UnityAction <1>__UpdateThunderstoreData; } [Serializable] [CompilerGenerated] private sealed class <>c { public static readonly <>c <>9 = new <>c(); public static Action <>9__14_0; public static Comparison<ModListing> <>9__31_0; public static Comparison<ModListing> <>9__31_1; public static Comparison<ModListing> <>9__31_2; public static Comparison<ModListing> <>9__31_8; public static Comparison<ModListing> <>9__31_9; public static Comparison<ModListing> <>9__31_10; public static Comparison<ModListing> <>9__31_11; public static Comparison<ModListing> <>9__31_12; public static Comparison<ModListing> <>9__31_13; public static Comparison<ModListing> <>9__31_3; public static Comparison<ModListing> <>9__31_4; public static Comparison<ModListing> <>9__31_5; public static Comparison<ModListing> <>9__31_6; public static Comparison<ModListing> <>9__31_7; public static Func<string, string> <>9__32_0; public static UnityAction <>9__34_0; public static UnityAction <>9__34_1; public static UnityAction <>9__34_2; public static UnityAction <>9__34_3; public static Func<ModListing, bool> <>9__34_24; public static UnityAction <>9__34_20; public static UnityAction <>9__34_21; internal void <Awake>b__14_0() { LMM_ModHandler.LoadThunderstoreData(ModManager.ForceUpdateUponOpening.Value); } internal int <ResortData>b__31_0(ModListing x, ModListing y) { return y.Updated.CompareTo(x.Updated); } internal int <ResortData>b__31_1(ModListing x, ModListing y) { return y.Created.CompareTo(x.Created); } internal int <ResortData>b__31_2(ModListing x, ModListing y) { return y.Downloads.CompareTo(x.Downloads); } internal int <ResortData>b__31_8(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().Dependents.CompareTo(x.Versions.FirstOrDefault().Dependents); } internal int <ResortData>b__31_9(ModListing x, ModListing y) { return y.Dependents.CompareTo(x.Dependents); } internal int <ResortData>b__31_10(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().CurrentDependents.CompareTo(x.Versions.FirstOrDefault().CurrentDependents); } internal int <ResortData>b__31_11(ModListing x, ModListing y) { return y.CurrentDependents.CompareTo(x.CurrentDependents); } internal int <ResortData>b__31_12(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().OnceDependents.CompareTo(x.Versions.FirstOrDefault().OnceDependents); } internal int <ResortData>b__31_13(ModListing x, ModListing y) { return y.OnceDependents.CompareTo(x.OnceDependents); } internal int <ResortData>b__31_3(ModListing x, ModListing y) { return y.Likes.CompareTo(x.Likes); } internal int <ResortData>b__31_4(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().FilteredDependencies.Count.CompareTo(x.Versions.FirstOrDefault().FilteredDependencies.Count); } internal int <ResortData>b__31_5(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().Dependencies.Count.CompareTo(x.Versions.FirstOrDefault().Dependencies.Count); } internal int <ResortData>b__31_6(ModListing x, ModListing y) { return y.Versions.Count.CompareTo(x.Versions.Count); } internal int <ResortData>b__31_7(ModListing x, ModListing y) { return y.Versions.FirstOrDefault().Size.CompareTo(x.Versions.FirstOrDefault().Size); } internal string <UpdateProfileSelection>b__32_0(string x) { return "TEMP: " + Path.GetFileName(x); } internal void <Start>b__34_0() { LoadMenu("Local"); } internal void <Start>b__34_1() { LoadMenu("Thunderstore"); } internal void <Start>b__34_2() { LoadMenu("Downloads"); } internal void <Start>b__34_3() { ConfigsToDownload = null; ModManager.JoiningLobbyId = null; ((Component)LMM_Canvas).gameObject.SetActive(false); } internal bool <Start>b__34_24(ModListing x) { int result; if (!x.Tags.Contains("Modpacks")) { VersionListing? versionListing = x.Versions.FirstOrDefault(); result = ((versionListing != null && versionListing.Dependencies?.Count < 10) ? 1 : 0); } else { result = 0; } return (byte)result != 0; } internal void <Start>b__34_20() { ModManager.MLS.LogFatal((object)"Attempting to open lobby via mod sync."); using WebClient webClient = new WebClient(); Dictionary<string, int> dictionary = new Dictionary<string, int>(); for (int i = 0; i < LP_Host.childCount; i++) { LMM_ModSlot component = ((Component)LP_Host.GetChild(i)).GetComponent<LMM_ModSlot>(); dictionary.Add(component.ModInfo.Full_Version, (component.State != ModSlotState.Optional) ? ((component.State == ModSlotState.Preferred) ? 1 : (-1)) : 0); } ((Component)LMM_Canvas).gameObject.SetActive(false); Dictionary<string, object> dictionary2 = new Dictionary<string, object> { ["Mods"] = dictionary, ["Configs"] = LMM_ModHandler.CompressConfigs() }; string data = "#lethalmodmanager\n" + Convert.ToBase64String(Encoding.ASCII.GetBytes(JsonConvert.SerializeObject((object)dictionary2))); webClient.Headers.Add("Content-Type", "application/octet-stream"); string text = webClient.UploadString("https://thunderstore.io/api/experimental/legacyprofile/create/", data); Dictionary<string, object> dictionary3 = JsonConvert.DeserializeObject<Dictionary<string, object>>(text); ModManager.MLS.LogWarning((object)text); if (!dictionary3.TryGetValue("key", out var value)) { FailedOpenLobby = Time.time + 1f; return; } ModManager.ModSyncKey = value.ToString(); ModManager.ModSyncCount = dictionary.Count; ModManager.MLS.LogWarning((object)ModManager.ModSyncKey); ModManager.OpeningLobby = true; Object.FindObjectOfType<MenuManager>().ConfirmHostButton(); } internal void <Start>b__34_21() { for (int i = 0; i < LP_LobbyMods.childCount; i++) { ((Component)LP_LobbyMods.GetChild(i)).GetComponent<LMM_ModSlot>()?.SetState(ModSlotState.Preferred); } } } public static LMM_UI Instance; public static Transform LMM_Canvas; public static Transform Actions; public static Transform ListPanel; public static Transform LP_Local; public static Transform LP_Thunderstore; public static Transform LP_Downloads; public static Transform LP_Host; public static Transform LP_Config; public static Transform LP_LobbyMods; public static Transform LP_LobbyConfigs; public static GameObject ModSlotTemp; public static GameObject ModManagerCanvas; public static float? FailedOpenLobby; public static bool AttemptQuickReload = false; public static ulong? AttemptQuickLobby = null; public static bool UpdateModSlots = false; public static bool BreakUI = false; public static bool ResortUI = false; public static bool UpdateUI = true; public static bool SwitchedPanel = true; public static bool PreviousActive = false; public static float PreviousWidth = 0f; public static float PreviousHeight = 0f; public static List<Button> DisableInteracts = new List<Button>(); public static List<Button> EnableInteracts = new List<Button>(); public static string ConfigsToDownload; public void AddModToUI(string DepString, Transform Parent, ModManifestV1 Manifest = null, ModSlotState State = ModSlotState.Enabled, bool IgnoreExisting = false) { //IL_00df: Unknown result type (might be due to invalid IL or missing references) if (!IgnoreExisting) { for (int i = 0; i < Parent.childCount; i++) { ModInfo modInfo = ModInfo.Parse(DepString); LMM_ModSlot component = ((Component)Parent.GetChild(i)).GetComponent<LMM_ModSlot>(); if (!(component.ModInfo.Full_Name != modInfo.Full_Name)) { component.ModInfo = modInfo; component.UpdateBorderByState(); component.UpdateModSlot(null, false); UpdateUI = true; return; } } } LMM_ModSlot lMM_ModSlot = Object.Instantiate<GameObject>(ModSlotTemp).AddComponent<LMM_ModSlot>(); lMM_ModSlot.ModManifest = Manifest; lMM_ModSlot.SetState(State); lMM_ModSlot.UpdateBorderByState(); lMM_ModSlot.SetModInfo(DepString); lMM_ModSlot.UpdateModSlot(null, false); ((Component)lMM_ModSlot).transform.SetParent(Parent); ((Component)lMM_ModSlot).transform.localScale = Vector3.one; UpdateUI = true; } private void Awake() { Instance = this; AssetBundle val = null; try { val = AssetBundle.LoadFromMemory(Resource1.LethalModManagerUI); } catch (Exception ex) { ModManager.MLS.LogError((object)ex); } if ((Object)(object)val == (Object)null) { ModManager.MLS.LogWarning((object)"LethalModManager could not load, WHAT."); return; } ModManager.MLS.LogWarning((object)"LethalModManagerUI has loaded."); Object obj = val.LoadAsset("ModSlotV2.prefab"); ModSlotTemp = (GameObject)(object)((obj is GameObject) ? obj : null); Object obj2 = val.LoadAsset("LMM_Canvas.prefab"); ModManagerCanvas = (GameObject)(object)((obj2 is GameObject) ? obj2 : null); ModManagerCanvas.GetComponent<CanvasScaler>().uiScaleMode = (ScaleMode)(ModManager.ScaleUI.Value ? 1 : 0); ModManagerCanvas.GetComponent<CanvasScaler>().matchWidthOrHeight = ModManager.ScaleBetweenWidthToHeight.Value; Object.DontDestroyOnLoad((Object)(object)ModManagerCanvas); Task.Run(delegate { LMM_ModHandler.LoadThunderstoreData(ModManager.ForceUpdateUponOpening.Value); }); } private void Update() { //IL_029c: Unknown result type (might be due to invalid IL or missing references) //IL_0428: Unknown result type (might be due to invalid IL or missing references) //IL_042d: Unknown result type (might be due to invalid IL or missing references) //IL_044d: Unknown result type (might be due to invalid IL or missing references) //IL_0452: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)Instance == (Object)null || BreakUI) { return; } if (AttemptQuickReload && LMM_ModHandler.QueuedDownloads.Count <= 0 && LMM_ModHandler.ExtractingMods.Count <= 0) { AttemptQuickReload = false; ModManager.DoorstopSettings.Add("isQuickReloaded=true"); ModManager.DoorstopSettings.Add("reloadLaunchMode=" + ((GameNetworkManager.Instance?.disableSteam).Value ? "LAN" : "Online")); if (AttemptQuickLobby.HasValue) { ModManager.DoorstopSettings.Add("joiningLobbyId=" + AttemptQuickLobby); } File.WriteAllLines(Path.Combine(Paths.GameRootPath, "doorstop_config.ini"), ModManager.DoorstopSettings); Process process = new Process { StartInfo = new ProcessStartInfo("steam://rungameid/1966720") { UseShellExecute = true } }; ModManager.MLS.LogWarning((object)process.Start()); Process.GetCurrentProcess().Kill(); return; } while (DisableInteracts.Count > 0) { ((Selectable)DisableInteracts[0]).interactable = false; DisableInteracts.Remove(DisableInteracts[0]); } while (EnableInteracts.Count > 0) { ((Selectable)EnableInteracts[0]).interactable = true; EnableInteracts.Remove(EnableInteracts[0]); } if (!((Component)LMM_Canvas).gameObject.activeSelf) { return; } if (FailedOpenLobby.HasValue) { if (FailedOpenLobby <= Time.time) { FailedOpenLobby = null; } Actions.Find<Text>("Host/OpenLobby/Text").text = ((!FailedOpenLobby.HasValue) ? "Open Lobby" : "Failed"); } if (ResortUI) { ResortUI = false; if ((Object)(object)Actions != (Object)null) { ((Transform)Actions.Find<RectTransform>("Thunderstore/ReverseSort/Text")).eulerAngles = new Vector3(0f, 0f, (float)(LMM_ModHandler.TS_Reversed ? 90 : (-90))); } ResortData(); } if (UpdateModSlots) { UpdateModSlots = false; for (int i = 0; i < LP_Host.childCount; i++) { ((Component)LP_Host.GetChild(i)).GetComponent<LMM_ModSlot>().UpdateModSlot(null, false); } for (int j = 0; j < LP_Local.childCount; j++) { ((Component)LP_Local.GetChild(j)).GetComponent<LMM_ModSlot>().UpdateModSlot(null, false); } for (int k = 0; k < LP_Downloads.childCount; k++) { ((Component)LP_Downloads.GetChild(k)).GetComponent<LMM_ModSlot>().UpdateModSlot(null, false); } } if (LMM_ModHandler.DownloadedMods.Count > 0) { string text = LMM_ModHandler.DownloadedMods.FirstOrDefault(); LMM_ModHandler.DownloadedMods.Remove(text); AddModToUI(Path.GetFileNameWithoutExtension(text), LP_Downloads); } bool flag = PreviousActive == (PreviousActive = ((Component)LMM_Canvas).gameObject.activeSelf); if (!UpdateUI && !SwitchedPanel && flag) { float previousWidth = PreviousWidth; Rect rect = LMM_Canvas.Find<RectTransform>().rect; if (previousWidth == (PreviousWidth = ((Rect)(ref rect)).width)) { float previousHeight = PreviousHeight; rect = ((Component)LMM_Canvas).GetComponent<RectTransform>().rect; if (previousHeight == (PreviousHeight = ((Rect)(ref rect)).height)) { return; } } } UpdateUI = false; SwitchedPanel = false; LMM_Utils.AdjustScroll(LP_Local); LMM_Utils.AdjustScroll(LP_Thunderstore); LMM_Utils.AdjustScroll(LP_Downloads); LMM_Utils.AdjustScroll(LP_Host); LMM_Utils.AdjustScroll(LP_LobbyMods); } public void UpdatePage(int Offset) { if (LMM_ModHandler.TS_SearchChoice == null) { return; } int count = LMM_ModHandler.TS_SearchChoice.Count; ModManager.MLS.LogWarning((object)$"{Offset} | {count} | {LMM_ModHandler.TS_Count} | {Math.Max(0, Mathf.FloorToInt((float)(count - 1) / (float)LMM_ModHandler.TS_Count) * LMM_ModHandler.TS_Count)}"); Offset = Math.Clamp(Offset, 0, Math.Max(0, Mathf.FloorToInt((float)(count - 1) / (float)LMM_ModHandler.TS_Count) * LMM_ModHandler.TS_Count)); for (int i = 0; i < Math.Min(Offset + LMM_ModHandler.TS_Count, count) - Offset; i++) { if (i < LP_Thunderstore.childCount) { LMM_ModSlot component = ((Component)LP_Thunderstore.GetChild(i)).GetComponent<LMM_ModSlot>(); if (Object.op_Implicit((Object)(object)component)) { ModListing modListing = LMM_ModHandler.TS_SearchChoice[i + Offset]; component.SetModInfo(modListing.Creator, modListing.Name, modListing?.Versions?.FirstOrDefault()?.Version); component.UpdateModSlot(true, false); } } else { AddModToUI(LMM_ModHandler.TS_SearchChoice[i + Offset].Versions.FirstOrDefault()?.Full_Version, LP_Thunderstore); } } for (int j = Math.Min(Offset + LMM_ModHandler.TS_Count, count) - Offset; j < LP_Thunderstore.childCount; j++) { LMM_ModSlot component2 = ((Component)LP_Thunderstore.GetChild(j)).GetComponent<LMM_ModSlot>(); ((MonoBehaviour)component2).StopAllCoroutines(); Object.Destroy((Object)(object)((Component)component2).gameObject); } LMM_ModHandler.TS_Offset = Offset; Actions.Find<InputField>("Thunderstore/InputPage").SetTextWithoutNotify($"{Math.Ceiling((float)(LMM_ModHandler.TS_Offset + LMM_ModHandler.TS_Count) / (float)LMM_ModHandler.TS_Count)}"); UpdateUI = true; SwitchedPanel = true; } public static void LoadMenu(string MenuName) { try { ((Component)LMM_Canvas).gameObject.SetActive(true); RectTransform val = ListPanel.Find<RectTransform>(MenuName); LMM_Utils.HideOthersInParent((Transform)(object)val); LMM_Utils.HideOthersInParent(Actions.Find(MenuName)); ListPanel.Find<ScrollRect>().content = val; UpdateUI = true; SwitchedPanel = true; } catch (Exception ex) { ModManager.MLS.LogWarning((object)ex.Message); } } public void ResortData(int? Value = null) { Dropdown val = Actions?.Find<Dropdown>("Thunderstore/SortDropdown"); if ((Object)(object)val == (Object)null) { return; } OptionData obj = val.options[Value ?? val.value]; switch (((obj != null) ? obj.text : null) ?? "Last Updated") { default: LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Updated.CompareTo(x.Updated)); break; case "Last Released": LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Created.CompareTo(x.Created)); break; case "Most Downloads": LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Downloads.CompareTo(x.Downloads)); break; case "Most Dependents": switch (ModManager.ModpackVersionCheck.Value) { case DependentVersionChecks.All: if (ModManager.SpecificModVersionDependents.Value) { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().Dependents.CompareTo(x.Versions.FirstOrDefault().Dependents)); } else { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Dependents.CompareTo(x.Dependents)); } break; case DependentVersionChecks.Latest: if (ModManager.SpecificModVersionDependents.Value) { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().CurrentDependents.CompareTo(x.Versions.FirstOrDefault().CurrentDependents)); } else { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.CurrentDependents.CompareTo(x.CurrentDependents)); } break; default: if (ModManager.SpecificModVersionDependents.Value) { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().OnceDependents.CompareTo(x.Versions.FirstOrDefault().OnceDependents)); } else { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.OnceDependents.CompareTo(x.OnceDependents)); } break; } break; case "Most Likes": LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Likes.CompareTo(x.Likes)); break; case "Most Dependencies": if (ModManager.CountFlattenedDependencies.Value) { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().FilteredDependencies.Count.CompareTo(x.Versions.FirstOrDefault().FilteredDependencies.Count)); } else { LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().Dependencies.Count.CompareTo(x.Versions.FirstOrDefault().Dependencies.Count)); } break; case "Most Versions": LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.Count.CompareTo(x.Versions.Count)); break; case "Latest Size": LMM_ModHandler.TS_SearchChoice.Sort((ModListing x, ModListing y) => y.Versions.FirstOrDefault().Size.CompareTo(x.Versions.FirstOrDefault().Size)); break; } if (LMM_ModHandler.TS_Reversed) { LMM_ModHandler.TS_SearchChoice?.Reverse(); } UpdatePage(LMM_ModHandler.TS_Offset); } public void UpdateProfileSelection(Dropdown ProfileSelectionDropdown, bool Select = false) { ProfileSelectionDropdown.ClearOptions(); ProfileSelectionDropdown.AddOptions(new List<string> { "Main Directory" }); List<string> list = (from x in Directory.GetDirectories(ModManager.DIR_TempProfiles.FullName) select "TEMP: " + Path.GetFileName(x)).ToList(); ProfileSelectionDropdown.AddOptions(list); List<string> list2 = Directory.GetDirectories(ModManager.DIR_Profiles.FullName).Select(Path.GetFileName).ToList(); ProfileSelectionDropdown.AddOptions(list2); string fullName = ModManager.DIR_CurrentProfile.Parent.FullName; ModManager.MLS.LogFatal((object)fullName); ModManager.MLS.LogFatal((object)ModManager.DIR_LethalCompany.FullName); string text = ((ModManager.DIR_Profiles.FullName == fullName) ? "LMM" : ((ModManager.DIR_TempProfiles.FullName == fullName) ? "TEMP" : ((ModManager.DIR_LethalCompany.FullName == ModManager.DIR_CurrentProfile.FullName) ? "MAIN" : "ALT"))); if (text == "ALT") { ProfileSelectionDropdown.AddOptions(new List<string> { "ALT: " + ModManager.DIR_CurrentProfile.Name }); if (Select) { ProfileSelectionDropdown.value = ProfileSelectionDropdown.options.Count; } } else { if (!(text != "MAIN")) { return; } List<string> ProfilesDirectory = ((text == "LMM") ? list2 : list); if (Select) { ProfileSelectionDropdown.value = ProfileSelectionDropdown.options.FindIndex((OptionData x) => !ProfilesDirectory.Contains(x.text)); } } } private void Start() { //IL_0060: Unknown result type (might be due to invalid IL or missing references) //IL_0065: Unknown result type (might be due to invalid IL or missing references) //IL_006b: Expected O, but got Unknown //IL_0099: Unknown result type (might be due to invalid IL or missing references) //IL_009e: Unknown result type (might be due to invalid IL or missing references) //IL_00a4: Expected O, but got Unknown //IL_00d2: Unknown result type (might be due to invalid IL or missing references) //IL_00d7: Unknown result type (might be due to invalid IL or missing references) //IL_00dd: Expected O, but got Unknown //IL_010b: Unknown result type (might be due to invalid IL or missing references) //IL_0110: Unknown result type (might be due to invalid IL or missing references) //IL_0116: Expected O, but got Unknown //IL_0263: Unknown result type (might be due to invalid IL or missing references) //IL_026d: Expected O, but got Unknown //IL_0289: Unknown result type (might be due to invalid IL or missing references) //IL_0293: Expected O, but got Unknown //IL_02af: Unknown result type (might be due to invalid IL or missing references) //IL_02b9: Expected O, but got Unknown //IL_046b: Unknown result type (might be due to invalid IL or missing references) //IL_0475: Expected O, but got Unknown //IL_04a1: Unknown result type (might be due to invalid IL or missing references) //IL_04ab: Expected O, but got Unknown //IL_04c7: Unknown result type (might be due to invalid IL or missing references) //IL_04d1: Expected O, but got Unknown //IL_04ed: Unknown result type (might be due to invalid IL or missing references) //IL_04f7: Expected O, but got Unknown //IL_0539: Unknown result type (might be due to invalid IL or missing references) //IL_0543: Expected O, but got Unknown //IL_055f: Unknown result type (might be due to invalid IL or missing references) //IL_0569: Expected O, but got Unknown //IL_0585: Unknown result type (might be due to invalid IL or missing references) //IL_058f: Expected O, but got Unknown //IL_0608: Unknown result type (might be due to invalid IL or missing references) //IL_0612: Expected O, but got Unknown //IL_0140: Unknown result type (might be due to invalid IL or missing references) //IL_0145: Unknown result type (might be due to invalid IL or missing references) //IL_014b: Expected O, but got Unknown //IL_063b: Unknown result type (might be due to invalid IL or missing references) //IL_0640: Unknown result type (might be due to invalid IL or missing references) //IL_0646: Expected O, but got Unknown //IL_06ba: Unknown result type (might be due to invalid IL or missing references) //IL_06c4: Expected O, but got Unknown //IL_0674: Unknown result type (might be due to invalid IL or missing references) //IL_0679: Unknown result type (might be due to invalid IL or missing references) //IL_067f: Expected O, but got Unknown //IL_09d5: Unknown result type (might be due to invalid IL or missing references) //IL_09da: Unknown result type (might be due to invalid IL or missing references) try { LMM_Canvas = Object.Instantiate<GameObject>(ModManagerCanvas, GameObject.Find("Canvas").transform.parent, false).transform; ButtonClickedEvent onClick = LMM_Canvas.Find<Button>("Menu/Local_Show").onClick; object obj = <>c.<>9__34_0; if (obj == null) { UnityAction val = delegate { LoadMenu("Local"); }; <>c.<>9__34_0 = val; obj = (object)val; } ((UnityEvent)onClick).AddListener((UnityAction)obj); ButtonClickedEvent onClick2 = LMM_Canvas.Find<Button>("Menu/TS_Show").onClick; object obj2 = <>c.<>9__34_1; if (obj2 == null) { UnityAction val2 = delegate { LoadMenu("Thunderstore"); }; <>c.<>9__34_1 = val2; obj2 = (object)val2; } ((UnityEvent)onClick2).AddListener((UnityAction)obj2); ButtonClickedEvent onClick3 = LMM_Canvas.Find<Button>("Menu/Downloads_Show").onClick; object obj3 = <>c.<>9__34_2; if (obj3 == null) { UnityAction val3 = delegate { LoadMenu("Downloads"); }; <>c.<>9__34_2 = val3; obj3 = (object)val3; } ((UnityEvent)onClick3).AddListener((UnityAction)obj3); ButtonClickedEvent onClick4 = LMM_Canvas.Find<Button>("Menu/ExitAction").onClick; object obj4 = <>c.<>9__34_3; if (obj4 == null) { UnityAction val4 = delegate { ConfigsToDownload = null; ModManager.JoiningLobbyId = null; ((Component)LMM_Canvas).gameObject.SetActive(false); }; <>c.<>9__34_3 = val4; obj4 = (object)val4; } ((UnityEvent)onClick4).AddListener((UnityAction)obj4); ButtonClickedEvent onClick5 = LMM_Canvas.Find<Button>("Menu/Reload").onClick; object obj5 = <>O.<1>__UpdateThunderstoreData; if (obj5 == null) { UnityAction val5 = LMM_ModHandler.UpdateThunderstoreData; <>O.<1>__UpdateThunderstoreData = val5; obj5 = (object)val5; } ((UnityEvent)onClick5).AddListener((UnityAction)obj5); LMM_Canvas.Find<Text>("LMM/Text").text = "LethalModManager v0.1.6 by Kyxino"; Actions = LMM_Canvas.Find("Menu/Actions"); InputField SaveProfileInput = Actions.Find<InputField>("Local/SaveProfile"); Text SaveProfileButtonText = Actions.Find<Text>("Local/SaveProfileButton/Text"); Dropdown ProfileSelectionDropdown = Actions.Find<Dropdown>("Local/ProfileSelectionDropdown"); Text ProfileDropdownText = Actions.Find<Text>("Local/ProfileSelectionDropdown/Text"); UpdateProfileSelection(ProfileSelectionDropdown, Select: true); ((UnityEvent<int>)(object)ProfileSelectionDropdown.onValueChanged).AddListener((UnityAction<int>)delegate(int Value) { string text11 = ProfileSelectionDropdown.options[Value].text; SaveProfileInput.text = ((text11.StartsWith("TEMP:") || text11.StartsWith("ALT:")) ? "" : text11); for (int num3 = 0; num3 < LP_Local.childCount; num3++) { LMM_ModSlot component4 = ((Component)LP_Local.GetChild(num3)).GetComponent<LMM_ModSlot>(); ((MonoBehaviour)component4).StopAllCoroutines(); Object.Destroy((Object)(object)((Component)component4).gameObject); } object obj8; if (!text11.StartsWith("TEMP: ")) { obj8 = (text11.StartsWith("ALT: ") ? Paths.PluginPath : ((text11 == "Main Directory") ? Path.Combine(ModManager.DIR_LethalCompany.FullName, "BepInEx", "plugins") : Path.Combine(ModManager.DIR_Profiles.FullName, text11, "BepInEx", "plugins"))); } else { string fullName = ModManager.DIR_TempProfiles.FullName; string text12 = text11; obj8 = Path.Combine(fullName, text12.Substring(7, text12.Length - 7), "BepInEx", "plugins"); } string text13 = (string)obj8; ModManager.MLS.LogInfo((object)text13); foreach (KeyValuePair<string, ModManifestV1> mod2 in LMM_ModHandler.GetMods(text13)) { AddModToUI($"{mod2.Key}-{mod2.Value.Version}", LP_Local, mod2.Value, ModSlotState.Enabled, IgnoreExisting: true); } UpdateUI = true; SwitchedPanel = true; }); char[] InvalidPathChars = Path.GetInvalidFileNameChars(); ModManager.MLS.LogFatal((object)InvalidPathChars); SaveProfileButtonText.text = "New Profile"; ((UnityEvent<string>)(object)SaveProfileInput.onValueChanged).AddListener((UnityAction<string>)delegate(string Value) { string text10 = string.Join("", Value.Where((char x) => !InvalidPathChars.Contains(x))); int caretPosition = SaveProfileInput.caretPosition; SaveProfileInput.SetTextWithoutNotify(text10); SaveProfileInput.caretPosition = caretPosition; SaveProfileButtonText.text = (Directory.Exists(Path.Combine(ModManager.DIR_Profiles.FullName, text10)) ? "Delete Profile" : "New Profile"); }); ((UnityEvent)Actions.Find<Button>("Local/SaveProfileButton").onClick).AddListener((UnityAction)delegate { string text9 = SaveProfileInput.text.Trim(); if (text9.Length >= 1 && !(text9 == "Main Directory")) { ModManager.MLS.LogFatal((object)text9); if (SaveProfileButtonText.text == "Delete Profile") { UpdateProfileSelection(ProfileSelectionDropdown, Select: true); } else { SaveProfileButtonText.text = "Delete Profile"; LMM_ModHandler.CreateProfile(text9); ProfileSelectionDropdown.AddOptions(new List<string> { text9 }); } } }); ((UnityEvent)Actions.Find<Button>("Local/LoadProfile").onClick).AddListener((UnityAction)delegate { string text6 = SaveProfileInput.text.Trim(); for (int n = 0; n < ModManager.DoorstopSettings.Count; n++) { string text7 = ModManager.DoorstopSettings[n]; if (text7.StartsWith("targetAssembly=")) { List<string> doorstopSettings = ModManager.DoorstopSettings; int index = n; object value3; if (!(ProfileDropdownText.text == "Main Directory")) { if (!ProfileDropdownText.text.StartsWith("ALT: ")) { if (!ProfileDropdownText.text.StartsWith("TEMP: ")) { value3 = "targetAssembly=.\\LethalModManager\\Profiles\\" + ProfileDropdownText.text + "\\BepInEx\\core\\BepInEx.Preloader.dll"; } else { string text8 = ProfileDropdownText.text; value3 = "targetAssembly=.\\LethalModManager\\TempProfiles\\" + text8.Substring(5, text8.Length - 5) + "\\BepInEx\\core\\BepInEx.Preloader.dll"; } } else { value3 = Paths.BepInExAssemblyDirectory + "\\BepInEx.Preloader.dll"; } } else { value3 = "targetAssembly=BepInEx\\core\\BepInEx.Preloader.dll"; } doorstopSettings[index] = (string)value3; } } LMM_ModHandler.QuickReload(); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/ReverseSort").onClick).AddListener((UnityAction)delegate { //IL_0035: Unknown result type (might be due to invalid IL or missing references) LMM_ModHandler.TS_Reversed = !LMM_ModHandler.TS_Reversed; ((Transform)Actions.Find<RectTransform>("Thunderstore/ReverseSort/Text")).eulerAngles = new Vector3(0f, 0f, (float)(LMM_ModHandler.TS_Reversed ? 90 : (-90))); LMM_ModHandler.TS_SearchChoice.Reverse(); UpdatePage(0); }); ModManager.MLS.LogWarning((object)"FFFFFFFFFFFFFFFFF"); Actions.Find<Dropdown>("Thunderstore/SortDropdown").ClearOptions(); Actions.Find<Dropdown>("Thunderstore/SortDropdown").AddOptions(new List<string>(8) { "Last Updated", "Last Released", "Most Downloads", "Most Dependents", "Most Likes", "Most Dependencies", "Most Versions", "Latest Size" }); ((UnityEvent<int>)(object)Actions.Find<Dropdown>("Thunderstore/SortDropdown").onValueChanged).AddListener((UnityAction<int>)delegate(int Value) { ResortData(Value); }); Actions.Find<Dropdown>("Thunderstore/CountDropdown").ClearOptions(); Actions.Find<Dropdown>("Thunderstore/CountDropdown").AddOptions(new List<string>(7) { "12 Results", "18 Results", "24 Results", "36 Results", "48 Results", "72 Results", "96 Results" }); ((UnityEvent<int>)(object)Actions.Find<Dropdown>("Thunderstore/CountDropdown").onValueChanged).AddListener((UnityAction<int>)delegate(int Value) { LMM_ModHandler.TS_Count = (int.TryParse(Actions.Find<Dropdown>("Thunderstore/CountDropdown").options[Value].text.Replace(" Results", ""), out var result3) ? result3 : 12); UpdatePage(LMM_ModHandler.TS_Offset); }); ModManager.MLS.LogWarning((object)"FFFFFFFFFFFFFFFFF"); Actions.Find<Dropdown>("Thunderstore/CountDropdown").value = 0; ((UnityEvent)Actions.Find<Button>("Thunderstore/SearchButton").onClick).AddListener((UnityAction)delegate { string Text = Actions.Find<InputField>("Thunderstore/Search").text.ToUpper(); LMM_ModHandler.TS_SearchChoice = LMM_ModHandler.TS_Search; if (Text.StartsWith(";")) { string text5 = Text; Text = text5.Substring(1, text5.Length - 1); LMM_ModHandler.TS_SearchChoice = LMM_ModHandler.TS_SearchChoice.Where(delegate(ModListing x) { int result2; if (!x.Tags.Contains("Modpacks")) { VersionListing? versionListing = x.Versions.FirstOrDefault(); result2 = ((versionListing != null && versionListing.Dependencies?.Count < 10) ? 1 : 0); } else { result2 = 0; } return (byte)result2 != 0; }).ToList(); } LMM_ModHandler.TS_SearchChoice = LMM_ModHandler.TS_SearchChoice.Where((ModListing x) => x.Full_Name.ToUpper().Contains(Text) || x.Versions.FirstOrDefault().Desc.ToUpper().Contains(Text)).ToList(); UpdatePage(0); }); ModManager.MLS.LogWarning((object)"FFFFFFFFFFFFFFFFF"); ((UnityEvent)Actions.Find<Button>("Thunderstore/FirstPage").onClick).AddListener((UnityAction)delegate { UpdatePage(0); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/DoubleBackPage").onClick).AddListener((UnityAction)delegate { UpdatePage(LMM_ModHandler.TS_Offset - 2 * LMM_ModHandler.TS_Count); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/BackPage").onClick).AddListener((UnityAction)delegate { UpdatePage(LMM_ModHandler.TS_Offset - LMM_ModHandler.TS_Count); }); ((UnityEvent<string>)(object)Actions.Find<InputField>("Thunderstore/InputPage").onEndEdit).AddListener((UnityAction<string>)delegate(string Input) { UpdatePage((int.Parse(Input) - 1) * LMM_ModHandler.TS_Count); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/NextPage").onClick).AddListener((UnityAction)delegate { UpdatePage(LMM_ModHandler.TS_Offset + LMM_ModHandler.TS_Count); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/DoubleNextPage").onClick).AddListener((UnityAction)delegate { UpdatePage(LMM_ModHandler.TS_Offset + 2 * LMM_ModHandler.TS_Count); }); ((UnityEvent)Actions.Find<Button>("Thunderstore/LastPage").onClick).AddListener((UnityAction)delegate { UpdatePage(Mathf.FloorToInt((float)LMM_ModHandler.TS_SearchChoice.Count / (float)LMM_ModHandler.TS_Count) * LMM_ModHandler.TS_Count); }); string[] AutoRequired = new string[6] { "Equipment", "Items", "Monsters", "Moons", "Furniture", "Modpacks" }; int AllSetting = 1; Actions.Find<Text>("Host/SetAllPriority/Text").text = "Set All Preferred"; ((UnityEvent)Actions.Find<Button>("Host/SetAllPriority").onClick).AddListener((UnityAction)delegate { for (int m = 0; m < LP_Host.childCount; m++) { LMM_ModSlot component3 = ((Component)LP_Host.GetChild(m)).GetComponent<LMM_ModSlot>(); if (!((Object)(object)component3 == (Object)null)) { switch (AllSetting) { case 0: component3.SetState(ModSlotState.Optional); break; case 1: component3.SetState(ModSlotState.Preferred); break; case -1: component3.SetState(ModSlotState.Required); break; default: { ModListing mod = component3.ModInfo.GetMod(); if (mod == null) { continue; } if (mod.Tags.Contains("Translations")) { component3.SetState(ModSlotState.Optional); } else if (mod.Tags.FirstOrDefault((string x) => AutoRequired.Contains(x)) != null || (mod.Tags.Contains("Server-side") && mod.Tags.Contains("Client-side"))) { component3.SetState(ModSlotState.Required); } else { component3.SetState(ModSlotState.Preferred); } break; } } component3.UpdateBorderByState(); } } AllSetting = (AllSetting + 2) % 4 - 1; Actions.Find<Text>("Host/SetAllPriority/Text").text = ((AllSetting == 0) ? "Set All Optional" : ((AllSetting == 1) ? "Set All Preferred" : ((AllSetting == -1) ? "Set All Required" : "Set All Mods Auto"))); }); ButtonClickedEvent onClick6 = Actions.Find<Button>("Host/OpenLobby").onClick; object obj6 = <>c.<>9__34_20; if (obj6 == null) { UnityAction val6 = delegate { ModManager.MLS.LogFatal((object)"Attempting to open lobby via mod sync."); using WebClient webClient = new WebClient(); Dictionary<string, int> dictionary2 = new Dictionary<string, int>(); for (int l = 0; l < LP_Host.childCount; l++) { LMM_ModSlot component2 = ((Component)LP_Host.GetChild(l)).GetComponent<LMM_ModSlot>(); dictionary2.Add(component2.ModInfo.Full_Version, (component2.State != ModSlotState.Optional) ? ((component2.State == ModSlotState.Preferred) ? 1 : (-1)) : 0); } ((Component)LMM_Canvas).gameObject.SetActive(false); Dictionary<string, object> dictionary3 = new Dictionary<string, object> { ["Mods"] = dictionary2, ["Configs"] = LMM_ModHandler.CompressConfigs() }; string data = "#lethalmodmanager\n" + Convert.ToBase64String(Encoding.ASCII.GetBytes(JsonConvert.SerializeObject((object)dictionary3))); webClient.Headers.Add("Content-Type", "application/octet-stream"); string text4 = webClient.UploadString("https://thunderstore.io/api/experimental/legacyprofile/create/", data); Dictionary<string, object> dictionary4 = JsonConvert.DeserializeObject<Dictionary<string, object>>(text4); ModManager.MLS.LogWarning((object)text4); if (!dictionary4.TryGetValue("key", out var value2)) { FailedOpenLobby = Time.time + 1f; } else { ModManager.ModSyncKey = value2.ToString(); ModManager.ModSyncCount = dictionary2.Count; ModManager.MLS.LogWarning((object)ModManager.ModSyncKey); ModManager.OpeningLobby = true; Object.FindObjectOfType<MenuManager>().ConfirmHostButton(); } }; <>c.<>9__34_20 = val6; obj6 = (object)val6; } ((UnityEvent)onClick6).AddListener((UnityAction)obj6); ButtonClickedEvent onClick7 = Actions.Find<Button>("LobbyMods/ApplyAll").onClick; object obj7 = <>c.<>9__34_21; if (obj7 == null) { UnityAction val7 = delegate { for (int k = 0; k < LP_LobbyMods.childCount; k++) { ((Component)LP_LobbyMods.GetChild(k)).GetComponent<LMM_ModSlot>()?.SetState(ModSlotState.Preferred); } }; <>c.<>9__34_21 = val7; obj7 = (object)val7; } ((UnityEvent)onClick7).AddListener((UnityAction)obj7); Actions.Find<Text>("LobbyMods/Download/Text").text = "Install/Launch"; ((UnityEvent)Actions.Find<Button>("LobbyMods/Download").onClick).AddListener((UnityAction)delegate { LMM_ModHandler.CreateProfile(ModManager.JoiningLobbyId.ToString(), TempProfile: true); for (int i = 0; i < LP_LobbyMods.childCount; i++) { LMM_ModSlot component = ((Component)LP_LobbyMods.GetChild(i)).GetComponent<LMM_ModSlot>(); if ((Object)(object)component != (Object)null && (component.State == ModSlotState.Preferred || component.State == ModSlotState.Forced)) { component.ModInfo.Download(IncludeDependencies: false, ModManager.JoiningLobbyId.ToString(), SaveToTempProfile: true, IgnoreConfigs: true); } } string text = Path.Combine(ModManager.DIR_TempProfiles.FullName, ModManager.JoiningLobbyId.ToString()); Match match = Regex.Match(ConfigsToDownload, "LMM\\$.+\\n"); while (match.Success) { ModManager.MLS.LogWarning((object)match.Index); string value = match.Value; string path = text + "\\BepInEx\\" + value.Substring(4, value.Length - 1 - 4).Replace('/', '\\'); int num = match.Index + match.Length; match = match.NextMatch(); new DirectoryInfo(path).Parent.Create(); string configsToDownload = ConfigsToDownload; int num2 = num; File.WriteAllText(path, configsToDownload.Substring(num2, (match.Success ? (match.Index - 1) : ConfigsToDownload.Length) - num2)); } string text2 = SaveProfileInput.text.Trim(); for (int j = 0; j < ModManager.DoorstopSettings.Count; j++) { string text3 = ModManager.DoorstopSettings[j]; if (text3.StartsWith("targetAssembly=")) { ModManager.DoorstopSettings[j] = $"targetAssembly=.\\LethalModManager\\TempProfiles\\{ModManager.JoiningLobbyId}\\BepInEx\\core\\BepInEx.Preloader.dll"; } } LMM_ModHandler.QuickReload(ModManager.JoiningLobbyId); }); ListPanel = LMM_Canvas.Find("Menu/ListPanel"); LP_Local = ListPanel.Find("Local"); LP_Thunderstore = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_Thunderstore).name = "Thunderstore"; LP_Downloads = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_Downloads).name = "Downloads"; LP_Host = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_Host).name = "Host"; LP_Config = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_Config).name = "Config"; LP_LobbyMods = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_LobbyMods).name = "LobbyMods"; LP_LobbyConfigs = Object.Instantiate<Transform>(LP_Local, ListPanel, false); ((Object)LP_LobbyConfigs).name = "LobbyConfigs"; LMM_ModHandler.UserMods = LMM_ModHandler.GetMods(); Dictionary<string, ModInfo> dictionary = new Dictionary<string, ModInfo>(); foreach (string item in Directory.EnumerateFiles(".\\LethalModManager\\ModStorage", "*.zip")) { if (!ModInfo.TryParse(Path.GetFileNameWithoutExtension(item), out var result)) { continue; } string full_Name = result.Full_Name; if (dictionary.ContainsKey(full_Name)) { if (dictionary[full_Name].Version < result.Version) { dictionary[full_Name] = result; } } else { dictionary.TryAdd(full_Name, result); } } foreach (KeyValuePair<string, ModInfo> item2 in dictionary) { AddModToUI(item2.Value.Full_Version, LP_Downloads); } foreach (KeyValuePair<string, ModManifestV1> userMod in LMM_ModHandler.UserMods) { AddModToUI($"{userMod.Key}-{userMod.Value.Version}", LP_Local, userMod.Value); if (userMod.Value.UserEnabled) { Instance.AddModToUI($"{userMod.Key}-{userMod.Value.Version}", LP_Host, userMod.Value, ModSlotState.Preferred); } } UpdateUI = true; SwitchedPanel = true; ResortData(0); Object.DontDestroyOnLoad((Object)(object)LMM_Canvas); ((Component)LMM_Canvas).gameObject.SetActive(false); ((Component)LMM_Canvas.Find("Tint")).gameObject.SetActive(true); ManualLogSource mLS = ModManager.MLS; Scene activeScene = SceneManager.GetActiveScene(); mLS.LogWarning((object)("Scene: " + ((Scene)(ref activeScene)).name + " | Loaded LMM_UI.")); } catch (Exception ex) { BreakUI = true; ModManager.MLS.LogError((object)"[LMM]: Unexpected error, disabling to prevent error spam."); ModManager.MLS.LogError((object)ex); } } } public enum LaunchOptions { None, Online, LAN } public enum DependentVersionChecks { Once, Latest, All } [DefaultExecutionOrder(int.MaxValue)] [BepInPlugin("Kyxino.LethalModManager", "LethalModManager", "0.1.6")] public class ModManager : BaseUnityPlugin { private readonly Harmony HarmonyX = new Harmony("Kyxino.LethalModManager"); public const string ModVersion = "0.1.6"; internal static ManualLogSource MLS = Logger.CreateLogSource("Kyxino.LethalModManager"); public static ModManager Instance; public static ConfigFile LMM_Config = new ConfigFile(Path.Combine("LethalModManager", "Settings.cfg"), true, MetadataHelper.GetMetadata(typeof(ModManager))); public static ConfigFile Mod_Config = new ConfigFile(Path.Combine(Paths.ConfigPath, "Kyxino.LethalModManager.cfg"), true, MetadataHelper.GetMetadata(typeof(ModManager))); public static ConfigEntry<bool> Active_LobbySearcher = Mod_Config.Bind<bool>("Active Settings", "LobbySearcher", true, "[Needs Restarting] LMM's lobby search for mod sync compatibility. (Handles basic stuff that other things that override the vanilla one typically handles, this will eventually be replaced with a lobby search in the LMM UI that won't affect the vanilla one at some point.)"); public static ConfigEntry<bool> SharedRequiredInstantLoading = LMM_Config.Bind<bool>("Mod Sync Settings", "SharedRequiredInstantLoading", false, "Temporary setting for joining hosts and sharing the same required mods to instantly join rather than download a temp profile and what not. (Warning: This is more likely to cause you to accidentally have missing mods/configs.)"); public static ConfigEntry<float> PositionalRelativityToHostButtonMultiplier = Mod_Config.Bind<float>("Mods Button", "PositionalRelativityToHostButtonMultiplier", 1f, "If another button is above the Host button, please set this to 2."); public static ConfigEntry<float> UpdateTime = LMM_Config.Bind<float>("API Settings", "UpdateTime", 30f, "How long (in minutes) between every API request to update mod info."); public static ConfigEntry<bool> ForceUpdateUponOpening = LMM_Config.Bind<bool>("API Settings", "ForceUpdateUponOpening", false, "If the mod data should update every time the game is opened REGARDLESS of the update timer."); public static ConfigEntry<bool> ScaleUI = LMM_Config.Bind<bool>("UI Settings", "ScaleUI", true, "If the UI should scale with your screen ratio."); public static ConfigEntry<float> ScaleBetweenWidthToHeight = LMM_Config.Bind<float>("UI Settings", "ScaleBetweenWidthToHeight", 1f, "How the UI should scale with your screen ratio. (Width: 0 -> Height: 1)"); public static ConfigEntry<string> ModsButtonText = LMM_Config.Bind<string>("UI Settings", "LMM_ButtonText", "> LethalModManager", "Feel free to name it whatever you want. (Modpacks can't change your choice.)"); public static ConfigEntry<int> RetryLogoLoadingTimes = LMM_Config.Bind<int>("Thunderstore Settings", "RetryLogoLoadingTimes", 5, "How many times should LMM try to load a logo from online."); public static ConfigEntry<bool> SpecificModVersionLink = LMM_Config.Bind<bool>("Thunderstore Settings", "SpecificModVersionLink", false, "If clicking the Web icon on a mod should take you to the specific version."); public static ConfigEntry<bool> HideLinkIfMissingVersion = LMM_Config.Bind<bool>("Thunderstore Settings", "HideLinkIfMissingVersion", true, "If the Web icon should be hidden from a mod if missing the selected version."); public static ConfigEntry<bool> CountFlattenedDependencies = LMM_Config.Bind<bool>("Thunderstore Settings", "CountFlattenedDependencies", false, "If it should count flattened dependencies or just listed dependencies."); public static ConfigEntry<bool> SpecificModVersionDownloads = LMM_Config.Bind<bool>("Thunderstore Settings", "SpecificModVersionDownloads", false, "If it should only show the specific version's downloads."); public static ConfigEntry<bool> SpecificModVersionDependents = LMM_Config.Bind<bool>("Thunderstore Settings", "SpecificModVersionDependents", false, "If it should only count the dependents for the specific version."); public static ConfigEntry<DependentVersionChecks> ModpackVersionCheck = LMM_Config.Bind<DependentVersionChecks>("Thunderstore Settings", "ModpackVersionCheck", DependentVersionChecks.Once, "How it should calculate those dependents."); public static ConfigEntry<bool> ForcedLobbySearch = Mod_Config.Bind<bool>("Search Settings", "ForcedLobbySearch", false, "If this is enabled, it will forcibly replace lobby searching if you want it to work regardless of other lobby mods that may change it."); public static ConfigEntry<bool> IncludeFullLobbies = Mod_Config.Bind<bool>("Search Settings", "IncludeFullLobbies", false, "Whether or not to show full lobbies. (You are weird.)"); public static ConfigEntry<bool> OnlyShowModSyncLobbies = Mod_Config.Bind<bool>("Search Settings", "OnlyShowModSyncLobbies", false, "Whether or not to ONLY show lobbies with LMM hosts for mod sync."); public static DirectoryInfo DIR_LMM = Directory.CreateDirectory("LethalModManager"); public static DirectoryInfo DIR_ModCache = DIR_LMM.CreateSubdirectory("ModCache"); public static DirectoryInfo DIR_ModStorage = DIR_LMM.CreateSubdirectory("ModStorage"); public static DirectoryInfo DIR_TempProfiles = DIR_LMM.CreateSubdirectory("TempProfiles"); public static DirectoryInfo DIR_Profiles = DIR_LMM.CreateSubdirectory("Profiles"); public static DirectoryInfo DIR_LethalCompany = DIR_LMM.Parent; public static DirectoryInfo DIR_CurrentProfile = Directory.GetParent(Paths.BepInExRootPath); public static List<string> DoorstopSettings; public static bool IsQuickReloaded; public static LaunchOptions QR_AutoLaunchMode; public static string ModSyncKey; public static int ModSyncCount; public static bool OpeningLobby; public static ulong? JoiningLobbyId; public static bool HasQuickReloaded; public static bool SkippedLaunchModeMenu; public static bool QR_SkipSplash; public static bool QR_SkipBootAnim; public static bool QL_SkipSplash; public static bool QL_SkipBootAnim; public static LaunchOptions QL_AutoLaunchMode; public static bool SkipSplash; public static bool SkipBootAnim; public static bool SkipUpdatePopup; public static bool SkipLANPopup; public static LaunchOptions AutoLaunchMode; private void Awake() { Instance = this; MLS.LogWarning((object)GeneralExtensions.Join<string>((IEnumerable<string>)DoorstopSettings, (Func<string, string>)null, "\n")); if (IsQuickReloaded) { DoorstopSettings.Remove("isQuickReloaded=true"); DoorstopSettings.Remove("reloadLaunchMode=LAN"); DoorstopSettings.Remove("reloadLaunchMode=Online"); for (int i = 0; i < DoorstopSettings.Count; i++) { string text = DoorstopSettings[i]; if (text.StartsWith("targetAssembly=")) { DoorstopSettings[i] = "targetAssembly=BepInEx\\core\\BepInEx.Preloader.dll"; } } File.WriteAllLines(Path.Combine(Paths.GameRootPath, "doorstop_config.ini"), DoorstopSettings.Where((string x) => !x.StartsWith("joiningLobbyId"))); } else { try { DirectoryInfo[] directories = DIR_TempProfiles.GetDirectories(); foreach (DirectoryInfo directoryInfo in directories) { directoryInfo.Delete(recursive: true); } } catch (Exception ex) { MLS.LogWarning((object)ex.Message); } } QuickLoad(); ((Object)((Component)this).gameObject).hideFlags = (HideFlags)63; Object.DontDestroyOnLoad((Object)(object)((Component)this).gameObject); ((Object)((Component)this).gameObject).name = "LethalModManager"; ((Component)this).gameObject.AddComponent<LMM_UI>(); MLS.LogInfo((object)"Loaded LethalModManager, patching."); JsonConvert.DefaultSettings = () => new JsonSerializerSettings { Converters = new List<JsonConverter> { (JsonConverter)(object)new ModInfoConverter() } }; HarmonyX.PatchAll(typeof(LMM_LobbySearcher)); HarmonyX.PatchAll(typeof(LMM_ModHandler)); HarmonyX.PatchAll(typeof(LMM_ModSyncer)); DirectoryInfo directoryInfo2 = new DirectoryInfo(Path.Combine(Paths.GameRootPath, "DELETE")); if (directoryInfo2.Exists) { directoryInfo2.Delete(recursive: true); } directoryInfo2.Create(); string[] files = Directory.GetFiles(Paths.GameRootPath, "*.lmm-delete", SearchOption.AllDirectories); foreach (string path in files) { try { File.Delete(path); } catch (Exception ex2) { MLS.LogError((object)ex2.Message); } } string[] files2 = Directory.GetFiles(Paths.BepInExRootPath, "*.lmm-delete", SearchOption.AllDirectories); foreach (string path2 in files2) { try { File.Delete(path2); } catch (Exception ex3) { MLS.LogError((object)ex3.Message); } } LMM_ModHandler.CreateProfile("Main Directory"); } private void QuickLoad() { if (HasQuickReloaded) { return; } HasQuickReloaded = true; SceneManager.sceneLoaded += OnSceneLoaded; HarmonyX.PatchAll(typeof(ModManager)); if (!SkipSplash) { return; } Task.Run(delegate { while (!SkippedLaunchModeMenu) { SplashScreen.Stop((StopBehavior)0); } MLS.LogWarning((object)SplashScreen.isFinished); }); } private static void OnSceneLoaded(Scene scene, LoadSceneMode mode) { if (((Scene)(ref scene)).name == "InitScene" || ((Scene)(ref scene)).name == "InitSceneLANMode") { SkippedLaunchModeMenu = true; if (SkipBootAnim) { InitializeGame val = Object.FindObjectOfType<InitializeGame>(); if (!((Object)(object)val == (Object)null)) { val.runBootUpScreen = false; } } } else { if (!(((Scene)(ref scene)).name == "MainMenu")) { return; } SkippedLaunchModeMenu = true; if (SkipUpdatePopup) { GameNetworkManager.Instance.firstTimeInMenu = false; } if (!SkipLANPopup) { return; } MenuManager obj = Object.FindObjectOfType<MenuManager>(); if (obj != null) { GameObject lanWarningContainer = obj.lanWarningContainer; if (lanWarningContainer != null) { lanWarningContainer.SetActive(false); } } } } [HarmonyPrefix] [HarmonyPatch(typeof(PreInitSceneScript), "SkipToFinalSetting")] public static bool SkipToFinalSetting(PreInitSceneScript __instance) { if (AutoLaunchMode == LaunchOptions.None) { return SkippedLaunchModeMenu = true; } GameObject launchSettingsPanelsContainer = __instance.launchSettingsPanelsContainer; if (launchSettingsPanelsContainer != null) { launchSettingsPanelsContainer.SetActive(false); } if (SkippedLaunchModeMenu) { return false; } SkippedLaunchModeMenu = true; SceneManager.LoadScene((AutoLaunchMode == LaunchOptions.LAN) ? "InitSceneLANMode" : "InitScene"); return false; } static ModManager() { //IL_002e: Unknown result type (might be due to invalid IL or missing references) //IL_0038: Expected O, but got Unknown //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_0061: Expected O, but got Unknown string[] array = File.ReadAllLines(Path.Combine(Paths.GameRootPath, "doorstop_config.ini")); List<string> list = new List<string>(array.Length); string[] array2 = array; foreach (string item in array2) { list.Add(item); } DoorstopSettings = list; IsQuickReloaded = DoorstopSettings.Contains("isQuickReloaded=true"); string text = DoorstopSettings.Where((string x) => x.StartsWith("reloadLaunchMode=")).LastOrDefault(); if (1 == 0) { } LaunchOptions qR_AutoLaunchMode = ((text == "reloadLaunchMode=Online") ? LaunchOptions.Online : ((text == "reloadLaunchMode=LAN") ? LaunchOptions.LAN : LaunchOptions.None)); if (1 == 0) { } QR_AutoLaunchMode = qR_AutoLaunchMode; OpeningLobby = false; JoiningLobbyId = (ulong.TryParse(DoorstopSettings.Where((string x) => x.StartsWith("joiningLobbyId=")).LastOrDefault()?.Replace("joiningLobbyId=", ""), out var result) ? new ulong?(result) : null); HasQuickReloaded = false; SkippedLaunchModeMenu = false; QR_SkipSplash = Mod_Config.Bind<bool>("Quick Reload", "SkipSplash", true, "Whether or not to skip the Unity/Zeekerss splash screen when quick reloading.").Value; QR_SkipBootAnim = Mod_Config.Bind<bool>("Quick Reload", "SkipBootAnim", true, "Whether or not to skip the OS boot animation when quick reloading.").Value; QL_SkipSplash = Mod_Config.Bind<bool>("Quick Launch", "SkipSplash", false, "Whether or not to skip the Unity/Zeekerss splash screen.").Value; QL_SkipBootAnim = Mod_Config.Bind<bool>("Quick Launch", "SkipBootAnim", false, "Whether or not to skip the OS boot animation.").Value; QL_AutoLaunchMode = Mod_Config.Bind<LaunchOptions>("Quick Launch", "AutoLaunchMode", LaunchOptions.None, "What mode should be automatically selected.").Value; SkipSplash = (IsQuickReloaded ? QR_SkipSplash : QL_SkipSplash); SkipBootAnim = (IsQuickReloaded ? QR_SkipBootAnim : QL_SkipBootAnim); SkipUpdatePopup = Mod_Config.Bind<bool>("Quick Launch", "SkipUpdatePopup", false, "Whether or not to skip the update popup.").Value; SkipLANPopup = Mod_Config.Bind<bool>("Quick Launch", "SkipLANPopup", false, "Whether or not to skip the LAN popup.").Value; AutoLaunchMode = (IsQuickReloaded ? QR_AutoLaunchMode : QL_AutoLaunchMode); } } [GeneratedCode("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] [DebuggerNonUserCode] [CompilerGenerated] internal class Resource1 { private static ResourceManager resourceMan; private static CultureInfo resourceCulture; [EditorBrowsable(EditorBrowsableState.Advanced)] internal static ResourceManager ResourceManager { get { if (resourceMan == null) { ResourceManager resourceManager = new ResourceManager("LethalModManager.Resource1", typeof(Resource1).Assembly); resourceMan = resourceManager; } return resourceMan; } } [EditorBrowsable(EditorBrowsableState.Advanced)] internal static CultureInfo Culture { get { return resourceCulture; } set { resourceCulture = value; } } internal static byte[] LethalModManagerUI { get { object @object = ResourceManager.GetObject("LethalModManagerUI", resourceCulture); return (byte[])@object; } } internal Resource1() { } } internal class LMM_LobbySearcher { [HarmonyPostfix] [HarmonyPatch(typeof(SteamLobbyManager), "loadLobbyListAndFilter")] private static void LobbyListFilter(SteamLobbyManager __instance, ref IEnumerator __result) { __result = LMM_Utils.HarmonyEnumerator(__result, null, delegate { //IL_0028: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) LobbySlot val2 = ((Component)__instance.levelListContainer).GetComponentsInChildren<LobbySlot>().LastOrDefault(); if (!((Object)(object)val2 == (Object)null)) { Lobby thisLobby2 = val2.thisLobby; if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby2)).GetData("LMM_Sync"))) { ((TMP_Text)((Component)val2).transform.Find<TextMeshProUGUI>("JoinButton/Text (TMP)")).text = "Sync"; } ((TMP_Text)val2.LobbyName).text = ((Lobby)(ref thisLobby2)).GetData("name"); ((TMP_Text)val2.playerCount).text = $"{((Lobby)(ref thisLobby2)).MemberCount} / {((Lobby)(ref thisLobby2)).MaxMembers}"; if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby2)).GetData("LMM_Mods"))) { TextMeshProUGUI playerCount2 = val2.playerCount; ((TMP_Text)playerCount2).text = ((TMP_Text)playerCount2).text + " (" + ((Lobby)(ref thisLobby2)).GetData("LMM_Mods") + " Mods | v" + ((Lobby)(ref thisLobby2)).GetData("vers") + ")"; } if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby2)).GetData("LethalModManager"))) { ((Component)val2).transform.SetAsFirstSibling(); } } }, null, null, delegate { //IL_0028: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) LobbySlot val = ((Component)__instance.levelListContainer).GetComponentsInChildren<LobbySlot>().LastOrDefault(); if (!((Object)(object)val == (Object)null)) { Lobby thisLobby = val.thisLobby; if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby)).GetData("LMM_Sync"))) { ((TMP_Text)((Component)val).transform.Find<TextMeshProUGUI>("JoinButton/Text (TMP)")).text = "Sync"; } ((TMP_Text)val.LobbyName).text = ((Lobby)(ref thisLobby)).GetData("name"); ((TMP_Text)val.playerCount).text = $"{((Lobby)(ref thisLobby)).MemberCount} / {((Lobby)(ref thisLobby)).MaxMembers}"; if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby)).GetData("LMM_Mods"))) { TextMeshProUGUI playerCount = val.playerCount; ((TMP_Text)playerCount).text = ((TMP_Text)playerCount).text + " (" + ((Lobby)(ref thisLobby)).GetData("LMM_Mods") + " Mods | v" + ((Lobby)(ref thisLobby)).GetData("vers") + ")"; } if (!Utility.IsNullOrWhiteSpace(((Lobby)(ref thisLobby)).GetData("LethalModManager"))) { ((Component)val).transform.SetAsFirstSibling(); } } }); } private static async void LobbyRedo(SteamLobbyManager __instance) { if (!GameNetworkManager.Instance.waitingForLobbyDataRefresh) { Coroutine loadLobbyListCoroutine = LMM_Utils.GetField<Coroutine>(__instance, "loadLobbyListCoroutine"); if (loadLobbyListCoroutine != null) { ((MonoBehaviour)__instance).StopCoroutine(loadLobbyListCoroutine); } LMM_Utils.SetField(__instance, "refreshServerListTimer", 0f); ((TMP_Text)__instance.serverListBlankText).text = "Loading server list..."; LobbySlot[] LobbySlots = Object.FindObjectsOfType<LobbySlot>(); LobbySlot[] array = LobbySlots; foreach (LobbySlot Destroy in array) { Object.Destroy((Object)(object)((Component)Destroy).gameObject); } Debug.Log((object)"Requested server list"); GameNetworkManager.Instance.waitingForLobbyDataRefresh = true; int sortByDistanceSetting = __instance.sortByDistanceSetting; if (1 == 0) { } LobbyQuery lobbyList; LobbyQuery val; switch (sortByDistanceSetting) { case 0: lobbyList = SteamMatchmaking.LobbyList; val = ((LobbyQuery)(ref lobbyList)).FilterDistanceClose(); break; case 1: lobbyList = SteamMatchmaking.LobbyList; val = ((LobbyQuery)(ref lobbyList)).FilterDistanceFar(); break; default: lobbyList = SteamMatchmaking.LobbyList; val = ((LobbyQuery)(ref lobbyList)).FilterDistanceWorldwide(); break; } if (1 == 0) { } LobbyQuery lobbyQuery = val; if (!LMM_Utils.GetField<bool>(__instance, "sortWithChallengeMoons")) { lobbyQuery = ((LobbyQuery)(ref lobbyQuery)).WithKeyValue("chal", "f"); } if (__instance.serverTagInputField.text != string.Empty) { lobbyQuery = ((LobbyQuery)(ref lobbyQuery)).WithKeyValue("tag", __instance.serverTagInputField.text.Substring(0, Mathf.Min(19, __instance.serverTagInputField.text.Length)).ToLower()); } val = ((LobbyQuery)(ref lobbyQuery)).WithSlotsAvailable((!ModManager.IncludeFullLobbies.Value) ? 1 : 0); Lobby[] AllLobbies = (await ((LobbyQuery)(ref val)).RequestAsync())?.ToArray(); Lobby[] currentLobbyList = LMM_Utils.SetField(__instance, "currentLobbyList", AllLobbies); GameNetworkManager.Instance.waitingForLobbyDataRefresh = false; if (currentLobbyList != null) { Debug.Log((object)"Got lobby list!"); LMM_Utils.InvokeMethod(__instance, "DebugLogServerList"); ((Component)__instance.serverListBlankText).gameObject.SetActive(currentLobbyList.Length == 0); ((TMP_Text)__instance.serverListBlankText).text = "No available servers to join."; LMM_Utils.SetField(__instance, "lobbySlotPositionOffset", 0f); LMM_Utils.SetField<Coroutine>(__instance, "loadLobbyListCoroutine", ((MonoBehaviour)__instance).StartCoroutine((IEnumerator)LMM_Utils.InvokeMethod(__instance, "loadLobbyListAndFilter", new object[1] { currentLobbyList }))); } else { Debug.Log((object)"Lobby list is null after request."); ((Component)__instance.serverListBlankText).gameObject.SetActive(true); ((TMP_Text)__instance.serverListBlankText).text = "No available servers to join."; } } } [HarmonyPrefix] [HarmonyPatch(typeof(SteamLobbyManager), "LoadServerList")] [HarmonyAfter(new string[] { "me.swipez.melonloader.morecompany" })] private static bool UnfortunateForcedPatch(SteamLobbyManager __instance) { if (!ModManager.ForcedLobbySearch.Value) { return true; } LobbyRedo(__instance); return false; } [HarmonyPostfix] [HarmonyPatch(typeof(SteamLobbyManager), "OnEnable")] private static void FixLobbySearchList(SteamLobbyManager __instance, Transform ___levelListContainer) { ContentSizeFitter val = ((Component)___levelListContainer).gameObject.AddComponent<ContentSizeFitter>(); val.verticalFit = (FitMode)2; VerticalLayoutGroup val2 = ((Component)___levelListContainer).gameObject.AddComponent<VerticalLayoutGroup>(); ((HorizontalOrVerticalLayoutGroup)val2).childControlHeight = false; ((HorizontalOrVerticalLayoutGroup)val2).spacing = 2f; } } internal static class LMM_ModHandler { [Serializable] [CompilerGenerated] private sealed class <>c { public static readonly <>c <>9 = new <>c(); public static Func<KeyValuePair<ModInfo, int>, string> <>9__21_0; public static Func<KeyValuePair<ModInfo, int>, (ModInfo Key, int Value)> <>9__21_1; public static Func<KeyValuePair<string, (ModInfo Key, int Value)>, ModInfo> <>9__21_2; public static Func<KeyValueP