10 changed files with 56 additions and 82 deletions
@ -1,42 +0,0 @@ |
|||||||
import { useEffect } from "react"; |
|
||||||
import { create } from "zustand"; |
|
||||||
import { persist } from "zustand/middleware"; |
|
||||||
import { immer } from "zustand/middleware/immer"; |
|
||||||
|
|
||||||
import i18n from "@/setup/i18n"; |
|
||||||
import { rtlLocales } from "@/assets/languages"; |
|
||||||
|
|
||||||
export interface LanguageStore { |
|
||||||
language: string; |
|
||||||
setLanguage(v: string): void; |
|
||||||
} |
|
||||||
|
|
||||||
export const useLanguageStore = create( |
|
||||||
persist( |
|
||||||
immer<LanguageStore>((set) => ({ |
|
||||||
language: "en", |
|
||||||
setLanguage(v) { |
|
||||||
set((s) => { |
|
||||||
s.language = v; |
|
||||||
}); |
|
||||||
}, |
|
||||||
})), |
|
||||||
{ name: "__MW::locale" } |
|
||||||
) |
|
||||||
); |
|
||||||
|
|
||||||
export function LanguageProvider() { |
|
||||||
const language = useLanguageStore((s) => s.language); |
|
||||||
|
|
||||||
useEffect(() => { |
|
||||||
i18n.changeLanguage(language); |
|
||||||
}, [language]); |
|
||||||
|
|
||||||
const isRtl = rtlLocales.includes(language); |
|
||||||
|
|
||||||
return ( |
|
||||||
<Helmet> |
|
||||||
<html dir={isRtl ? "rtl" : "ltr"} /> |
|
||||||
</Helmet> |
|
||||||
); |
|
||||||
} |
|
Loading…
Reference in new issue