Commit 7d0fb9cc authored by Moody Salem's avatar Moody Salem

workaround for the url locale not sticking

parent 8633dc7a
import { DEFAULT_LOCALE, SupportedLocale, SUPPORTED_LOCALES } from 'constants/locales' import { DEFAULT_LOCALE, SupportedLocale, SUPPORTED_LOCALES } from 'constants/locales'
import { useMemo } from 'react' import { useEffect, useMemo } from 'react'
import { useUserLocale } from 'state/user/hooks' import { useUserLocaleManager } from 'state/user/hooks'
import useParsedQueryString from './useParsedQueryString' import useParsedQueryString from './useParsedQueryString'
/** /**
...@@ -34,11 +34,16 @@ function navigatorLocale(): SupportedLocale | undefined { ...@@ -34,11 +34,16 @@ function navigatorLocale(): SupportedLocale | undefined {
*/ */
export function useActiveLocale(): SupportedLocale { export function useActiveLocale(): SupportedLocale {
const parsed = useParsedQueryString() const parsed = useParsedQueryString()
const userLocale = useUserLocale() const [userLocale, setUserLocale] = useUserLocaleManager()
return useMemo(() => { useEffect(() => {
const urlLocale = () => (typeof parsed.lng === 'string' && parseLocale(parsed.lng)) || undefined const urlLocale = typeof parsed.lng === 'string' ? parseLocale(parsed.lng) : undefined
if (urlLocale) {
setUserLocale(urlLocale)
}
}, [parsed.lng, setUserLocale, userLocale])
return userLocale ?? urlLocale() ?? navigatorLocale() ?? DEFAULT_LOCALE return useMemo(() => {
}, [userLocale, parsed]) return userLocale ?? navigatorLocale() ?? DEFAULT_LOCALE
}, [userLocale])
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment