mirror of
https://github.com/fazo96/ipfs-boards
synced 2025-01-25 14:54:19 +01:00
95 lines
3.2 KiB
JavaScript
95 lines
3.2 KiB
JavaScript
var React = require('react')
|
|
var GetIPFS = require('getipfs.jsx')
|
|
var Icon = require('icon.jsx')
|
|
|
|
module.exports = function (boardsAPI) {
|
|
return React.createClass({
|
|
getInitialState () {
|
|
return { loading: true }
|
|
},
|
|
componentDidMount () {
|
|
boardsAPI.use(boards => {
|
|
boards.init()
|
|
boards.getEventEmitter().on('init', err => {
|
|
if (!err && this.isMounted()) {
|
|
this.init(boards)
|
|
}
|
|
})
|
|
if (this.isMounted() && boards.isInit) {
|
|
this.init(boards)
|
|
}
|
|
})
|
|
},
|
|
getProfile (boards) {
|
|
boards.getProfile(boards.getMyID(), (err, p) => {
|
|
if (!this.isMounted()) return
|
|
else if (err) this.setState({ loading: false })
|
|
else if (this.state.loading) {
|
|
// State isn't set to p directly to avoid XSS.
|
|
// There is no knowing what's gonna be in a profile
|
|
// Should also convert to string and check length etc.
|
|
this.setState({ p: p.name, description: p.description, loading: false })
|
|
}
|
|
})
|
|
},
|
|
init (boards) {
|
|
if (this.state.init) return
|
|
this.setState({ api: boards })
|
|
this.getProfile(boards)
|
|
},
|
|
handleChange (event) {
|
|
if (event.target.id === 'name') {
|
|
this.setState({ name: event.target.value })
|
|
} else {
|
|
this.setState({ description: event.target.value })
|
|
}
|
|
},
|
|
skip () {
|
|
this.setState({ loading: false })
|
|
},
|
|
save () {
|
|
var boards = this.state.api
|
|
var profile = {
|
|
name: this.state.name,
|
|
description: this.state.description
|
|
}
|
|
boards.createProfile(profile, err => {
|
|
console.log('CREATE:', err)
|
|
})
|
|
},
|
|
render () {
|
|
if (this.state.api) {
|
|
if (this.state.loading) {
|
|
return <div>
|
|
<div className="text-center">
|
|
<Icon className="center-block fa-spin fa-3x light" name="refresh" />
|
|
<h4 className="top-half-em">Fetching your current profile...</h4>
|
|
<button className="button button-primary center-block" onClick={this.skip}>Skip</button>
|
|
</div>
|
|
</div>
|
|
} else {
|
|
return (
|
|
<div className="editor">
|
|
<h2><Icon name="user" className="light" /> Edit Profile</h2>
|
|
<p>This App uses IPFS to store your profile. When you are offline,
|
|
other users or servers that viewed your profile will serve it to
|
|
others.</p>
|
|
<div className="center-block thin">
|
|
<label htmlFor="name">Name</label>
|
|
<input className="u-full-width" type="text" id="name" value={this.state.name} onChange={this.handleChange} placeholder="Who are you on the interwebs?" />
|
|
</div>
|
|
<div>
|
|
<label htmlFor="desc">Caption</label>
|
|
<textarea className="u-full-width" id="desc" value={this.state.description} onChange={this.handleChange} placeholder="Say something about yourself." />
|
|
</div>
|
|
<div className="buttons">
|
|
<button className="button button-primary" onClick={this.save}>Publish</button>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
} else return <GetIPFS api={this.state.api} />
|
|
}
|
|
})
|
|
}
|