mirror of
https://github.com/fazo96/ipfs-boards
synced 2025-01-25 14:54:19 +01:00
WIP board editor
This commit is contained in:
parent
107e835342
commit
06d7d65dd1
@ -130,6 +130,10 @@ BoardsAPI.prototype.createProfile = function (profile, done) {
|
|||||||
], done)
|
], done)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BoardsAPI.prototype.createBoard = function (board, done) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
BoardsAPI.prototype.backupCache = function () {
|
BoardsAPI.prototype.backupCache = function () {
|
||||||
if (window && window.localStorage !== undefined) {
|
if (window && window.localStorage !== undefined) {
|
||||||
// Use localStorage to store the IPNS cache
|
// Use localStorage to store the IPNS cache
|
||||||
|
130
webapp/pages/board-editor.jsx
Normal file
130
webapp/pages/board-editor.jsx
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
var React = require('react')
|
||||||
|
var GetIPFS = require('getipfs.jsx')
|
||||||
|
var Icon = require('icon.jsx')
|
||||||
|
var Link = require('react-router').Link
|
||||||
|
|
||||||
|
module.exports = function (boardsAPI) {
|
||||||
|
return React.createClass({
|
||||||
|
getInitialState () {
|
||||||
|
return { }
|
||||||
|
},
|
||||||
|
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)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
init (boards) {
|
||||||
|
if (this.state.init) return
|
||||||
|
this.setState({ api: boards, init: true })
|
||||||
|
this.getBoardSettings(boards)
|
||||||
|
},
|
||||||
|
getBoardSettings (boards) {
|
||||||
|
if (!this.props.params.board) return
|
||||||
|
boards.getBoardSettings(boards.getMyID(), this.props.params.board)
|
||||||
|
},
|
||||||
|
handleChange (event) {
|
||||||
|
var obj = {}
|
||||||
|
obj[event.target.id] = event.target.value
|
||||||
|
this.setState(obj)
|
||||||
|
},
|
||||||
|
skip () {
|
||||||
|
this.setState({ loading: false, updating: false, error: false })
|
||||||
|
},
|
||||||
|
refresh () {
|
||||||
|
this.setState({ loading: true })
|
||||||
|
boardsAPI.use(b => this.getBoardSettings(b))
|
||||||
|
},
|
||||||
|
save () {
|
||||||
|
var boards = this.state.api
|
||||||
|
var board = {
|
||||||
|
id: this.state.shortname,
|
||||||
|
fullname: this.state.name,
|
||||||
|
description: this.state.description
|
||||||
|
}
|
||||||
|
this.setState({ updating: true })
|
||||||
|
boards.createBoard(board, (err) => {
|
||||||
|
console.log('CREATE:', err)
|
||||||
|
})
|
||||||
|
},
|
||||||
|
additionalButtons () {
|
||||||
|
if (this.state.api && this.props.params.board) {
|
||||||
|
var url = '/@' + this.state.api.getMyID() + '/' + this.props.params.board
|
||||||
|
return <span>
|
||||||
|
<button onClick={this.refresh} className="button not-first">Refresh</button>
|
||||||
|
<Link to={url} className="button not-first">View</Link>
|
||||||
|
</span>
|
||||||
|
} else {
|
||||||
|
return <span></span>
|
||||||
|
}
|
||||||
|
},
|
||||||
|
render () {
|
||||||
|
if (this.state.api) {
|
||||||
|
if (this.state.error) {
|
||||||
|
return <div>
|
||||||
|
<div className="text-center">
|
||||||
|
<Icon className="center-block fa-3x light" name="ban" />
|
||||||
|
<h4 className="top-half-em">Ooops</h4>
|
||||||
|
<p>{this.state.error}</p>
|
||||||
|
<button className="button button-primary center-block" onClick={this.skip}>Continue</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
} else 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 if (this.state.updating) {
|
||||||
|
return <div>
|
||||||
|
<div className="text-center">
|
||||||
|
<Icon className="center-block fa-spin fa-3x light" name="refresh" />
|
||||||
|
<h4 className="top-half-em">Publishing...</h4>
|
||||||
|
<p>Pressing the Skip button will not abort the publish operation.</p>
|
||||||
|
<button className="button button-primary center-block" onClick={this.skip}>Skip</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
} else {
|
||||||
|
return (
|
||||||
|
<div className="editor">
|
||||||
|
<h2><Icon name="inbox" className="light" /> Board Settings</h2>
|
||||||
|
<p>This App uses IPFS to store your Boards. When you are offline,
|
||||||
|
other users or servers that viewed your content will serve it to
|
||||||
|
others.</p>
|
||||||
|
<p><b>Warning:</b> due to a bug in go-ipfs, it may take up to a minute
|
||||||
|
for your changes to be visibile. Your Boards will appear unchanged during
|
||||||
|
this time.</p>
|
||||||
|
<div className="row">
|
||||||
|
<div className="six columns">
|
||||||
|
<label htmlFor="shortname">ID</label>
|
||||||
|
<input className="u-full-width" type="text" id="shortname" value={this.state.name} onChange={this.handleChange} placeholder="Choose a short name that identifies your Board." />
|
||||||
|
</div>
|
||||||
|
<div className="six columns">
|
||||||
|
<label htmlFor="name">Title</label>
|
||||||
|
<input className="u-full-width" type="text" id="name" value={this.state.port} onChange={this.onChange} placeholder="Name your board" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<label htmlFor="desc">Description</label>
|
||||||
|
<textarea className="u-full-width" id="desc" value={this.state.description} onChange={this.handleChange} placeholder="What's this Board about? Markdown is supported :)" />
|
||||||
|
</div>
|
||||||
|
<div className="buttons">
|
||||||
|
<button className="button button-primary" onClick={this.save}>Publish</button>
|
||||||
|
{this.additionalButtons()}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
} else return <GetIPFS api={this.state.api} />
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user