Browse Source

feature(filters): add filters to reducer and add selector to get the non-active one

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
3aa9cfe034
  1. 14
      app/reducers/activity.js
  2. 26
      app/routes/activity/components/Activity.js
  3. 3
      app/routes/activity/containers/ActivityContainer.js

14
app/reducers/activity.js

@ -5,6 +5,13 @@ import { createSelector } from 'reselect'
// ------------------------------------ // ------------------------------------
const initialState = { const initialState = {
filter: 'ALL_ACTIVITY', filter: 'ALL_ACTIVITY',
filters: [
{ key: 'ALL_ACTIVITY', name: 'Activity'},
{ key: 'LN_ACTIVITY', name: 'Lightning Network'},
{ key: 'PAYMENT_ACTIVITY', name: 'Payments'},
{ key: 'INVOICE_ACTIVITY', name: 'Invoices'},
{ key: 'TRANSACTION_ACTIVITY', name: 'Transactions'}
],
modal: { modal: {
modalType: null, modalType: null,
modalProps: {} modalProps: {}
@ -54,6 +61,7 @@ const ACTION_HANDLERS = {
// Selectors // Selectors
// ------------------------------------ // ------------------------------------
const activitySelectors = {} const activitySelectors = {}
const filtersSelector = state => state.activity.filters
const filterSelector = state => state.activity.filter const filterSelector = state => state.activity.filter
const paymentsSelector = state => state.payment.payments const paymentsSelector = state => state.payment.payments
const invoicesSelector = state => state.invoice.invoices const invoicesSelector = state => state.invoice.invoices
@ -106,6 +114,12 @@ activitySelectors.currentActivity = createSelector(
filter => FILTERS[filter] filter => FILTERS[filter]
) )
activitySelectors.nonActiveFilters = createSelector(
filtersSelector,
filterSelector,
(filters, filter) => filters.filter(f => f.key !== filter)
)
const FILTERS = { const FILTERS = {
ALL_ACTIVITY: allActivity, ALL_ACTIVITY: allActivity,
LN_ACTIVITY: lnActivity, LN_ACTIVITY: lnActivity,

26
app/routes/activity/components/Activity.js

@ -15,7 +15,7 @@ class Activity extends Component {
constructor(props, context) { constructor(props, context) {
super(props, context) super(props, context)
this.state = { this.state = {
tab: 1 pulldown: false
} }
this.renderActivity = this.renderActivity.bind(this) this.renderActivity = this.renderActivity.bind(this)
@ -45,7 +45,6 @@ class Activity extends Component {
} }
render() { render() {
const { tab } = this.state
const { const {
ticker, ticker,
searchInvoices, searchInvoices,
@ -59,7 +58,8 @@ class Activity extends Component {
currentTicker, currentTicker,
activity: { modal }, activity: { modal },
hideActivityModal, hideActivityModal,
currentActivity currentActivity,
nonActiveFilters
} = this.props } = this.props
if (invoiceLoading || paymentLoading) { return <div>Loading...</div> } if (invoiceLoading || paymentLoading) { return <div>Loading...</div> }
@ -79,10 +79,10 @@ class Activity extends Component {
<MdSearch /> <MdSearch />
</label> </label>
<input <input
value={tab === 1 ? '' : invoicesSearchText} value={invoicesSearchText}
onChange={event => (tab === 1 ? null : searchInvoices(event.target.value))} onChange={event => searchInvoices(event.target.value)}
className={`${styles.text} ${styles.input}`} className={`${styles.text} ${styles.input}`}
placeholder={tab === 1 ? 'Search by amount, hash, memo, etc' : 'Search requests by memo'} placeholder='Search by amount, hash, memo, etc'
type='text' type='text'
id='invoiceSearch' id='invoiceSearch'
/> />
@ -90,7 +90,19 @@ class Activity extends Component {
<div className={styles.activities}> <div className={styles.activities}>
<header className={styles.header}> <header className={styles.header}>
<h2>Activity</h2> <h2 onClick={() => this.setState({ pulldown: true })}>Activity</h2>
<ul className={styles.filters}>
{
nonActiveFilters.map(filter => {
console.log('filter: ', filter)
return (
<li key={filter.key}>
{filter.name}
</li>
)
})
}
</ul>
</header> </header>
<ul className={styles.activityContainer}> <ul className={styles.activityContainer}>
{ {

3
app/routes/activity/containers/ActivityContainer.js

@ -41,7 +41,8 @@ const mapStateToProps = state => ({
currentTicker: tickerSelectors.currentTicker(state), currentTicker: tickerSelectors.currentTicker(state),
currentActivity: activitySelectors.currentActivity(state)(state) currentActivity: activitySelectors.currentActivity(state)(state),
nonActiveFilters: activitySelectors.nonActiveFilters(state)
}) })
export default connect(mapStateToProps, mapDispatchToProps)(Activity) export default connect(mapStateToProps, mapDispatchToProps)(Activity)

Loading…
Cancel
Save