using System.Diagnostics;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Runtime.Versioning;
using BepInEx;
using BepInEx.Logging;
using HarmonyLib;
using UnityEngine;
using WeNeedToGoDeeper.Patches;
[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.Default | DebuggableAttribute.DebuggingModes.DisableOptimizations | DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints | DebuggableAttribute.DebuggingModes.EnableEditAndContinue)]
[assembly: AssemblyTitle("WeNeedToGoDeeper")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
[assembly: AssemblyProduct("WeNeedToGoDeeper")]
[assembly: AssemblyCopyright("Copyright ©  2023")]
[assembly: AssemblyTrademark("")]
[assembly: ComVisible(false)]
[assembly: Guid("1ef81f2f-53f0-4c30-b4e6-40f441c3f147")]
[assembly: AssemblyFileVersion("1.0.0.0")]
[assembly: TargetFramework(".NETFramework,Version=v4.8", FrameworkDisplayName = ".NET Framework 4.8")]
[assembly: AssemblyVersion("1.0.0.0")]
namespace WeNeedToGoDeeper
{
	[BepInPlugin("Sirus.WeNeedToGoDeeper", "We Need To Go Deeper", "1.0.0.0")]
	public class WeNeedToGoDeeperBase : BaseUnityPlugin
	{
		private const string modGUID = "Sirus.WeNeedToGoDeeper";
		private const string modName = "We Need To Go Deeper";
		private const string modVersion = "1.0.0.0";
		private readonly Harmony harmony = new Harmony("Sirus.WeNeedToGoDeeper");
		private static WeNeedToGoDeeperBase Instance;
		internal ManualLogSource mls;
		private void Awake()
		{
			if ((Object)(object)Instance == (Object)null)
			{
				Instance = this;
			}
			mls = Logger.CreateLogSource("Sirus.WeNeedToGoDeeper");
			mls.LogInfo((object)"Ice Bucket Challenge: Mod has been loaded");
			harmony.PatchAll(typeof(WeNeedToGoDeeperBase));
			harmony.PatchAll(typeof(EntranceTeleportPatch));
			harmony.PatchAll(typeof(HUDManagerPatch));
		}
	}
}
namespace WeNeedToGoDeeper.Patches
{
	[HarmonyPatch(typeof(HUDManager))]
	internal class HUDManagerPatch : HarmonyPatch
	{
		[HarmonyPatch("DisplayTip")]
		[HarmonyPostfix]
		public static void DisplayTipPostfix(string headerText, string bodyText, bool isWarning = false, bool useSave = false, string prefsKey = "LC_Tip1")
		{
			Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)(bodyText ?? ""));
		}
	}
	[HarmonyPatch(typeof(EntranceTeleport))]
	internal class EntranceTeleportPatch : HarmonyPatch
	{
		[HarmonyPatch("TeleportPlayer")]
		[HarmonyPrefix]
		public static bool TeleportPlayerPrefix(bool ___isEntranceToBuilding, int ___entranceId, bool ___gotExitPoint)
		{
			if (!___gotExitPoint)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"IS");
			}
			else if (___entranceId != 0 && ___isEntranceToBuilding)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"FE");
				HUDManager.Instance.DisplayTip("???", "Read the sign, it says exit not entrance.", false, false, "LC_Tip1");
				return false;
			}
			if (___entranceId == 0 && !___isEntranceToBuilding)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"ME");
				HUDManager.Instance.DisplayTip("???", "The entrance appears to be blocked.", false, false, "LC_Tip1");
				return false;
			}
			return true;
		}
		[HarmonyPatch("FindExitPoint")]
		[HarmonyPostfix]
		public static void FindExitPointPostfix(bool ___isEntranceToBuilding, int ___entranceId, bool ___gotExitPoint, ref bool __result)
		{
			Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)$"Entrance ID: {___entranceId}");
			Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)$"Is Entrance?: {___isEntranceToBuilding}");
			if (!___gotExitPoint)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"Initial Sweep");
			}
			else if (___entranceId != 0 && ___isEntranceToBuilding)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"Fire Exit Denied");
				HUDManager.Instance.DisplayTip("???", "Read the sign, it says exit not entrance.", false, false, "LC_Tip1");
				__result = false;
			}
			if (___entranceId == 0 && !___isEntranceToBuilding)
			{
				Logger.CreateLogSource("Sirus.WeNeedToGoDeeper").LogInfo((object)"Main Entrance Denied");
				HUDManager.Instance.DisplayTip("???", "The entrance appears to be blocked.", false, false, "LC_Tip1");
				__result = false;
			}
		}
	}
}