import React, { Component } from 'react' import PropTypes from 'prop-types' import { MdSearch } from 'react-icons/lib/md' import { FaAngleDown } from 'react-icons/lib/fa' import Invoice from './components/Invoice' import Payment from './components/Payment' import Transaction from './components/Transaction' import Modal from './components/Modal' import styles from './Activity.scss' class Activity extends Component { constructor(props, context) { super(props, context) this.renderActivity = this.renderActivity.bind(this) } componentWillMount() { const { fetchPayments, fetchInvoices, fetchTransactions } = this.props fetchPayments() fetchInvoices() fetchTransactions() } renderActivity(activity) { const { ticker, currentTicker, showActivityModal } = this.props if (Object.prototype.hasOwnProperty.call(activity, 'block_hash')) { // activity is an on-chain tx return } else if (Object.prototype.hasOwnProperty.call(activity, 'payment_request')) { // activity is an LN invoice return } // activity is an LN payment return } render() { const { ticker, searchInvoices, invoice: { invoicesSearchText, invoiceLoading }, payment: { paymentLoading }, currentTicker, activity: { modal, filter, filterPulldown }, hideActivityModal, changeFilter, toggleFilterPulldown, currentActivity, nonActiveFilters } = this.props if (invoiceLoading || paymentLoading) { return
Loading...
} return (
searchInvoices(event.target.value)} className={`${styles.text} ${styles.input}`} placeholder='Search by amount, hash, memo, etc' type='text' id='invoiceSearch' />

{filter.name}

    { nonActiveFilters.map(f => (
  • changeFilter(f)}> {f.name}
  • ) ) }
    { currentActivity.map((activity, index) => (
  • {this.renderActivity(activity)}
  • )) }
) } } Activity.propTypes = { fetchPayments: PropTypes.func.isRequired, fetchInvoices: PropTypes.func.isRequired, fetchTransactions: PropTypes.func.isRequired, ticker: PropTypes.object.isRequired, searchInvoices: PropTypes.func.isRequired, invoice: PropTypes.object.isRequired, payment: PropTypes.object.isRequired, currentTicker: PropTypes.object.isRequired, showActivityModal: PropTypes.func.isRequired, hideActivityModal: PropTypes.func.isRequired, changeFilter: PropTypes.func.isRequired, toggleFilterPulldown: PropTypes.func.isRequired, activity: PropTypes.object.isRequired, currentActivity: PropTypes.array.isRequired, nonActiveFilters: PropTypes.array.isRequired } export default Activity