mirror of
https://github.com/mastermindzh/rickvanlieshout.com
synced 2025-01-26 05:22:28 +01:00
a77594f1ba
The component didn't render because pages were undefined. I found that they are stored inside the route object. This fixed it for me.
45 lines
1.3 KiB
JavaScript
45 lines
1.3 KiB
JavaScript
import React from 'react'
|
|
import { Link } from 'react-router'
|
|
import { prune, include as includes } from 'underscore.string'
|
|
import find from 'lodash/find'
|
|
|
|
import './style.css'
|
|
|
|
class ReadNext extends React.Component {
|
|
render() {
|
|
const {post} = this.props
|
|
const {pages} = this.props.route
|
|
const {readNext} = post
|
|
|
|
let nextPost
|
|
if (readNext) {
|
|
nextPost = find(pages, (page) => includes(page.path, readNext)
|
|
)
|
|
}
|
|
if (!nextPost) {
|
|
return React.createElement('noscript', null)
|
|
} else {
|
|
nextPost = find(pages, (page) => includes(page.path, readNext.slice(1, -1))
|
|
)
|
|
const description = nextPost.data.description
|
|
|
|
return (
|
|
<div>
|
|
<h6 style={ { fontSize: '16px', margin: '20px 0 0'} }>READ THIS NEXT:</h6>
|
|
<h3 style={ { margin: '5px 0 0'} }><Link to={ nextPost.path } query={ { readNext: true} } > { nextPost.data.title } </Link></h3>
|
|
<p className='description'>
|
|
{ description }
|
|
</p>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
ReadNext.propTypes = {
|
|
post: React.PropTypes.object.isRequired,
|
|
pages: React.PropTypes.array,
|
|
}
|
|
|
|
export default ReadNext
|