52 lines
1.5 KiB
JavaScript
52 lines
1.5 KiB
JavaScript
/* @flow */
|
|
|
|
import React from "react";
|
|
import PropTypes from "prop-types";
|
|
|
|
import "../general.css";
|
|
|
|
export class CountrySelect extends React.PureComponent<{
|
|
dispatch: ({}) => any
|
|
}> {
|
|
static propTypes = {
|
|
loading: PropTypes.bool.isRequired,
|
|
list: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
onSelect: PropTypes.func.isRequired,
|
|
getCountries: PropTypes.func.isRequired
|
|
};
|
|
|
|
componentDidMount() {
|
|
this.props.getCountries();
|
|
}
|
|
|
|
onSelect = (e: { target: HTMLOptionElement }) =>
|
|
this.props.onSelect(e.target.value);
|
|
|
|
render() {
|
|
if (this.props.loading) {
|
|
return <div className="bordered">Loading countries...</div>;
|
|
} else {
|
|
const sortedCountries = [...this.props.list].sort(
|
|
(a, b) => (a.countryName < b.countryName ? -1 : 1)
|
|
);
|
|
|
|
return (
|
|
<div className="bordered">
|
|
Country:
|
|
<select onChange={this.onSelect}>
|
|
<option value="">Select a country:</option>
|
|
{sortedCountries.map(x => (
|
|
<option
|
|
key={x.countryCode}
|
|
value={x.countryCode}
|
|
>
|
|
{x.countryName}
|
|
</option>
|
|
))}
|
|
</select>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
}
|