|
@ -1,122 +1,130 @@ |
|
|
import React from 'react' |
|
|
import React, { Component } from 'react' |
|
|
import PropTypes from 'prop-types' |
|
|
import PropTypes from 'prop-types' |
|
|
import { FaBolt, FaChain } from 'react-icons/lib/fa' |
|
|
import { FaBolt, FaChain } from 'react-icons/lib/fa' |
|
|
import CurrencyIcon from '../../../../../../../components/CurrencyIcon' |
|
|
import CurrencyIcon from '../../../../../../../components/CurrencyIcon' |
|
|
import { btc } from '../../../../../../../utils' |
|
|
import { btc } from '../../../../../../../utils' |
|
|
import styles from './Pay.scss' |
|
|
import styles from './Pay.scss' |
|
|
|
|
|
|
|
|
const Pay = ({ |
|
|
class Pay extends Component { |
|
|
paymentType, |
|
|
componentDidUpdate() { |
|
|
setPaymentType, |
|
|
if (this.props.paymentType !== 'lnd') { this.amountInput.focus() } |
|
|
invoiceAmount, |
|
|
|
|
|
onchainAmount, |
|
|
|
|
|
setOnchainAmount, |
|
|
|
|
|
payment_request, |
|
|
|
|
|
setPaymentRequest, |
|
|
|
|
|
fetchInvoice, |
|
|
|
|
|
payInvoice, |
|
|
|
|
|
currency, |
|
|
|
|
|
crypto, |
|
|
|
|
|
close |
|
|
|
|
|
}) => { |
|
|
|
|
|
const payClicked = () => { |
|
|
|
|
|
if (payment_request.length !== 124) { return } |
|
|
|
|
|
|
|
|
|
|
|
payInvoice(payment_request) |
|
|
|
|
|
close() |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const paymentRequestOnChange = payreq => { |
|
|
render() { |
|
|
setPaymentRequest(payreq) |
|
|
const { |
|
|
if (payreq.length === 124) { |
|
|
paymentType, |
|
|
setPaymentType('ln') |
|
|
setPaymentType, |
|
|
fetchInvoice(payreq) |
|
|
invoiceAmount, |
|
|
} else if (payreq.length === 42) { |
|
|
onchainAmount, |
|
|
setPaymentType('onchain') |
|
|
setOnchainAmount, |
|
|
} else { |
|
|
payment_request, |
|
|
setPaymentType('') |
|
|
setPaymentRequest, |
|
|
|
|
|
fetchInvoice, |
|
|
|
|
|
payInvoice, |
|
|
|
|
|
currency, |
|
|
|
|
|
crypto, |
|
|
|
|
|
close |
|
|
|
|
|
} = this.props |
|
|
|
|
|
const payClicked = () => { |
|
|
|
|
|
if (payment_request.length !== 124) { return } |
|
|
|
|
|
|
|
|
|
|
|
payInvoice(payment_request) |
|
|
|
|
|
close() |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const calculateAmount = value => (currency === 'usd' ? btc.satoshisToUsd(value, currentTicker.price_usd) : btc.satoshisToBtc(value)) |
|
|
|
|
|
|
|
|
|
|
|
return ( |
|
|
const paymentRequestOnChange = payreq => { |
|
|
<div className={styles.container}> |
|
|
setPaymentRequest(payreq) |
|
|
<section className={`${styles.amountContainer} ${paymentType === 'ln' ? styles.ln : ''}`}> |
|
|
if (payreq.length === 124) { |
|
|
<label htmlFor='amount'> |
|
|
setPaymentType('ln') |
|
|
<CurrencyIcon currency={currency} crypto={crypto} /> |
|
|
fetchInvoice(payreq) |
|
|
</label> |
|
|
} else if (payreq.length === 42) { |
|
|
<input |
|
|
setPaymentType('onchain') |
|
|
type='text' |
|
|
} else { |
|
|
size='' |
|
|
setPaymentType('') |
|
|
style={ |
|
|
} |
|
|
paymentType === 'ln' ? |
|
|
} |
|
|
{ width: '75%', fontSize: '85px' } |
|
|
|
|
|
: |
|
|
const calculateAmount = value => (currency === 'usd' ? btc.satoshisToUsd(value, currentTicker.price_usd) : btc.satoshisToBtc(value)) |
|
|
{ width: `${onchainAmount.length > 1 ? (onchainAmount.length * 15) - 5 : 25}%`, fontSize: `${190 - (onchainAmount.length ** 2)}px` } |
|
|
|
|
|
} |
|
|
return ( |
|
|
value={paymentType === 'ln' ? calculateAmount(invoiceAmount) : onchainAmount} |
|
|
<div className={styles.container}> |
|
|
onChange={event => setOnchainAmount(event.target.value)} |
|
|
<section className={`${styles.amountContainer} ${paymentType === 'ln' ? styles.ln : ''}`}> |
|
|
id='amount' |
|
|
<label htmlFor='amount'> |
|
|
readOnly={paymentType === 'ln'} |
|
|
<CurrencyIcon currency={currency} crypto={crypto} /> |
|
|
/> |
|
|
</label> |
|
|
</section> |
|
|
|
|
|
<div className={styles.inputContainer}> |
|
|
|
|
|
<div className={styles.info}> |
|
|
|
|
|
{(() => { |
|
|
|
|
|
switch(paymentType) { |
|
|
|
|
|
case 'onchain': |
|
|
|
|
|
return ( |
|
|
|
|
|
<span>{`You're about to send ${onchainAmount} on-chain which should take around 10 minutes`}</span> |
|
|
|
|
|
) |
|
|
|
|
|
case 'ln': |
|
|
|
|
|
return ( |
|
|
|
|
|
<span>{`You're about to send ${calculateAmount(invoiceAmount)} over the Lightning Network which will be instant`}</span> |
|
|
|
|
|
) |
|
|
|
|
|
default: |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
})()} |
|
|
|
|
|
</div> |
|
|
|
|
|
<aside className={styles.paymentIcon}> |
|
|
|
|
|
{(() => { |
|
|
|
|
|
switch(paymentType) { |
|
|
|
|
|
case 'onchain': |
|
|
|
|
|
return ( |
|
|
|
|
|
<i> |
|
|
|
|
|
<span>on-chain</span> |
|
|
|
|
|
<FaChain /> |
|
|
|
|
|
</i> |
|
|
|
|
|
) |
|
|
|
|
|
case 'ln': |
|
|
|
|
|
return ( |
|
|
|
|
|
<i> |
|
|
|
|
|
<span>lightning network</span> |
|
|
|
|
|
<FaBolt /> |
|
|
|
|
|
</i> |
|
|
|
|
|
) |
|
|
|
|
|
default: |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
})()} |
|
|
|
|
|
</aside> |
|
|
|
|
|
<section className={styles.input}> |
|
|
|
|
|
<input |
|
|
<input |
|
|
type='text' |
|
|
type='text' |
|
|
placeholder='Payment request or bitcoin address' |
|
|
ref={(input) => this.amountInput = input} |
|
|
value={payment_request} |
|
|
size='' |
|
|
onChange={event => paymentRequestOnChange(event.target.value)} |
|
|
style={ |
|
|
id='paymentRequest' |
|
|
paymentType === 'ln' ? |
|
|
|
|
|
{ width: '75%', fontSize: '85px' } |
|
|
|
|
|
: |
|
|
|
|
|
{ width: `${onchainAmount.length > 1 ? (onchainAmount.length * 15) - 5 : 25}%`, fontSize: `${190 - (onchainAmount.length ** 2)}px` } |
|
|
|
|
|
} |
|
|
|
|
|
value={paymentType === 'ln' ? calculateAmount(invoiceAmount) : onchainAmount} |
|
|
|
|
|
onChange={event => setOnchainAmount(event.target.value)} |
|
|
|
|
|
id='amount' |
|
|
|
|
|
readOnly={paymentType === 'ln'} |
|
|
/> |
|
|
/> |
|
|
</section> |
|
|
</section> |
|
|
</div> |
|
|
<div className={styles.inputContainer}> |
|
|
<section className={styles.buttonGroup}> |
|
|
<div className={styles.info}> |
|
|
<div className={styles.button} onClick={payClicked}> |
|
|
{(() => { |
|
|
Pay |
|
|
switch(paymentType) { |
|
|
|
|
|
case 'onchain': |
|
|
|
|
|
return ( |
|
|
|
|
|
<span>{`You're about to send ${onchainAmount} on-chain which should take around 10 minutes`}</span> |
|
|
|
|
|
) |
|
|
|
|
|
case 'ln': |
|
|
|
|
|
return ( |
|
|
|
|
|
<span>{`You're about to send ${calculateAmount(invoiceAmount)} over the Lightning Network which will be instant`}</span> |
|
|
|
|
|
) |
|
|
|
|
|
default: |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
})()} |
|
|
|
|
|
</div> |
|
|
|
|
|
<aside className={styles.paymentIcon}> |
|
|
|
|
|
{(() => { |
|
|
|
|
|
switch(paymentType) { |
|
|
|
|
|
case 'onchain': |
|
|
|
|
|
return ( |
|
|
|
|
|
<i> |
|
|
|
|
|
<span>on-chain</span> |
|
|
|
|
|
<FaChain /> |
|
|
|
|
|
</i> |
|
|
|
|
|
) |
|
|
|
|
|
case 'ln': |
|
|
|
|
|
return ( |
|
|
|
|
|
<i> |
|
|
|
|
|
<span>lightning network</span> |
|
|
|
|
|
<FaBolt /> |
|
|
|
|
|
</i> |
|
|
|
|
|
) |
|
|
|
|
|
default: |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
})()} |
|
|
|
|
|
</aside> |
|
|
|
|
|
<section className={styles.input}> |
|
|
|
|
|
<input |
|
|
|
|
|
type='text' |
|
|
|
|
|
placeholder='Payment request or bitcoin address' |
|
|
|
|
|
value={payment_request} |
|
|
|
|
|
onChange={event => paymentRequestOnChange(event.target.value)} |
|
|
|
|
|
id='paymentRequest' |
|
|
|
|
|
/> |
|
|
|
|
|
</section> |
|
|
</div> |
|
|
</div> |
|
|
</section> |
|
|
<section className={styles.buttonGroup}> |
|
|
</div> |
|
|
<div className={styles.button} onClick={payClicked}> |
|
|
) |
|
|
Pay |
|
|
|
|
|
</div> |
|
|
|
|
|
</section> |
|
|
|
|
|
</div> |
|
|
|
|
|
) |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Pay.propTypes = { |
|
|
Pay.propTypes = { |
|
|