2025-04-17 10:38:45 +00:00
|
|
|
using SharedTools;
|
|
|
|
|
|
|
|
namespace AIStudio.Tools.PluginSystem;
|
|
|
|
|
|
|
|
public static class ILangExtensions
|
|
|
|
{
|
|
|
|
private static readonly ILogger<ILang> LOGGER = Program.LOGGER_FACTORY.CreateLogger<ILang>();
|
|
|
|
|
|
|
|
public static string GetText(this ILang lang, ILanguagePlugin plugin, string fallbackEN)
|
|
|
|
{
|
|
|
|
var type = lang.GetType();
|
|
|
|
var ns = $"{type.Namespace!}::{type.Name}".ToUpperInvariant().Replace(".", "::");
|
|
|
|
var key = $"root::{ns}::T{fallbackEN.ToFNV32()}";
|
|
|
|
|
|
|
|
if(plugin is NoPluginLanguage)
|
|
|
|
return fallbackEN;
|
|
|
|
|
|
|
|
if(plugin.TryGetText(key, out var text, logWarning: false))
|
|
|
|
{
|
|
|
|
if(string.IsNullOrWhiteSpace(text))
|
|
|
|
return fallbackEN;
|
|
|
|
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
2025-04-21 10:12:39 +00:00
|
|
|
LOGGER.LogDebug($"Missing translation key '{key}' for content '{fallbackEN}'.");
|
2025-04-17 10:38:45 +00:00
|
|
|
return fallbackEN;
|
|
|
|
}
|
|
|
|
}
|