2025-04-24 11:50:14 +00:00
|
|
|
using SharedTools;
|
|
|
|
|
|
|
|
namespace AIStudio.Tools.PluginSystem;
|
|
|
|
|
|
|
|
public static class ILangExtensions
|
|
|
|
{
|
|
|
|
private static readonly ILogger<ILang> LOGGER = Program.LOGGER_FACTORY.CreateLogger<ILang>();
|
|
|
|
|
2025-04-27 10:21:00 +00:00
|
|
|
public static string GetText(this ILang lang, ILanguagePlugin plugin, string fallbackEN, string? typeNamespace = null, string? typeName = null)
|
2025-04-24 11:50:14 +00:00
|
|
|
{
|
|
|
|
var type = lang.GetType();
|
2025-04-27 10:21:00 +00:00
|
|
|
typeName ??= type.Name;
|
|
|
|
typeNamespace ??= type.Namespace!;
|
|
|
|
|
|
|
|
var ns = $"{typeNamespace}::{typeName}".ToUpperInvariant().Replace(".", "::");
|
2025-04-24 11:50:14 +00:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
LOGGER.LogDebug($"Missing translation key '{key}' for content '{fallbackEN}'.");
|
|
|
|
return fallbackEN;
|
|
|
|
}
|
|
|
|
}
|