2015-11-20 20:21:54 +01:00
|
|
|
var React = require('react')
|
|
|
|
var Icon = require('icon.jsx')
|
|
|
|
var Link = require('react-router').Link
|
|
|
|
|
2015-11-22 00:10:46 +01:00
|
|
|
module.exports = function(boardsAPI){
|
2015-11-20 20:21:54 +01:00
|
|
|
return React.createClass({
|
|
|
|
getInitialState: function(){
|
|
|
|
return { }
|
|
|
|
},
|
|
|
|
componentDidMount: function(){
|
2015-11-22 00:10:46 +01:00
|
|
|
boardsAPI.use(boards => {
|
|
|
|
if(boards.isInit){
|
|
|
|
this.getProfile(boards)
|
|
|
|
}
|
|
|
|
boards.getEventEmitter().on('init',err => {
|
|
|
|
if(!err) this.getProfile(boards)
|
|
|
|
else console.log('ERR INIT',err)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
getProfile: function(boards){
|
|
|
|
if(this.props.id === undefined) return
|
|
|
|
boards.getProfile(this.props.id, (err,res) => {
|
2015-11-20 20:21:54 +01:00
|
|
|
if(!this.isMounted()) return true
|
2015-11-22 00:10:46 +01:00
|
|
|
if(err){
|
|
|
|
console.log('Error while resolving user badge:',err)
|
|
|
|
} else {
|
2015-11-20 20:21:54 +01:00
|
|
|
this.setState({ name: res.name || 'Unknown Name' })
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
getContent: function(){
|
|
|
|
if(this.state.name){
|
|
|
|
return (<Icon name="user" />)
|
|
|
|
} else {
|
|
|
|
return '@'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
render: function(){
|
2015-11-22 00:10:46 +01:00
|
|
|
if(this.props.id === undefined || this.props.id === 'undefined')
|
|
|
|
return <div className="user-id">
|
|
|
|
<Icon name="ban" /> Unknown User
|
|
|
|
</div>
|
|
|
|
else
|
2015-11-20 20:21:54 +01:00
|
|
|
return (<div className="user-id">
|
|
|
|
<Link className="light nounderline" to={'/@'+this.props.id}>
|
|
|
|
{this.getContent()}{this.state.name || this.props.id}
|
|
|
|
</Link>
|
|
|
|
</div>)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|