import React from 'react' import PropTypes from 'prop-types' import FaAngleDown from 'react-icons/lib/fa/angle-down' import FaExclamationCircle from 'react-icons/lib/fa/exclamation-circle' import AmountInput from 'components/AmountInput' import styles from './SubmitChannelForm.scss' class SubmitChannelForm extends React.Component { constructor(props) { super(props) this.amountInput = React.createRef() } componentDidMount() { // Clear and Focus the amount input field. this.amountInput.current.clearTextInput() this.amountInput.current.focusTextInput() } render() { const { closeChannelForm, closeContactsForm, node, contactCapacity, updateContactCapacity, openChannel, fiatTicker, dupeChanInfo, ticker, toggleCurrencyProps: { setContactsCurrencyFilters, showCurrencyFilters, currencyName, currentCurrencyFilters, onCurrencyFilterClick, contactFormFiatAmount } } = this.props const renderTitle = () => { // if the node has an alias set we will show that with the pubkey in parens // if not, just show the pubkey (would look ugly with rando parens) if (node.alias && node.alias.length) { return `${node.alias} (${node.pub_key})` } return node.pub_key } const renderWarning = dupeChanInfo => { const { alias, activeChannels, capacity, currencyName } = dupeChanInfo const chansMsg = activeChannels === 1 ? ' an active channel ' : ` ${activeChannels} active channels ` const aliasMsg = alias ? {alias} : ' this node ' return (

{`You currently have ${chansMsg} open to `} {aliasMsg} {` with a capacity of ${capacity} ${currencyName}.`}

) } const formSubmitted = () => { // dont submit to LND if they havent set channel capacity amount if (contactCapacity <= 0) { return } // submit the channel to LND openChannel({ pubkey: node.pub_key, host: node.addresses[0].addr, local_amt: contactCapacity }) // close the ChannelForm component closeChannelForm() // close the AddChannel component closeContactsForm() } return (

Add Funds to Network

Opening a channel will help you send and receive money on the Lightning Network. You aren't spending any money, rather moving the money you plan to use onto the network.

{renderTitle()}

{dupeChanInfo && (
{renderWarning(dupeChanInfo)}
)}
setContactsCurrencyFilters(!showCurrencyFilters)} > {currencyName}
    {currentCurrencyFilters.map(filter => (
  • onCurrencyFilterClick(filter.key)}> {filter.name}
  • ))}
{`≈ ${contactFormFiatAmount || 0} ${fiatTicker}`}
0 ? styles.active : undefined}`} onClick={formSubmitted} > Submit
) } } SubmitChannelForm.propTypes = { closeChannelForm: PropTypes.func.isRequired, closeContactsForm: PropTypes.func.isRequired, node: PropTypes.object.isRequired, contactCapacity: PropTypes.PropTypes.oneOfType([PropTypes.number, PropTypes.string]), updateContactCapacity: PropTypes.func.isRequired, openChannel: PropTypes.func.isRequired, fiatTicker: PropTypes.string.isRequired, dupeChanInfo: PropTypes.object, ticker: PropTypes.object.isRequired, toggleCurrencyProps: PropTypes.object.isRequired } export default SubmitChannelForm