2020-01-17 23:37:52 +03:00
|
|
|
import React, { ComponentType, useCallback } from 'react';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2020-07-22 13:01:12 +03:00
|
|
|
|
|
|
|
import { useReduxDispatch, useReduxSelector } from 'app/functions';
|
2020-07-20 15:19:15 +03:00
|
|
|
import { getLocaleIconUrl } from 'app/components/i18n';
|
2019-12-07 21:02:00 +02:00
|
|
|
import LANGS from 'app/i18n';
|
|
|
|
import { create as createPopup } from 'app/components/ui/popup/actions';
|
|
|
|
import LanguageSwitcher from 'app/components/languageSwitcher';
|
2019-06-30 16:32:50 +03:00
|
|
|
|
2017-12-30 23:38:54 +02:00
|
|
|
import styles from './link.scss';
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
const LanguageLink: ComponentType = () => {
|
2020-07-22 13:01:12 +03:00
|
|
|
const dispatch = useReduxDispatch();
|
2020-05-24 02:08:24 +03:00
|
|
|
const showLanguageSwitcherPopup = useCallback(() => {
|
|
|
|
dispatch(createPopup({ Popup: LanguageSwitcher }));
|
|
|
|
}, [dispatch]);
|
2020-01-17 23:37:52 +03:00
|
|
|
|
2020-07-22 13:01:12 +03:00
|
|
|
const userLang = useReduxSelector((state) => state.user.lang);
|
|
|
|
const interfaceLocale = useReduxSelector((state) => state.i18n.locale);
|
2019-06-30 16:32:50 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
const localeDefinition = LANGS[userLang] || LANGS[interfaceLocale];
|
2019-05-21 18:23:13 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return (
|
|
|
|
<span
|
|
|
|
className={clsx(styles.languageLink, {
|
|
|
|
[styles.mark]: userLang !== interfaceLocale,
|
|
|
|
})}
|
|
|
|
onClick={showLanguageSwitcherPopup}
|
|
|
|
>
|
|
|
|
<span
|
|
|
|
className={styles.languageIcon}
|
|
|
|
style={{
|
2020-07-20 15:19:15 +03:00
|
|
|
backgroundImage: `url('${getLocaleIconUrl(localeDefinition.code)}')`,
|
2020-05-24 02:08:24 +03:00
|
|
|
}}
|
|
|
|
/>
|
|
|
|
{localeDefinition.name}
|
|
|
|
</span>
|
|
|
|
);
|
2020-01-17 23:37:52 +03:00
|
|
|
};
|
2017-12-30 23:38:54 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
export default LanguageLink;
|