1
0
mirror of https://github.com/fazo96/ipfs-boards synced 2025-01-25 14:54:19 +01:00
ipfs-boards/webapp/components/userID.jsx

53 lines
1.4 KiB
React
Raw Normal View History

2015-11-20 20:21:54 +01:00
var React = require('react')
var Icon = require('icon.jsx')
var Link = require('react-router').Link
module.exports = function(boardsAPI){
2015-11-20 20:21:54 +01:00
return React.createClass({
getInitialState: function(){
return { }
},
componentDidMount: function(){
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
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(){
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>)
}
})
}