mirror of
https://github.com/hexastack/hexabot
synced 2025-06-26 18:27:28 +00:00
50 lines
1.5 KiB
TypeScript
50 lines
1.5 KiB
TypeScript
/*
|
|
* Copyright © 2024 Hexastack. All rights reserved.
|
|
*
|
|
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
|
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
|
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
|
*/
|
|
|
|
import { useCallback } from "react";
|
|
|
|
import { useTranslations } from "../providers/TranslationProvider";
|
|
|
|
// Define a recursive interface for nested objects
|
|
interface NestedTranslation {
|
|
[key: string]: string | NestedTranslation;
|
|
}
|
|
|
|
const getNestedTranslation = (
|
|
obj: NestedTranslation,
|
|
path: string,
|
|
): string | undefined => {
|
|
return path
|
|
.split(".")
|
|
.reduce((acc: NestedTranslation | string | undefined, part) => {
|
|
if (typeof acc === "object" && acc !== null) {
|
|
return acc[part];
|
|
}
|
|
|
|
return undefined;
|
|
}, obj) as string | undefined;
|
|
};
|
|
|
|
export const useTranslation = () => {
|
|
const { translations, language } = useTranslations();
|
|
const t = useCallback(
|
|
(key: string, variables: Record<string, string> = {}): string => {
|
|
const translation =
|
|
getNestedTranslation(translations[language], key) || key;
|
|
|
|
return translation.replace(
|
|
/{(\w+)}/g,
|
|
(_, v) => variables[v] || `{${v}}`,
|
|
);
|
|
},
|
|
[language, translations],
|
|
);
|
|
|
|
return { t };
|
|
};
|