2019-09-04 17:43:37 -04:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import React, { useState } from 'react';
|
|
|
|
import { FormField } from 'component/common/form';
|
|
|
|
import Spinner from 'component/spinner';
|
2020-10-15 13:56:55 -04:00
|
|
|
import SUPPORTED_LANGUAGES from 'constants/supported_languages';
|
2021-07-16 19:51:08 +02:00
|
|
|
import LANGUAGES from 'constants/languages';
|
2021-06-07 09:54:39 +08:00
|
|
|
import { getDefaultLanguage, sortLanguageMap } from 'util/default-languages';
|
2019-09-04 17:43:37 -04:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
language: string,
|
2021-04-05 12:43:42 +08:00
|
|
|
setLanguage: (string) => void,
|
2019-09-04 17:43:37 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
function SettingLanguage(props: Props) {
|
2021-08-05 21:16:10 +08:00
|
|
|
const { language, setLanguage } = props;
|
2019-11-05 13:54:58 -05:00
|
|
|
const [previousLanguage, setPreviousLanguage] = useState(null);
|
2019-10-03 12:55:21 -04:00
|
|
|
|
2019-11-05 13:54:58 -05:00
|
|
|
if (previousLanguage && language !== previousLanguage) {
|
|
|
|
setPreviousLanguage(null);
|
|
|
|
}
|
2019-09-04 17:43:37 -04:00
|
|
|
|
|
|
|
function onLanguageChange(e) {
|
|
|
|
const { value } = e.target;
|
2020-11-20 08:21:31 -05:00
|
|
|
setPreviousLanguage(language || getDefaultLanguage());
|
2019-11-05 13:54:58 -05:00
|
|
|
setLanguage(value);
|
2021-07-16 19:51:08 +02:00
|
|
|
if (document && document.documentElement) {
|
|
|
|
if (LANGUAGES[value].length >= 3) {
|
|
|
|
document.documentElement.dir = LANGUAGES[value][2];
|
|
|
|
} else {
|
|
|
|
document.documentElement.dir = 'ltr';
|
|
|
|
}
|
|
|
|
}
|
2019-09-04 17:43:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<React.Fragment>
|
2021-09-13 15:42:46 +08:00
|
|
|
{!previousLanguage && (
|
|
|
|
<FormField
|
|
|
|
name="language_select"
|
|
|
|
type="select"
|
|
|
|
onChange={onLanguageChange}
|
|
|
|
value={language || getDefaultLanguage()}
|
|
|
|
>
|
|
|
|
{sortLanguageMap(SUPPORTED_LANGUAGES).map(([langKey, langName]) => (
|
|
|
|
<option key={langKey} value={langKey}>
|
|
|
|
{langName}
|
|
|
|
</option>
|
|
|
|
))}
|
|
|
|
</FormField>
|
|
|
|
)}
|
2021-08-05 21:16:10 +08:00
|
|
|
|
2021-09-13 15:42:46 +08:00
|
|
|
{previousLanguage && <Spinner type="small" />}
|
2019-09-04 17:43:37 -04:00
|
|
|
</React.Fragment>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SettingLanguage;
|