You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
125 lines
3.4 KiB
125 lines
3.4 KiB
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import copy from 'copy-to-clipboard'
|
|
import QRCode from 'qrcode.react'
|
|
import copyIcon from 'icons/copy.svg'
|
|
import Isvg from 'react-inlinesvg'
|
|
|
|
import x from 'icons/x.svg'
|
|
import { showNotification } from 'lib/utils/notifications'
|
|
|
|
import styles from './ReceiveModal.scss'
|
|
|
|
class ReceiveModal extends React.Component {
|
|
constructor(props) {
|
|
super(props)
|
|
|
|
this.state = {
|
|
qrCodeType: 1
|
|
}
|
|
}
|
|
|
|
render() {
|
|
const copyOnClick = data => {
|
|
copy(data)
|
|
showNotification('Noice', 'Successfully copied to clipboard')
|
|
}
|
|
|
|
const changeQrCode = () => {
|
|
const { qrCodeType } = this.state
|
|
if (qrCodeType === 1) {
|
|
this.setState({ qrCodeType: 2 })
|
|
} else {
|
|
this.setState({ qrCodeType: 1 })
|
|
}
|
|
}
|
|
|
|
const { isOpen, pubkey, address, alias, closeReceiveModal, network } = this.props
|
|
|
|
const { qrCodeType } = this.state
|
|
|
|
if (!isOpen) {
|
|
return null
|
|
}
|
|
|
|
return (
|
|
<div className={styles.container}>
|
|
<div className={styles.closeContainer}>
|
|
<span onClick={closeReceiveModal}>
|
|
<Isvg src={x} />
|
|
</span>
|
|
</div>
|
|
|
|
<div className={styles.content}>
|
|
<section className={styles.left}>
|
|
<header className={styles.header}>
|
|
<h2>{alias && alias.length ? alias : pubkey.substring(0, 10)}</h2>
|
|
|
|
<div className={styles.qrCodeOptions}>
|
|
<div className={qrCodeType === 1 && styles.active} onClick={changeQrCode}>
|
|
Node Pubkey
|
|
</div>
|
|
<div className={qrCodeType === 2 && styles.active} onClick={changeQrCode}>
|
|
Bitcoin Address
|
|
</div>
|
|
</div>
|
|
</header>
|
|
|
|
<div className={styles.qrCodeContainer}>
|
|
<QRCode
|
|
value={qrCodeType === 1 ? pubkey : address}
|
|
renderAs="svg"
|
|
size={150}
|
|
bgColor="transparent"
|
|
fgColor="white"
|
|
level="L"
|
|
/>
|
|
</div>
|
|
</section>
|
|
<section className={styles.right}>
|
|
<div className={styles.pubkey}>
|
|
<h4>Node Public Key</h4>
|
|
<p>
|
|
<span className={styles.data}>{pubkey}</span>
|
|
<span
|
|
onClick={() => copyOnClick(pubkey)}
|
|
className={`${styles.copy} hint--left`}
|
|
data-hint="Copy pubkey"
|
|
>
|
|
<Isvg src={copyIcon} />
|
|
</span>
|
|
</p>
|
|
</div>
|
|
|
|
<div className={styles.address}>
|
|
<h4>Bitcoin {network.name} Address</h4>
|
|
<p>
|
|
<span className={styles.data}>{address}</span>
|
|
<span
|
|
onClick={() => copyOnClick(address)}
|
|
className={`${styles.copy} hint--left`}
|
|
data-hint="Copy address"
|
|
>
|
|
<Isvg src={copyIcon} />
|
|
</span>
|
|
</p>
|
|
</div>
|
|
</section>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
}
|
|
|
|
ReceiveModal.propTypes = {
|
|
network: PropTypes.shape({
|
|
name: PropTypes.string
|
|
}).isRequired,
|
|
isOpen: PropTypes.bool.isRequired,
|
|
pubkey: PropTypes.string,
|
|
address: PropTypes.string,
|
|
alias: PropTypes.string,
|
|
closeReceiveModal: PropTypes.func.isRequired
|
|
}
|
|
|
|
export default ReceiveModal
|
|
|