mirror of
https://github.com/elyby/accounts-frontend.git
synced 2025-01-16 08:33:15 +05:30
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import React, { ComponentType, useCallback } from 'react';
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
import LOCALES from 'app/i18n';
|
|
import { changeLang } from 'app/components/user/actions';
|
|
import { RootState } from 'app/reducers';
|
|
|
|
import LanguageSwitcherPopup from './LanguageSwitcherPopup';
|
|
|
|
type Props = {
|
|
onClose?: () => void;
|
|
};
|
|
|
|
const LanguageSwitcher: ComponentType<Props> = ({ onClose = () => {} }) => {
|
|
const selectedLocale = useSelector((state: RootState) => state.i18n.locale);
|
|
const dispatch = useDispatch();
|
|
|
|
const onChangeLang = useCallback(
|
|
(lang: string) => {
|
|
Promise.all([
|
|
// 300ms is necessary for the visual animation of the language change to be completed
|
|
new Promise((resolve) => setTimeout(resolve, 300)),
|
|
dispatch(changeLang(lang)),
|
|
]).then(onClose);
|
|
},
|
|
[dispatch, onClose],
|
|
);
|
|
|
|
return (
|
|
<LanguageSwitcherPopup
|
|
locales={LOCALES}
|
|
activeLocale={selectedLocale}
|
|
onSelect={onChangeLang}
|
|
onClose={onClose}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export default LanguageSwitcher;
|