74 lines
2.1 KiB
JavaScript
74 lines
2.1 KiB
JavaScript
// @flow
|
|
|
|
import React, { useState } from 'react';
|
|
import { FormField } from 'component/common/form';
|
|
import Spinner from 'component/spinner';
|
|
import SUPPORTED_LANGUAGES from 'constants/supported_languages';
|
|
import { getDefaultLanguage } from 'util/default-languages';
|
|
|
|
type Props = {
|
|
language: string,
|
|
setLanguage: (string) => void,
|
|
searchInLanguage: boolean,
|
|
setSearchInLanguage: (boolean) => void,
|
|
};
|
|
|
|
function SettingLanguage(props: Props) {
|
|
const { language, setLanguage, searchInLanguage, setSearchInLanguage } = props;
|
|
|
|
const [previousLanguage, setPreviousLanguage] = useState(null);
|
|
const languages = SUPPORTED_LANGUAGES;
|
|
|
|
if (previousLanguage && language !== previousLanguage) {
|
|
setPreviousLanguage(null);
|
|
}
|
|
|
|
function onLanguageChange(e) {
|
|
const { value } = e.target;
|
|
setPreviousLanguage(language || getDefaultLanguage());
|
|
setLanguage(value);
|
|
}
|
|
|
|
return (
|
|
<React.Fragment>
|
|
<FormField
|
|
name="language_select"
|
|
type="select"
|
|
label={__('Language')}
|
|
onChange={onLanguageChange}
|
|
value={language || getDefaultLanguage()}
|
|
helper={__(
|
|
'Multi-language support is brand new and incomplete. Switching your language may have unintended consequences, like glossolalia.'
|
|
)}
|
|
>
|
|
{Object.entries(languages)
|
|
.sort((a, b) => {
|
|
const lhs = String(a[1]);
|
|
const rhs = String(b[1]);
|
|
if (lhs < rhs) return -1;
|
|
if (lhs > rhs) return 1;
|
|
return 0;
|
|
})
|
|
.map((language) => {
|
|
const langKey = language[0];
|
|
const langName = String(language[1]);
|
|
return (
|
|
<option key={langKey} value={langKey}>
|
|
{langName}
|
|
</option>
|
|
);
|
|
})}
|
|
</FormField>
|
|
{previousLanguage && <Spinner type="small" />}
|
|
<FormField
|
|
name="search-in-language"
|
|
type="checkbox"
|
|
label={__('Search only in this language by default')}
|
|
checked={searchInLanguage}
|
|
onChange={() => setSearchInLanguage(!searchInLanguage)}
|
|
/>
|
|
</React.Fragment>
|
|
);
|
|
}
|
|
|
|
export default SettingLanguage;
|