1
0
mirror of https://github.com/fazo96/ipfs-boards synced 2025-01-25 14:54:19 +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 UserID = require('userID.jsx')
var Comment = React.createClass({ var Comment = React.createClass({
getInitialState: function () { getInitialState () {
return { moment: false } return { moment: false }
}, },
componentDidMount: function () { componentDidMount () {
require.ensure(['moment'], _ => { require.ensure(['moment'], _ => {
if (this.isMounted()) this.setState({ moment: require('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) { if (this.props.adminID && this.props.board && this.props.post && this.props.comment.hash) {
return <div className="inline not-first"> 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> <Icon name="code" /> <Link to={'/@' + this.props.adminID + '/' + this.props.board + '/' + this.props.post + '/' + this.props.comment.hash}>Permalink</Link>
</div> </div>
} }
}, },
getParentlink: function () { getParentlink () {
if (this.props.showParent && this.props.comment.parent && this.props.comment.parent !== this.props.post) { if (this.props.showParent && this.props.comment.parent && this.props.comment.parent !== this.props.post) {
return <div className="inline not-first"> 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> <Icon name="level-up" /> <Link to={'/@' + this.props.adminID + '/' + this.props.board + '/' + this.props.post + '/' + this.props.comment.parent}>Parent</Link>
</div> </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} /> 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) { if (this.props.comment) {
return <div className="comment"><hr/> return <div className="comment"><hr/>
<div className="icons"> <div className="icons">
@ -49,10 +49,10 @@ var Comment = React.createClass({
}) })
var Comments = React.createClass({ var Comments = React.createClass({
getInitialState: function () { getInitialState () {
return { comments: [] } return { comments: [] }
}, },
componentDidMount: function () { componentDidMount () {
var boards = this.props.api var boards = this.props.api
if (boards) { if (boards) {
boards.getEventEmitter().on('comment for ' + this.props.parent, cmnt => { 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) { 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} />)) 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> else return <div></div>
}, },
render: function () { render () {
return <div className={this.props.className + ' comments'} >{this.getComments()}</div> 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 Link = require('react-router').Link
var Clock = require('clock.jsx') var Clock = require('clock.jsx')
var UserID = require('userID.jsx') var UserID = require('userID.jsx')
var { Error, Loading } = require('status-components.jsx') var { Error } = require('status-components.jsx')
module.exports = React.createClass({ module.exports = React.createClass({
getInitialState () { getInitialState () {
return { loading: true } return { loading: true }
}, },
componentDidMount () { 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) { componentWillReceiveProps (props) {
this.init(props) this.init(props)
@ -52,7 +57,12 @@ module.exports = React.createClass({
if (this.state.error) { if (this.state.error) {
return <Error className="content" error={this.state.error} /> return <Error className="content" error={this.state.error} />
} else if (this.state.loading) { } 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 { } else {
return <div className="content"> return <div className="content">
{ this.state.post.title { this.state.post.title

View File

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

View File

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

View File

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

View File

@ -14,13 +14,6 @@ module.exports = function (boardsAPI) {
}, },
componentDidMount () { componentDidMount () {
boardsAPI.use(boards => { 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 if (!this.isMounted()) return
var ee = boards.getEventEmitter() var ee = boards.getEventEmitter()
ee.on('init', err => { ee.on('init', err => {

View File

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