1
0
mirror of https://github.com/fazo96/ipfs-boards synced 2025-01-26 15:04:19 +01:00
ipfs-boards/webapp/components/post.jsx

99 lines
3.5 KiB
React
Raw Normal View History

2015-11-20 20:21:54 +01:00
var React = require('react')
var Markdown = require('markdown.jsx')
var Icon = require('icon.jsx')
var Link = require('react-router').Link
var Clock = require('clock.jsx')
var UserID = require('userID.jsx')
2015-12-18 22:22:26 +01:00
var { Error } = require('status-components.jsx')
2015-12-23 11:47:31 +01:00
var { Comments, CommentEditor } = require('comment.jsx')
2015-11-20 20:21:54 +01:00
module.exports = React.createClass({
2015-12-17 22:19:21 +01:00
getInitialState () {
return { loading: true }
},
2015-12-17 22:19:21 +01:00
componentDidMount () {
2015-12-18 22:22:26 +01:00
if (this.props.api) {
2015-12-19 17:43:55 +01:00
this.props.api.getEventEmitter().on('init', (err, limited) => {
if (!err || limited) this.init(this.props)
2015-12-18 22:22:26 +01:00
})
2015-12-19 17:43:55 +01:00
if (this.props.api.isInit || this.props.api.limited) this.init(this.props)
2015-12-18 22:22:26 +01:00
}
2015-12-17 22:19:21 +01:00
},
componentWillReceiveProps (props) {
this.init(props)
},
init (props) {
var boards = props.api
if (!boards) return this.setState({ error: 'Could not connect to IPFS' })
this.setState({ loading: true, userid: boards.getMyID() })
2015-12-17 22:19:21 +01:00
boards.downloadPost(props.hash, props.adminID, props.board, (err, hash, date, post) => {
this.setState({ error: err, post: post, loading: false })
})
},
2015-12-17 22:19:21 +01:00
postLink () {
if (this.state.post.op) {
if (this.props.board) {
2015-12-17 22:19:21 +01:00
return '/@' + this.state.post.op + '/' + this.props.board + '/' + this.props.hash
2015-11-23 13:00:49 +01:00
} else {
2015-12-17 22:19:21 +01:00
return '/@' + this.state.post.op + '/post/' + this.props.hash
2015-11-23 13:00:49 +01:00
}
} else {
2015-12-17 22:19:21 +01:00
return '/post/' + this.props.hash
}
},
editorLink () {
if (this.state.post.op === this.state.userid) {
var board = this.props.board || this.state.post.board
if (board) {
var url = '/edit/board/' + board + '/post/' + this.props.hash
2016-06-20 18:07:11 +02:00
return <Link to={url} className='nounderline'>
<Icon name='edit' className='not-first'/> Edit
</Link>
} else {
return <span/>
}
} else return <span/>
},
2015-12-23 11:47:31 +01:00
toggleReply () {
this.setState({ reply: !this.state.reply })
},
2015-12-17 22:19:21 +01:00
getContent () {
if (this.state.error) {
2016-06-20 18:07:11 +02:00
return <Error className='content' error={this.state.error} />
2015-12-17 22:19:21 +01:00
} else if (this.state.loading) {
2016-06-20 18:07:11 +02:00
return <div className='text-center'>
<div className='center-block' style={{marginTop: '1em'}}>
<Icon className='center-block fa-spin fa-2x light' name='refresh' />
2015-12-18 22:22:26 +01:00
</div>
<h5>Downloading Post</h5>
</div>
2015-12-17 22:19:21 +01:00
} else {
2016-06-20 18:07:11 +02:00
return <div className='content'>
2015-12-17 22:19:21 +01:00
{ this.state.post.title
? <div><h5>{this.state.post.title}</h5><hr/></div>
: <div />
}
<Markdown source={this.state.post.text} /><hr/>
2016-06-20 18:07:11 +02:00
<div className='icons'>
2015-12-17 22:19:21 +01:00
<UserID id={this.state.post.op} api={this.props.api} ></UserID>
2016-06-20 18:07:11 +02:00
<Clock className='not-first' date={this.state.post.date} />
<Icon name='comments' className='not-first' /> <Link className='nounderline' to={this.postLink()}>View</Link>
2015-12-23 11:47:31 +01:00
{ this.props.allowReply
2016-06-20 18:07:11 +02:00
? <a className='nounderline' onClick={this.toggleReply}><Icon className='not-first' name='reply' /> Reply</a>
2015-12-23 11:47:31 +01:00
: <span/>}
{this.editorLink()}
2015-11-20 20:21:54 +01:00
</div>
</div>
2015-12-17 22:19:21 +01:00
}
},
render () {
2015-12-19 17:43:55 +01:00
return <div>
2016-06-20 18:07:11 +02:00
<div className='post'>{this.getContent()}</div>
2015-12-23 11:47:31 +01:00
{ this.state.reply
? <CommentEditor parent={this.props.hash} api={this.props.api} adminID={this.props.adminID} board={this.props.board} />
: <div/>}
<Comments allowReply={this.props.allowReply} parent={this.props.hash} post={this.props.hash} api={this.props.api} adminID={this.props.adminID} board={this.props.board} />
2015-12-19 17:43:55 +01:00
</div>
}
})