1
0
mirror of https://github.com/fazo96/ipfs-boards synced 2025-01-10 12:24:20 +01:00

refactoring code for quality

This commit is contained in:
Enrico Fasoli 2015-12-18 22:22:26 +01:00
parent 1a713c8559
commit 7c558e749b
7 changed files with 62 additions and 70 deletions

View File

@ -6,32 +6,32 @@ var Link = require('react-router').Link
var UserID = require('userID.jsx')
var Comment = React.createClass({
getInitialState: function () {
getInitialState () {
return { moment: false }
},
componentDidMount: function () {
componentDidMount () {
require.ensure(['moment'], _ => {
if (this.isMounted()) this.setState({ moment: require('moment') })
})
},
getPermalink: function () {
getPermalink () {
if (this.props.adminID && this.props.board && this.props.post && this.props.comment.hash) {
return <div className="inline not-first">
<Icon name="code" /> <Link to={'/@' + this.props.adminID + '/' + this.props.board + '/' + this.props.post + '/' + this.props.comment.hash}>Permalink</Link>
</div>
}
},
getParentlink: function () {
getParentlink () {
if (this.props.showParent && this.props.comment.parent && this.props.comment.parent !== this.props.post) {
return <div className="inline not-first">
<Icon name="level-up" /> <Link to={'/@' + this.props.adminID + '/' + this.props.board + '/' + this.props.post + '/' + this.props.comment.parent}>Parent</Link>
</div>
}
},
getComments: function () {
getComments () {
return <Comments className="shifted" parent={this.props.comment.hash} post={this.props.post} adminID={this.props.adminID} board={this.props.board} api={this.props.api} />
},
render: function () {
render () {
if (this.props.comment) {
return <div className="comment"><hr/>
<div className="icons">
@ -49,10 +49,10 @@ var Comment = React.createClass({
})
var Comments = React.createClass({
getInitialState: function () {
getInitialState () {
return { comments: [] }
},
componentDidMount: function () {
componentDidMount () {
var boards = this.props.api
if (boards) {
boards.getEventEmitter().on('comment for ' + this.props.parent, cmnt => {
@ -68,13 +68,13 @@ var Comments = React.createClass({
})
}
},
getComments: function () {
getComments () {
if (this.state.comments.length > 0) {
return this.state.comments.map(cmnt => (<Comment key={cmnt.hash} comment={cmnt} post={this.props.post} adminID={this.props.adminID} board={this.props.board} api={this.props.api} />))
}
else return <div></div>
},
render: function () {
render () {
return <div className={this.props.className + ' comments'} >{this.getComments()}</div>
}
})

View File

@ -4,14 +4,19 @@ var Icon = require('icon.jsx')
var Link = require('react-router').Link
var Clock = require('clock.jsx')
var UserID = require('userID.jsx')
var { Error, Loading } = require('status-components.jsx')
var { Error } = require('status-components.jsx')
module.exports = React.createClass({
getInitialState () {
return { loading: true }
},
componentDidMount () {
this.init(this.props)
if (this.props.api) {
this.props.api.getEventEmitter().on('init', err => {
if (!err) this.init(this.props)
})
if (this.props.api.isInit) this.init(this.props)
}
},
componentWillReceiveProps (props) {
this.init(props)
@ -52,7 +57,12 @@ module.exports = React.createClass({
if (this.state.error) {
return <Error className="content" error={this.state.error} />
} else if (this.state.loading) {
return <Loading className="content" title="Downloading post"/>
return <div className="text-center">
<div className="center-block" style={{marginTop: '1em'}}>
<Icon className="center-block fa-spin fa-2x light" name="refresh" />
</div>
<h5>Downloading Post</h5>
</div>
} else {
return <div className="content">
{ this.state.post.title

View File

@ -4,14 +4,20 @@ var Icon = require('icon.jsx')
var Post = require('post.jsx')
module.exports = React.createClass({
getInitialState: function () {
getInitialState () {
return { posts: [], api: false }
},
sortFn: function (a, b) {
sortFn (a, b) {
return (b.date || 0) - (a.date || 0)
},
init: function (boards) {
componentWillReceiveProps (props) {
if (props.api) {
this.init(props.api, props)
}
},
init (boards, props) {
if (this.state.init) return
props = props || this.props
this.setState({ api: true })
var onPost = (hash, date, post) => {
if (!this.isMounted()) return true
@ -27,11 +33,11 @@ module.exports = React.createClass({
}*/
this.setState({ posts })
}
boards.getEventEmitter().on('post in ' + this.props.board + (this.props.admin ? '@' + this.props.admin : ''), onPost)
boards.getPostsInBoard(this.props.admin, this.props.board)
boards.getEventEmitter().on('post in ' + props.board + (props.admin ? '@' + props.admin : ''), onPost)
boards.getPostsInBoard(props.admin, props.board)
this.setState({ init: true })
},
componentDidMount: function () {
componentDidMount () {
var boards = this.props.api
if (boards) {
if (boards.isInit) {
@ -43,7 +49,7 @@ module.exports = React.createClass({
}
}
},
getPosts: function () {
getPosts () {
if (this.state.posts.length > 0 || this.state.api) {
return this.state.posts.map(hash => {
return <Post key={hash} board={this.props.board} admin={this.props.admin} hash={hash} api={this.props.api} />
@ -54,7 +60,7 @@ module.exports = React.createClass({
</div>
}
},
render: function () {
render () {
return (
<div className="postList">
{this.getPosts()}

View File

@ -16,24 +16,13 @@ var Error = React.createClass({
var Loading = React.createClass({
render () {
// TODO: merge these (duplicated code) and use css to get desired style
if (this.props.small) {
return <div>
<div className="text-center">
<Icon className="center-block fa-spin fa-2x light" name="refresh" />
<h5 className="top-half-em">{this.props.title}</h5>
{ this.props.children }
</div>
return <div className="loading" >
<div className="text-center">
<Icon className="center-block fa-spin fa-3x light" name="refresh" />
<h4 className="top-half-em">{this.props.title}</h4>
{ this.props.children }
</div>
} else {
return <div>
<div className="text-center">
<Icon className="center-block fa-spin fa-3x light" name="refresh" />
<h4 className="top-half-em">{this.props.title}</h4>
{ this.props.children }
</div>
</div>
}
</div>
}
})

View File

@ -3,22 +3,28 @@ var Icon = require('icon.jsx')
var Link = require('react-router').Link
module.exports = React.createClass({
getInitialState: function () {
getInitialState () {
return { }
},
componentDidMount: function () {
var boards = this.props.api
componentWillReceiveProps (props) {
this.init(props)
},
componentDidMount () {
this.init()
},
init (props) {
props = props || this.props
var boards = props.api
if (boards) {
boards.getEventEmitter().on('init', err => {
if (!err && this.isMounted()) this.getProfile(boards)
})
if (boards.isInit) {
this.getProfile(boards)
}
boards.getEventEmitter().on('init', err => {
if (!err && this.isMounted()) this.getProfile(boards)
else console.log('ERR INIT', err)
})
}
},
getProfile: function (boards) {
getProfile (boards) {
if (this.props.id === undefined) return
boards.getProfile(this.props.id, (err, res) => {
if (!this.isMounted()) return true
@ -29,14 +35,14 @@ module.exports = React.createClass({
}
})
},
getContent: function () {
getContent () {
if (this.state.name) {
return (<Icon name="user" />)
} else {
return '@'
}
},
render: function () {
render () {
if (this.props.id === undefined || this.props.id === 'undefined') {
return <div className="user-id">
<Icon name="ban" /> Unknown User

View File

@ -14,13 +14,6 @@ module.exports = function (boardsAPI) {
},
componentDidMount () {
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 => {

View File

@ -12,27 +12,15 @@ module.exports = function (boardsAPI) {
},
componentDidMount: function () {
boardsAPI.use(boards => {
boards.getEventEmitter().on('init', err => {
if (!err && this.isMounted()) {
this.init(boards)
}
})
if (this.isMounted() && boards.isInit) {
this.init(boards)
}
boards.init()
this.setState({ api: boards })
})
},
init: function (boards) {
if (this.state.init) return
this.setState({ api: boards })
},
getContext: function () {
if (this.props.params.userid) {
if (this.props.params.boardname) {
return <div>Posted by <UserID id={this.props.params.userid} api={this.state.boards} /> in <Link to={'@' + this.props.params.userid + '/' + this.props.params.boardname}>#{this.props.params.boardname}</Link></div>
return <div>Posted by <UserID id={this.props.params.userid} api={this.state.api} /> in <Link to={'@' + this.props.params.userid + '/' + this.props.params.boardname}>#{this.props.params.boardname}</Link></div>
} else {
return <div>Posted by <UserID id={this.props.params.userid} api={this.state.boards} /></div>
return <div>Posted by <UserID id={this.props.params.userid} api={this.state.api} /></div>
}
} else return <div><h6 className="light">You are viewing a single post</h6></div>
},