From 141faf78ba691c92a750c4913615b7ada65ea60b Mon Sep 17 00:00:00 2001 From: Dave Dunkin Date: Wed, 24 Oct 2018 08:20:50 -0700 Subject: [PATCH] fix(locale) Add navigator.userLanguage fallback for IE11. --- frontend/src/component/user/show-user-component.jsx | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/frontend/src/component/user/show-user-component.jsx b/frontend/src/component/user/show-user-component.jsx index 9b2d704b9b..140f7af47d 100644 --- a/frontend/src/component/user/show-user-component.jsx +++ b/frontend/src/component/user/show-user-component.jsx @@ -18,15 +18,19 @@ export default class ShowUserComponent extends React.Component { componentDidMount() { this.props.fetchUser(); // find default locale and add it in choices if not present - let locale = navigator.language; + const locale = navigator.language || navigator.userLanguage; let found = this.possibleLocales.find(l => l.value === locale); if (!found) { this.possibleLocales.push({ value: locale, image: 'unknown-locale' }); } } + getLocale() { + return (this.props.location && this.props.location.locale) || navigator.language || navigator.userLanguage; + } + updateLocale() { - const locale = (this.props.location && this.props.location.locale) || navigator.language; + const locale = this.getLocale(); let index = this.possibleLocales.findIndex(v => v.value === locale); index = (index + 1) % this.possibleLocales.length; this.props.updateSettingLocation('locale', this.possibleLocales[index].value); @@ -34,7 +38,7 @@ export default class ShowUserComponent extends React.Component { render() { const email = this.props.profile ? this.props.profile.email : ''; - const locale = (this.props.location && this.props.location.locale) || navigator.language; + const locale = this.getLocale(); let foundLocale = this.possibleLocales.find(l => l.value === locale); const imageUrl = email ? this.props.profile.imageUrl : 'public/unknown-user.png'; const imageLocale = foundLocale ? `public/${foundLocale.image}.png` : `public/unknown-locale.png`;