* Started adding locale translations :) * Added some more translations * Working on translating even more pages * More translations * Added test default locale retrieval * replace `intl.formatMessage` with custom `t` hook * add more translations * improve title syntax * add more translations * translate admin config page * translated error messages * add language selecter * minor fixes * improve language handling * add upcoming languages * add `crowdin.yml` * run formatter --------- Co-authored-by: Steve Tautonico <stautonico@gmail.com>
40 lines
997 B
TypeScript
40 lines
997 B
TypeScript
import { getCookie } from "cookies-next";
|
|
import { createIntl, createIntlCache, useIntl } from "react-intl";
|
|
import i18nUtil from "../utils/i18n.util";
|
|
|
|
const useTranslate = () => {
|
|
const intl = useIntl();
|
|
return (
|
|
id: string,
|
|
values?: Parameters<typeof intl.formatMessage>[1],
|
|
opts?: Parameters<typeof intl.formatMessage>[2]
|
|
) => {
|
|
return intl.formatMessage({ id }, values, opts) as string;
|
|
};
|
|
};
|
|
|
|
const cache = createIntlCache();
|
|
|
|
export const translateOutsideContext = () => {
|
|
const locale =
|
|
getCookie("language")?.toString() ?? navigator.language.split("-")[0];
|
|
|
|
const intl = createIntl(
|
|
{
|
|
locale,
|
|
messages: i18nUtil.getLocaleByCode(locale)?.messages,
|
|
defaultLocale: "en",
|
|
},
|
|
cache
|
|
);
|
|
return (
|
|
id: string,
|
|
values?: Parameters<typeof intl.formatMessage>[1],
|
|
opts?: Parameters<typeof intl.formatMessage>[2]
|
|
) => {
|
|
return intl.formatMessage({ id }, values, opts) as string;
|
|
};
|
|
};
|
|
|
|
export default useTranslate;
|