45 lines
1 KiB
React
45 lines
1 KiB
React
|
// @flow
|
||
|
import React from 'react';
|
||
|
// $FlowFixMe
|
||
|
import homepages from 'homepages';
|
||
|
import LANGUAGES from 'constants/languages';
|
||
|
import { FormField } from 'component/common/form';
|
||
|
import { getDefaultHomepageKey } from 'util/default-languages';
|
||
|
|
||
|
type Props = {
|
||
|
homepage: string,
|
||
|
setHomepage: string => void,
|
||
|
};
|
||
|
|
||
|
function SelectHomepage(props: Props) {
|
||
|
const { homepage, setHomepage } = props;
|
||
|
|
||
|
function handleSetHomepage(e) {
|
||
|
const { value } = e.target;
|
||
|
setHomepage(value);
|
||
|
}
|
||
|
if (Object.keys(homepages).length <= 1) {
|
||
|
return null;
|
||
|
}
|
||
|
return (
|
||
|
<React.Fragment>
|
||
|
<FormField
|
||
|
name="homepage_select"
|
||
|
type="select"
|
||
|
label={__('Homepage')}
|
||
|
onChange={handleSetHomepage}
|
||
|
value={homepage || getDefaultHomepageKey()}
|
||
|
helper={__('Tailor your experience.')}
|
||
|
>
|
||
|
{Object.keys(homepages).map(hp => (
|
||
|
<option key={'hp' + hp} value={hp}>
|
||
|
{`${LANGUAGES[hp][1]}`}
|
||
|
</option>
|
||
|
))}
|
||
|
</FormField>
|
||
|
</React.Fragment>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export default SelectHomepage;
|