|
@ -1,7 +1,7 @@ |
|
|
import React, { Component } from 'react' |
|
|
import React, { Component } from 'react' |
|
|
import PropTypes from 'prop-types' |
|
|
import PropTypes from 'prop-types' |
|
|
import { MdSearch } from 'react-icons/lib/md' |
|
|
import { MdSearch } from 'react-icons/lib/md' |
|
|
import { FaChain, FaBolt, FaAngleDown } from 'react-icons/lib/fa' |
|
|
import { FaAngleDown } from 'react-icons/lib/fa' |
|
|
|
|
|
|
|
|
import Invoice from './components/Invoice' |
|
|
import Invoice from './components/Invoice' |
|
|
import Payment from './components/Payment' |
|
|
import Payment from './components/Payment' |
|
@ -14,10 +14,6 @@ import styles from './Activity.scss' |
|
|
class Activity extends Component { |
|
|
class Activity extends Component { |
|
|
constructor(props, context) { |
|
|
constructor(props, context) { |
|
|
super(props, context) |
|
|
super(props, context) |
|
|
this.state = { |
|
|
|
|
|
pulldown: false |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
this.renderActivity = this.renderActivity.bind(this) |
|
|
this.renderActivity = this.renderActivity.bind(this) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -32,29 +28,23 @@ class Activity extends Component { |
|
|
renderActivity(activity) { |
|
|
renderActivity(activity) { |
|
|
const { ticker, currentTicker, showActivityModal } = this.props |
|
|
const { ticker, currentTicker, showActivityModal } = this.props |
|
|
|
|
|
|
|
|
if (activity.hasOwnProperty('block_hash')) { |
|
|
if (Object.prototype.hasOwnProperty.call(activity, 'block_hash')) { |
|
|
// activity is an on-chain tx
|
|
|
// activity is an on-chain tx
|
|
|
return <Transaction transaction={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
return <Transaction transaction={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
} else if (activity.hasOwnProperty('payment_request')) { |
|
|
} else if (Object.prototype.hasOwnProperty.call(activity, 'payment_request')) { |
|
|
// activity is an LN invoice
|
|
|
// activity is an LN invoice
|
|
|
return <Invoice invoice={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
return <Invoice invoice={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
} else { |
|
|
|
|
|
// activity is an LN payment
|
|
|
|
|
|
return <Payment payment={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
// activity is an LN payment
|
|
|
|
|
|
return <Payment payment={activity} ticker={ticker} currentTicker={currentTicker} showActivityModal={showActivityModal} /> |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { |
|
|
const { |
|
|
ticker, |
|
|
ticker, |
|
|
searchInvoices, |
|
|
searchInvoices, |
|
|
invoices, |
|
|
invoice: { invoicesSearchText, invoiceLoading }, |
|
|
invoice: { invoicesSearchText, invoice, invoiceLoading }, |
|
|
payment: { paymentLoading }, |
|
|
payment: { payment, payments, paymentLoading }, |
|
|
|
|
|
setPayment, |
|
|
|
|
|
setInvoice, |
|
|
|
|
|
paymentModalOpen, |
|
|
|
|
|
invoiceModalOpen, |
|
|
|
|
|
currentTicker, |
|
|
currentTicker, |
|
|
activity: { modal, filter, filterPulldown }, |
|
|
activity: { modal, filter, filterPulldown }, |
|
|
hideActivityModal, |
|
|
hideActivityModal, |
|
@ -64,8 +54,6 @@ class Activity extends Component { |
|
|
nonActiveFilters |
|
|
nonActiveFilters |
|
|
} = this.props |
|
|
} = this.props |
|
|
|
|
|
|
|
|
const { pulldown } = this.state |
|
|
|
|
|
|
|
|
|
|
|
if (invoiceLoading || paymentLoading) { return <div>Loading...</div> } |
|
|
if (invoiceLoading || paymentLoading) { return <div>Loading...</div> } |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
@ -77,7 +65,7 @@ class Activity extends Component { |
|
|
ticker={ticker} |
|
|
ticker={ticker} |
|
|
currentTicker={currentTicker} |
|
|
currentTicker={currentTicker} |
|
|
/> |
|
|
/> |
|
|
|
|
|
|
|
|
<div className={styles.search}> |
|
|
<div className={styles.search}> |
|
|
<label className={`${styles.label} ${styles.input}`} htmlFor='invoiceSearch'> |
|
|
<label className={`${styles.label} ${styles.input}`} htmlFor='invoiceSearch'> |
|
|
<MdSearch /> |
|
|
<MdSearch /> |
|
@ -100,10 +88,10 @@ class Activity extends Component { |
|
|
</h2> |
|
|
</h2> |
|
|
<ul className={`${styles.filters} ${filterPulldown ? styles.active : ''}`}> |
|
|
<ul className={`${styles.filters} ${filterPulldown ? styles.active : ''}`}> |
|
|
{ |
|
|
{ |
|
|
nonActiveFilters.map(filter => |
|
|
nonActiveFilters.map(f => |
|
|
<li key={filter.key} onClick={() => changeFilter(filter)}> |
|
|
(<li key={f.key} onClick={() => changeFilter(f)}> |
|
|
{filter.name} |
|
|
{f.name} |
|
|
</li> |
|
|
</li>) |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
</ul> |
|
|
</ul> |
|
@ -111,13 +99,11 @@ class Activity extends Component { |
|
|
</header> |
|
|
</header> |
|
|
<ul className={`${styles.activityContainer} ${filterPulldown ? styles.pulldown : ''}`}> |
|
|
<ul className={`${styles.activityContainer} ${filterPulldown ? styles.pulldown : ''}`}> |
|
|
{ |
|
|
{ |
|
|
currentActivity.map((activity, index) => { |
|
|
currentActivity.map((activity, index) => ( |
|
|
return ( |
|
|
<li className={styles.activity} key={index}> |
|
|
<li className={styles.activity} key={index}> |
|
|
{this.renderActivity(activity)} |
|
|
{this.renderActivity(activity)} |
|
|
</li> |
|
|
</li> |
|
|
)) |
|
|
) |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
} |
|
|
</ul> |
|
|
</ul> |
|
|
</div> |
|
|
</div> |
|
@ -129,16 +115,19 @@ class Activity extends Component { |
|
|
Activity.propTypes = { |
|
|
Activity.propTypes = { |
|
|
fetchPayments: PropTypes.func.isRequired, |
|
|
fetchPayments: PropTypes.func.isRequired, |
|
|
fetchInvoices: PropTypes.func.isRequired, |
|
|
fetchInvoices: PropTypes.func.isRequired, |
|
|
|
|
|
fetchTransactions: PropTypes.func.isRequired, |
|
|
ticker: PropTypes.object.isRequired, |
|
|
ticker: PropTypes.object.isRequired, |
|
|
searchInvoices: PropTypes.func.isRequired, |
|
|
searchInvoices: PropTypes.func.isRequired, |
|
|
invoices: PropTypes.array.isRequired, |
|
|
|
|
|
invoice: PropTypes.object.isRequired, |
|
|
invoice: PropTypes.object.isRequired, |
|
|
payment: PropTypes.object.isRequired, |
|
|
payment: PropTypes.object.isRequired, |
|
|
setPayment: PropTypes.func.isRequired, |
|
|
currentTicker: PropTypes.object.isRequired, |
|
|
setInvoice: PropTypes.func.isRequired, |
|
|
showActivityModal: PropTypes.func.isRequired, |
|
|
paymentModalOpen: PropTypes.bool.isRequired, |
|
|
hideActivityModal: PropTypes.func.isRequired, |
|
|
invoiceModalOpen: PropTypes.bool.isRequired, |
|
|
changeFilter: PropTypes.func.isRequired, |
|
|
currentTicker: PropTypes.object.isRequired |
|
|
toggleFilterPulldown: PropTypes.func.isRequired, |
|
|
|
|
|
activity: PropTypes.object.isRequired, |
|
|
|
|
|
currentActivity: PropTypes.array.isRequired, |
|
|
|
|
|
nonActiveFilters: PropTypes.array.isRequired |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
export default Activity |
|
|
export default Activity |
|
|