static-cms/src/components/EntryListing.js

96 lines
2.7 KiB
JavaScript
Raw Normal View History

import React from 'react';
import ImmutablePropTypes from 'react-immutable-proptypes';
2016-07-15 15:05:04 -03:00
import Bricks from 'bricks.js';
import history from '../routing/history';
2016-07-11 18:57:54 -03:00
import Cards from './Cards';
2016-07-21 11:40:41 -03:00
import _ from 'lodash';
import styles from './EntryListing.css'
2016-07-11 18:57:54 -03:00
export default class EntryListing extends React.Component {
constructor(props) {
super(props);
this.bricksInstance = null;
this.bricksConfig = {
packed: 'data-packed',
sizes: [
2016-07-14 17:17:18 -03:00
{ columns: 1, gutter: 15 },
{ mq: '495px', columns: 2, gutter: 15 },
{ mq: '750px', columns: 3, gutter: 15 },
{ mq: '1005px', columns: 4, gutter: 15 },
{ mq: '1260px', columns: 5, gutter: 15 },
{ mq: '1515px', columns: 6, gutter: 15 },
{ mq: '1770px', columns: 7, gutter: 15 },
2016-07-11 18:57:54 -03:00
]
};
2016-07-21 11:40:41 -03:00
this.updateBricks = _.throttle(this.updateBricks.bind(this), 30);
2016-07-11 18:57:54 -03:00
}
componentDidMount() {
this.bricksInstance = Bricks({
container: this._entries,
packed: this.bricksConfig.packed,
sizes: this.bricksConfig.sizes
});
this.bricksInstance.resize(true);
if (this.props.entries && this.props.entries.size > 0) {
setTimeout(() => {
this.bricksInstance.pack();
}, 0);
}
}
componentDidUpdate(prevProps) {
if ((prevProps.entries === undefined || prevProps.entries.size === 0) && this.props.entries.size === 0) {
return;
}
this.bricksInstance.pack();
}
componengWillUnmount() {
this.bricksInstance.resize(false);
}
2016-07-21 11:40:41 -03:00
updateBricks() {
this.bricksInstance.pack();
}
2016-07-11 18:57:54 -03:00
cardFor(collection, entry, link) {
//const { entry, getMedia, onChange, onAddMedia, onRemoveMedia } = this.props;
const card = Cards[collection.getIn(['card', 'type'])] || Cards._unknown;
return React.createElement(card, {
key: entry.get('slug'),
collection: collection,
2016-07-15 15:05:04 -03:00
onClick: history.push.bind(this, link),
2016-07-21 11:40:41 -03:00
onImageLoaded: this.updateBricks,
2016-07-11 18:57:54 -03:00
text: entry.getIn(['data', collection.getIn(['card', 'text'])]),
2016-07-21 11:40:41 -03:00
description: entry.getIn(['data', collection.getIn(['card', 'description'])]),
2016-07-12 17:03:39 -03:00
image: entry.getIn(['data', collection.getIn(['card', 'image'])]),
2016-07-11 18:57:54 -03:00
});
}
render() {
const { collection, entries } = this.props;
const name = collection.get('name');
2016-07-21 11:40:41 -03:00
return <div className={styles.root}>
2016-07-13 17:20:41 -03:00
<h1>Listing {name}</h1>
2016-07-11 18:57:54 -03:00
<div ref={(c) => this._entries = c}>
{entries.map((entry) => {
const path = `/collections/${name}/entries/${entry.get('slug')}`;
return this.cardFor(collection, entry, path);
})}
</div>
</div>;
}
}
EntryListing.propTypes = {
collection: ImmutablePropTypes.map.isRequired,
entries: ImmutablePropTypes.list,
};