gettext-universal 1.0.23 → 1.0.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -16,10 +16,16 @@
|
|
|
16
16
|
* via refs, so a settings picker that calls `setLocale` stays in effect
|
|
17
17
|
* across re-renders.
|
|
18
18
|
*
|
|
19
|
-
* Returns
|
|
20
|
-
*
|
|
19
|
+
* Returns the currently active locale string from `config.getLocale()`
|
|
20
|
+
* (or `undefined` when no locale has been set yet) so callers can pass
|
|
21
|
+
* it as a `useEffect` dependency. The hook's own `setTick` subscription
|
|
22
|
+
* to `onLocaleChange` makes the return value reactive — including
|
|
23
|
+
* imperative `config.setLocale(...)` calls from a settings picker that
|
|
24
|
+
* does not also push through `TranslateContext`. For the callable-
|
|
25
|
+
* translator pattern, keep using `useTranslate()` / `useTranslateExpo()`
|
|
26
|
+
* — both hooks remain available.
|
|
21
27
|
*
|
|
22
|
-
* @returns {
|
|
28
|
+
* @returns {string | undefined}
|
|
23
29
|
*/
|
|
24
|
-
export default function useLocaleExpo():
|
|
30
|
+
export default function useLocaleExpo(): string | undefined;
|
|
25
31
|
//# sourceMappingURL=use-locale-expo.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-locale-expo.d.ts","sourceRoot":"","sources":["../../src/use-locale-expo.js"],"names":[],"mappings":"AAQA
|
|
1
|
+
{"version":3,"file":"use-locale-expo.d.ts","sourceRoot":"","sources":["../../src/use-locale-expo.js"],"names":[],"mappings":"AAQA;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,yCAFa,MAAM,GAAG,SAAS,CAwE9B"}
|
|
@@ -22,10 +22,16 @@ import TranslateContext from "./translate-context.js";
|
|
|
22
22
|
* via refs, so a settings picker that calls `setLocale` stays in effect
|
|
23
23
|
* across re-renders.
|
|
24
24
|
*
|
|
25
|
-
* Returns
|
|
26
|
-
*
|
|
25
|
+
* Returns the currently active locale string from `config.getLocale()`
|
|
26
|
+
* (or `undefined` when no locale has been set yet) so callers can pass
|
|
27
|
+
* it as a `useEffect` dependency. The hook's own `setTick` subscription
|
|
28
|
+
* to `onLocaleChange` makes the return value reactive — including
|
|
29
|
+
* imperative `config.setLocale(...)` calls from a settings picker that
|
|
30
|
+
* does not also push through `TranslateContext`. For the callable-
|
|
31
|
+
* translator pattern, keep using `useTranslate()` / `useTranslateExpo()`
|
|
32
|
+
* — both hooks remain available.
|
|
27
33
|
*
|
|
28
|
-
* @returns {
|
|
34
|
+
* @returns {string | undefined}
|
|
29
35
|
*/
|
|
30
36
|
export default function useLocaleExpo() {
|
|
31
37
|
const localeContext = useContext(TranslateContext);
|
|
@@ -78,5 +84,12 @@ export default function useLocaleExpo() {
|
|
|
78
84
|
lastWrittenFallbacksRef.current = deviceLocales;
|
|
79
85
|
config.setFallbacks(deviceLocales);
|
|
80
86
|
}, [deviceLocales]);
|
|
87
|
+
// Read the authoritative locale from `config` (rather than returning the
|
|
88
|
+
// derived `primaryLocale`) so an imperative `config.setLocale("de")` from a
|
|
89
|
+
// settings picker — which emits `onLocaleChange` and re-renders this hook
|
|
90
|
+
// via `setTick` above — surfaces in the return value too. Returning
|
|
91
|
+
// `primaryLocale` would miss those overrides whenever the host app does not
|
|
92
|
+
// also push the new locale through `TranslateContext`.
|
|
93
|
+
return config.getLocale();
|
|
81
94
|
}
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"use-locale-expo.js","sourceRoot":"","sources":["../../src/use-locale-expo.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {useContext, useEffect, useMemo, useRef, useState} from \"react\"\nimport {useLocales} from \"expo-localization\"\nimport config from \"./config.js\"\nimport events from \"./events.js\"\nimport TranslateContext from \"./translate-context.js\"\n\n/**\n * Subscribes the calling component to the current locale so it re-renders\n * when any code calls `config.setLocale(...)` (e.g. a settings picker).\n * Also syncs the context-set locale + device locales into the global\n * `config` on first mount and whenever the context/device values change,\n * so direct callers of `translate(...)` read the right values without\n * needing the hook's return value.\n *\n * Pair with a class-field `_ = translate` (or a direct `import translate\n * from \"gettext-universal/build/src/translate.js\"`) so the translator is\n * always defined and typechecks cleanly, instead of relying on the\n * `useTranslate()` return value being assigned inside `setup()`.\n *\n * Does NOT fight explicit `config.setLocale(...)` callers — the hook\n * only writes when ITS OWN derived primary/fallback changes, tracked\n * via refs, so a settings picker that calls `setLocale` stays in effect\n * across re-renders.\n *\n * Returns the currently active locale string from `config.getLocale()`\n * (or `undefined` when no locale has been set yet) so callers can pass\n * it as a `useEffect` dependency. The hook's own `setTick` subscription\n * to `onLocaleChange` makes the return value reactive — including\n * imperative `config.setLocale(...)` calls from a settings picker that\n * does not also push through `TranslateContext`. For the callable-\n * translator pattern, keep using `useTranslate()` / `useTranslateExpo()`\n * — both hooks remain available.\n *\n * @returns {string | undefined}\n */\nexport default function useLocaleExpo() {\n  const localeContext = useContext(TranslateContext)\n  const locales = useLocales()\n  const contextLocale = localeContext?.locale\n\n  const deviceLocales = useMemo(() => {\n    if (!Array.isArray(locales)) return []\n\n    return locales\n      .map((localeData) => localeData.languageCode)\n      .filter(/** @type {(value: string | null) => value is string} */ ((value) => typeof value === \"string\" && value.length > 0))\n  }, [locales])\n\n  const primaryLocale = contextLocale || deviceLocales[0]\n\n  // Re-render whenever any code calls `config.setLocale(...)` — e.g. a\n  // settings picker that swaps the active locale from another screen.\n  //\n  // Must subscribe BEFORE the primary/fallbacks `useEffect`s below —\n  // those call `config.setLocale(...)` which emits `onLocaleChange`, and\n  // without a live listener the first-mount sync of a stale `config`\n  // would be silently missed, leaving the component rendering stale\n  // translations from `translate(...)` until an unrelated re-render.\n  const [, setTick] = useState(0)\n\n  useEffect(() => {\n    /** @returns {void} */\n    const onLocaleChange = () => {\n      setTick((tick) => tick + 1)\n    }\n\n    events.on(\"onLocaleChange\", onLocaleChange)\n\n    return () => {\n      events.off(\"onLocaleChange\", onLocaleChange)\n    }\n  }, [])\n\n  /** @type {React.MutableRefObject<string | null>} */\n  const lastWrittenPrimaryRef = useRef(null)\n\n  useEffect(() => {\n    if (!primaryLocale) return\n    if (lastWrittenPrimaryRef.current === primaryLocale) return\n\n    lastWrittenPrimaryRef.current = primaryLocale\n    config.setLocale(primaryLocale)\n  }, [primaryLocale])\n\n  /** @type {React.MutableRefObject<string[] | null>} */\n  const lastWrittenFallbacksRef = useRef(null)\n\n  useEffect(() => {\n    const previous = lastWrittenFallbacksRef.current\n\n    if (previous && previous.length === deviceLocales.length && previous.every((locale, index) => locale === deviceLocales[index])) {\n      return\n    }\n\n    lastWrittenFallbacksRef.current = deviceLocales\n    config.setFallbacks(deviceLocales)\n  }, [deviceLocales])\n\n  // Read the authoritative locale from `config` (rather than returning the\n  // derived `primaryLocale`) so an imperative `config.setLocale(\"de\")` from a\n  // settings picker — which emits `onLocaleChange` and re-renders this hook\n  // via `setTick` above — surfaces in the return value too. Returning\n  // `primaryLocale` would miss those overrides whenever the host app does not\n  // also push the new locale through `TranslateContext`.\n  return config.getLocale()\n}\n"]}
|