UNPKG

@helpwave/hightide

Version:

helpwave's component and theming library

151 lines (144 loc) 5.1 kB
var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/localization/LanguageProvider.tsx var LanguageProvider_exports = {}; __export(LanguageProvider_exports, { LanguageContext: () => LanguageContext, LanguageProvider: () => LanguageProvider, useLanguage: () => useLanguage, useLocale: () => useLocale }); module.exports = __toCommonJS(LanguageProvider_exports); var import_react2 = require("react"); // src/hooks/useLocalStorage.ts var import_react = require("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 = (0, import_react.useCallback)(() => { if (typeof window === "undefined") { return initValue; } const storageService = new LocalStorageService(); const value = storageService.get(key); return value || initValue; }, [initValue, key]); const [storedValue, setStoredValue] = (0, import_react.useState)(get); const setValue = (0, import_react.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 var import_jsx_runtime = require("react/jsx-runtime"); var LanguageContext = (0, import_react2.createContext)({ language: LanguageUtil.DEFAULT_LANGUAGE, setLanguage: (v) => v }); var useLanguage = () => (0, import_react2.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] = (0, import_react2.useState)(initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE); const [storedLanguage, setStoredLanguage] = useLocalStorage("language", initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE); (0, import_react2.useEffect)(() => { if (language !== initialLanguage && initialLanguage) { console.warn("LanguageProvider initial state changed: Prefer using languageProvider's setLanguage instead"); setLanguage(initialLanguage); } }, [initialLanguage]); (0, import_react2.useEffect)(() => { document.documentElement.setAttribute("lang", language); setStoredLanguage(language); }, [language]); (0, import_react2.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__ */ (0, import_jsx_runtime.jsx)(LanguageContext.Provider, { value: { language, setLanguage }, children }); }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { LanguageContext, LanguageProvider, useLanguage, useLocale }); //# sourceMappingURL=LanguageProvider.js.map