Browse Source

feature(sendcoins): blinking cursor to show editing state for amount when they are not using LN

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
cfc41382e6
  1. 216
      app/routes/app/components/components/Form/components/Pay/Pay.js

216
app/routes/app/components/components/Form/components/Pay/Pay.js

@ -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 = {

Loading…
Cancel
Save