diff --git a/Assembly-CSharp.csproj b/Assembly-CSharp.csproj
index 1f41b540..df26e2ea 100644
--- a/Assembly-CSharp.csproj
+++ b/Assembly-CSharp.csproj
@@ -273,6 +273,7 @@
+
diff --git a/Assets.Scripts.Core/GameSystem.cs b/Assets.Scripts.Core/GameSystem.cs
index fdb58943..9b86dfd4 100644
--- a/Assets.Scripts.Core/GameSystem.cs
+++ b/Assets.Scripts.Core/GameSystem.cs
@@ -12,6 +12,7 @@
using Assets.Scripts.UI.Choice;
using Assets.Scripts.UI.Config;
using Assets.Scripts.UI.Prompt;
+using MOD.Scripts.Core;
using System;
using System.Collections;
using System.Collections.Generic;
@@ -262,6 +263,7 @@ public bool IsInWindowBounds
private void Initialize()
{
Logger.Log($"GameSystem: Starting GameSystem - DLL Version: {MODUtility.InformationalVersion()}");
+ MODLocalization.LoadFromJSON();
IsInitialized = true;
AssetManager = new AssetManager();
AudioController = new AudioController();
diff --git a/MOD.Scripts.Core/MODLocalization.cs b/MOD.Scripts.Core/MODLocalization.cs
new file mode 100644
index 00000000..26f02d2c
--- /dev/null
+++ b/MOD.Scripts.Core/MODLocalization.cs
@@ -0,0 +1,124 @@
+using Newtonsoft.Json;
+using System.Collections.Generic;
+using System.IO;
+using UnityEngine;
+using Assets.Scripts.Core;
+using MOD.Scripts.UI;
+
+namespace MOD.Scripts.Core
+{
+ public class LocalizationEntry
+ {
+ public string comment;
+ public string text;
+ public string textJP;
+ }
+
+ public class LocalizationInfo
+ {
+ public Dictionary allChapters;
+
+ public LocalizationInfo()
+ {
+ allChapters = new Dictionary();
+ }
+ }
+
+ public class MODLocalization
+ {
+ private static bool initializeAttempted;
+ private static readonly LocalizationEntry notInitializedEntry;
+ private static readonly LocalizationEntry defaultEntry;
+ private static readonly LocalizationInfo fallbackInfo;
+ private static LocalizationInfo info;
+
+ static MODLocalization()
+ {
+ // This entry is shown if you try to access this class too early (before GameSystem has inititalized).
+ notInitializedEntry = new LocalizationEntry()
+ {
+ comment = "This shows if LoadFromJSON() has not been called yet",
+ text = "#NOT INITIALIZED#",
+ textJP = "#NOT INITIALIZED#",
+ };
+
+ defaultEntry = new LocalizationEntry()
+ {
+ comment = "This localization entry is missing!",
+ text = "#TEXT MISSING#",
+ textJP = "#TEXT MISSING#",
+ };
+
+ info = new LocalizationInfo();
+ fallbackInfo = new LocalizationInfo();
+
+ void addFallbackEntry(string name, string comment, string text, string textJP)
+ {
+ fallbackInfo.allChapters[name] = new LocalizationEntry()
+ {
+ comment = comment,
+ text = text,
+ textJP = textJP,
+ };
+ }
+
+ addFallbackEntry(
+ name: "no-tips-available",
+ comment: "This text appears at the top of the tips menu when there are no tips available",
+ text: "No new tips available",
+ textJP: "入手TIPSはありません"
+ );
+ }
+
+ private static LocalizationEntry GetEntry(string name)
+ {
+ if(!initializeAttempted)
+ {
+ return notInitializedEntry;
+ }
+
+ if (info.allChapters.TryGetValue(name, out LocalizationEntry entry))
+ {
+ return entry;
+ }
+
+ if (fallbackInfo.allChapters.TryGetValue(name, out LocalizationEntry fallbackEntry))
+ {
+ return fallbackEntry;
+ }
+
+ return defaultEntry;
+ }
+
+ public static string Get(string name)
+ {
+ LocalizationEntry entry = GetEntry(name);
+ return GameSystem.Instance.UseEnglishText ? entry.text : entry.textJP;
+ }
+
+ public static void LoadFromJSON()
+ {
+ initializeAttempted = true;
+ string localizationPath = Path.Combine(MODSystem.BaseDirectory, "localization.json");
+
+ if (!File.Exists(localizationPath))
+ {
+ Debug.Log($"MODLocalizationController(): No localization file at [{localizationPath}] - will use hardcoded localization");
+ return;
+ }
+
+ try
+ {
+ using (var reader = new JsonTextReader(new StreamReader(localizationPath)))
+ {
+ info = JsonSerializer.Create(new JsonSerializerSettings()).Deserialize(reader);
+ }
+ }
+ catch (System.Exception e)
+ {
+ Debug.LogError($"MODLocalizationController(): Failed to read localization file at [{localizationPath}]: {e.Message}");
+ MODToaster.Show("localization.json fail - check logs");
+ }
+ }
+ }
+}