chore(website/i18n): different load mechanism for translations

This commit is contained in:
Elian Doran
2025-10-25 20:27:42 +03:00
parent eb93762ecc
commit c08386450a
2 changed files with 20 additions and 19 deletions

View File

@@ -1,7 +1,3 @@
import { default as i18next } from "i18next";
import HttpApi from 'i18next-http-backend';
import { initReactI18next } from "react-i18next";
interface Locale { interface Locale {
id: string; id: string;
name: string; name: string;
@@ -21,16 +17,4 @@ export const LOCALES: Locale[] = [
{ id: "ar", name: "اَلْعَرَبِيَّةُ", rtl: true }, { id: "ar", name: "اَلْعَرَبِيَّةُ", rtl: true },
].toSorted((a, b) => a.name.localeCompare(b.name)); ].toSorted((a, b) => a.name.localeCompare(b.name));
i18next
.use(HttpApi)
.use(initReactI18next);
await i18next.init({
debug: true,
lng: "en",
fallbackLng: "en",
backend: {
loadPath: "/translations/{{lng}}/{{ns}}.json",
},
returnEmptyString: false
});

View File

@@ -8,9 +8,11 @@ import Footer from './components/Footer.js';
import GetStarted from './pages/GetStarted/get-started.js'; import GetStarted from './pages/GetStarted/get-started.js';
import SupportUs from './pages/SupportUs/SupportUs.js'; import SupportUs from './pages/SupportUs/SupportUs.js';
import { createContext } from 'preact'; import { createContext } from 'preact';
import { useEffect } from 'preact/hooks'; import { useEffect, useLayoutEffect, useState } from 'preact/hooks';
import { changeLanguage } from 'i18next'; import { default as i18next, changeLanguage } from 'i18next';
import { LOCALES } from './i18n'; import { LOCALES } from './i18n';
import HttpApi from 'i18next-http-backend';
import { initReactI18next } from "react-i18next";
export const LocaleContext = createContext('en'); export const LocaleContext = createContext('en');
@@ -36,6 +38,21 @@ export function App(props: {repoStargazersCount: number}) {
export function LocaleProvider({ children }) { export function LocaleProvider({ children }) {
const { path } = useLocation(); const { path } = useLocation();
const localeId = path.split('/')[1] || 'en'; const localeId = path.split('/')[1] || 'en';
const [ loaded, setLoaded ] = useState(false);
useLayoutEffect(() => {
i18next
.use(HttpApi)
.use(initReactI18next);
i18next.init({
lng: localeId,
fallbackLng: "en",
backend: {
loadPath: "/translations/{{lng}}/{{ns}}.json",
},
returnEmptyString: false
}).then(() => setLoaded(true))
}, []);
useEffect(() => { useEffect(() => {
changeLanguage(localeId); changeLanguage(localeId);
@@ -46,7 +63,7 @@ export function LocaleProvider({ children }) {
return ( return (
<LocaleContext.Provider value={localeId}> <LocaleContext.Provider value={localeId}>
{children} {loaded && children}
</LocaleContext.Provider> </LocaleContext.Provider>
); );
} }