mirror of
https://github.com/elyby/accounts-frontend.git
synced 2025-01-10 05:47:55 +05:30
82abe0a746
Split popups controllers into separate components Implemented storybooks for all project's popups
38 lines
1.0 KiB
TypeScript
38 lines
1.0 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) => {
|
|
dispatch(changeLang(lang));
|
|
// TODO: await language change and close popup, but not earlier than after 300ms
|
|
setTimeout(onClose, 300);
|
|
},
|
|
[dispatch, onClose],
|
|
);
|
|
|
|
return (
|
|
<LanguageSwitcherPopup
|
|
locales={LOCALES}
|
|
activeLocale={selectedLocale}
|
|
onSelect={onChangeLang}
|
|
onClose={onClose}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export default LanguageSwitcher;
|