1
0
mirror of https://github.com/fazo96/ipfs-boards synced 2025-01-11 12:34:20 +01:00
ipfs-boards/webapp/pages/board.jsx

71 lines
2.7 KiB
React
Raw Normal View History

2015-11-20 20:21:54 +01:00
var React = require('react')
var Markdown = require('markdown.jsx')
var Link = require('react-router').Link
var Icon = require('icon.jsx')
var UserID = require('userID.jsx')
var PostList = require('postlist.jsx')
var GetIPFS = require('getipfs.jsx')
2015-11-20 20:21:54 +01:00
module.exports = function(boardsAPI){
2015-11-20 20:21:54 +01:00
return React.createClass({
getInitialState: function(){
return { name: this.props.params.boardname, api: false, whitelist: [] }
2015-11-20 20:21:54 +01:00
},
componentDidMount: function(){
boardsAPI.use(boards => {
/*
When a component inside the component being rendered by the router also needs
access to the boards api, it appears unitialized and never initializes to it
for no apparent reason. Calling init twice (one automgically and one
when the root component mounts) works as a cheap, horrible workaround
*/
boards.init()
if(!this.isMounted()) return
var ee = boards.getEventEmitter()
ee.on('init',err => {
if(!err && this.isMounted()){
this.init(boards)
}
})
2015-11-26 18:21:28 +01:00
if(this.props.params.userid){
ee.on('whitelist for '+this.props.params.boardname+'@'+this.props.params.userid,(whitelist) => {
if(this.isMounted())
this.setState({ whitelist })
else return true
})
2015-11-26 18:21:28 +01:00
ee.on('settings for '+this.props.params.boardname+'@'+this.props.params.userid, (res) => {
if(!this.isMounted()) return true
if(res) this.setState({ name: res.fullname, description: res.description })
})
} else {
this.setState({ description: 'All the messages posted in __#'+this.props.params.boardname+'__' })
}
if(boards.isInit || this.state.api){
this.init(boards)
}
2015-11-20 20:21:54 +01:00
})
},
init: function(boards){
if(!this.state.init){
2015-11-26 18:21:28 +01:00
if(this.props.params.userid)
boards.getBoardSettings(this.props.params.userid,this.props.params.boardname)
this.setState({ init: true, api: true, boards: boards })
}
},
2015-11-20 20:21:54 +01:00
render: function(){
if(this.state.api){
return (<div className="board">
<h2>{this.state.name}</h2>
<Markdown source={this.state.description} skipHtml={true} />
{this.props.params.userid?<h5><UserID id={this.props.params.userid} api={this.state.boards} /></h5>:<p></p>}
<div className="whitelist">
{this.state.whitelist.map(i => <UserID id={i} api={this.state.boards} />)}
</div>
2015-11-26 18:21:28 +01:00
<hr />
<PostList board={this.props.params.boardname} admin={this.props.params.userid} api={this.state.boards} />
</div>)
} else return <GetIPFS api={this.state.boards} />
2015-11-20 20:21:54 +01:00
}
})
}