import React from 'react'; import PropTypes from 'prop-types'; import { connect } from 'react-redux'; import { defineMessages, injectIntl } from 'react-intl'; import classNames from 'classnames'; import Icon from 'soapbox/components/icon'; import Button from 'soapbox/components/button'; import { fetchAliasesSuggestions, clearAliasesSuggestions, changeAliasesSuggestions } from '../../../actions/aliases'; const messages = defineMessages({ search: { id: 'aliases.search', defaultMessage: 'Search your old account' }, searchTitle: { id: 'tabs_bar.search', defaultMessage: 'Search' }, }); const mapStateToProps = state => ({ value: state.getIn(['aliases', 'suggestions', 'value']), }); const mapDispatchToProps = dispatch => ({ onSubmit: value => dispatch(fetchAliasesSuggestions(value)), onClear: () => dispatch(clearAliasesSuggestions()), onChange: value => dispatch(changeAliasesSuggestions(value)), }); export default @connect(mapStateToProps, mapDispatchToProps) @injectIntl class Search extends React.PureComponent { static propTypes = { intl: PropTypes.object.isRequired, value: PropTypes.string.isRequired, onChange: PropTypes.func.isRequired, onSubmit: PropTypes.func.isRequired, onClear: PropTypes.func.isRequired, }; handleChange = e => { this.props.onChange(e.target.value); } handleKeyUp = e => { if (e.keyCode === 13) { this.props.onSubmit(this.props.value); } } handleSubmit = () => { this.props.onSubmit(this.props.value); } handleClear = () => { this.props.onClear(); } render() { const { value, intl } = this.props; const hasValue = value.length > 0; return (