UNPKG

@helpwave/hightide

Version:

helpwave's component and theming library

124 lines (118 loc) 3.8 kB
// src/localization/LanguageProvider.tsx import { createContext, useContext, useEffect, useState as useState2 } from "react"; // src/hooks/useLocalStorage.ts import { useCallback, useState } from "react"; // src/util/storage.ts var StorageService = class { // this seems to be a bug in eslint as 'paramter-properties' is a special syntax of typescript constructor(storage) { this.storage = storage; } get(key) { const value = this.storage.getItem(key); if (value === null) { return null; } return JSON.parse(value); } set(key, value) { this.storage.setItem(key, JSON.stringify(value)); } delete(key) { this.storage.removeItem(key); } deleteAll() { this.storage.clear(); } }; var LocalStorageService = class extends StorageService { constructor() { super(window.localStorage); } }; // src/util/resolveSetState.ts function resolveSetState(action, prev) { return typeof action === "function" ? action(prev) : action; } // src/hooks/useLocalStorage.ts var useLocalStorage = (key, initValue) => { const get = useCallback(() => { if (typeof window === "undefined") { return initValue; } const storageService = new LocalStorageService(); const value = storageService.get(key); return value || initValue; }, [initValue, key]); const [storedValue, setStoredValue] = useState(get); const setValue = useCallback((action) => { const newValue = resolveSetState(action, storedValue); const storageService = new LocalStorageService(); storageService.set(key, newValue); setStoredValue(newValue); }, [storedValue, setStoredValue, key]); return [storedValue, setValue]; }; // src/localization/util.ts var languages = ["en", "de"]; var languagesLocalNames = { en: "English", de: "Deutsch" }; var DEFAULT_LANGUAGE = "en"; var LanguageUtil = { languages, DEFAULT_LANGUAGE, languagesLocalNames }; // src/localization/LanguageProvider.tsx import { jsx } from "react/jsx-runtime"; var LanguageContext = createContext({ language: LanguageUtil.DEFAULT_LANGUAGE, setLanguage: (v) => v }); var useLanguage = () => useContext(LanguageContext); var useLocale = (overWriteLanguage) => { const { language } = useLanguage(); const mapping = { en: "en-US", de: "de-DE" }; return mapping[overWriteLanguage ?? language]; }; var LanguageProvider = ({ initialLanguage, children }) => { const [language, setLanguage] = useState2(initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE); const [storedLanguage, setStoredLanguage] = useLocalStorage("language", initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE); useEffect(() => { if (language !== initialLanguage && initialLanguage) { console.warn("LanguageProvider initial state changed: Prefer using languageProvider's setLanguage instead"); setLanguage(initialLanguage); } }, [initialLanguage]); useEffect(() => { document.documentElement.setAttribute("lang", language); setStoredLanguage(language); }, [language]); useEffect(() => { if (storedLanguage !== null) { setLanguage(storedLanguage); return; } const LanguageToTestAgainst = Object.values(LanguageUtil.languages); const matchingBrowserLanguage = window.navigator.languages.map((language2) => LanguageToTestAgainst.find((test) => language2 === test || language2.split("-")[0] === test)).filter((entry) => entry !== void 0); if (matchingBrowserLanguage.length === 0) return; const firstMatch = matchingBrowserLanguage[0]; setLanguage(firstMatch); }, []); return /* @__PURE__ */ jsx(LanguageContext.Provider, { value: { language, setLanguage }, children }); }; export { LanguageContext, LanguageProvider, useLanguage, useLocale }; //# sourceMappingURL=LanguageProvider.mjs.map