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.
112 lines
3.3 KiB
112 lines
3.3 KiB
import React, { Component } from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import { MdSearch } from 'react-icons/lib/md'
|
|
import Payments from './components/Payments'
|
|
import Invoices from './components/Invoices'
|
|
import styles from './Activity.scss'
|
|
|
|
class Activity extends Component {
|
|
constructor(props, context) {
|
|
super(props, context)
|
|
this.state = {
|
|
tab: 1
|
|
}
|
|
}
|
|
|
|
componentWillMount() {
|
|
const { fetchPayments, fetchInvoices } = this.props
|
|
|
|
fetchPayments()
|
|
fetchInvoices()
|
|
}
|
|
|
|
render() {
|
|
const { tab } = this.state
|
|
const {
|
|
ticker,
|
|
searchInvoices,
|
|
invoices,
|
|
invoice: { invoicesSearchText, invoice, invoiceLoading },
|
|
payment: { payment, payments, paymentLoading },
|
|
setPayment,
|
|
setInvoice,
|
|
paymentModalOpen,
|
|
invoiceModalOpen,
|
|
currentTicker
|
|
} = this.props
|
|
|
|
if (invoiceLoading || paymentLoading) { return <div>Loading...</div> }
|
|
return (
|
|
<div>
|
|
<div className={styles.search}>
|
|
<label className={`${styles.label} ${styles.input}`} htmlFor='invoiceSearch'>
|
|
<MdSearch />
|
|
</label>
|
|
<input
|
|
value={tab === 1 ? '' : invoicesSearchText}
|
|
onChange={event => (tab === 1 ? null : searchInvoices(event.target.value))}
|
|
className={`${styles.text} ${styles.input}`}
|
|
placeholder={tab === 1 ? 'Search transactions by amount, public key, channel' : 'Search requests by memo'}
|
|
type='text'
|
|
id='invoiceSearch'
|
|
/>
|
|
</div>
|
|
|
|
<div className={styles.activities}>
|
|
<header className={styles.header}>
|
|
<span
|
|
className={`${styles.title} ${tab === 1 ? styles.active : null}`}
|
|
onClick={() => this.setState({ tab: 1 })}
|
|
>
|
|
Payments
|
|
</span>
|
|
<span
|
|
className={`${styles.title} ${tab === 2 ? styles.active : null}`}
|
|
onClick={() => this.setState({ tab: 2 })}
|
|
>
|
|
Requests
|
|
</span>
|
|
</header>
|
|
<div className={styles.activityContainer}>
|
|
{
|
|
tab === 1 ?
|
|
<Payments
|
|
payment={payment}
|
|
payments={payments}
|
|
ticker={ticker}
|
|
setPayment={setPayment}
|
|
paymentModalOpen={paymentModalOpen}
|
|
currentTicker={currentTicker}
|
|
/>
|
|
:
|
|
<Invoices
|
|
invoice={invoice}
|
|
invoices={invoices}
|
|
ticker={ticker}
|
|
setInvoice={setInvoice}
|
|
invoiceModalOpen={invoiceModalOpen}
|
|
currentTicker={currentTicker}
|
|
/>
|
|
}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
}
|
|
|
|
Activity.propTypes = {
|
|
fetchPayments: PropTypes.func.isRequired,
|
|
fetchInvoices: PropTypes.func.isRequired,
|
|
ticker: PropTypes.object.isRequired,
|
|
searchInvoices: PropTypes.func.isRequired,
|
|
invoices: PropTypes.array.isRequired,
|
|
invoice: PropTypes.object.isRequired,
|
|
payment: PropTypes.object.isRequired,
|
|
setPayment: PropTypes.func.isRequired,
|
|
setInvoice: PropTypes.func.isRequired,
|
|
paymentModalOpen: PropTypes.bool.isRequired,
|
|
invoiceModalOpen: PropTypes.bool.isRequired
|
|
}
|
|
|
|
export default Activity
|
|
|