import React, { PropTypes } from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { connect } from 'react-redux'; import { loadEntries } from '../actions/entries'; import { selectEntries } from '../reducers'; import { Loader } from '../components/UI'; import EntryListing from '../components/EntryListing'; import EditorialWorkflow from './EditorialWorkflowHoC'; class DashboardPage extends React.Component { componentDidMount() { const { collection, dispatch } = this.props; if (collection) { dispatch(loadEntries(collection)); } } componentWillReceiveProps(nextProps) { const { collection, dispatch } = this.props; if (nextProps.collection !== collection) { dispatch(loadEntries(nextProps.collection)); } } render() { const { collections, collection, entries } = this.props; if (collections == null) { return

No collections defined in your config.yml

; } return
{entries ? : {['Loading Entries', 'Caching Entries', 'This might take several minutes']} }
; } } DashboardPage.propTypes = { collection: ImmutablePropTypes.map.isRequired, collections: ImmutablePropTypes.orderedMap.isRequired, dispatch: PropTypes.func.isRequired, entries: ImmutablePropTypes.list, }; /* * Instead of checking the publish mode everywhere to dispatch & render the additional editorial workflow stuff, * We delegate it to a Higher Order Component */ DashboardPage = EditorialWorkflow(DashboardPage); function mapStateToProps(state, ownProps) { const { collections } = state; const { name, slug } = ownProps.params; const collection = name ? collections.get(name) : collections.first(); const entries = selectEntries(state, collection.get('name')); return { slug, collection, collections, entries }; } export default connect(mapStateToProps)(DashboardPage);