2020-07-06 19:29:56 +03:00
|
|
|
import React, { ComponentType, useCallback } from 'react';
|
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
2019-06-30 16:32:50 +03:00
|
|
|
|
2020-07-06 19:29:56 +03:00
|
|
|
import LOCALES from 'app/i18n';
|
|
|
|
import { changeLang } from 'app/components/user/actions';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { RootState } from 'app/reducers';
|
2017-12-17 03:26:09 +03:00
|
|
|
|
2020-07-06 19:29:56 +03:00
|
|
|
import LanguageSwitcherPopup from './LanguageSwitcherPopup';
|
2017-12-30 23:38:54 +02:00
|
|
|
|
2020-07-06 19:29:56 +03:00
|
|
|
type Props = {
|
|
|
|
onClose?: () => void;
|
2019-06-30 16:32:50 +03:00
|
|
|
};
|
|
|
|
|
2020-07-06 19:29:56 +03:00
|
|
|
const LanguageSwitcher: ComponentType<Props> = ({ onClose = () => {} }) => {
|
|
|
|
const selectedLocale = useSelector((state: RootState) => state.i18n.locale);
|
|
|
|
const dispatch = useDispatch();
|
2017-12-30 23:38:54 +02:00
|
|
|
|
2020-07-06 19:29:56 +03:00
|
|
|
const onChangeLang = useCallback(
|
|
|
|
(lang: string) => {
|
|
|
|
dispatch(changeLang(lang));
|
|
|
|
// TODO: await language change and close popup, but not earlier than after 300ms
|
|
|
|
setTimeout(onClose, 300);
|
2020-05-24 02:08:24 +03:00
|
|
|
},
|
2020-07-06 19:29:56 +03:00
|
|
|
[dispatch, onClose],
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<LanguageSwitcherPopup
|
|
|
|
locales={LOCALES}
|
|
|
|
activeLocale={selectedLocale}
|
|
|
|
onSelect={onChangeLang}
|
|
|
|
onClose={onClose}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default LanguageSwitcher;
|