mirror of
https://github.com/hexastack/hexabot
synced 2025-06-26 18:27:28 +00:00
46 lines
1.4 KiB
TypeScript
46 lines
1.4 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 { useTranslation } from "react-i18next";
|
|
|
|
import {
|
|
TOptionsBaseExtended,
|
|
TTranslateProps,
|
|
TTranslationKeys,
|
|
} from "@/i18n/i18n.types";
|
|
|
|
export const useTranslate = (ns?: string) => {
|
|
const { t, i18n } = useTranslation(ns);
|
|
const translate: TTranslateProps = (
|
|
prop1: unknown,
|
|
prop2?: unknown,
|
|
prop3?: unknown,
|
|
): string => {
|
|
// full key. For example: prop1 = label.buttons
|
|
if (typeof prop1 === "string" && prop1.includes(".")) {
|
|
const key = prop1 as TTranslationKeys;
|
|
const options = (prop2 || {}) as TOptionsBaseExtended;
|
|
|
|
return t(key, { defaultValue: "", ...options });
|
|
}
|
|
|
|
// key with nested key. For example: prop1=label prop2=buttons
|
|
const options = (prop3 || {}) as TOptionsBaseExtended;
|
|
|
|
return t([prop1, prop2].join(".") as TTranslationKeys, {
|
|
defaultValue: "",
|
|
...options,
|
|
});
|
|
};
|
|
|
|
return {
|
|
t: translate,
|
|
i18n,
|
|
};
|
|
};
|