|
@ -8,7 +8,9 @@ import styles from './Pay.scss' |
|
|
const Pay = ({ |
|
|
const Pay = ({ |
|
|
paymentType, |
|
|
paymentType, |
|
|
setPaymentType, |
|
|
setPaymentType, |
|
|
amount, |
|
|
invoiceAmount, |
|
|
|
|
|
onchainAmount, |
|
|
|
|
|
setAmount, |
|
|
payment_request, |
|
|
payment_request, |
|
|
setPaymentRequest, |
|
|
setPaymentRequest, |
|
|
fetchInvoice, |
|
|
fetchInvoice, |
|
@ -26,59 +28,84 @@ const Pay = ({ |
|
|
|
|
|
|
|
|
const paymentRequestOnChange = payreq => { |
|
|
const paymentRequestOnChange = payreq => { |
|
|
setPaymentRequest(payreq) |
|
|
setPaymentRequest(payreq) |
|
|
if (payreq.length === 124) { fetchInvoice(payreq) } |
|
|
if (payreq.length === 124) { |
|
|
|
|
|
setPaymentType('ln') |
|
|
|
|
|
fetchInvoice(payreq) |
|
|
|
|
|
} else if (payreq.length === 42) { |
|
|
|
|
|
setPaymentType('onchain') |
|
|
|
|
|
} else { |
|
|
|
|
|
setPaymentType('') |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const calculateAmount = value => (currency === 'usd' ? btc.satoshisToUsd(value, currentTicker.price_usd) : btc.satoshisToBtc(value)) |
|
|
const calculateAmount = value => (currency === 'usd' ? btc.satoshisToUsd(value, currentTicker.price_usd) : btc.satoshisToBtc(value)) |
|
|
|
|
|
|
|
|
|
|
|
console.log('paymentType: ', paymentType) |
|
|
|
|
|
console.log('onchainAmount: ', onchainAmount) |
|
|
return ( |
|
|
return ( |
|
|
<div className={styles.container}> |
|
|
<div className={styles.container}> |
|
|
<section className={styles.amountContainer}> |
|
|
<section className={`${styles.amountContainer} ${paymentType === 'ln' ? styles.ln : ''}`}> |
|
|
<label htmlFor='amount'> |
|
|
<label htmlFor='amount'> |
|
|
<CurrencyIcon currency={currency} crypto={crypto} /> |
|
|
<CurrencyIcon currency={currency} crypto={crypto} /> |
|
|
</label> |
|
|
</label> |
|
|
<input |
|
|
<input |
|
|
type='text' |
|
|
type='text' |
|
|
size='' |
|
|
size='' |
|
|
style={{ width: '75%', fontSize: '85px' }} |
|
|
style={ |
|
|
value={calculateAmount(amount)} |
|
|
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 => setAmount(event.target.value)} |
|
|
id='amount' |
|
|
id='amount' |
|
|
readOnly |
|
|
readOnly={paymentType === 'ln'} |
|
|
/> |
|
|
/> |
|
|
</section> |
|
|
</section> |
|
|
<div |
|
|
<div className={styles.inputContainer}> |
|
|
className={`${styles.onchain} ${paymentType === 'onchain' ? styles.active : null}`} |
|
|
<div className={styles.info}> |
|
|
onClick={() => setPaymentType('onchain')} |
|
|
{(() => { |
|
|
> |
|
|
switch(paymentType) { |
|
|
<aside className={`${styles.paymentIcon} ${styles.chain}`}> |
|
|
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> |
|
|
<span>on-chain</span> |
|
|
<FaChain /> |
|
|
<FaChain /> |
|
|
</aside> |
|
|
</i> |
|
|
<section className={styles.inputContainer}> |
|
|
) |
|
|
<label htmlFor='paymentRequest'>Address:</label> |
|
|
case 'ln': |
|
|
<input |
|
|
return ( |
|
|
type='text' |
|
|
<i> |
|
|
placeholder='Bitcoin address' |
|
|
|
|
|
value={payment_request} |
|
|
|
|
|
onChange={event => paymentRequestOnChange(event.target.value)} |
|
|
|
|
|
id='paymentRequest' |
|
|
|
|
|
/> |
|
|
|
|
|
</section> |
|
|
|
|
|
</div> |
|
|
|
|
|
<div className={styles.divider} /> |
|
|
|
|
|
<div |
|
|
|
|
|
className={`${styles.ln} ${paymentType === 'ln' ? styles.active : null}`} |
|
|
|
|
|
onClick={() => setPaymentType('ln')} |
|
|
|
|
|
> |
|
|
|
|
|
<aside className={`${styles.paymentIcon} ${styles.bolt}`}> |
|
|
|
|
|
<span>lightning network</span> |
|
|
<span>lightning network</span> |
|
|
<FaBolt /> |
|
|
<FaBolt /> |
|
|
|
|
|
</i> |
|
|
|
|
|
) |
|
|
|
|
|
default: |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
})()} |
|
|
</aside> |
|
|
</aside> |
|
|
<section className={styles.inputContainer}> |
|
|
<section className={styles.input}> |
|
|
<label htmlFor='paymentRequest'>Request:</label> |
|
|
|
|
|
<input |
|
|
<input |
|
|
type='text' |
|
|
type='text' |
|
|
placeholder='Payment Request' |
|
|
placeholder='Payment request or bitcoin address' |
|
|
value={payment_request} |
|
|
value={payment_request} |
|
|
onChange={event => paymentRequestOnChange(event.target.value)} |
|
|
onChange={event => paymentRequestOnChange(event.target.value)} |
|
|
id='paymentRequest' |
|
|
id='paymentRequest' |
|
@ -95,7 +122,10 @@ const Pay = ({ |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Pay.propTypes = { |
|
|
Pay.propTypes = { |
|
|
amount: PropTypes.string.isRequired, |
|
|
amount: PropTypes.oneOfType([ |
|
|
|
|
|
PropTypes.string, |
|
|
|
|
|
PropTypes.number |
|
|
|
|
|
]), |
|
|
setPaymentRequest: PropTypes.func.isRequired, |
|
|
setPaymentRequest: PropTypes.func.isRequired, |
|
|
fetchInvoice: PropTypes.func.isRequired, |
|
|
fetchInvoice: PropTypes.func.isRequired, |
|
|
payInvoice: PropTypes.func.isRequired, |
|
|
payInvoice: PropTypes.func.isRequired, |
|
|