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.

128 lines
3.8 KiB

import React from 'react'
import PropTypes from 'prop-types'
import ReactModal from 'react-modal'
import { FaUser } from 'react-icons/lib/fa'
import CurrencyIcon from 'components/CurrencyIcon'
import { usd, btc } from 'utils'
import styles from './ChannelForm.scss'
const ChannelForm = ({ form, setForm, ticker, peers, openChannel, currentTicker }) => {
const submitClicked = () => {
const { node_key, local_amt, push_amt } = form
const localamt = ticker.currency === 'usd' ? btc.btcToSatoshis(usd.usdToBtc(local_amt, currentTicker.price_usd)) : btc.btcToSatoshis(local_amt)
const pushamt = ticker.currency === 'usd' ? btc.btcToSatoshis(usd.usdToBtc(push_amt, currentTicker.price_usd)) : btc.btcToSatoshis(push_amt)
openChannel({ pubkey: node_key, localamt, pushamt })
setForm({ isOpen: false })
}
const customStyles = {
overlay: {
cursor: 'pointer',
overflowY: 'auto'
},
content: {
top: 'auto',
left: '20%',
right: '0',
bottom: 'auto',
width: '40%',
margin: '50px auto',
padding: '40px'
}
}
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}>Open a new channel</h1>
<section className={styles.pubkey}>
<label htmlFor='nodekey'><FaUser /></label>
<input
type='text'
size=''
placeholder='Peer public key'
value={form.node_key}
onChange={event => setForm({ node_key: event.target.value })}
id='nodekey'
/>
</section>
<section className={styles.local}>
<label htmlFor='localamount'>
<CurrencyIcon currency={ticker.currency} crypto={ticker.crypto} />
</label>
<input
type='text'
size=''
placeholder='Local amount'
value={form.local_amt}
onChange={event => setForm({ local_amt: event.target.value })}
id='localamount'
/>
</section>
<section className={styles.push}>
<label htmlFor='pushamount'>
<CurrencyIcon currency={ticker.currency} crypto={ticker.crypto} />
</label>
<input
type='text'
size=''
placeholder='Push amount'
value={form.push_amt}
onChange={event => setForm({ push_amt: event.target.value })}
id='pushamount'
/>
</section>
<ul className={styles.peers}>
<h2>Connected Peers</h2>
{
peers.length ?
peers.map(peer =>
(
<li
key={peer.peer_id}
className={styles.peer}
onClick={() => setForm({ node_key: peer.pub_key })}
>
<h4>{peer.address}</h4>
<h1>{peer.pub_key}</h1>
</li>
)
)
:
null
}
</ul>
<div className={styles.buttonGroup}>
<div className={styles.button} onClick={submitClicked}>Submit</div>
</div>
</div>
</ReactModal>
</div>
)
}
ChannelForm.propTypes = {
form: PropTypes.object.isRequired,
setForm: PropTypes.func.isRequired,
ticker: PropTypes.object.isRequired,
peers: PropTypes.array.isRequired,
openChannel: PropTypes.func.isRequired,
currentTicker: PropTypes.object.isRequired
}
export default ChannelForm