import { compose } from 'ramda' import React, { Component } from 'react' import emoji from 'react-easy-emoji' import { withNamespaces } from 'react-i18next' import { connect } from 'react-redux' import { withRouter } from 'react-router' const languageCodeToEmoji = { en: '🇬🇧', fr: '🇫🇷' } export default compose( withRouter, withNamespaces(), connect( null, dispatch => ({ changeLanguage: lang => dispatch({ type: 'SWITCH_LANG', lang }) }) ) )( class LangSwitcher extends Component { getUnusedLanguageCode = () => { let languageCode = this.props.i18n.language return !languageCode || languageCode === 'fr' ? 'en' : 'fr' } changeLanguage = () => { let nextLanguage = this.getUnusedLanguageCode() this.props.changeLanguage(nextLanguage) this.props.i18n.changeLanguage(nextLanguage) this.forceUpdate() } render() { const languageCode = this.getUnusedLanguageCode() return ( ) } } )