2015-11-20 20:21:54 +01:00
|
|
|
var React = require('react')
|
|
|
|
var Markdown = require('markdown.jsx')
|
|
|
|
var Icon = require('icon.jsx')
|
2015-11-22 00:10:46 +01:00
|
|
|
var Link = require('react-router').Link
|
2015-11-23 18:38:21 +01:00
|
|
|
var Clock = require('clock.jsx')
|
2015-11-28 10:18:06 +01:00
|
|
|
var UserID = require('userID.jsx')
|
2015-11-20 20:21:54 +01:00
|
|
|
|
2015-11-28 10:18:06 +01:00
|
|
|
module.exports = React.createClass({
|
2015-12-14 00:29:25 +01:00
|
|
|
getInitialState: function () {
|
2015-11-28 10:18:06 +01:00
|
|
|
return { moment: false }
|
|
|
|
},
|
2015-12-14 00:29:25 +01:00
|
|
|
componentDidMount: function () {
|
|
|
|
require.ensure(['moment'], _ => {
|
|
|
|
if (this.isMounted()) this.setState({ moment: require('moment') })
|
2015-11-28 10:18:06 +01:00
|
|
|
})
|
|
|
|
},
|
2015-12-14 00:29:25 +01:00
|
|
|
postLink: function () {
|
|
|
|
if (this.props.post.op) {
|
|
|
|
if (this.props.board) {
|
|
|
|
return '/@' + this.props.post.op + '/' + this.props.board + '/' + this.props.post.hash
|
2015-11-23 13:00:49 +01:00
|
|
|
} else {
|
2015-12-14 00:29:25 +01:00
|
|
|
return '/@' + this.props.post.op + '/post/' + this.props.post.hash
|
2015-11-23 13:00:49 +01:00
|
|
|
}
|
2015-11-28 10:18:06 +01:00
|
|
|
} else {
|
2015-12-14 00:29:25 +01:00
|
|
|
return '/post/' + this.props.post.hash
|
2015-11-28 10:18:06 +01:00
|
|
|
}
|
|
|
|
},
|
2015-12-14 00:29:25 +01:00
|
|
|
render: function () {
|
2015-11-28 10:18:06 +01:00
|
|
|
return <div key={this.props.post.title} className="post">
|
|
|
|
<div className="content">
|
|
|
|
<h5>{this.props.post.title}</h5><hr/>
|
|
|
|
<Markdown source={this.props.post.text} /><hr/>
|
|
|
|
<div className="icons">
|
|
|
|
<UserID id={this.props.post.op} api={this.props.api} ></UserID>
|
|
|
|
<Clock className="not-first" date={this.props.post.date} />
|
|
|
|
<Icon name="comments" className="not-first" /> <Link className="nounderline" to={this.postLink()}>View</Link>
|
2015-11-20 20:21:54 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2015-11-28 10:18:06 +01:00
|
|
|
</div>
|
|
|
|
}
|
|
|
|
})
|