2023-03-03 15:23:46 +00:00
|
|
|
import { I18n } from "i18n";
|
|
|
|
import { inject, injectable } from "tsyringe";
|
|
|
|
|
|
|
|
import { ILocaleConfig } from "../models/spt/config/ILocaleConfig";
|
|
|
|
import { ILogger } from "../models/spt/utils/ILogger";
|
2023-04-23 11:26:11 +01:00
|
|
|
import { DatabaseServer } from "../servers/DatabaseServer";
|
2023-08-01 12:51:40 +01:00
|
|
|
import { RandomUtil } from "../utils/RandomUtil";
|
2023-03-03 15:23:46 +00:00
|
|
|
import { LocaleService } from "./LocaleService";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles translating server text into different langauges
|
|
|
|
*/
|
|
|
|
@injectable()
|
|
|
|
export class LocalisationService
|
|
|
|
{
|
|
|
|
protected localeConfig: ILocaleConfig;
|
|
|
|
protected i18n: I18n;
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
@inject("WinstonLogger") protected logger: ILogger,
|
2023-08-01 12:51:40 +01:00
|
|
|
@inject("RandomUtil") protected randomUtil: RandomUtil,
|
2023-04-23 11:26:11 +01:00
|
|
|
@inject("DatabaseServer") protected databaseServer: DatabaseServer,
|
2023-03-03 15:23:46 +00:00
|
|
|
@inject("LocaleService") protected localeService: LocaleService
|
|
|
|
)
|
|
|
|
{
|
2023-03-25 15:37:50 +00:00
|
|
|
const localeFileDirectory = (globalThis.G_RELEASE_CONFIGURATION) ? "Aki_Data/Server/database/locales/server" : "./assets/database/locales/server";
|
2023-03-03 15:23:46 +00:00
|
|
|
this.i18n = new I18n(
|
|
|
|
{
|
|
|
|
locales: this.localeService.getServerSupportedLocales(),
|
|
|
|
defaultLocale: "en",
|
|
|
|
directory: localeFileDirectory,
|
|
|
|
retryInDefaultLocale: true
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
this.i18n.setLocale(this.localeService.getDesiredServerLocale());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a localised value using the passed in key
|
|
|
|
* @param key Key to loop up locale for
|
|
|
|
* @param args optional arguments
|
|
|
|
* @returns Localised string
|
|
|
|
*/
|
|
|
|
public getText(key: string, args = undefined): string
|
|
|
|
{
|
|
|
|
return this.i18n.__(key.toLowerCase(), args);
|
|
|
|
}
|
2023-03-08 13:26:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all locale keys
|
|
|
|
* @returns string array of keys
|
|
|
|
*/
|
|
|
|
public getKeys(): string[]
|
|
|
|
{
|
2023-04-23 11:26:11 +01:00
|
|
|
return Object.keys(this.databaseServer.getTables().locales.server["en"]);
|
2023-03-08 13:26:32 +00:00
|
|
|
}
|
2023-08-01 12:51:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* From the provided partial key, find all keys that start with text and choose a random match
|
|
|
|
* @param partialKey Key to match locale keys on
|
|
|
|
* @returns locale text
|
|
|
|
*/
|
|
|
|
public getRandomTextThatMatchesPartialKey(partialKey: string): string
|
|
|
|
{
|
|
|
|
const filteredKeys = Object.keys(this.databaseServer.getTables().locales.server["en"]).filter(x => x.startsWith(partialKey));
|
|
|
|
const chosenKey = this.randomUtil.getArrayValue(filteredKeys);
|
|
|
|
|
|
|
|
return this.getText(chosenKey);
|
|
|
|
}
|
2023-03-03 15:23:46 +00:00
|
|
|
}
|