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

implemented new Post component

This commit is contained in:
Enrico Fasoli 2015-12-17 22:19:21 +01:00
parent 0bf9dcca1f
commit 086e6da860
4 changed files with 76 additions and 61 deletions

View File

@ -10,7 +10,6 @@ Needs to be browserified to work in the browser
var EventEmitter = require('wolfy87-eventemitter')
var asyncjs = require('async')
var semver = require('semver')
var moment = require('moment')
function asObj (str, done) {
if (str.toString) str = str.toString()
@ -168,7 +167,7 @@ BoardsAPI.prototype.createBoard = function (board, done) {
BoardsAPI.prototype.createPost = function (post, board, done) {
try {
post.date = moment().unix()
post.date = (new Date()).getTime()
post.op = this.id
var post_str = JSON.stringify(post)
} catch (e) {
@ -423,9 +422,18 @@ BoardsAPI.prototype.getBoardSettings = function (userID, board, done) {
}
BoardsAPI.prototype.downloadPost = function (hash, adminID, board, op, done) {
if (typeof adminID === 'function') done = adminID
if (typeof board === 'function') done = board
if (typeof op === 'function') done = op
if (typeof adminID === 'function') {
done = adminID
adminID = undefined
}
if (typeof board === 'function') {
done = board
board = undefined
}
if (typeof op === 'function') {
done = op
op = undefined
}
console.log('Downloading post', hash)
this.ipfs.cat(hash, (err2, r) => {
if (err2) {
@ -439,11 +447,11 @@ BoardsAPI.prototype.downloadPost = function (hash, adminID, board, op, done) {
post.hash = hash
if (op) post.op = op // Inject op
if (board) {
if (adminID) this.ee.emit('post in ' + board + '@' + adminID, post, hash)
else this.ee.emit('post in ' + board, post, hash)
if (adminID) this.ee.emit('post in ' + board + '@' + adminID, hash, post.date, post)
else this.ee.emit('post in ' + board, hash, post.date, post)
}
this.ee.emit(hash, post, adminID, board)
if (done && done.apply) done(null, post)
if (done && done.apply) done(null, hash, post.date, post)
})
}
})
@ -484,17 +492,19 @@ BoardsAPI.prototype.getAllowedContentProducers = function (adminID, board, optio
return this.ee
}
BoardsAPI.prototype.getPostsInBoard = function (adminID, board) {
BoardsAPI.prototype.getPostsInBoard = function (adminID, board, opt) {
opt = opt || {}
var emitPost = i => this.ee.emit('post in ' + board + '@' + adminID, i.hash, i.date)
if (adminID) {
this.ee.on('approved posts for ' + board + '@' + adminID, ret => {
// Automatically download approved posts
ret.forEach(item => this.downloadPost(item.hash, adminID, board))
ret.forEach(emitPost)
})
this.ee.on('whitelist for ' + board + '@' + adminID, whitelist => {
// download posts for each user in whitelist
whitelist.forEach(item => {
this.getUserPostListInBoard(item, board, (err, postList) => {
if (!err) postList.forEach(i => this.downloadPost(i.hash, adminID, board, item))
if (!err) postList.forEach(emitPost)
})
})
})
@ -502,7 +512,7 @@ BoardsAPI.prototype.getPostsInBoard = function (adminID, board) {
this.getAllowedContentProducers(adminID, board, { posts: true })
// Get the admin's posts
this.getUserPostListInBoard(adminID, board, (err, res) => {
if (!err) res.forEach(item => this.downloadPost(item.hash, adminID, board, adminID))
if (!err) res.forEach(emitPost)
})
} else {
// TODO: Download all posts in board from everyone
@ -510,7 +520,7 @@ BoardsAPI.prototype.getPostsInBoard = function (adminID, board) {
this.getUserPostListInBoard(this.id, board, (err, res) => {
if (err) {
console.log(err)
} else res.forEach(item => this.downloadPost(item.hash, undefined, board, this.id))
} else res.forEach(emitPost)
})
}
return this.ee

View File

@ -4,38 +4,58 @@ 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')
module.exports = React.createClass({
getInitialState: function () {
return { moment: false }
getInitialState () {
return { loading: true }
},
componentDidMount: function () {
require.ensure(['moment'], _ => {
if (this.isMounted()) this.setState({ moment: require('moment') })
componentDidMount () {
this.init(this.props)
},
componentWillReceiveProps (props) {
this.init(props)
},
init (props) {
var boards = props.api
if (!boards) return this.setState({ error: 'Could not connect to IPFS' })
this.setState({ loading: true })
boards.downloadPost(props.hash, props.adminID, props.board, (err, hash, date, post) => {
this.setState({ error: err, post: post, loading: false })
})
},
postLink: function () {
if (this.props.post.op) {
postLink () {
if (this.state.post.op) {
if (this.props.board) {
return '/@' + this.props.post.op + '/' + this.props.board + '/' + this.props.post.hash
return '/@' + this.state.post.op + '/' + this.props.board + '/' + this.props.hash
} else {
return '/@' + this.props.post.op + '/post/' + this.props.post.hash
return '/@' + this.state.post.op + '/post/' + this.props.hash
}
} else {
return '/post/' + this.props.post.hash
return '/post/' + this.props.hash
}
},
render: function () {
return <div key={this.props.post.title} className="post">
<div className="content">
<h5>{this.props.post.title}</h5><hr/>
<Markdown source={this.props.post.text} /><hr/>
getContent () {
if (this.state.error) {
return <Error className="content" error={this.state.error} />
} else if (this.state.loading) {
return <Loading className="content" title="Downloading post"/>
} else {
return <div className="content">
{ this.state.post.title
? <div><h5>{this.state.post.title}</h5><hr/></div>
: <div />
}
<Markdown source={this.state.post.text} /><hr/>
<div className="icons">
<UserID id={this.props.post.op} api={this.props.api} ></UserID>
<Clock className="not-first" date={this.props.post.date} />
<UserID id={this.state.post.op} api={this.props.api} ></UserID>
<Clock className="not-first" date={this.state.post.date} />
<Icon name="comments" className="not-first" /> <Link className="nounderline" to={this.postLink()}>View</Link>
</div>
</div>
</div>
}
},
render () {
return <div className="post">{this.getContent()}</div>
}
})

View File

@ -13,18 +13,18 @@ module.exports = React.createClass({
init: function (boards) {
if (this.state.init) return
this.setState({ api: true })
var onPost = (post, hash) => {
var onPost = (hash, date, post) => {
if (!this.isMounted()) return true
var now = (new Date()).getTime()
var posts = this.state.posts
if (post.date === undefined || post.date <= 0) {
posts.push(post)
} else if (post.date <= now) {
var i = sortedIndex(posts, post, (p) => now - p.date || now)
posts.splice(i, 0, post)
} else {
console.log('Post discarded cause date in the future:', post)
}
if (date === undefined || date <= 0) {
posts.push(hash)
} else /* if (date <= now) */ {
var i = sortedIndex(posts, post, (p) => now - date || now)
posts.splice(i, 0, hash)
} /* else {
console.log('Post discarded cause date in the future:', hash)
}*/
this.setState({ posts })
}
boards.getEventEmitter().on('post in ' + this.props.board + (this.props.admin ? '@' + this.props.admin : ''), onPost)
@ -45,8 +45,8 @@ module.exports = React.createClass({
},
getPosts: function () {
if (this.state.posts.length > 0 || this.state.api) {
return this.state.posts.map(post => {
return <Post key={post.hash} board={this.props.board} admin={this.props.admin} post={post} api={this.props.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} />
})
} else {
return <div className="center-block text-center">

View File

@ -8,11 +8,10 @@ var Comments = require('comment.jsx').Comments
module.exports = function (boardsAPI) {
return React.createClass({
getInitialState: function () {
return { post: { title: '...', text: '...' }, api: false }
return { }
},
componentDidMount: function () {
boardsAPI.use(boards => {
boards.init()
boards.getEventEmitter().on('init', err => {
if (!err && this.isMounted()) {
this.init(boards)
@ -21,26 +20,12 @@ module.exports = function (boardsAPI) {
if (this.isMounted() && boards.isInit) {
this.init(boards)
}
})
},
componentWillReceiveProps: function (nextProps) {
boardsAPI.use(boards => this.downloadPost(boards, nextProps))
},
downloadPost: function (boards, props) {
boards.downloadPost(props.params.posthash, props.params.userid, props.params.boardname, props.params.userid, (err, post) => {
if (err) {
this.setState({
post: { title: 'Error', text: err.Message || err.Error }
})
} else {
this.setState({ post })
}
boards.init()
})
},
init: function (boards) {
if (this.state.init) return
this.setState({ api: true, boards: boards })
this.downloadPost(boards, this.props)
this.setState({ api: boards })
},
getContext: function () {
if (this.props.params.userid) {
@ -57,7 +42,7 @@ module.exports = function (boardsAPI) {
<div className="text-center">
{this.getContext()}
</div>
<Post post={this.state.post} board={this.props.params.boardname} api={this.state.boards} />
<Post hash={this.props.params.posthash} board={this.props.params.boardname} api={this.state.api} />
<Comments parent={this.props.params.posthash} board={this.props.params.boardname} adminID={this.props.params.userid} post={this.props.params.posthash} api={this.state.boards} />
</div>
} else {