|
@ -5,17 +5,31 @@ import { MdClose } from 'react-icons/lib/md' |
|
|
import { FaCircle } from 'react-icons/lib/fa' |
|
|
import { FaCircle } from 'react-icons/lib/fa' |
|
|
import styles from './ContactsForm.scss' |
|
|
import styles from './ContactsForm.scss' |
|
|
|
|
|
|
|
|
const ContactsForm = ({ |
|
|
class ContactsForm extends React.Component { |
|
|
|
|
|
constructor(props) { |
|
|
|
|
|
super(props) |
|
|
|
|
|
|
|
|
|
|
|
this.state = { |
|
|
|
|
|
editing: false |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
render() { |
|
|
|
|
|
const { |
|
|
contactsform, |
|
|
contactsform, |
|
|
closeContactsForm, |
|
|
closeContactsForm, |
|
|
updateContactFormSearchQuery, |
|
|
updateContactFormSearchQuery, |
|
|
|
|
|
updateContactCapacity, |
|
|
openChannel, |
|
|
openChannel, |
|
|
|
|
|
|
|
|
activeChannelPubkeys, |
|
|
activeChannelPubkeys, |
|
|
nonActiveChannelPubkeys, |
|
|
nonActiveChannelPubkeys, |
|
|
pendingOpenChannelPubkeys, |
|
|
pendingOpenChannelPubkeys, |
|
|
filteredNetworkNodes |
|
|
filteredNetworkNodes |
|
|
}) => { |
|
|
} = this.props |
|
|
|
|
|
|
|
|
|
|
|
const { editing } = this.state |
|
|
|
|
|
|
|
|
const renderRightSide = (node) => { |
|
|
const renderRightSide = (node) => { |
|
|
if (activeChannelPubkeys.includes(node.pub_key)) { |
|
|
if (activeChannelPubkeys.includes(node.pub_key)) { |
|
|
return ( |
|
|
return ( |
|
@ -53,13 +67,19 @@ const ContactsForm = ({ |
|
|
<span |
|
|
<span |
|
|
className={`${styles.connect} hint--left`} |
|
|
className={`${styles.connect} hint--left`} |
|
|
data-hint='Connect with 0.1 BTC' |
|
|
data-hint='Connect with 0.1 BTC' |
|
|
onClick={() => openChannel({ pubkey: node.pub_key, host: node.addresses[0].addr, local_amt: 0.1 })} |
|
|
onClick={() => openChannel({ pubkey: node.pub_key, host: node.addresses[0].addr, local_amt: contactsform.contactsform.contactCapacity })} |
|
|
> |
|
|
> |
|
|
Connect |
|
|
Connect |
|
|
</span> |
|
|
</span> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const inputClicked = () => { |
|
|
|
|
|
if (editing) { return } |
|
|
|
|
|
|
|
|
|
|
|
this.setState({ editing: true }) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<div> |
|
|
<div> |
|
|
<ReactModal |
|
|
<ReactModal |
|
@ -80,7 +100,7 @@ const ContactsForm = ({ |
|
|
</div> |
|
|
</div> |
|
|
</header> |
|
|
</header> |
|
|
|
|
|
|
|
|
<div className={styles.form} onKeyPress={event => event.charCode === 13 && console.log('gaaaang')}> |
|
|
<div className={styles.form}> |
|
|
<div className={styles.search}> |
|
|
<div className={styles.search}> |
|
|
<input |
|
|
<input |
|
|
type='text' |
|
|
type='text' |
|
@ -122,7 +142,15 @@ const ContactsForm = ({ |
|
|
<footer className={styles.footer}> |
|
|
<footer className={styles.footer}> |
|
|
<div> |
|
|
<div> |
|
|
<span className={styles.amount}> |
|
|
<span className={styles.amount}> |
|
|
0.1 |
|
|
<input |
|
|
|
|
|
type='text' |
|
|
|
|
|
value={contactsform.contactCapacity} |
|
|
|
|
|
onChange={event => updateContactCapacity(event.target.value)} |
|
|
|
|
|
onClick={inputClicked} |
|
|
|
|
|
onKeyPress={event => event.charCode === 13 && this.setState({ editing: false })} |
|
|
|
|
|
readOnly={!editing} |
|
|
|
|
|
style={{ width: `${editing ? 20 : contactsform.contactCapacity.toString().length + 1}%` }} |
|
|
|
|
|
/> |
|
|
</span> |
|
|
</span> |
|
|
<span className={styles.caption}> |
|
|
<span className={styles.caption}> |
|
|
BTC per contact |
|
|
BTC per contact |
|
@ -133,6 +161,8 @@ const ContactsForm = ({ |
|
|
</div> |
|
|
</div> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ContactsForm.propTypes = { |
|
|
ContactsForm.propTypes = { |
|
|
|
|
|
|
|
|