You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

109 lines
3.0 KiB

import React from 'react'
import PropTypes from 'prop-types'
import { FormattedMessage, injectIntl } from 'react-intl'
import Button from 'components/UI/Button'
import messages from './messages'
import styles from './ConnectManually.scss'
class ConnectManually extends React.Component {
render() {
const {
manualSearchQuery,
manualFormIsValid,
updateManualFormErrors,
openSubmitChannelForm,
updateManualFormSearchQuery,
setNode,
showErrors,
intl
} = this.props
const formSubmitted = () => {
if (!manualFormIsValid.isValid) {
updateManualFormErrors(manualFormIsValid.errors)
return
}
// clear any existing errors
updateManualFormErrors({ manualInput: null })
const [pub_key, addr] = manualSearchQuery && manualSearchQuery.split('@')
// the SubmitChannel component is expecting a node object that looks like the following
// {
// pub_key: 'some_string',
// addresses: [
// {
// addr: 'some_host_address'
// }
// ]
// }
// knowing this we will set the node object with the known format and plug in the pubkey + host accordingly
setNode({ pub_key, addresses: [{ addr }] })
// now we close the ConnectManually form and open the SubmitChannel form by chaning the channelFormType
openSubmitChannelForm()
}
return (
<div className={styles.content}>
<header className={styles.header}>
<h1>
<FormattedMessage {...messages.title} />
</h1>
<p>
<FormattedMessage {...messages.description} />
</p>
</header>
<section className={styles.peer}>
<div className={styles.input}>
<input
type="text"
placeholder={intl.formatMessage({ ...messages.placeholder })}
value={manualSearchQuery}
onChange={event => updateManualFormSearchQuery(event.target.value)}
/>
</div>
</section>
<section
className={`${styles.errorMessage} ${showErrors.manualInput ? styles.active : undefined}`}
>
{showErrors.manualInput && (
<span>{manualFormIsValid && manualFormIsValid.errors.manualInput}</span>
)}
</section>
<section className={styles.submit}>
<Button disabled={!manualFormIsValid.isValid} onClick={formSubmitted} size="large">
<FormattedMessage {...messages.submit} />
</Button>
</section>
</div>
)
}
}
ConnectManually.propTypes = {
manualSearchQuery: PropTypes.string.isRequired,
manualFormIsValid: PropTypes.object.isRequired,
updateManualFormErrors: PropTypes.func.isRequired,
openSubmitChannelForm: PropTypes.func.isRequired,
updateManualFormSearchQuery: PropTypes.func.isRequired,
setNode: PropTypes.func.isRequired,
showErrors: PropTypes.object.isRequired
}
export default injectIntl(ConnectManually)