2018-01-31 07:36:20 +00:00
|
|
|
import React from 'react'
|
|
|
|
import { provide, types } from 'ioc'
|
|
|
|
import { Link, Router } from '../routes'
|
|
|
|
import Component1 from '../components/component1'
|
|
|
|
|
|
|
|
const posts = [
|
|
|
|
{ slug: 'hello-world', title: 'Hello world' },
|
|
|
|
{ slug: 'another-blog-post', title: 'Another blog post' }
|
|
|
|
]
|
|
|
|
|
|
|
|
@provide({
|
|
|
|
@types.func.isRequired
|
|
|
|
Link,
|
|
|
|
|
|
|
|
@types.object
|
|
|
|
Router
|
|
|
|
})
|
|
|
|
export default class extends React.Component {
|
2018-12-17 16:34:32 +00:00
|
|
|
static async getInitialProps({ query, res }) {
|
2018-01-31 07:36:20 +00:00
|
|
|
const post = posts.find(post => post.slug === query.slug)
|
|
|
|
|
|
|
|
if (!post && res) {
|
|
|
|
res.statusCode = 404
|
|
|
|
}
|
|
|
|
|
|
|
|
return { post }
|
|
|
|
}
|
|
|
|
|
2018-12-17 16:34:32 +00:00
|
|
|
render() {
|
2018-01-31 07:36:20 +00:00
|
|
|
const { post } = this.props
|
|
|
|
|
|
|
|
if (!post) return <h1>Post not found</h1>
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<h1>{post.title}</h1>
|
|
|
|
<Component1 />
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|