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

wip auto updater

This commit is contained in:
Enrico Fasoli 2015-12-15 17:15:12 +01:00
parent 6685340b42
commit 86e58b87aa
2 changed files with 29 additions and 4 deletions

View File

@ -551,4 +551,8 @@ BoardsAPI.prototype.getMyID = function () {
return this.id return this.id
} }
BoardsAPI.prototype.getIPFS = function () {
return this.ipfs
}
module.exports = BoardsAPI module.exports = BoardsAPI

View File

@ -2,20 +2,40 @@ var React = require('react')
var Icon = require('icon.jsx') var Icon = require('icon.jsx')
var Link = require('react-router').Link var Link = require('react-router').Link
var Updater = React.createClass({
componentDidMount () {
if (this.props.api) this.checkForUpdates(this.props.api)
},
componentWillReceiveProps (props) {
this.checkForUpdates(props.api)
},
checkForUpdates (boards) {
var v = window.location.pathname
if (/\/ipfs\/./.test(v)) {
boards.getIPFS().path.resolve(v.substring(6), (err, res) => {
console.log('PATH RESOLVE', err, res)
})
}
},
render () {
return <div></div>
}
})
module.exports = function (boardsAPI) { module.exports = function (boardsAPI) {
return React.createClass({ return React.createClass({
getInitialState: function () { getInitialState: function () {
return { api: false, loading: true } return { loading: true }
}, },
componentDidMount () { componentDidMount () {
boardsAPI.use(boards => { boardsAPI.use(boards => {
if (boards.isInit) this.setState({ api: true }) if (boards.isInit) this.setState({ api: boards })
boards.getEventEmitter().on('init', err => { boards.getEventEmitter().on('init', err => {
if (!this.isMounted()) return if (!this.isMounted()) return
if (err) { if (err) {
this.setState({ loading: false, api: false }) this.setState({ loading: false, api: false })
} else { } else {
this.setState({ api: true }) this.setState({ api: boards })
} }
}) })
}) })
@ -25,6 +45,7 @@ module.exports = function (boardsAPI) {
return <span> return <span>
<Link className="nounderline" to="/@me"><Icon name="user" className="fa-2x light"/></Link> <Link className="nounderline" to="/@me"><Icon name="user" className="fa-2x light"/></Link>
<Link className="nounderline" to="/users"><Icon name="globe" className="fa-2x light"/></Link> <Link className="nounderline" to="/users"><Icon name="globe" className="fa-2x light"/></Link>
<Updater api={this.state.api} />
</span> </span>
} else if (this.state.loading) { } else if (this.state.loading) {
return <Icon name="refresh" className="fa-2x fa-spin light"/> return <Icon name="refresh" className="fa-2x fa-spin light"/>
@ -36,7 +57,7 @@ module.exports = function (boardsAPI) {
return ( return (
<div className="navbar"> <div className="navbar">
<div className="container"> <div className="container">
{this.props.children || <h4><Link to="/"><Icon name="comments" className="light"/> Boards</Link></h4>} <h4><Link to="/"><Icon name="comments" className="light"/> Boards</Link></h4>
<div className="u-pull-right iconbar"> <div className="u-pull-right iconbar">
{this.extraButtons()} {this.extraButtons()}
<Link className="nounderline" to="/settings"><Icon name="cog" className="fa-2x light"/></Link> <Link className="nounderline" to="/settings"><Icon name="cog" className="fa-2x light"/></Link>