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.
83 lines
2.0 KiB
83 lines
2.0 KiB
8 years ago
|
import React from 'react'
|
||
|
import PropTypes from 'prop-types'
|
||
8 years ago
|
import ReactModal from 'react-modal'
|
||
|
import styles from './PeerForm.scss'
|
||
|
|
||
8 years ago
|
const PeerForm = ({ form, setForm, connect }) => {
|
||
|
const submit = () => {
|
||
|
const { pubkey, host } = form
|
||
8 years ago
|
connect({ pubkey, host })
|
||
8 years ago
|
}
|
||
8 years ago
|
|
||
8 years ago
|
const customStyles = {
|
||
|
overlay: {
|
||
|
cursor: 'pointer',
|
||
|
overflowY: 'auto'
|
||
|
},
|
||
|
content: {
|
||
|
top: 'auto',
|
||
|
left: '20%',
|
||
|
right: '0',
|
||
|
bottom: 'auto',
|
||
|
width: '40%',
|
||
|
margin: '50px auto',
|
||
|
padding: '40px'
|
||
8 years ago
|
}
|
||
8 years ago
|
}
|
||
8 years ago
|
|
||
8 years ago
|
return (
|
||
|
<div>
|
||
|
<ReactModal
|
||
|
isOpen={form.isOpen}
|
||
|
contentLabel='No Overlay Click Modal'
|
||
|
ariaHideApp
|
||
|
shouldCloseOnOverlayClick
|
||
|
onRequestClose={() => setForm({ isOpen: false })}
|
||
|
parentSelector={() => document.body}
|
||
|
style={customStyles}
|
||
|
>
|
||
|
<div className={styles.form}>
|
||
|
<h1 className={styles.title}>Connect to a peer</h1>
|
||
8 years ago
|
|
||
8 years ago
|
<section className={styles.pubkey}>
|
||
|
<label htmlFor='pubkey'>Pubkey</label>
|
||
|
<input
|
||
|
type='text'
|
||
|
size=''
|
||
|
placeholder='Public key'
|
||
|
value={form.pubkey}
|
||
|
onChange={event => setForm({ pubkey: event.target.value })}
|
||
|
id='pubkey'
|
||
|
/>
|
||
|
</section>
|
||
|
<section className={styles.local}>
|
||
|
<label htmlFor='address'>Address</label>
|
||
|
<input
|
||
|
type='text'
|
||
|
size=''
|
||
|
placeholder='Host address'
|
||
|
value={form.host}
|
||
|
onChange={event => setForm({ host: event.target.value })}
|
||
|
id='address'
|
||
|
/>
|
||
|
</section>
|
||
8 years ago
|
|
||
8 years ago
|
<div className={styles.buttonGroup}>
|
||
|
<div className={styles.button} onClick={submit}>
|
||
|
Submit
|
||
8 years ago
|
</div>
|
||
|
</div>
|
||
8 years ago
|
</div>
|
||
|
</ReactModal>
|
||
|
</div>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
PeerForm.propTypes = {
|
||
|
form: PropTypes.object.isRequired,
|
||
|
setForm: PropTypes.func.isRequired,
|
||
|
connect: PropTypes.func.isRequired
|
||
8 years ago
|
}
|
||
|
|
||
8 years ago
|
export default PeerForm
|