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/EntryListing'; import styles from './breakpoints.css'; class CollectionPage extends React.Component { static propTypes = { collection: ImmutablePropTypes.map.isRequired, collections: ImmutablePropTypes.orderedMap.isRequired, publicFolder: PropTypes.string.isRequired, dispatch: PropTypes.func.isRequired, page: PropTypes.number, entries: ImmutablePropTypes.list, }; 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)); } } handleLoadMore = (page) => { const { collection, dispatch } = this.props; dispatch(loadEntries(collection, page)); }; render() { const { collections, collection, publicFolder, page, entries } = this.props; if (collections == null) { return

No collections defined in your config.yml

; } return (
{entries ? {collection.get('label')} : {['Loading Entries', 'Caching Entries', 'This might take several minutes']} }
); } } function mapStateToProps(state, ownProps) { const { collections, config } = state; const { name, slug } = ownProps.params; const publicFolder = config.get('public_folder'); const collection = name ? collections.get(name) : collections.first(); const page = state.entries.getIn(['pages', collection.get('name'), 'page']); const entries = selectEntries(state, collection.get('name')); return { slug, publicFolder, collection, collections, page, entries }; } export default connect(mapStateToProps)(CollectionPage);